/* =================================================================
   NINE FATHOM — "The Heritage Clubhouse"
   Cream & charcoal · serif voice, sans utility · navy reserved for buy
   ================================================================= */

:root{
  --bg:            #F3F1ED;   /* cream field */
  --cream:         #FBFAF8;   /* raised cream */
  --plate-top:     #FCFBF9;
  --plate-bot:     #ECE9E2;   /* product plate foot (greige, lifts white goods) */
  --ink:           #262429;   /* charcoal text */
  --ink-2:         #514E56;
  --ink-soft:      #6E6A73;   /* muted */
  --line:          #DED9D1;   /* hairline */
  --line-2:        #E7E3DB;
  --line-dark:     rgba(243,241,237,0.16);
  --navy:          #1B2634;   /* deep navy surface */
  --navy-2:        #223045;
  --accent:        #1B2634;   /* CTA fill — ONLY */
  --accent-hover:  #2a3a51;
  --on-dark:       #F3F1ED;

  --serif: "Cormorant Garamond", "Georgia", "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --wrap: 1280px;
  --gutter: clamp(1.25rem, 4.2vw, 4.5rem);
  --sp: clamp(4.5rem, 9vw, 8.5rem);      /* section rhythm */

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --announce-h: 40px;
  --nav-h: 74px;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  font-family:var(--sans); background:var(--bg); color:var(--ink);
  font-size:1.0625rem; line-height:1.7; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
img,video,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul,ol{ list-style:none; }
::selection{ background:var(--navy); color:var(--on-dark); }

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.skip-link{ position:fixed; left:-999px; top:0; z-index:300; background:var(--accent); color:var(--on-dark); padding:.7rem 1.2rem; }
.skip-link:focus{ left:1rem; top:1rem; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:1px; }

/* ---------- type utilities ---------- */
.eyebrow{
  font-family:var(--sans); font-weight:500; font-size:.7rem; text-transform:uppercase;
  letter-spacing:.26em; color:var(--ink-soft); display:inline-flex; align-items:center; gap:.7rem;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.6;
  transform:scaleX(0); transform-origin:left; transition:transform .8s var(--ease); }
.reveal.is-in .eyebrow::before, .eyebrow.is-in::before{ transform:scaleX(1); }
.eyebrow--light{ color:rgba(243,241,237,.66); }
.eyebrow--center{ justify-content:center; }
.eyebrow--center::after{ content:""; width:26px; height:1px; background:currentColor; opacity:.6;
  transform:scaleX(0); transform-origin:right; transition:transform .8s var(--ease); }
.reveal.is-in .eyebrow--center::after{ transform:scaleX(1); }

.h-display{ font-family:var(--serif); font-weight:600; line-height:1.0; letter-spacing:-.015em; }
.h-title{ font-family:var(--serif); font-weight:500; font-size:clamp(2.1rem,4.4vw,3.4rem); line-height:1.06; letter-spacing:-.01em; color:var(--ink); }
.h-title--light{ color:var(--on-dark); }
.lede{ color:var(--ink-2); font-size:clamp(1rem,1.3vw,1.15rem); max-width:52ch; }
.price{ font-variant-numeric:tabular-nums; font-weight:400; color:var(--ink); }

.section-head{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.1rem; }
.section-head .lede{ margin-top:.2rem; }

/* ---------- buttons ---------- */
.btn{
  --pad-y:1.05rem; --pad-x:2rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.7rem;
  font-family:var(--sans); font-weight:500; font-size:.76rem; text-transform:uppercase; letter-spacing:.16em;
  padding:var(--pad-y) var(--pad-x); border-radius:2px; position:relative;
  transition:background .35s var(--ease), color .35s var(--ease), transform .3s var(--ease), border-color .35s var(--ease), letter-spacing .35s var(--ease);
  will-change:transform;
}
.btn--sm{ --pad-y:.72rem; --pad-x:1.3rem; font-size:.68rem; letter-spacing:.14em; }
.btn--block{ width:100%; }
.btn--primary{ background:var(--accent); color:var(--on-dark); }        /* the ONLY navy fill */
.btn--primary:hover{ background:var(--accent-hover); }
.btn--ghost{ background:transparent; color:var(--ink); border:1px solid var(--ink); overflow:hidden; z-index:0; }
.btn--ghost::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--ink); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); }
.btn--ghost:hover{ color:var(--bg); letter-spacing:.19em; }
.btn--ghost:hover::before{ transform:scaleX(1); }
.btn--ghost-light{ color:var(--on-dark); border-color:rgba(243,241,237,.55); }
.btn--ghost-light::before{ background:var(--on-dark); }
.btn--ghost-light:hover{ color:var(--navy); }
.btn__count{ display:inline-grid; place-items:center; min-width:1.4em; height:1.4em; padding:0 .35em; background:rgba(243,241,237,.18); border-radius:50px; font-size:.82em; line-height:1; }
.link-underline{ font-size:.72rem; text-transform:uppercase; letter-spacing:.18em; font-weight:500; position:relative; padding-bottom:3px; }
.link-underline::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.link-underline:hover::after{ transform:scaleX(1); }

/* =================================================================
   ANNOUNCEMENT + NAV
   ================================================================= */
.announce{
  position:fixed; top:0; left:0; right:0; z-index:110; height:var(--announce-h);
  background:var(--navy); color:rgba(243,241,237,.86);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  font-size:.68rem; text-transform:uppercase; letter-spacing:.2em; text-align:center; padding:0 1rem;
  transition:transform .5s var(--ease), opacity .4s var(--ease);
}
body.scrolled .announce{ transform:translateY(-100%); opacity:0; }

.nav{ position:fixed; top:var(--announce-h); left:0; right:0; z-index:120; transition:top .5s var(--ease), background .5s var(--ease), box-shadow .5s var(--ease), backdrop-filter .5s var(--ease); }
body.scrolled .nav{ top:0; }
.nav__inner{ max-width:1440px; margin-inline:auto; display:flex; align-items:center; gap:1.5rem; padding:0 var(--gutter); height:var(--nav-h); }
.nav__brand{ display:flex; align-items:center; gap:.6rem; flex:1; }
.nav__mark{ width:32px; height:32px; object-fit:contain; filter:brightness(0) invert(1); transition:filter .5s var(--ease); }
.nav__word{ font-family:var(--serif); font-weight:600; font-size:1.4rem; letter-spacing:.06em; color:var(--on-dark); transition:color .5s var(--ease); line-height:1; }
.nav__links{ display:flex; align-items:center; gap:2.2rem; }
.nav__links a{ font-size:.72rem; text-transform:uppercase; letter-spacing:.18em; font-weight:500; color:rgba(243,241,237,.82); position:relative; padding:.4rem 0; transition:color .3s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease); }
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__right{ display:flex; align-items:center; gap:1.4rem; flex:1; justify-content:flex-end; }
.nav__cart{ }

.nav[data-state="scrolled"]{ background:rgba(251,250,248,.85); backdrop-filter:blur(16px) saturate(1.3); -webkit-backdrop-filter:blur(16px) saturate(1.3); box-shadow:0 1px 0 var(--line); }
.nav[data-state="scrolled"] .nav__mark{ filter:none; }
.nav[data-state="scrolled"] .nav__word{ color:var(--ink); }
.nav[data-state="scrolled"] .nav__links a{ color:var(--ink); }
.nav__toggle{ display:none; width:42px; height:42px; flex-direction:column; gap:6px; align-items:center; justify-content:center; }
.nav__toggle span{ width:22px; height:1.5px; background:var(--on-dark); transition:.35s var(--ease); }
.nav[data-state="scrolled"] .nav__toggle span{ background:var(--ink); }
.nav__toggle[aria-expanded="true"] span:first-child{ transform:translateY(3.75px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:last-child{ transform:translateY(-3.75px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:calc(var(--announce-h) + var(--nav-h)) 0 auto 0; z-index:115;
  background:rgba(251,250,248,.98); backdrop-filter:blur(16px);
  display:flex; flex-direction:column; padding:1rem var(--gutter) 2.5rem; border-bottom:1px solid var(--line);
  transform:translateY(-12px); opacity:0; pointer-events:none; transition:.4s var(--ease);
}
body.scrolled .mobile-menu{ inset:var(--nav-h) 0 auto 0; }
.mobile-menu:not([hidden]){ transform:none; opacity:1; pointer-events:auto; }
.mobile-menu a{ font-family:var(--serif); font-size:1.7rem; padding:.75rem 0; border-bottom:1px solid var(--line); color:var(--ink); }
.mobile-menu a:last-child{ border-bottom:none; }

/* =================================================================
   HERO
   ================================================================= */
.hero{ position:relative; height:100svh; min-height:600px; display:flex; align-items:flex-end; overflow:hidden; background:var(--navy); }
.hero__media{ position:absolute; inset:0; }
.hero__video{ width:100%; height:100%; object-fit:cover; }
.hero__scrim{ position:absolute; inset:0; background:
  linear-gradient(to right, rgba(16,19,25,.66) 0%, rgba(16,19,25,.44) 36%, rgba(16,19,25,.10) 64%, rgba(16,19,25,0) 82%),
  linear-gradient(to top, rgba(16,19,25,.80) 0%, rgba(16,19,25,.30) 36%, rgba(16,19,25,.06) 62%, rgba(16,19,25,.26) 100%); }
.hero__content{ position:relative; z-index:2; width:100%; max-width:1440px; margin-inline:auto; padding:0 var(--gutter) clamp(3.5rem,9vh,7rem); }
.hero__eyebrow{ color:rgba(243,241,237,.82); margin-bottom:1.6rem; }
.hero__title{ color:var(--on-dark); font-size:clamp(3rem,8.2vw,7rem); max-width:15ch; margin-bottom:1.7rem; text-shadow:0 2px 28px rgba(10,12,16,.5), 0 1px 4px rgba(10,12,16,.35); }
.hero__title .line{ display:block; overflow:hidden; padding-bottom:.04em; }
.hero__title .line > span{ display:block; transform:translateY(112%); }
.hero.is-loaded .hero__title .line > span{ transform:none; transition:transform 1.05s var(--ease-out); }
.hero.is-loaded .hero__title .line:nth-child(2) > span{ transition-delay:.09s; }
.hero.is-loaded .hero__title .line:nth-child(3) > span{ transition-delay:.18s; }
.hero__sub{ color:rgba(243,241,237,.88); font-size:clamp(1.02rem,1.4vw,1.22rem); max-width:46ch; text-shadow:0 1px 14px rgba(10,12,16,.55); }
.hero__cta{ display:flex; gap:1rem; margin-top:2.4rem; flex-wrap:wrap; }
.hero__meta{ position:absolute; right:var(--gutter); bottom:clamp(3.5rem,9vh,7rem); z-index:2; text-align:right; display:flex; flex-direction:column; gap:.3rem; }
.hero__meta span:first-child{ font-family:var(--serif); font-style:italic; font-size:1.15rem; color:rgba(243,241,237,.62); }
.hero__meta span:last-child{ font-size:.62rem; text-transform:uppercase; letter-spacing:.24em; color:rgba(243,241,237,.42); }

/* =================================================================
   MARQUEE
   ================================================================= */
.marquee{ background:var(--bg); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; padding:1.15rem 0; }
.marquee__track{ display:flex; align-items:center; gap:2.6rem; width:max-content; animation:marquee 38s linear infinite; }
.marquee__track span{ font-family:var(--serif); font-size:1.4rem; color:var(--ink-2); white-space:nowrap; }
.marquee__track i{ color:var(--ink-soft); font-style:normal; font-size:.6rem; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* =================================================================
   product plate (shared)
   ================================================================= */
.plate{ position:relative; background:linear-gradient(178deg,var(--plate-top),var(--plate-bot)); border:1px solid var(--line); border-radius:4px; overflow:hidden; }
.plate::after{ content:""; position:absolute; left:50%; bottom:7%; width:56%; height:6%; transform:translateX(-50%);
  background:radial-gradient(ellipse at center, rgba(38,36,41,.22), transparent 70%); filter:blur(7px); }
.plate img{ position:relative; z-index:1; }

/* =================================================================
   FLAGSHIP (product feature with gallery)
   ================================================================= */
.flagship{ padding:var(--sp) 0 calc(var(--sp) * .7); }
.flagship__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.gallery__main{ aspect-ratio:1/1.02; display:grid; place-items:center; }
.gallery__main img{ width:88%; height:88%; object-fit:contain; filter:drop-shadow(0 26px 34px rgba(38,36,41,.16)); transition:opacity .4s var(--ease); }
.gallery__thumbs{ display:flex; gap:.75rem; margin-top:1rem; }
.gallery__thumb{ flex:1; aspect-ratio:1/1; border:1px solid var(--line); border-radius:3px; background:linear-gradient(178deg,var(--plate-top),var(--plate-bot)); display:grid; place-items:center; overflow:hidden; transition:border-color .3s var(--ease); }
.gallery__thumb img{ width:78%; height:78%; object-fit:contain; }
.gallery__thumb.is-active{ border-color:var(--ink); }
.gallery__thumb:hover{ border-color:var(--ink-soft); }

.flagship__eyebrow{ margin-bottom:1.3rem; }
.flagship__name{ font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem,3.8vw,3.3rem); line-height:1.03; margin-bottom:1.1rem; }
.flagship__lead{ color:var(--ink-2); max-width:46ch; }
.flagship__rating{ display:flex; align-items:center; gap:.6rem; margin-top:1rem; color:var(--ink-soft); font-size:.82rem; }
.flagship__rating .stars{ color:var(--ink); letter-spacing:.15em; }
.spec{ margin:1.8rem 0; border-top:1px solid var(--line); }
.spec li{ display:flex; justify-content:space-between; gap:1.5rem; padding:.85rem 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.spec li span:first-child{ color:var(--ink-soft); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; padding-top:.2rem; }
.spec li span:last-child{ text-align:right; max-width:62%; color:var(--ink-2); }
.flagship__buy{ display:flex; flex-direction:column; gap:1.3rem; }
.flagship__buyrow{ display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.flagship__buyrow .price{ font-family:var(--serif); font-size:2rem; }
.flagship__buyrow .btn{ flex:1; min-width:180px; }

/* size selector (charcoal active — never navy) */
.sizes{ display:flex; flex-wrap:wrap; gap:.45rem; }
.sizes-label{ font-size:.66rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); margin-bottom:.6rem; display:block; }
.size{ min-width:46px; min-height:42px; padding:.3rem .6rem; border:1px solid var(--line); background:transparent; color:var(--ink-2);
  font-family:var(--sans); font-size:.76rem; font-weight:500; letter-spacing:.05em; font-variant-numeric:tabular-nums; transition:.2s var(--ease); }
.size:hover{ border-color:var(--ink); color:var(--ink); }
.size.is-active{ background:var(--ink); color:var(--on-dark); border-color:var(--ink); }
.sizes.needs-size .size{ border-color:#a13d3d; }
.sizes.needs-size{ animation:shake .4s var(--ease); }
@keyframes shake{ 20%,60%{ transform:translateX(-4px); } 40%,80%{ transform:translateX(4px); } }

/* =================================================================
   COLLECTION
   ================================================================= */
.collection{ padding-bottom:var(--sp); }
.collection__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; padding-top:var(--sp); margin-bottom:clamp(2rem,4vw,3.2rem); }
.collection__head .link-underline{ color:var(--ink-2); white-space:nowrap; padding-bottom:.5rem; }
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.2vw,2rem); }
@media (min-width:1100px){
  .grid{ grid-template-columns:repeat(5,1fr); gap:clamp(.9rem,1.4vw,1.4rem); }
  .p-card__body{ padding-top:1rem; }
  .p-card__name{ font-size:1.18rem; }
  .p-card__desc{ display:none; }
  .size{ min-width:30px; padding:.28rem .4rem; font-size:.7rem; }
}
.p-card{ display:flex; flex-direction:column; }
.p-card__media{ aspect-ratio:1/1.12; display:grid; place-items:center; }
.p-card__media img{ width:84%; height:84%; object-fit:contain; filter:drop-shadow(0 18px 26px rgba(38,36,41,.15)); transition:transform .6s var(--ease); }
.p-card:hover .p-card__media img{ transform:translateY(-8px) scale(1.015); }
.p-card__badge{ position:absolute; top:1rem; left:1rem; z-index:2; font-size:.6rem; text-transform:uppercase; letter-spacing:.16em; background:var(--ink); color:var(--on-dark); padding:.34rem .6rem; border-radius:2px; }
.p-card__body{ padding-top:1.3rem; display:flex; flex-direction:column; flex:1; }
.p-card__cat{ font-size:.64rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); margin-bottom:.45rem; }
.p-card__name{ font-family:var(--serif); font-weight:500; font-size:1.5rem; line-height:1.12; }
.p-card__desc{ color:var(--ink-soft); font-size:.9rem; margin-top:.5rem; }
@media (hover:hover) and (pointer:fine){
  .p-card__desc{ max-height:0; opacity:0; margin-top:0; overflow:hidden; transition:max-height .5s var(--ease), opacity .5s var(--ease), margin .5s var(--ease); }
  .p-card:hover .p-card__desc, .p-card:focus-within .p-card__desc{ max-height:7rem; opacity:1; margin-top:.5rem; }
}
.p-card__swatches{ display:flex; gap:.5rem; margin-top:.9rem; }
.swatch{ width:17px; height:17px; border-radius:50%; background:var(--sw); border:1px solid rgba(0,0,0,.12); position:relative; transition:transform .25s var(--ease); }
.swatch::after{ content:""; position:absolute; inset:-4px; border:1px solid transparent; border-radius:50%; transition:border-color .25s; }
.swatch.is-active::after{ border-color:var(--ink); }
.swatch:hover{ transform:scale(1.12); }
.p-card__sizes{ margin-top:1rem; }
.p-card__foot{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-top:auto; padding-top:1.2rem; }
.p-card__foot .price{ font-family:var(--serif); font-size:1.4rem; }

/* =================================================================
   CRAFT
   ================================================================= */
.craft{ background:var(--cream); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:var(--sp) 0; }
.craft__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,5.5rem); align-items:center; }
.craft__media{ position:relative; overflow:hidden; border:1px solid var(--line); border-radius:4px; background:linear-gradient(178deg,var(--plate-top),var(--plate-bot)); aspect-ratio:4/5; display:grid; place-items:center; }
.craft__media img{ width:88%; height:88%; object-fit:contain; }
.craft__media--photo img{ width:100%; height:100%; object-fit:cover; object-position:62% center; }
.craft__body .h-title{ margin:1rem 0 .5rem; }
.craft__list{ margin-top:1.8rem; }
.craft__list li{ display:flex; gap:1.6rem; padding:1.5rem 0; border-top:1px solid var(--line); }
.craft__list li:last-child{ border-bottom:1px solid var(--line); }
.craft__num{ font-family:var(--serif); font-weight:500; font-size:2rem; color:var(--ink); line-height:1; min-width:2.2rem; }
.craft__list h3{ font-family:var(--serif); font-weight:500; font-size:1.45rem; margin-bottom:.2rem; }
.craft__list p{ color:var(--ink-soft); font-size:.92rem; max-width:44ch; }

/* =================================================================
   CREST (navy interlude)
   ================================================================= */
.crest{ position:relative; background:var(--navy); color:var(--on-dark); text-align:center; padding:calc(var(--sp) * 1.1) 0; overflow:hidden; }
.crest__ghost{ position:absolute; right:-5%; top:6%; width:min(44vw,500px); opacity:.055; filter:brightness(0) invert(1); pointer-events:none; }
.crest__ghost--l{ left:-6%; right:auto; top:auto; bottom:2%; opacity:.04; }
.crest__inner{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; }
.medallion{ width:clamp(148px,19vw,206px); aspect-ratio:1/1; border-radius:50%; background:var(--cream); display:grid; place-items:center; margin-bottom:2.4rem;
  box-shadow:0 34px 70px -28px rgba(0,0,0,.65), inset 0 0 0 1px rgba(255,255,255,.5), 0 0 0 9px rgba(243,241,237,.05); }
.medallion img{ width:84%; }
.crest .h-title{ margin-top:.4rem; }
.crest__manifesto{ max-width:54ch; margin:1.5rem auto 0; color:rgba(243,241,237,.82); font-size:1.1rem; }
.crest__legend{ display:flex; flex-wrap:wrap; justify-content:center; gap:clamp(1.5rem,5vw,4.5rem); margin-top:3.4rem; }
.crest__legend li{ max-width:22ch; font-size:.88rem; color:rgba(243,241,237,.64); }
.crest__legend span{ display:block; font-family:var(--serif); font-size:1.35rem; color:var(--on-dark); margin-bottom:.35rem; }

/* =================================================================
   LOOKBOOK (editorial photo plates)
   ================================================================= */
.lookbook{ padding:var(--sp) 0; }
.lookbook__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; margin-bottom:clamp(1.6rem,3vw,2.6rem); }
.lookbook__head .link-underline{ color:var(--ink-2); white-space:nowrap; padding-bottom:.5rem; }
.lb-rowA{ display:grid; grid-template-columns:1.5fr 1fr; gap:clamp(.9rem,2vw,1.6rem); height:clamp(360px,46vw,600px); }
.lb-rowB{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(.9rem,2vw,1.6rem); height:clamp(300px,34vw,470px); }
.plateimg{ position:relative; overflow:hidden; background:var(--cream); border:1px solid var(--line); border-radius:4px; }
.plateimg img{ width:100%; height:100%; object-fit:cover; object-position:center 26%; transition:transform 1.4s var(--ease); }
.plateimg:hover img{ transform:scale(1.045); }
.plateimg figcaption{ position:absolute; left:1rem; bottom:1rem; z-index:2; font-size:.64rem; text-transform:uppercase; letter-spacing:.18em; color:var(--on-dark);
  background:rgba(27,38,52,.6); backdrop-filter:blur(4px); padding:.42rem .75rem; border-radius:2px; }
.lb-quote{ text-align:center; max-width:24ch; margin:clamp(2.4rem,5vw,4rem) auto; }
.lb-quote p{ font-family:var(--serif); font-weight:500; font-style:italic; font-size:clamp(1.7rem,3.4vw,3rem); line-height:1.16; color:var(--ink); }
.lb-quote cite{ display:block; font-style:normal; font-family:var(--sans); font-size:.68rem; text-transform:uppercase; letter-spacing:.22em; color:var(--ink-soft); margin-top:1.4rem; }

/* =================================================================
   FILM BAND (navy cinematic)
   ================================================================= */
.film{ position:relative; height:min(64vh,560px); display:grid; place-items:center; overflow:hidden; background:var(--navy); }
.film__media{ position:absolute; inset:0; }
.film__media video{ width:100%; height:100%; object-fit:cover; }
.film__scrim{ position:absolute; inset:0; background:linear-gradient(rgba(16,19,25,.6),rgba(16,19,25,.74)); }
.film__inner{ position:relative; z-index:1; text-align:center; padding:0 var(--gutter); display:flex; flex-direction:column; align-items:center; gap:1.6rem; }
.film__quote{ font-family:var(--serif); font-weight:500; color:var(--on-dark); font-size:clamp(2rem,5vw,4.2rem); line-height:1.08; max-width:20ch; }

/* =================================================================
   STORY
   ================================================================= */
.story{ padding:var(--sp) 0; }
.story__col{ max-width:768px; margin-inline:auto; text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.1rem; }
.story .h-title{ max-width:20ch; }
.prose{ text-align:left; max-width:60ch; margin-top:.6rem; }
.prose p{ margin-bottom:1.3rem; color:var(--ink-2); }
.dropcap{ float:left; font-family:var(--serif); font-weight:600; font-size:4.4rem; line-height:.78; padding:.35rem .55rem 0 0; color:var(--ink); }
.story__sign{ width:clamp(280px,34vw,400px); margin-top:2rem; opacity:.9; }
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3.5rem); margin-top:clamp(3.5rem,7vw,6rem); padding-top:clamp(3rem,5vw,4rem); border-top:1px solid var(--line); }
.pillar{ text-align:center; }
.pillar__ico{ width:34px; height:34px; margin:0 auto 1.1rem; opacity:.9; }
.pillar h3{ font-family:var(--serif); font-weight:500; font-size:1.45rem; margin-bottom:.6rem; }
.pillar p{ color:var(--ink-soft); font-size:.92rem; max-width:34ch; margin-inline:auto; }

/* =================================================================
   DETAILS
   ================================================================= */
.details{ background:var(--cream); border-top:1px solid var(--line); padding:var(--sp) 0; }
.assurances{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.5vw,2rem); margin-bottom:clamp(3rem,6vw,5rem); }
.assurance{ text-align:center; padding:1.75rem 1rem; border:1px solid var(--line); border-radius:4px; background:var(--bg); }
.assurance strong{ display:block; font-family:var(--serif); font-weight:500; font-size:1.25rem; margin-bottom:.2rem; }
.assurance span{ font-size:.82rem; color:var(--ink-soft); }
.details__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3.5rem); margin-top:clamp(2rem,4vw,3rem); }
.detail{ scroll-margin-top:130px; }
.detail h3{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin-bottom:.9rem; }
.detail p{ font-size:.92rem; color:var(--ink-soft); margin-bottom:.7rem; }
.sizechart{ width:100%; border-collapse:collapse; margin-top:.4rem; font-size:.82rem; font-variant-numeric:tabular-nums; }
.sizechart th,.sizechart td{ border:1px solid var(--line); padding:.5rem; text-align:center; }
.sizechart th{ background:var(--bg); font-weight:500; text-transform:uppercase; letter-spacing:.08em; font-size:.66rem; color:var(--ink-soft); }

/* =================================================================
   MEMBERS
   ================================================================= */
.members{ padding:var(--sp) 0; }
.members__card{ max-width:760px; margin-inline:auto; text-align:center; border:1px solid var(--line); border-radius:5px; background:var(--cream); padding:clamp(2.75rem,6vw,4.75rem) clamp(1.5rem,5vw,4rem); display:flex; flex-direction:column; align-items:center; gap:1rem; }
.members__pitch{ color:var(--ink-soft); max-width:48ch; }
.members__form{ display:flex; gap:.75rem; max-width:470px; width:100%; margin-top:.8rem; flex-wrap:wrap; }
.members__form input{ flex:1; min-width:200px; background:transparent; border:none; border-bottom:1px solid var(--ink); padding:.85rem .2rem; font-family:var(--sans); font-size:1rem; color:var(--ink); }
.members__form input::placeholder{ color:var(--ink-soft); }
.members__form input:focus{ outline:none; border-color:var(--accent); }
.members__msg{ min-height:1.2rem; font-size:.9rem; color:var(--ink); font-weight:500; }
.members__fine{ font-size:.76rem; color:var(--ink-soft); }

/* =================================================================
   FOOTER
   ================================================================= */
.footer{ background:var(--navy); color:var(--on-dark); padding:clamp(4rem,7vw,6rem) 0 2.5rem; }
.footer__top{ display:grid; grid-template-columns:1.3fr 2fr; gap:clamp(2.5rem,5vw,4.5rem); padding-bottom:3.2rem; border-bottom:1px solid var(--line-dark); }
.footer__brand{ display:flex; flex-direction:column; gap:1.4rem; align-items:flex-start; }
.medallion--sm{ width:72px; margin:0; box-shadow:0 14px 32px -16px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.4); }
.footer__tag{ font-family:var(--serif); font-size:1.3rem; line-height:1.35; color:rgba(243,241,237,.9); }
.footer__social{ display:flex; gap:1.2rem; margin-top:.3rem; }
.footer__social a{ font-size:.7rem; text-transform:uppercase; letter-spacing:.16em; color:rgba(243,241,237,.7); transition:color .25s; }
.footer__social a:hover{ color:var(--on-dark); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer__cols h3{ font-family:var(--sans); font-size:.68rem; text-transform:uppercase; letter-spacing:.18em; font-weight:500; color:rgba(243,241,237,.5); margin-bottom:1.2rem; }
.footer__cols a{ display:block; font-size:.9rem; color:rgba(243,241,237,.82); padding:.34rem 0; transition:color .25s, padding-left .25s; }
.footer__cols a:hover{ color:var(--on-dark); padding-left:.25rem; }
.footer__base{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:1.8rem; font-size:.76rem; color:rgba(243,241,237,.5); }

/* =================================================================
   CART DRAWER
   ================================================================= */
.cart-overlay{ position:fixed; inset:0; z-index:200; background:rgba(16,19,25,.5); backdrop-filter:blur(2px); opacity:0; transition:opacity .4s var(--ease); }
.cart-overlay.is-open{ opacity:1; }
.cart{ position:fixed; top:0; right:0; z-index:210; height:100dvh; width:min(430px,100vw); background:var(--bg); display:flex; flex-direction:column; transform:translateX(100%); transition:transform .5s var(--ease); box-shadow:-30px 0 60px -30px rgba(0,0,0,.4); }
.cart.is-open{ transform:none; }
.cart__head{ display:flex; align-items:center; justify-content:space-between; padding:1.6rem var(--gutter); border-bottom:1px solid var(--line); }
.cart__head h2{ font-family:var(--serif); font-weight:500; font-size:1.6rem; }
.cart__close{ width:44px; height:44px; display:grid; place-items:center; font-size:1.7rem; line-height:1; color:var(--ink-soft); transition:color .25s; margin-right:-.6rem; }
.cart__close:hover{ color:var(--ink); }
.cart__items{ flex:1; overflow-y:auto; padding:1.2rem var(--gutter); }
.cart__empty{ color:var(--ink-soft); text-align:center; margin-top:3rem; font-family:var(--serif); font-size:1.25rem; }
.cart-item{ display:grid; grid-template-columns:66px 1fr auto; gap:1rem; align-items:center; padding:1.1rem 0; border-bottom:1px solid var(--line); }
.cart-item__img{ width:66px; height:66px; object-fit:contain; background:linear-gradient(178deg,var(--plate-top),var(--plate-bot)); border:1px solid var(--line); border-radius:3px; }
.cart-item__name{ font-family:var(--serif); font-size:1.15rem; line-height:1.2; }
.cart-item__meta{ font-size:.8rem; color:var(--ink-soft); display:flex; align-items:center; gap:.7rem; margin-top:.35rem; flex-wrap:wrap; }
.cart-item__size{ text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; }
.cart-item__qty{ display:inline-flex; align-items:center; border:1px solid var(--line); }
.cart-item__qty button{ width:34px; height:34px; color:var(--ink-soft); display:grid; place-items:center; }
.cart-item__qty span{ min-width:22px; text-align:center; font-size:.82rem; }
.cart-item__price{ font-variant-numeric:tabular-nums; }
.cart-item__remove{ font-size:.7rem; color:var(--ink-soft); text-decoration:underline; padding:.4rem 0; }
@media (hover:none),(pointer:coarse){
  .cart-item__qty button{ width:44px; height:44px; }
  .cart-item__remove{ padding:.6rem 0; }
  /* swatches: keep the small dot, grow the tap area to 40px via transparent border */
  .p-card__swatches{ gap:.3rem; }
  .swatch{ width:40px; height:40px; border:11px solid transparent; background-clip:padding-box; }
  .swatch::after{ inset:7px; }
}
.cart__foot{ padding:1.4rem var(--gutter) 1.8rem; border-top:1px solid var(--line); }
.cart__row{ display:flex; justify-content:space-between; font-size:.86rem; color:var(--ink-soft); margin-bottom:.5rem; }
.cart__subtotal{ display:flex; justify-content:space-between; align-items:baseline; font-size:1rem; margin:.6rem 0 1rem; padding-top:.8rem; border-top:1px solid var(--line); }
.cart__subtotal span:last-child{ font-variant-numeric:tabular-nums; font-family:var(--serif); font-size:1.5rem; color:var(--ink); }
.cart__note{ font-size:.74rem; color:var(--ink-soft); text-align:center; margin-top:.8rem; }

/* toast */
.toast{ position:fixed; left:50%; bottom:2rem; z-index:260; transform:translate(-50%,1.5rem); background:var(--ink); color:var(--on-dark); padding:.95rem 1.6rem; font-size:.84rem; letter-spacing:.02em; opacity:0; transition:.4s var(--ease); border-radius:2px; box-shadow:0 20px 40px -18px rgba(0,0,0,.5); }
.toast.is-show{ opacity:1; transform:translateX(-50%); }

/* =================================================================
   REVEAL
   ================================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1080px){
  .footer__top{ grid-template-columns:1fr; }
}
@media (max-width:920px){
  .nav__links{ display:none; }
  .nav__toggle{ display:flex; }
  .nav__right .link-underline{ display:none; }
  .flagship__grid, .craft__grid{ grid-template-columns:1fr; }
  .craft__media{ order:-1; max-width:460px; margin-inline:auto; aspect-ratio:1/1; }
  .grid{ grid-template-columns:repeat(2,1fr); }
  .lb-rowA,.lb-rowB{ grid-template-columns:1fr; height:auto; }
  .lb-rowA .plateimg,.lb-rowB .plateimg{ aspect-ratio:4/5; }
  .details__grid{ grid-template-columns:1fr; gap:2.5rem; }
}
@media (max-width:640px){
  .announce{ font-size:.6rem; letter-spacing:.14em; }
  .announce__more{ display:none; }
}
@media (max-width:600px){
  body{ font-size:1rem; }
  .hero__title{ font-size:2.6rem; }
  .grid{ grid-template-columns:1fr; }
  .collection__head, .lookbook__head{ flex-direction:column; align-items:flex-start; gap:1rem; }
  .assurances{ grid-template-columns:1fr; }
  .pillars{ grid-template-columns:1fr; gap:2.5rem; }
  .footer__cols{ grid-template-columns:repeat(2,1fr); gap:1.5rem 1rem; }
  .footer__base{ flex-direction:column; gap:.4rem; }
  .hero__cta{ flex-direction:column; align-items:stretch; }
  .hero__cta .btn{ width:100%; }
  .hero__meta{ display:none; }
  .members__form{ flex-direction:column; }
  .members__form .btn{ width:100%; }
  .flagship__buyrow .btn{ width:100%; }
}
@media (max-height:640px) and (orientation:landscape){
  .hero{ min-height:520px; align-items:center; }
  .hero__content{ padding-top:calc(var(--nav-h) + 1.5rem); padding-bottom:2rem; }
  .hero__meta{ display:none; }
}

/* =================================================================
   PRODUCT PAGES (PDP)
   ================================================================= */
.pdp{ padding:calc(var(--announce-h) + var(--nav-h) + clamp(1.5rem,3vw,3rem)) 0 clamp(2.5rem,5vw,4rem); }
.crumbs{ display:flex; flex-wrap:wrap; gap:.6rem; font-size:.78rem; color:var(--ink-soft); margin-bottom:clamp(1.4rem,3vw,2.4rem); }
.crumbs a{ transition:color .2s; }
.crumbs a:hover{ color:var(--ink); }
.crumbs [aria-current]{ color:var(--ink); }
.pdp__grid{ display:grid; grid-template-columns:minmax(0,6fr) minmax(0,5fr); gap:clamp(2rem,5vw,5rem); align-items:start; }
.pdp__body{ display:flex; flex-direction:column; align-items:flex-start; gap:1.05rem; position:sticky; top:calc(var(--nav-h) + 24px); }
.pdp__name{ font-family:var(--serif); font-weight:500; font-size:clamp(2rem,3.6vw,2.9rem); line-height:1.05; letter-spacing:-.01em; }
.pdp__price{ font-size:1.25rem; }
.pdp__lead{ color:var(--ink-2); }
.pdp__opt{ display:flex; flex-direction:column; gap:.55rem; }
.pdp__optlabel{ font-size:.7rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); }
.pdp__body .btn--block{ margin-top:.4rem; }
.pdp__spec{ width:100%; margin-top:1.2rem; }
.pdp__assure{ font-size:.82rem; color:var(--ink-soft); }
.pdp__assure a{ text-decoration:underline; text-underline-offset:3px; }
.pdp-story{ padding:clamp(2.5rem,5vw,4.5rem) 0; border-top:1px solid var(--line); }
.pdp-quote{ margin-top:clamp(1.8rem,3vw,2.6rem); text-align:center; }
.pdp-quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.05rem,1.5vw,1.3rem); line-height:1.55; color:var(--ink); }
.pdp-quote cite{ display:block; font-style:normal; font-size:.62rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); margin-top:.7rem; }
.pairs-sec{ padding:0 0 var(--sp); }
.pairs{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.5vw,2rem); margin-top:clamp(2rem,4vw,3rem); }
.pair{ display:flex; flex-direction:column; gap:.55rem; }
.pair__media{ aspect-ratio:1/1; }
.pair__media img{ width:100%; height:100%; object-fit:contain; padding:9%; transition:transform .8s var(--ease); }
.pair:hover .pair__media img{ transform:scale(1.04); }
.pair__name{ font-family:var(--serif); font-size:1.15rem; color:var(--ink); }
.pair__price{ font-size:.85rem; color:var(--ink-soft); }
.p-card__link{ color:inherit; }
@media (max-width:900px){
  .pdp__grid{ grid-template-columns:1fr; }
  .pdp__body{ position:static; }
  .pairs{ grid-template-columns:1fr 1fr; }
  .pairs .pair:nth-child(3){ display:none; }
}

/* =================================================================
   THE RIME (the story behind the name)
   ================================================================= */
.rime{ padding:var(--sp) 0; }
.rime__grid{ display:grid; grid-template-columns:minmax(0,5fr) minmax(0,6fr); gap:clamp(2.2rem,5vw,5rem); align-items:center; }
.rime__plate{ background:var(--cream); border:1px solid var(--line); border-radius:4px;
  padding:clamp(.8rem,1.6vw,1.4rem); box-shadow:0 30px 60px -38px rgba(38,36,41,.45); }
.rime__plate img{ width:100%; border-radius:2px; filter:sepia(.08) contrast(.98); }
.rime__plate figcaption{ font-size:.66rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-soft); padding-top:.95rem; text-align:center; }
.rime__body{ display:flex; flex-direction:column; align-items:flex-start; gap:1.1rem; }
.rime__body .prose{ margin-top:.2rem; }
.rime__quote{ border-left:2px solid var(--line); padding-left:1.4rem; margin-top:.5rem; }
.rime__quote p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.15rem,1.7vw,1.4rem); line-height:1.5; color:var(--ink); }
.rime__quote cite{ display:block; font-style:normal; font-size:.68rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-soft); margin-top:.9rem; }
@media (max-width:900px){
  .rime__grid{ grid-template-columns:1fr; }
  .rime__plate{ max-width:520px; margin-inline:auto; }
}

/* =================================================================
   REDUCED MOTION
   ================================================================= */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.2s !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .hero__title .line > span{ transform:none !important; }
  .marquee__track{ animation:none !important; transform:none !important; }
  .hero__video, .film__media video{ display:none; }
  .hero__media, .film__media{ background:url("../brand/poster.svg") center/cover no-repeat; }
  [data-parallax]{ transform:none !important; }
}
