/* =========================================================================
   ADEIRLINA — Design System
   Extracted from Adeirlina.dc.html (Claude Design mockup)
   Fonts: Cormorant Garamond (display) · Jost (UI/body)
   ========================================================================= */

:root{
  /* ---- palette ---- */
  --ink:#161616;
  --paper:#FFFFFF;
  --rose:#C8324A;
  --rose-dark:#A8273B;
  --muted:#555555;
  --muted-2:#9A9A9A;
  --muted-3:#8A8A8A;
  --muted-4:#B0B0B0;
  --line:#E4E4E4;
  --line-2:#EAEAEA;
  --line-3:#D6D6D6;
  --line-4:#CFCFCF;
  --panel:#F2F2F0;
  --soft:#F7F7F7;
  --tint:#E6E6E6;

  /* ---- type ---- */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  /* ---- layout ---- */
  --maxw:1320px;
  --pad:clamp(20px,5vw,56px);

  /* ---- chrome heights ---- */
  --announce-h:39px;
  --header-h:72px;
  --chrome-h:111px; /* announce + header */
}

/* ---- reset ---- */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--paper);}
body{
  font-family:var(--sans);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
}
::selection{background:#DDDDDD;color:var(--ink);}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:var(--sans);}
input,textarea,select{font-family:var(--sans);}
h1,h2,h3,h4{margin:0;font-weight:500;}
p{margin:0;}

/* =========================================================================
   ANIMATIONS
   ========================================================================= */
@keyframes adFadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes adOverlay{from{opacity:0;}to{opacity:1;}}

[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .8s ease,transform .8s ease;}
[data-reveal].in{opacity:1;transform:translateY(0);}
.fade-up{animation:adFadeUp .9s ease both;}
.fade-up.d1{animation-delay:.05s;}
.fade-up.d2{animation-delay:.12s;}
.fade-up.d3{animation-delay:.20s;}
.fade-up.d4{animation-delay:.28s;}

/* =========================================================================
   TYPOGRAPHY HELPERS
   ========================================================================= */
.serif{font-family:var(--serif);}
.eyebrow{
  font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--muted-2);font-weight:500;
}
.eyebrow--rose{color:var(--rose);}
.section-head{text-align:center;margin-bottom:clamp(32px,5vw,56px);}
.section-head .eyebrow{margin-bottom:14px;}
.section-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(30px,4vw,46px);line-height:1.05;color:var(--ink);
}
.lede{font-weight:300;font-size:16px;line-height:1.7;color:var(--muted);}

/* =========================================================================
   LAYOUT
   ========================================================================= */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.wrap--narrow{max-width:780px;}
.section{padding-top:clamp(48px,7vw,84px);padding-bottom:clamp(48px,7vw,84px);}
.page-top{padding-top:var(--chrome-h);}     /* offset fixed chrome on inner pages */

.two-col{display:grid;grid-template-columns:1fr 1fr;}
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:12px;letter-spacing:0.2em;text-transform:uppercase;
  font-weight:500;padding:17px 38px;cursor:pointer;border:none;border-radius:1px;
  transition:background .3s,color .3s,border-color .3s;white-space:nowrap;
}
.btn--light{background:#FFFFFF;color:var(--ink);}
.btn--light:hover{background:var(--rose);color:#FFFFFF;}
.btn--dark{background:var(--ink);color:#FFFFFF;}
.btn--dark:hover{background:var(--rose);}
.btn--rose{background:var(--rose);color:#FFFFFF;}
.btn--rose:hover{background:var(--rose-dark);}
.btn--outline{background:transparent;color:var(--ink);border:1px solid var(--line-4);}
.btn--outline:hover{background:var(--ink);color:#FFFFFF;}
.btn--block{display:flex;width:100%;}
.btn[disabled]{background:var(--muted-4)!important;cursor:not-allowed;}

.text-link{
  cursor:pointer;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--line-4);padding-bottom:4px;
  display:inline-block;transition:border-color .3s;
}
.text-link:hover{border-color:var(--rose);}

/* =========================================================================
   FORM FIELDS
   ========================================================================= */
.field{
  width:100%;background:transparent;border:1px solid var(--line-3);color:var(--ink);
  font-family:var(--sans);font-size:14px;padding:15px 16px;outline:none;
  transition:border-color .25s;
}
.field:focus{border-color:var(--ink);}
textarea.field{resize:vertical;}
.field--line{
  border:none;border-bottom:1px solid var(--line-4);padding:12px 2px;
}

/* =========================================================================
   ANNOUNCEMENT + HEADER
   ========================================================================= */
.site-chrome{position:fixed;top:0;left:0;right:0;z-index:90;}
.announce{
  background:var(--ink);color:#F2F2F2;text-align:center;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;font-weight:400;
  padding:11px 16px;
}
.site-header{transition:background .4s,box-shadow .4s;background:transparent;}
.site-header.solid{
  background:rgba(255,255,255,0.96);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(0,0,0,0.07);
}
.header-inner{
  position:relative;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);height:var(--header-h);
  display:flex;align-items:center;gap:24px;
}
.site-header .nav,
.site-header .utils,
.site-header .burger{color:#FFFFFF;transition:color .4s;}
.site-header.solid .nav,
.site-header.solid .utils,
.site-header.solid .burger{color:var(--ink);}

/* logo left · nav centered · utils right */
.nav{
  display:flex;gap:22px;flex:1;align-items:center;justify-content:center;
  font-size:11.5px;letter-spacing:0.14em;text-transform:uppercase;font-weight:400;
}
.nav a{
  cursor:pointer;padding:6px 0;border-bottom:1px solid transparent;
  transition:border-color .3s;white-space:nowrap;
}
.nav a:hover,.nav a.active,.nav a.previewing{border-bottom:1px solid currentColor;}

.brand{
  cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:flex-start;
}
.brand img{width:clamp(118px,13vw,146px);height:auto;display:block;}
/* transparent logos: white wordmark over the dark hero, dark wordmark on the solid header */
.brand .logo-dark{display:none;}
.site-header.solid .brand .logo-dark{display:block;}
.site-header.solid .brand .logo-white{display:none;}
/* brand wordmark fallback (used where image blend is unreliable) */
.brand-text{
  font-family:var(--serif);font-weight:500;font-size:26px;letter-spacing:0.32em;
  text-transform:uppercase;cursor:pointer;white-space:nowrap;
}

.utils{display:flex;gap:20px;flex-shrink:0;justify-content:flex-end;align-items:center;}
.utils .ico{cursor:pointer;font-size:18px;line-height:1;}
.utils a{cursor:pointer;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;}
.cart-btn{
  cursor:pointer;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  position:relative;display:flex;align-items:center;gap:6px;background:none;border:none;color:inherit;
}
.cart-count{
  background:var(--rose);color:#FFFFFF;border-radius:50%;min-width:18px;height:18px;
  display:none;align-items:center;justify-content:center;font-size:10px;padding:0 4px;
}
.cart-count.show{display:inline-flex;}

.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;width:24px;background:none;border:none;padding:0;}
.burger span{height:1.4px;background:currentColor;width:22px;display:block;}
.burger span:last-child{width:14px;}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:95;background:#FFFFFF;padding:120px 32px 40px;
  display:none;
}
.mobile-menu.open{display:block;animation:adOverlay .3s ease;}
.mobile-menu .close{position:absolute;top:36px;right:32px;font-size:24px;cursor:pointer;}
.mobile-menu nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto;max-height:100%;}
.mobile-menu nav a{
  cursor:pointer;font-family:var(--serif);font-size:30px;font-weight:500;color:var(--ink);
  padding:7px 0;border-bottom:1px solid var(--line-2);
}
.mobile-menu .minor{
  font-family:var(--sans)!important;font-size:12px!important;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--muted-2)!important;margin-top:20px;border:none!important;
}

@media (max-width:1080px){
  .nav{display:none;}
  .utils a.acct{display:none;}
  .burger{display:flex;}
  /* logo re-centers between burger (left) and utils (right) on mobile */
  .brand{position:absolute;left:50%;transform:translateX(-50%);}
  .utils{margin-left:auto;}
  .mega,.mega-scrim{display:none!important;}
}

/* =========================================================================
   MEGA MENU (full-width dropdown, injected by JS into .site-chrome)
   ========================================================================= */
.mega{
  position:absolute;top:100%;left:0;right:0;
  background:#FFFFFF;border-top:1px solid var(--line-2);
  box-shadow:0 26px 44px rgba(0,0,0,0.10);
  opacity:0;transform:translateY(-12px);pointer-events:none;
  transition:opacity .3s ease,transform .38s cubic-bezier(.2,.7,.2,1);
}
.mega.open{opacity:1;transform:translateY(0);pointer-events:auto;}
.mega-inner{
  max-width:var(--maxw);margin:0 auto;padding:clamp(30px,3.4vw,48px) var(--pad);
  display:grid;grid-template-columns:0.85fr 2fr;gap:clamp(36px,5vw,80px);align-items:start;
}
.mega-rail .eyebrow{margin-bottom:12px;}
.mega-rail h3{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3vw,42px);line-height:1.04;margin:0 0 14px;color:var(--ink);}
.mega-rail p{font-weight:300;font-size:14px;line-height:1.7;color:var(--muted);margin:0 0 24px;max-width:32ch;}
.mega-links{display:flex;flex-direction:column;gap:13px;}
.mega-links a{
  width:fit-content;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid transparent;padding-bottom:3px;transition:border-color .25s,color .25s;cursor:pointer;
}
.mega-links a:hover{color:var(--rose);border-bottom-color:var(--rose);}
.mega-feature{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,24px);}
.mega-feature .card-name{font-size:18px;}
.mega-feature .card-body{padding-top:12px;}
.mega-feature .eyebrow-cap{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px;}
.mega-empty{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  border-left:1px solid var(--line);padding:8px 0 8px 36px;min-height:160px;}
.mega-empty h4{font-family:var(--serif);font-size:24px;font-weight:500;margin:0 0 10px;color:var(--ink);}

.mega-scrim{
  position:fixed;inset:0;z-index:85;background:rgba(22,22,22,0.30);
  -webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.mega-scrim.show{opacity:1;pointer-events:auto;}

/* =========================================================================
   PRODUCT CARD + GRID
   ========================================================================= */
.product-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:clamp(16px,2vw,30px);
}
.product-grid--lg{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));}

.card{cursor:pointer;display:block;color:inherit;}
.card-media{
  position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--tint);
}
.card-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity .6s ease,transform 1.2s ease;
}
.card-media .img-hover{opacity:0;}
.card:hover .card-media .img-hover{opacity:1;}
.card:hover .card-media .img-main{transform:scale(1.04);}
.card.is-out .card-media img{filter:grayscale(0.25) brightness(0.99);}

.badge{
  position:absolute;top:14px;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  padding:6px 11px;z-index:2;
}
.badge--out{left:14px;background:rgba(255,255,255,0.92);color:var(--muted);}
.badge--sale{left:14px;background:var(--rose);color:#FFFFFF;}
.badge--new{right:14px;background:rgba(200,50,74,0.92);color:#FFFFFF;}

.card-body{padding-top:15px;text-align:center;}
.card-name{font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink);line-height:1.2;}
.card-cat{font-size:11px;letter-spacing:0.1em;color:var(--muted-2);margin-top:4px;text-transform:uppercase;}
.card-price{margin-top:9px;font-size:14px;color:var(--ink);display:flex;gap:9px;justify-content:center;}
.card-price .was{text-decoration:line-through;color:var(--muted-4);}
.card-price .now{color:var(--rose);}

/* section header w/ "view all" */
.row-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-bottom:clamp(28px,4vw,46px);
}
.row-head .eyebrow{margin-bottom:12px;}
.row-head .section-title{text-align:left;}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{
  position:relative;height:100vh;min-height:640px;display:flex;align-items:flex-end;
  overflow:hidden;background:#DADADA;
}
.hero__media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero__scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0.46) 0%,rgba(0,0,0,0.16) 28%,rgba(0,0,0,0.22) 60%,rgba(0,0,0,0.62) 100%);}
.hero__inner{
  position:relative;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:0 var(--pad) clamp(56px,9vh,104px);color:#FFFFFF;
}
.hero__eyebrow{font-size:11px;letter-spacing:0.3em;text-transform:uppercase;margin-bottom:22px;opacity:.9;}
.hero__title{
  font-family:var(--serif);font-weight:500;font-size:clamp(44px,7vw,92px);
  line-height:0.98;letter-spacing:0.005em;margin:0 0 22px;max-width:14ch;
}
.hero__text{font-weight:300;font-size:clamp(15px,1.4vw,18px);line-height:1.7;max-width:42ch;margin:0 0 34px;opacity:.94;}

/* smaller page hero */
.page-hero{
  position:relative;height:72vh;min-height:460px;display:flex;align-items:flex-end;overflow:hidden;background:#DDDDDD;
}
.page-hero .hero__scrim{background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,0.45) 100%);}
.page-hero__inner{position:relative;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad) clamp(44px,7vh,80px);color:#FFFFFF;}
.page-hero__title{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6vw,84px);line-height:.98;margin:0;max-width:16ch;}

/* =========================================================================
   CATEGORY TILES
   ========================================================================= */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(14px,1.6vw,22px);}
.tile{cursor:pointer;}
.tile-media{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--tint);}
.tile-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease;}
.tile:hover .tile-media img{transform:scale(1.05);}
.tile-media::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .5s;}
.tile:hover .tile-media::after{background:rgba(0,0,0,0.08);}
.tile-name{text-align:center;padding-top:18px;font-family:var(--serif);font-size:23px;font-weight:500;color:var(--ink);}
.tile-cta{text-align:center;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted-2);margin-top:5px;}

/* =========================================================================
   BRAND STORY / EDITORIAL SPLIT
   ========================================================================= */
.editorial{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
.editorial__media{position:relative;min-height:clamp(360px,46vw,560px);overflow:hidden;background:#DDDDDD;}
.editorial__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.editorial__body{background:var(--panel);display:flex;align-items:center;padding:clamp(40px,6vw,88px);}
.editorial__body .inner{max-width:460px;}
.editorial__body h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.4vw,42px);line-height:1.08;margin:0 0 22px;}
.editorial__body p{font-weight:300;font-size:16px;line-height:1.85;color:var(--muted);margin:0 0 30px;}

/* feature band */
.feature{position:relative;min-height:clamp(420px,52vw,640px);display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:#F0F0F0;}
.feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.feature::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,0.30);}
.feature__inner{position:relative;padding:40px;z-index:1;}
.feature__title{font-family:var(--serif);font-weight:500;font-style:italic;font-size:clamp(40px,6vw,80px);line-height:1;margin:0 0 24px;color:var(--ink);}

/* quote band */
.quote-band{background:var(--ink);color:#F2F2F2;text-align:center;padding:clamp(64px,9vw,120px) var(--pad);}
.quote-band .q{font-family:var(--serif);font-style:italic;font-size:clamp(26px,3.6vw,42px);line-height:1.4;max-width:780px;margin:0 auto;}

/* =========================================================================
   UGC GRID
   ========================================================================= */
.ugc{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;}
.ugc-item{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer;background:var(--tint);}
.ugc-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s ease;}
.ugc-item::after{content:"♥";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#FFF;opacity:0;background:rgba(0,0,0,0);transition:opacity .4s,background .4s;font-size:20px;}
.ugc-item:hover::after{opacity:1;background:rgba(0,0,0,0.28);}
.ugc-item:hover img{transform:scale(1.06);}

/* =========================================================================
   NEWSLETTER BAND
   ========================================================================= */
.newsletter{background:var(--ink);color:#F2F2F2;padding:clamp(56px,8vw,104px) var(--pad);text-align:center;}
.newsletter .inner{max-width:540px;margin:0 auto;}
.newsletter h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4vw,48px);line-height:1.05;margin:0 0 16px;}
.newsletter p{font-weight:300;font-size:15px;line-height:1.7;color:#BBBBBB;margin:0 0 30px;}
.newsletter form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center;}
.newsletter input{
  flex:1;min-width:200px;background:transparent;border:none;border-bottom:1px solid #3A3A3A;
  color:#F2F2F2;font-size:14px;padding:12px 4px;outline:none;
}
.newsletter input::placeholder{color:#7A7A7A;}
.newsletter .ok{color:var(--rose);font-size:13px;letter-spacing:.04em;margin-top:18px;min-height:18px;}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--panel);color:var(--muted);padding:clamp(56px,7vw,88px) var(--pad) 32px;}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(28px,4vw,48px);}
.footer-brand{grid-column:1/-1;max-width:380px;}
.footer-brand img{width:150px;height:auto;margin-bottom:16px;cursor:pointer;}
.footer-brand p{font-weight:300;font-size:14px;line-height:1.8;margin:0;}
.footer-col h4{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink);font-weight:500;margin:0 0 18px;}
.footer-col .links{display:flex;flex-direction:column;gap:11px;}
.footer-col .links a{cursor:pointer;font-size:14px;font-weight:300;transition:color .3s;}
.footer-col .links a:hover{color:var(--rose);}
.footer-news p{font-weight:300;font-size:13px;line-height:1.7;margin:0 0 14px;}
.footer-news .inline{display:flex;border-bottom:1px solid var(--line-4);}
.footer-news input{flex:1;background:transparent;border:none;color:var(--ink);font-size:13px;padding:8px 2px;outline:none;}
.footer-news .send{cursor:pointer;font-size:18px;color:var(--ink);padding:6px;background:none;border:none;}
.footer-social{display:flex;gap:18px;margin-top:24px;}
.footer-social a{color:var(--muted-3);display:inline-flex;transition:color .3s,transform .3s;}
.footer-social a:hover{color:var(--rose);transform:translateY(-2px);}
.footer-social svg{width:18px;height:18px;display:block;fill:currentColor;}
.footer-bottom{max-width:var(--maxw);margin:clamp(40px,5vw,60px) auto 0;padding-top:28px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;}
.footer-bottom .copy{flex:1;font-size:12px;font-weight:300;color:var(--muted-3);}
.pay{display:flex;gap:13px;align-items:center;flex:0 0 auto;}
.pay-mark{
  display:inline-flex;align-items:center;
  font-family:Arial,Helvetica,sans-serif;font-size:12px;font-weight:800;
  letter-spacing:.04em;line-height:1;
}
.pc-visa{color:#1A1F71;font-style:italic;letter-spacing:.07em;}
.pc-amex{color:#1F72CD;letter-spacing:.05em;}
.pc-pp{font-style:italic;}
.pc-pp i{color:#003087;font-style:italic;}
.pc-pp b{color:#009CDE;}
.pay-mc svg{width:26px;height:16px;display:block;}
.footer-credit{flex:1;text-align:right;font-size:11px;letter-spacing:0.06em;color:var(--muted-3);transition:color .3s;white-space:nowrap;}
.footer-credit strong{font-weight:500;color:var(--ink);transition:color .3s;}
.footer-credit:hover,.footer-credit:hover strong{color:var(--rose);}

/* =========================================================================
   COLLECTION PAGE
   ========================================================================= */
.collection-head{text-align:center;padding:clamp(40px,6vw,72px) var(--pad) clamp(20px,3vw,36px);max-width:var(--maxw);margin:0 auto;}
.collection-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(38px,5.5vw,68px);line-height:1;margin:0 0 18px;}
.collection-head p{font-weight:300;font-size:16px;line-height:1.7;color:var(--muted);max-width:52ch;margin:0 auto;}

.filterbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.filterbar .left{display:flex;align-items:center;gap:10px;}
.filterbar .toggle{cursor:pointer;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:9px;background:none;border:none;}
.filterbar .count{font-size:12px;color:var(--muted-2);font-weight:300;}
.filterbar .right{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.filterbar .right .lbl{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);}
.sort-opt{cursor:pointer;font-size:12px;letter-spacing:0.06em;color:var(--muted-2);border-bottom:1px solid transparent;padding-bottom:3px;white-space:nowrap;}
.sort-opt.active{color:var(--ink);border-bottom-color:var(--ink);}

.filters{padding:26px 0 22px;border-bottom:1px solid var(--line);display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px;animation:adFadeUp .35s ease;}
.filters.hidden{display:none;}
.filters .grp-title{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);font-weight:500;margin-bottom:14px;}
.pill-row{display:flex;gap:8px;flex-wrap:wrap;}
.pill{cursor:pointer;min-width:42px;text-align:center;padding:9px 14px;font-size:12px;letter-spacing:0.06em;
  border:1px solid var(--line-3);background:transparent;color:var(--muted);transition:all .2s;}
.pill.active{background:var(--ink);color:#FFFFFF;border-color:var(--ink);}

.empty{text-align:center;padding:80px 20px;}
.empty h3{font-family:var(--serif);font-size:26px;color:var(--ink);margin:0 0 12px;font-weight:500;}

/* =========================================================================
   PRODUCT DETAIL (PDP)
   ========================================================================= */
.crumbs{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:clamp(20px,3vw,32px);}
.crumbs a{cursor:pointer;}
.crumbs .here{color:var(--muted);}

.pdp{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,4vw,64px);align-items:start;}
.gallery{display:flex;gap:16px;flex-direction:row-reverse;}
.gallery__main{flex:1;position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--tint);}
.gallery__main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.gallery__thumbs{display:flex;flex-direction:column;gap:12px;width:74px;}
.thumb{aspect-ratio:3/4;overflow:hidden;cursor:pointer;outline:1.5px solid transparent;outline-offset:-1px;background:var(--tint);}
.thumb img{width:100%;height:100%;object-fit:cover;}
.thumb.active{outline-color:var(--ink);}

.pdp-info{position:sticky;top:130px;}
.pdp-cat{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted-2);margin-bottom:12px;}
.pdp-title{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4.2vw,52px);line-height:1.02;margin:0 0 16px;}
.pdp-price{display:flex;align-items:baseline;gap:12px;margin-bottom:6px;font-size:22px;}
.pdp-price .was{font-size:18px;text-decoration:line-through;color:var(--muted-4);}
.pdp-price .now{color:var(--rose);font-size:24px;}
.pdp-desc{font-weight:300;font-size:15px;line-height:1.8;color:var(--muted);margin:18px 0 28px;border-top:1px solid var(--line-2);padding-top:24px;}

.opt-group{margin-bottom:24px;}
.opt-label{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;}
.opt-label .muted{color:var(--muted-2);}
.swatches{display:flex;gap:10px;}
.swatch{cursor:pointer;width:30px;height:30px;border-radius:50%;outline:2px solid transparent;outline-offset:2px;border:1px solid rgba(0,0,0,0.12);}
.swatch.active{outline-color:var(--ink);}
.size-row{display:flex;gap:10px;flex-wrap:wrap;}
.size{cursor:pointer;min-width:52px;text-align:center;padding:13px 8px;font-size:13px;letter-spacing:0.06em;
  border:1px solid var(--line-3);background:transparent;color:var(--muted);transition:all .2s;}
.size.active{background:var(--ink);color:#FFFFFF;border-color:var(--ink);}
.size-error{font-size:12px;color:var(--rose);margin-top:10px;display:none;}
.size-error.show{display:block;}

.buy-row{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap;}
.stepper{display:flex;align-items:center;border:1px solid var(--line-3);height:54px;}
.stepper button{cursor:pointer;width:46px;height:54px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px;background:none;border:none;}
.stepper .val{width:40px;text-align:center;font-size:14px;}
.add-btn{flex:1;min-width:200px;height:54px;background:var(--rose);color:#FFFFFF;border:none;
  font-size:12px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:background .3s;}
.add-btn:hover{background:var(--rose-dark);}
.add-btn:disabled{background:var(--muted-4);cursor:not-allowed;}

.trust{display:flex;flex-direction:column;gap:10px;margin:22px 0;padding:20px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);}
.trust div{display:flex;align-items:center;gap:12px;font-size:13px;font-weight:300;color:var(--muted);}
.trust .mark{color:var(--rose);font-size:14px;}

.tabs{display:flex;gap:24px;border-bottom:1px solid var(--line-2);flex-wrap:wrap;}
.tab{cursor:pointer;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);
  padding:0 0 14px;border-bottom:2px solid transparent;margin-bottom:-1px;background:none;border-top:none;border-left:none;border-right:none;}
.tab.active{color:var(--ink);border-bottom-color:var(--rose);}
.tab-body{padding:22px 0;}
.tab-body .bullet{display:flex;gap:12px;font-size:14px;font-weight:300;line-height:1.7;color:var(--muted);margin-bottom:10px;}
.tab-body .bullet .dash{color:var(--line-4);}

.related{margin-top:clamp(56px,8vw,96px);border-top:1px solid var(--line);padding-top:clamp(40px,5vw,60px);}
.related h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.4vw,40px);text-align:center;margin:0 0 clamp(28px,4vw,44px);}
.carousel{display:flex;gap:clamp(16px,2vw,26px);overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory;}
.carousel .card{flex:0 0 clamp(220px,26vw,290px);scroll-snap-align:start;}

/* =========================================================================
   WHITE EDIT
   ========================================================================= */
.white-hero{position:relative;height:92vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:#F0F0F0;}
.white-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.white-hero::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,0.34);}
.white-hero__inner{position:relative;z-index:1;padding:40px;}
.white-hero__title{font-family:var(--serif);font-weight:500;font-style:italic;font-size:clamp(52px,9vw,128px);line-height:.92;margin:0;color:var(--ink);}
.pull-quote{max-width:760px;margin:0 auto;padding:clamp(64px,9vw,110px) var(--pad);text-align:center;
  font-family:var(--serif);font-style:italic;font-size:clamp(24px,3vw,34px);line-height:1.45;color:var(--ink);}
.lookbook{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}
.lookbook__img{aspect-ratio:4/5;overflow:hidden;background:#F0F0F0;}
.lookbook__img img{width:100%;height:100%;object-fit:cover;}

/* =========================================================================
   CART PAGE
   ========================================================================= */
.cart-page{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(32px,5vw,64px);align-items:start;}
.cart-lines{display:flex;flex-direction:column;}
.cart-line{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--line-2);}
.cart-line .media{width:96px;height:124px;flex-shrink:0;overflow:hidden;background:var(--tint);}
.cart-line .media img{width:100%;height:100%;object-fit:cover;}
.cart-line .info{flex:1;display:flex;flex-direction:column;}
.cart-line .name{font-family:var(--serif);font-size:20px;font-weight:500;line-height:1.15;}
.cart-line .meta{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted-2);margin-top:5px;}
.cart-line .bottom{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:14px;}
.mini-stepper{display:flex;align-items:center;border:1px solid var(--line-3);}
.mini-stepper button{cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--muted);background:none;border:none;}
.mini-stepper .v{width:32px;text-align:center;font-size:13px;}
.line-remove{cursor:pointer;color:var(--muted-4);font-size:13px;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;margin-top:6px;text-align:left;padding:0;}
.summary{background:var(--panel);padding:clamp(26px,3vw,36px);position:sticky;top:130px;}
.summary h3{font-family:var(--serif);font-size:22px;font-weight:500;margin:0 0 22px;}
.summary .row{display:flex;justify-content:space-between;font-size:14px;color:var(--muted);margin-bottom:10px;}
.summary .row span:last-child{color:var(--ink);}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:16px;margin-top:6px;}
.summary .total .lbl{font-size:12px;letter-spacing:0.1em;text-transform:uppercase;}
.summary .total .amt{font-family:var(--serif);font-size:26px;}
.promo{display:flex;gap:8px;margin:6px 0 20px;}
.promo input{flex:1;background:#FFF;border:1px solid var(--line-3);font-size:13px;padding:12px 14px;outline:none;}
.promo button{background:var(--ink);color:#FFF;border:none;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:0 18px;cursor:pointer;}
.ship-bar{margin:4px 0 22px;}
.ship-bar .msg{font-size:12px;font-weight:300;color:var(--muted);margin-bottom:10px;}
.ship-bar .track{height:4px;background:var(--line-2);border-radius:4px;overflow:hidden;}
.ship-bar .fill{height:100%;background:var(--rose);border-radius:4px;width:0;transition:width .5s;}

/* =========================================================================
   CHECKOUT
   ========================================================================= */
.checkout{display:grid;grid-template-columns:1.35fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;}
.co-block{margin-bottom:40px;}
.co-head{font-family:var(--serif);font-size:24px;font-weight:500;margin-bottom:20px;display:flex;align-items:baseline;justify-content:space-between;}
.co-head .num{font-size:14px;color:var(--rose);font-family:var(--sans);margin-right:10px;}
.co-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.co-grid .full{grid-column:1/-1;}
.delivery-opt{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line-3);padding:16px 18px;margin-bottom:10px;cursor:pointer;transition:all .2s;}
.delivery-opt.active{border-color:var(--rose);background:var(--panel);}
.delivery-opt .left{display:flex;align-items:center;gap:14px;}
.delivery-opt .radio{width:16px;height:16px;border-radius:50%;border:1px solid var(--line-4);display:inline-flex;align-items:center;justify-content:center;}
.delivery-opt.active .radio{border-color:var(--rose);}
.delivery-opt .radio i{width:8px;height:8px;border-radius:50%;background:transparent;display:block;}
.delivery-opt.active .radio i{background:var(--rose);}
.delivery-opt .lbl{font-size:14px;}
.delivery-opt .eta{font-size:12px;color:var(--muted-2);font-weight:300;}
.secure-note{text-align:center;margin-top:14px;font-size:12px;font-weight:300;color:var(--muted-2);}
.confirm{max-width:560px;margin:0 auto;padding:clamp(60px,10vw,140px) var(--pad);text-align:center;}
.confirm h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5vw,56px);line-height:1.05;margin:0 0 18px;}
.confirm p{font-weight:300;font-size:16px;line-height:1.8;color:var(--muted);margin:0 0 30px;}

/* =========================================================================
   ACCOUNT / AUTH
   ========================================================================= */
.auth{max-width:440px;margin:0 auto;padding:clamp(40px,7vw,90px) var(--pad) clamp(56px,8vw,100px);}
.auth-tabs{display:flex;gap:28px;justify-content:center;margin-bottom:36px;}
.auth-tabs a{cursor:pointer;font-family:var(--serif);font-size:26px;font-weight:500;color:var(--muted-4);border-bottom:2px solid transparent;padding-bottom:8px;}
.auth-tabs a.active{color:var(--ink);border-bottom-color:var(--rose);}
.auth form{display:flex;flex-direction:column;gap:14px;}
.auth .note{text-align:center;font-size:12px;font-weight:300;color:var(--muted-2);margin-top:6px;}

.account-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(28px,4vw,44px);flex-wrap:wrap;gap:16px;}
.account-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4vw,48px);margin:0;}
.acct-tabs{display:flex;gap:26px;border-bottom:1px solid var(--line);margin-bottom:clamp(28px,4vw,40px);flex-wrap:wrap;}
.acct-tabs a{cursor:pointer;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);padding:0 0 16px;border-bottom:2px solid transparent;margin-bottom:-1px;}
.acct-tabs a.active{color:var(--ink);border-bottom-color:var(--rose);}
.acct-panel{display:none;}
.acct-panel.active{display:block;}
.order{border:1px solid var(--line);padding:22px 24px;margin-bottom:16px;}
.order .top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px;}
.order .oid{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted-2);}
.order .odate{font-size:14px;color:var(--muted);font-weight:300;margin-top:4px;}
.order .ostatus{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--rose);text-align:right;}
.order .ototal{font-family:var(--serif);font-size:22px;margin-top:2px;text-align:right;}
.order .thumbs{display:flex;gap:10px;}
.order .thumbs img{width:54px;height:70px;object-fit:cover;}
.addr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.addr{border:1px solid var(--line);padding:24px;}
.addr .tag{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--rose);margin-bottom:12px;}
.addr p{font-size:15px;color:var(--ink);line-height:1.7;font-weight:300;}
.addr--add{border:1px dashed var(--line-4);display:flex;align-items:center;justify-content:center;color:var(--muted-2);font-size:13px;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;min-height:120px;}

/* =========================================================================
   GIFT CARD
   ========================================================================= */
.gift{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;}
.gift-visual{position:relative;aspect-ratio:4/3;background:linear-gradient(135deg,#E6E6E6,#DDDDDD);overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ink);}
.gift-visual .wm{font-family:var(--serif);font-weight:500;font-size:clamp(26px,4vw,40px);letter-spacing:0.3em;text-transform:uppercase;}
.gift-visual .amt{font-family:var(--serif);font-style:italic;font-size:clamp(40px,7vw,72px);margin-top:24px;}
.gift-form{position:sticky;top:130px;}
.gift-form h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4.2vw,52px);line-height:1.02;margin:0 0 18px;}
.gift-steps{margin-top:30px;display:flex;flex-direction:column;gap:14px;}
.gift-steps .step{display:flex;gap:14px;align-items:flex-start;}
.gift-steps .n{font-family:var(--serif);font-size:22px;color:var(--rose);line-height:1;flex-shrink:0;}

/* =========================================================================
   POLICY / UTILITY PAGES
   ========================================================================= */
.policy{display:grid;grid-template-columns:240px 1fr;gap:clamp(32px,5vw,64px);align-items:start;}
.policy-nav{position:sticky;top:130px;display:flex;flex-direction:column;gap:4px;}
.policy-nav a{cursor:pointer;font-size:13px;letter-spacing:0.06em;color:var(--muted-3);padding:11px 16px;
  border-left:2px solid transparent;transition:all .2s;}
.policy-nav a:hover{color:var(--ink);}
.policy-nav a.active{color:var(--ink);border-left-color:var(--rose);background:var(--panel);}
.policy-body .block{margin-bottom:32px;}
.policy-body .block h2{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.6vw,30px);margin:0 0 12px;}
.policy-body .block p{font-weight:300;font-size:15px;line-height:1.85;color:var(--muted);margin:0;}

.size-table{border:1px solid var(--line);overflow:hidden;margin-bottom:36px;}
.size-table .thead,.size-table .trow{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;}
.size-table .thead{background:var(--ink);color:#F2F2F2;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;}
.size-table .thead div{padding:14px 16px;}
.size-table .trow{border-top:1px solid var(--line-2);font-size:14px;color:var(--ink);font-weight:300;}
.size-table .trow:nth-child(odd){background:var(--soft);}
.size-table .trow div{padding:14px 16px;}
.size-table .trow .s{font-weight:400;}
.measure{display:grid;grid-template-columns:280px 1fr;gap:32px;align-items:start;}
.measure__media{aspect-ratio:3/4;overflow:hidden;background:#ECECEC;}
.measure__media img{width:100%;height:100%;object-fit:cover;}
.measure__steps{display:flex;flex-direction:column;gap:18px;}
.measure__steps .t{font-size:13px;letter-spacing:0.06em;color:var(--ink);font-weight:500;margin-bottom:6px;}
.measure__steps p{font-weight:300;font-size:14px;line-height:1.7;color:var(--muted);margin:0;}

/* =========================================================================
   FAQ ACCORDION (contact)
   ========================================================================= */
.faq{border-bottom:1px solid var(--line);padding:20px 0;cursor:pointer;}
.faq .q{display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq .q span:first-child{font-size:16px;color:var(--ink);font-weight:400;}
.faq .icon{color:var(--rose);font-size:18px;flex-shrink:0;}
.faq .a{font-weight:300;font-size:14px;line-height:1.75;color:var(--muted);margin:0;max-height:0;overflow:hidden;transition:max-height .35s ease,margin .35s ease;}
.faq.open .a{margin:14px 0 0;max-height:240px;}

.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(36px,5vw,72px);align-items:start;}
.contact-card{background:var(--panel);padding:clamp(28px,3vw,40px);}
.contact-card h3{font-family:var(--serif);font-size:22px;font-weight:500;margin:0 0 8px;}
.contact-card .k{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:6px;}
.contact-card .v{font-size:15px;color:var(--ink);margin-bottom:20px;}

/* =========================================================================
   CART DRAWER + POPUP (shared chrome, injected by JS)
   ========================================================================= */
.drawer-wrap{position:fixed;inset:0;z-index:120;pointer-events:none;}
.drawer-wrap.open{pointer-events:auto;}
.drawer-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.4);opacity:0;transition:opacity .35s ease;}
.drawer-wrap.open .drawer-overlay{opacity:1;}
.drawer{position:absolute;top:0;right:0;bottom:0;width:min(440px,100vw);background:#FFFFFF;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,0.14);}
.drawer-wrap.open .drawer{transform:translateX(0);}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:26px 28px 18px;border-bottom:1px solid var(--line-2);}
.drawer-head h3{font-family:var(--serif);font-size:24px;font-weight:500;}
.drawer-head .n{font-size:15px;color:var(--muted-2);}
.drawer-head .x{cursor:pointer;font-size:24px;color:var(--muted);line-height:1;}
.drawer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:40px;text-align:center;}
.drawer-empty h4{font-family:var(--serif);font-size:26px;color:var(--ink);font-weight:500;}
.drawer-empty p{font-weight:300;font-size:14px;color:var(--muted-3);margin:0;}
.drawer-ship{padding:18px 28px 12px;}
.drawer-ship .msg{font-size:12px;font-weight:300;color:var(--muted);margin-bottom:10px;text-align:center;}
.drawer-ship .track{height:4px;background:var(--line-2);border-radius:4px;overflow:hidden;}
.drawer-ship .fill{height:100%;background:var(--rose);border-radius:4px;width:0;transition:width .5s;}
.drawer-lines{flex:1;overflow-y:auto;padding:8px 28px;}
.dline{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line-2);}
.dline .media{width:84px;height:108px;flex-shrink:0;overflow:hidden;background:var(--tint);}
.dline .media img{width:100%;height:100%;object-fit:cover;}
.dline .info{flex:1;display:flex;flex-direction:column;}
.dline .name{font-family:var(--serif);font-size:18px;font-weight:500;line-height:1.15;}
.dline .x{cursor:pointer;color:var(--muted-4);font-size:16px;line-height:1;background:none;border:none;}
.dline .meta{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted-2);margin-top:4px;}
.dline .bottom{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:12px;}
.drawer-foot{border-top:1px solid var(--line-2);padding:22px 28px 26px;}
.drawer-foot .sub{display:flex;justify-content:space-between;margin-bottom:6px;font-size:14px;}
.drawer-foot .sub .lbl{letter-spacing:0.08em;text-transform:uppercase;font-size:12px;}
.drawer-foot .sub .amt{font-family:var(--serif);font-size:22px;}
.drawer-foot .tax{font-size:12px;font-weight:300;color:var(--muted-3);margin-bottom:18px;}
.drawer-foot .cont{text-align:center;margin-top:14px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted-3);cursor:pointer;}

.popup-wrap{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:none;}
.popup-wrap.open{pointer-events:auto;}
.popup-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.45);opacity:0;transition:opacity .4s ease;}
.popup-wrap.open .popup-overlay{opacity:1;}
.popup{position:relative;display:grid;grid-template-columns:1fr 1fr;max-width:760px;width:100%;background:#FFFFFF;
  box-shadow:0 30px 80px rgba(0,0,0,0.3);overflow:hidden;opacity:0;transform:translateY(20px) scale(.98);
  transition:opacity .4s ease,transform .45s cubic-bezier(.2,.7,.2,1);}
.popup-wrap.open .popup{opacity:1;transform:translateY(0) scale(1);}
.popup__media{position:relative;min-height:240px;overflow:hidden;background:#DADADA;}
.popup__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.popup__body{padding:clamp(32px,5vw,52px);position:relative;}
.popup__body .x{position:absolute;top:18px;right:20px;font-size:22px;color:var(--muted-2);cursor:pointer;line-height:1;}
.popup__body h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.5vw,38px);line-height:1.05;margin:0 0 14px;}
.popup__body p{font-weight:300;font-size:14px;line-height:1.7;color:var(--muted);margin:0 0 24px;}
.popup__body .decline{text-align:center;margin-top:14px;font-size:11px;letter-spacing:0.08em;color:var(--muted-2);cursor:pointer;}
.popup .ok{color:var(--rose);font-size:13px;text-align:center;margin-top:14px;min-height:16px;}

/* toast */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);z-index:200;
  background:var(--ink);color:#FFF;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  padding:14px 26px;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:980px){
  .pdp{grid-template-columns:1fr;}
  .pdp-info{position:static;}
  .cart-page{grid-template-columns:1fr;}
  .checkout{grid-template-columns:1fr;}
  .gift{grid-template-columns:1fr;}
  .gift-form{position:static;}
  .contact-grid{grid-template-columns:1fr;}
  .policy{grid-template-columns:1fr;}
  .policy-nav{position:static;flex-direction:row;flex-wrap:wrap;overflow-x:auto;}
  .policy-nav a{border-left:none;border-bottom:2px solid transparent;}
  .policy-nav a.active{border-left:none;border-bottom-color:var(--rose);}
  .summary,.gift-form{position:static;}
}
@media (max-width:880px){
  .two-col,.split,.editorial,.lookbook{grid-template-columns:1fr;}
  .measure{grid-template-columns:1fr;}
  .measure__media{max-width:280px;}
  .hero__inner,.page-hero__inner{padding-left:24px;padding-right:24px;}
  .gallery{flex-direction:column-reverse;}
  .gallery__thumbs{flex-direction:row;width:auto;}
  .thumb{width:64px;}
}
@media (max-width:560px){
  .co-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .btn{padding:16px 30px;}
}
