/* ============================================================
   MÖRK — Concept demo for Talbawy Studios
   Art direction: "Vantablack Atelier" — severe runway minimalism.
   Near-black canvas, bone-white architectural type, one cold
   platinum accent. Huge condensed display, tight tracking.
   ============================================================ */

:root{
  --ink:        #060607;   /* vantablack canvas      */
  --ink-2:      #0c0d10;   /* raised surface         */
  --ink-3:      #15161b;   /* card / hairline base   */
  --bone:       #f4f1ea;   /* bone white             */
  --bone-dim:   #b4b1aa;   /* muted text             */
  --bone-faint: #8a8884;   /* faint captions (>=4.5:1 on ink) */
  --steel:      #b9c2cc;   /* cold metallic accent   */
  --steel-deep: #7d8893;   /* accent shade           */
  --line:       rgba(244,241,234,.12);
  --line-soft:  rgba(244,241,234,.07);

  --maxw: 1480px;
  --gut:  clamp(20px, 5vw, 64px);

  --ff-display: "Archivo", "Arial Narrow", sans-serif;
  --ff-body:    "Inter", system-ui, sans-serif;
  --ff-mono:    "Space Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.16,.84,.34,1);   /* ease-out, no bounce */
  --slow: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
html,body{ overflow-x:clip; }

body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--ff-body);
  font-size:16px;
  line-height:1.6;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }

::selection{ background:var(--steel); color:var(--ink); }

/* film-grain / vignette atmosphere ------------------------- */
body::after{
  content:"";
  position:fixed; inset:0;
  pointer-events:none; z-index:9000;
  background:
    radial-gradient(120% 100% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}

/* focus -------------------------------------------------- */
:focus-visible{
  outline:2px solid var(--steel);
  outline-offset:3px;
  border-radius:1px;
}

.skip{
  position:absolute; left:-999px; top:0; z-index:10000;
  background:var(--bone); color:var(--ink);
  padding:.7em 1.1em; font-family:var(--ff-mono); font-size:.7rem;
  letter-spacing:.12em; text-transform:uppercase;
}
.skip:focus{ left:12px; top:12px; }

/* ---------------------------------------------------------
   Layout primitives
   --------------------------------------------------------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.eyebrow{
  font-family:var(--ff-mono);
  font-size:.7rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--steel);
}
.eyebrow--dim{ color:var(--bone-faint); }

.display{
  font-family:var(--ff-display);
  font-weight:800;
  line-height:.92;
  letter-spacing:-.02em;
  text-transform:uppercase;
}

/* ---------------------------------------------------------
   Concept badge + skip + nav
   --------------------------------------------------------- */
.badge{
  position:fixed; right:14px; bottom:14px; z-index:8000;
  display:inline-flex; align-items:center; gap:.55em;
  padding:.5em .85em;
  background:rgba(8,8,10,.72);
  backdrop-filter:blur(10px);
  border:1px solid var(--line);
  border-radius:999px;
  font-family:var(--ff-mono);
  font-size:.62rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--bone-dim);
  transition:border-color .4s var(--ease), color .4s var(--ease);
}
.badge:hover{ color:var(--bone); border-color:var(--steel); }
.badge::before{
  content:""; width:7px; height:7px; border-radius:50%;
  background:var(--steel); box-shadow:0 0 10px var(--steel);
}

.nav{
  position:fixed; top:0; left:0; right:0; z-index:7000;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .5s var(--ease), border-color .5s var(--ease), padding .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(6,6,7,.78);
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
  padding-block:13px;
}
.brand{
  font-family:var(--ff-display);
  font-weight:800; font-size:1.45rem; letter-spacing:.16em;
  line-height:1; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.45em;
}
.brand .dot{ color:var(--steel); }
.nav-links{
  display:flex; gap:clamp(14px,2.4vw,38px); align-items:center;
  font-family:var(--ff-mono);
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone-dim);
}
.nav-links a{ position:relative; padding:.4em 0; transition:color .35s var(--ease); }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:.05em; height:1px; width:100%;
  background:var(--steel); transform:scaleX(0); transform-origin:left;
  transition:transform .45s var(--ease);
}
.nav-links a:hover,.nav-links a[aria-current="page"]{ color:var(--bone); }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ transform:scaleX(1); }
.nav-cart{
  display:inline-flex; align-items:center; gap:.5em;
  border:1px solid var(--line); padding:.55em .9em; border-radius:999px;
  color:var(--bone); transition:border-color .35s var(--ease), background .35s var(--ease);
}
.nav-cart:hover{ border-color:var(--steel); background:rgba(185,194,204,.08); }
.nav-cart .count{
  font-family:var(--ff-mono); font-size:.62rem;
  background:var(--steel); color:var(--ink);
  border-radius:999px; min-width:1.5em; text-align:center; padding:.05em .25em;
}

.nav-toggle{ display:none; }

@media (max-width:760px){
  .nav-links{
    position:fixed; inset:0; z-index:-1;
    flex-direction:column; justify-content:center; gap:34px;
    background:rgba(6,6,7,.97); backdrop-filter:blur(20px);
    font-size:1rem; letter-spacing:.2em;
    opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s;
  }
  body.menu-open .nav-links{ opacity:1; visibility:visible; z-index:6900; }
  .nav-toggle{
    display:inline-flex; flex-direction:column; gap:5px;
    width:34px; height:34px; align-items:center; justify-content:center; z-index:7100;
  }
  .nav-toggle span{ width:22px; height:1.5px; background:var(--bone); transition:transform .4s var(--ease), opacity .3s; }
  body.menu-open .nav-toggle span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
  body.menu-open .nav-toggle span:nth-child(2){ opacity:0; }
  body.menu-open .nav-toggle span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }
}

/* ---------------------------------------------------------
   Reveal system
   --------------------------------------------------------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }

/* line-mask reveal for big type */
.mask{ overflow:hidden; }
.mask > *{ display:block; transform:translateY(105%); transition:transform 1.1s var(--slow); }
.mask.in > *{ transform:none; }
.mask[data-delay="1"] > *{ transition-delay:.1s; }
.mask[data-delay="2"] > *{ transition-delay:.2s; }
.mask[data-delay="3"] > *{ transition-delay:.3s; }

/* ---------------------------------------------------------
   HERO (home)
   --------------------------------------------------------- */
.hero{
  position:relative;
  min-height:100svh;
  display:flex; align-items:flex-end;
  overflow:hidden;
  isolation:isolate;
}
#mork-canvas{
  position:absolute; inset:0; width:100%; height:100%;
  z-index:0; display:block;
}
.hero-fallback{
  position:absolute; inset:0; z-index:0;
  background:center/cover no-repeat;
  opacity:0; transition:opacity 1.2s var(--ease);
  filter:grayscale(.3) contrast(1.05);
}
.hero-fallback.show{ opacity:.7; }
.hero::before{ /* readability scrim */
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(6,6,7,.55) 0%, transparent 28%, transparent 55%, rgba(6,6,7,.92) 100%);
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:2; width:100%;
  padding-bottom:clamp(40px,7vh,90px); padding-top:140px;
}
.hero-kicker{
  display:flex; flex-wrap:wrap; gap:.6em 1.4em; align-items:center;
  margin-bottom:clamp(20px,4vh,40px);
}
.hero h1{
  font-family:var(--ff-display); font-weight:800;
  font-size:clamp(4.2rem, 20vw, 19rem);
  line-height:.82; letter-spacing:-.03em; text-transform:uppercase;
}
.hero h1 .sub{
  display:block;
  font-size:clamp(.95rem,2.4vw,1.5rem); letter-spacing:.42em;
  font-weight:600; line-height:1; margin-top:clamp(14px,2.5vh,26px);
  color:var(--bone-dim); padding-left:.2em;
}
.hero-meta{
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:18px;
  margin-top:clamp(24px,5vh,52px);
  border-top:1px solid var(--line); padding-top:20px;
  font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--bone-dim);
}
.hero-meta p{ max-width:34ch; line-height:1.7; }
.scroll-cue{
  position:absolute; left:var(--gut); bottom:clamp(40px,7vh,90px); z-index:2;
  writing-mode:vertical-rl; font-family:var(--ff-mono);
  font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--bone-faint);
  display:flex; align-items:center; gap:14px;
}
.scroll-cue::after{ content:""; width:1px; height:54px; background:linear-gradient(var(--steel),transparent); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{transform:scaleY(0);transform-origin:top} 45%{transform:scaleY(1);transform-origin:top} 55%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }
@media (max-width:760px){ .scroll-cue{ display:none; } }

.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  padding:1em 1.6em; border:1px solid var(--bone);
  color:var(--bone); border-radius:999px;
  transition:background .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease), transform .45s var(--ease);
}
.btn .arr{ transition:transform .45s var(--ease); }
.btn:hover{ background:var(--bone); color:var(--ink); }
.btn:hover .arr{ transform:translateX(5px); }
.btn--solid{ background:var(--bone); color:var(--ink); }
.btn--solid:hover{ background:var(--steel); border-color:var(--steel); }
.btn--steel{ border-color:var(--steel); color:var(--steel); }
.btn--steel:hover{ background:var(--steel); color:var(--ink); }

/* ---------------------------------------------------------
   Marquee
   --------------------------------------------------------- */
.marquee{
  border-block:1px solid var(--line); overflow:hidden; padding-block:20px;
  background:var(--ink-2);
}
.marquee-track{
  display:flex; gap:0; width:max-content;
  animation:marq 38s linear infinite;
  font-family:var(--ff-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(1.5rem,4vw,2.6rem); letter-spacing:.02em;
}
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ padding-inline:.5em; display:inline-flex; align-items:center; gap:.6em; color:var(--bone); }
.marquee-track span::after{ content:"✶"; color:var(--steel); font-size:.5em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------------------------------------------------------
   Section scaffolding
   --------------------------------------------------------- */
.section{ padding-block:clamp(70px,12vh,160px); position:relative; }
.section-head{
  display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end;
  gap:24px; margin-bottom:clamp(40px,7vh,80px);
}
.section-head h2{
  font-family:var(--ff-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(2.2rem,7vw,5.5rem); line-height:.9; letter-spacing:-.02em;
}
.section-head .idx{ font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.2em; color:var(--bone-faint); }
.lead{ font-size:clamp(1.05rem,1.6vw,1.35rem); color:var(--bone-dim); max-width:46ch; line-height:1.7; }

/* split feature ------------------------------------------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,72px); align-items:center; }
.split--rev{ grid-template-columns:.95fr 1.05fr; }
@media (max-width:860px){ .split,.split--rev{ grid-template-columns:1fr; } }
.split-media{ position:relative; overflow:hidden; aspect-ratio:4/5; background:var(--ink-3); }
.split-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--slow); filter:grayscale(.18) contrast(1.04); }
.split:hover .split-media img{ transform:scale(1.05); }
.split-media .tag{
  position:absolute; top:16px; left:16px;
  font-family:var(--ff-mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink); background:var(--steel); padding:.4em .7em;
}
.split-body h3{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(1.8rem,4vw,3.2rem); line-height:.95; letter-spacing:-.01em; margin-bottom:.4em; }
.split-body p{ color:var(--bone-dim); max-width:42ch; margin-bottom:1.6em; }
.spec-list{ list-style:none; display:grid; gap:0; margin-bottom:2em; border-top:1px solid var(--line); }
.spec-list li{ display:flex; justify-content:space-between; gap:16px; padding:.85em 0; border-bottom:1px solid var(--line); font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; }
.spec-list li span:first-child{ color:var(--bone-faint); }
.spec-list li span:last-child{ color:var(--bone); }

/* manifesto pull -------------------------------------------- */
.manifesto{ background:var(--ink-2); border-block:1px solid var(--line); }
.manifesto p{
  font-family:var(--ff-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(1.8rem,5.5vw,4.6rem); line-height:1.02; letter-spacing:-.02em; max-width:18ch;
}
.manifesto p em{ color:var(--steel); font-style:normal; }

/* ---------------------------------------------------------
   PRODUCT GRID (collection)
   --------------------------------------------------------- */
.toolbar{
  display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center;
  border-block:1px solid var(--line); padding-block:16px; margin-bottom:clamp(30px,5vh,56px);
  font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone-dim);
}
.filters{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  border:1px solid var(--line); padding:.55em 1em; border-radius:999px;
  color:var(--bone-dim); transition:all .35s var(--ease);
}
.chip[aria-pressed="true"]{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.chip:hover{ border-color:var(--steel); color:var(--bone); }

.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,30px); }
@media (max-width:960px){ .grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .grid{ grid-template-columns:1fr; } }

.card{ position:relative; display:block; }
.card-media{
  position:relative; aspect-ratio:3/4; overflow:hidden; background:var(--ink-3);
}
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--slow), opacity .6s var(--ease), filter 1.2s var(--ease); filter:grayscale(.22) contrast(1.05); }
.card-media .alt{ position:absolute; inset:0; opacity:0; }
.card:hover .card-media .primary{ opacity:0; transform:scale(1.04); }
.card:hover .card-media .alt{ opacity:1; transform:scale(1.04); }
.card:hover .card-media img{ filter:grayscale(0) contrast(1.06); }
.card-badge{
  position:absolute; top:12px; left:12px; z-index:2;
  font-family:var(--ff-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase;
  background:var(--ink); color:var(--bone); border:1px solid var(--line); padding:.35em .6em;
}
.card-badge.sold{ background:var(--steel); color:var(--ink); border-color:var(--steel); }
.card-quick{
  position:absolute; left:12px; right:12px; bottom:12px; z-index:2;
  display:flex; justify-content:center;
  transform:translateY(14px); opacity:0;
  transition:transform .5s var(--ease), opacity .5s var(--ease);
}
.card:hover .card-quick{ transform:none; opacity:1; }
.card-quick .btn{ width:100%; justify-content:center; background:rgba(6,6,7,.72); backdrop-filter:blur(8px); padding-block:.85em; }
.card-quick .btn:hover{ background:var(--bone); }
.card-info{ display:flex; justify-content:space-between; gap:14px; padding-top:14px; }
.card-info h3{ font-family:var(--ff-display); font-weight:700; text-transform:uppercase; font-size:1.05rem; letter-spacing:.01em; line-height:1.05; }
.card-info .meta{ font-family:var(--ff-mono); font-size:.66rem; letter-spacing:.08em; color:var(--bone-faint); margin-top:.3em; }
.card-info .price{ font-family:var(--ff-mono); font-size:.82rem; letter-spacing:.04em; color:var(--bone); white-space:nowrap; }
.card-info .price s{ color:var(--bone-faint); margin-right:.5em; }

/* ---------------------------------------------------------
   LOOKBOOK
   --------------------------------------------------------- */
.lb-hero{
  min-height:88svh; display:flex; align-items:center; position:relative; overflow:hidden;
  border-bottom:1px solid var(--line);
}
.lb-hero .lb-bg{ position:absolute; inset:-12% 0; z-index:0; background:center/cover no-repeat; filter:grayscale(.4) contrast(1.05) brightness(.65); will-change:transform; }
.lb-hero::after{ content:""; position:absolute; inset:0; background:radial-gradient(80% 80% at 30% 50%, transparent, rgba(6,6,7,.82)); z-index:1; }
.lb-hero .wrap{ position:relative; z-index:2; }
.lb-hero h1{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(3rem,15vw,13rem); line-height:.84; letter-spacing:-.03em; }
.lb-hero .credit{ margin-top:24px; font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--bone-dim); }

.spread{ display:grid; gap:clamp(20px,3vw,40px); align-items:center; }
.spread--2{ grid-template-columns:1fr 1fr; }
.spread--off{ grid-template-columns:1.3fr .7fr; }
.spread--off2{ grid-template-columns:.7fr 1.3fr; }
@media (max-width:780px){ .spread--2,.spread--off,.spread--off2{ grid-template-columns:1fr; } }
.plate{ position:relative; overflow:hidden; background:var(--ink-3); }
.plate img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.2) contrast(1.05); transition:transform 1.6s var(--slow); }
.plate--tall{ aspect-ratio:3/4; }
.plate--wide{ aspect-ratio:16/11; }
.plate--port{ aspect-ratio:4/5; }
.plate .num{ position:absolute; bottom:14px; left:14px; font-family:var(--ff-mono); font-size:.62rem; letter-spacing:.16em; color:var(--bone); background:rgba(6,6,7,.55); padding:.3em .55em; }
.parallax-img{ will-change:transform; }
.note{ max-width:40ch; }
.note .eyebrow{ margin-bottom:14px; display:block; }
.note h3{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(1.6rem,4vw,3rem); line-height:.95; letter-spacing:-.01em; margin-bottom:.5em; }
.note p{ color:var(--bone-dim); }

.lb-full{ position:relative; overflow:hidden; height:clamp(380px,80vh,820px); display:flex; align-items:flex-end; border-block:1px solid var(--line); }
.lb-full .lb-bg{ position:absolute; inset:-12% 0; z-index:0; background:center/cover no-repeat; filter:grayscale(.3) contrast(1.05) brightness(.8); will-change:transform; }
.lb-full::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(6,6,7,.85)); z-index:1; }
.lb-full .cap{ position:relative; z-index:2; padding:var(--gut); }
.lb-full .cap h3{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(2rem,8vw,6rem); line-height:.88; letter-spacing:-.02em; }

/* ---------------------------------------------------------
   PRODUCT DETAIL
   --------------------------------------------------------- */
.pdp{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(28px,4vw,64px); align-items:start; }
@media (max-width:920px){ .pdp{ grid-template-columns:1fr; } }
.gallery{ display:grid; gap:12px; position:sticky; top:88px; }
@media (max-width:920px){ .gallery{ position:static; } }
.gallery-main{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--ink-3); }
.gallery-main img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.12) contrast(1.05); transition:opacity .6s var(--ease), transform 1.4s var(--slow); }
.gallery-main:hover img{ transform:scale(1.04); }
.gallery-main .zoom-hint{ position:absolute; bottom:12px; right:12px; font-family:var(--ff-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone-dim); background:rgba(6,6,7,.6); padding:.35em .6em; }
.thumbs{ display:flex; gap:10px; }
.thumb{ flex:1; aspect-ratio:1; overflow:hidden; background:var(--ink-3); border:1px solid transparent; transition:border-color .35s var(--ease); }
.thumb img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.3); transition:filter .4s var(--ease); }
.thumb[aria-current="true"]{ border-color:var(--steel); }
.thumb:hover img,.thumb[aria-current="true"] img{ filter:grayscale(0); }

.pdp-info .crumbs{ font-family:var(--ff-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone-faint); margin-bottom:22px; }
.pdp-info .crumbs a:hover{ color:var(--bone); }
.pdp-info h1{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(2.4rem,6vw,4.4rem); line-height:.9; letter-spacing:-.02em; }
.pdp-info .sub{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--steel); margin-top:14px; }
.pdp-price{ display:flex; align-items:baseline; gap:14px; margin-block:24px 8px; font-family:var(--ff-mono); }
.pdp-price .now{ font-size:1.5rem; color:var(--bone); }
.pdp-price s{ color:var(--bone-faint); font-size:1rem; }
.pdp-price .off{ font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); background:var(--steel); padding:.3em .55em; }
.pdp-desc{ color:var(--bone-dim); max-width:46ch; margin-block:18px 30px; line-height:1.75; }

.opt-block{ margin-bottom:26px; }
.opt-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:12px; font-family:var(--ff-mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone-dim); }
.opt-head .guide{ color:var(--steel); }
.opt-head .guide:hover{ text-decoration:underline; }
.swatches,.sizes{ display:flex; flex-wrap:wrap; gap:10px; }
.swatch{ width:34px; height:34px; border-radius:50%; border:1px solid var(--line); position:relative; transition:transform .3s var(--ease); }
.swatch[aria-pressed="true"]{ box-shadow:0 0 0 2px var(--ink),0 0 0 3px var(--steel); }
.swatch:hover{ transform:scale(1.08); }
.size{ min-width:46px; padding:.7em .4em; text-align:center; border:1px solid var(--line); font-family:var(--ff-mono); font-size:.74rem; letter-spacing:.05em; color:var(--bone-dim); transition:all .3s var(--ease); }
.size[aria-pressed="true"]{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.size:hover:not([disabled]){ border-color:var(--steel); color:var(--bone); }
.size[disabled]{ opacity:.32; cursor:not-allowed; text-decoration:line-through; }

.qty-row{ display:flex; gap:12px; align-items:stretch; margin-bottom:14px; }
.qty{ display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:999px; }
.qty button{ width:44px; height:100%; font-size:1.1rem; color:var(--bone); transition:color .3s var(--ease); }
.qty button:hover{ color:var(--steel); }
.qty output{ min-width:34px; text-align:center; font-family:var(--ff-mono); font-size:.9rem; }
.add-cart{ flex:1; justify-content:center; }
.add-cart[disabled]{ opacity:.4; cursor:not-allowed; }

.assure{ list-style:none; display:grid; gap:0; margin-top:8px; border-top:1px solid var(--line); }
.assure li{ display:flex; gap:12px; align-items:center; padding:.9em 0; border-bottom:1px solid var(--line); font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--bone-dim); }
.assure li::before{ content:"—"; color:var(--steel); }

.accordion details{ border-bottom:1px solid var(--line); }
.accordion summary{ list-style:none; cursor:pointer; padding:1.1em 0; display:flex; justify-content:space-between; align-items:center; font-family:var(--ff-mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; }
.accordion summary::-webkit-details-marker{ display:none; }
.accordion summary::after{ content:"+"; color:var(--steel); font-size:1.1rem; transition:transform .4s var(--ease); }
.accordion details[open] summary::after{ transform:rotate(45deg); }
.accordion .panel{ padding-bottom:1.4em; color:var(--bone-dim); max-width:50ch; line-height:1.7; }

/* toast (add to cart) */
.toast{
  position:fixed; left:50%; bottom:26px; transform:translate(-50%,140%);
  z-index:9500; background:var(--bone); color:var(--ink);
  padding:.9em 1.3em; display:flex; gap:12px; align-items:center;
  font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
  transition:transform .6s var(--ease); max-width:calc(100vw - 32px);
}
.toast.show{ transform:translate(-50%,0); }
.toast a{ color:var(--steel-deep); text-decoration:underline; }

/* related */
.related .grid{ grid-template-columns:repeat(4,1fr); }
@media (max-width:960px){ .related .grid{ grid-template-columns:repeat(2,1fr); } }

/* ---------------------------------------------------------
   Newsletter + footer
   --------------------------------------------------------- */
.signup{ border-block:1px solid var(--line); background:var(--ink-2); }
.signup .inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,64px); align-items:center; }
@media (max-width:780px){ .signup .inner{ grid-template-columns:1fr; } }
.signup h2{ font-family:var(--ff-display); font-weight:800; text-transform:uppercase; font-size:clamp(1.8rem,5vw,3.6rem); line-height:.92; letter-spacing:-.02em; }
.signup form{ display:flex; gap:0; border-bottom:1px solid var(--bone); }
.signup input{ flex:1; background:none; border:none; color:var(--bone); padding:.9em 0; font-family:var(--ff-mono); font-size:.82rem; letter-spacing:.06em; }
.signup input::placeholder{ color:var(--bone-faint); text-transform:uppercase; letter-spacing:.12em; font-size:.72rem; }
.signup input:focus{ outline:none; }
.signup button{ font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--steel); padding-left:1em; transition:color .3s var(--ease); }
.signup button:hover{ color:var(--bone); }
.signup .ok{ font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--steel); margin-top:14px; min-height:1.2em; }

.site-footer{ padding-block:clamp(50px,8vh,90px) 30px; }
.footer-top{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; padding-bottom:clamp(40px,7vh,72px); border-bottom:1px solid var(--line); }
@media (max-width:780px){ .footer-top{ grid-template-columns:1fr 1fr; gap:36px 20px; } }
@media (max-width:420px){ .footer-top{ grid-template-columns:1fr; } }
.footer-brand .brand{ font-size:2.4rem; margin-bottom:18px; }
.footer-brand p{ color:var(--bone-dim); max-width:34ch; font-size:.92rem; }
.footer-col h4{ font-family:var(--ff-mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone-faint); margin-bottom:16px; }
.footer-col a{ display:block; color:var(--bone-dim); font-size:.9rem; padding:.3em 0; transition:color .3s var(--ease); }
.footer-col a:hover{ color:var(--bone); }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:16px; padding-top:28px; font-family:var(--ff-mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--bone-faint); }
.footer-bottom .disclaimer{ max-width:62ch; line-height:1.7; }
.footer-bottom a{ color:var(--steel); }
.footer-bottom a:hover{ color:var(--bone); text-decoration:underline; }

/* ---------------------------------------------------------
   Reduced motion
   --------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .mask > *{ transform:none; }
  .marquee-track{ animation:none; }
  .scroll-cue::after{ animation:none; }
}
