/* ============================================================
   StitchTantra — Redesign Concept
   Design system: high-energy youthful streetwear, brand palette
   ============================================================ */

:root{
  /* Brand palette (kept from brand "design code") */
  --paper:    #F1ECE1;   /* warm off-white */
  --paper-2:  #E7DFD0;   /* deeper paper */
  --paper-3:  #DACFBA;   /* card ground */
  --ink:      #14120D;   /* deep warm black */
  --ink-2:    #211E17;
  --soil:     #6E4226;   /* warm soil brown */
  --soil-2:   #9A6438;
  --red:      #C23B2B;   /* muted brick red — the energy accent */
  --red-2:    #A82E20;
  --sage:     #98A088;   /* sage grey */
  --sage-2:   #C3C8B6;

  --maxw: 1320px;
  --gut: clamp(18px, 4vw, 64px);

  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-body: "Hanken Grotesk", system-ui, sans-serif;
  --font-mono: "Space Mono", ui-monospace, monospace;
  --font-deva: "Mukta", "Noto Sans Devanagari", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }

/* ---- type helpers ---- */
.mono{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.16em; font-size:.72rem; }
.eyebrow{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.22em;
  font-size:.7rem; font-weight:700; color:var(--soil);
  display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--red); display:inline-block; }
.display{ font-family:var(--font-display); font-weight:800; line-height:.92; letter-spacing:-.02em; }

/* ============================================================
   Ticker
   ============================================================ */
.ticker{
  background:var(--ink); color:var(--paper);
  overflow:hidden; white-space:nowrap; border-bottom:2px solid var(--ink);
}
.ticker__track{
  display:inline-flex; align-items:center; gap:0;
  animation:scroll-x 28s linear infinite;
  will-change:transform;
}
.ticker:hover .ticker__track{ animation-play-state:paused; }
.ticker__track span{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.2em;
  font-size:.74rem; font-weight:700; padding:11px 0; display:inline-flex; align-items:center;
}
.ticker__track span::after{ content:"✦"; color:var(--red); margin:0 1.4em; font-size:.8em; }
@keyframes scroll-x{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

.ticker--red{ background:var(--red); color:var(--paper); border-color:var(--red-2); }
.ticker--red .ticker__track span::after{ color:var(--ink); }

/* ============================================================
   Header / nav
   ============================================================ */
.head{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:blur(12px);
  border-bottom:1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}
.head__row{
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  height:80px;
}
.nav{ display:flex; gap:26px; align-items:center; }
.nav a{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.12em;
  font-size:.72rem; font-weight:700; position:relative; padding:4px 0;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--red);
  transition:width .25s ease;
}
.nav a:hover::after{ width:100%; }
.brandmark{
  justify-self:center; font-family:var(--font-display); font-weight:800;
  letter-spacing:-.03em; line-height:1;
  display:inline-flex; flex-direction:column; align-items:center; gap:5px;
}
.brandmark__emblem{ height:34px; width:auto; flex:none; }
.brandmark__txt{ display:inline-flex; align-items:baseline; font-size:1.16rem; }
.brandmark .deva{ font-family:var(--font-deva); font-weight:700; color:var(--red); margin-left:.04em; }
/* footer / dark contexts */
.brandmark--light{ color:var(--paper); align-items:flex-start; }
.brandmark--light .brandmark__emblem{ height:42px; }
.brandmark--light .brandmark__txt{ font-size:1.5rem; }
/* inline brand name treatment for body copy */
.brandword{ font-family:var(--font-display); font-weight:700; letter-spacing:-.01em; white-space:nowrap; }
.brandword .deva{ font-family:var(--font-deva); font-weight:700; color:var(--red); margin-left:.02em; }
.tools{ justify-self:end; display:flex; align-items:center; gap:16px; }
.tools button{ display:grid; place-items:center; color:var(--ink); transition:transform .15s ease; }
.tools button:hover{ transform:translateY(-2px); color:var(--red); }
.icn{ width:21px; height:21px; stroke:currentColor; stroke-width:1.7; fill:none; }
.cart-pill{
  display:inline-flex; align-items:center; gap:8px; background:var(--ink); color:var(--paper);
  padding:8px 14px; border-radius:999px; font-family:var(--font-mono); font-size:.7rem;
  font-weight:700; letter-spacing:.08em; transition:background .2s ease;
}
.cart-pill:hover{ background:var(--red); }

/* hamburger (mobile) */
.nav-toggle{ display:none; width:42px; height:42px; align-items:center; justify-content:center; color:var(--ink); }
.nav-toggle svg{ width:24px; height:24px; stroke:currentColor; stroke-width:2; fill:none; }
.head__left{ display:flex; align-items:center; gap:6px; justify-self:start; }

/* mobile nav drawer */
.mnav-scrim{ position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:90; opacity:0; pointer-events:none; transition:opacity .3s ease; }
.mnav-scrim.show{ opacity:1; pointer-events:auto; }
.mnav{
  position:fixed; top:0; left:0; bottom:0; width:min(82vw,360px); z-index:100;
  background:var(--ink); color:var(--paper); transform:translateX(-100%);
  transition:transform .32s cubic-bezier(.2,.7,.2,1); display:flex; flex-direction:column;
  padding:22px 26px calc(env(safe-area-inset-bottom) + 28px); overflow-y:auto;
}
.mnav.open{ transform:translateX(0); }
.mnav__top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:30px; }
.mnav__top .brandmark{ align-items:flex-start; }
.mnav__top .brandmark__emblem{ height:30px; }
.mnav__top .brandmark__txt{ font-size:1.05rem; color:var(--paper); }
.mnav__close{ width:42px; height:42px; display:grid; place-items:center; color:var(--paper); }
.mnav__close svg{ width:24px; height:24px; stroke:currentColor; stroke-width:2; fill:none; }
.mnav__links{ display:flex; flex-direction:column; }
.mnav__links a{
  font-family:var(--font-display); font-weight:800; font-size:1.7rem; letter-spacing:-.02em;
  padding:15px 0; border-bottom:1px solid color-mix(in srgb,var(--paper) 14%,transparent);
  display:flex; align-items:center; justify-content:space-between;
}
.mnav__links a span{ font-family:var(--font-mono); font-size:.8rem; color:var(--red); }
.mnav__sub{ margin-top:26px; display:flex; flex-direction:column; gap:13px; }
.mnav__sub a{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.1em; font-size:.72rem; font-weight:700; color:color-mix(in srgb,var(--paper) 72%,transparent); }
.mnav__sub a:hover{ color:var(--red); }
.mnav__cta{ margin-top:auto; padding-top:26px; }
.mnav__cta a{ display:flex; align-items:center; justify-content:center; gap:10px; background:var(--red); color:var(--paper); border-radius:999px; padding:16px; font-family:var(--font-mono); font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.78rem; }

/* ============================================================
   Hero
   ============================================================ */
.hero{ position:relative; padding-top:clamp(24px,5vw,56px); padding-bottom:0; overflow:hidden; }
.hero__grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(20px,4vw,56px);
  align-items:end;
}
.hero__copy{ padding-bottom:clamp(28px,4vw,64px); }
.hero h1{
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(3.2rem, 9vw, 8.2rem); line-height:.86; letter-spacing:-.035em;
  margin:.28em 0 .42em;
}
.hero h1 .out{
  -webkit-text-stroke:2px var(--ink); color:transparent;
}
.hero h1 .red{ color:var(--red); }
.hero p.lede{
  font-size:clamp(1rem,1.3vw,1.18rem); max-width:46ch; color:var(--ink-2);
  text-wrap:pretty;
}
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.btn{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.1em;
  font-size:.78rem; font-weight:700; padding:16px 26px; border-radius:999px;
  display:inline-flex; align-items:center; gap:10px; transition:transform .18s ease, background .2s ease, color .2s ease;
}
.btn--solid{ background:var(--ink); color:var(--paper); }
.btn--solid:hover{ background:var(--red); transform:translateY(-3px); }
.btn--ghost{ border:2px solid var(--ink); color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-3px); }
.btn .arr{ transition:transform .18s ease; }
.btn:hover .arr{ transform:translate(3px,-3px); }

.hero__meta{ display:flex; gap:26px; margin-top:34px; flex-wrap:wrap; }
.hero__meta .m{ }
.hero__meta .m b{ font-family:var(--font-display); font-size:1.5rem; display:block; line-height:1; }
.hero__meta .m span{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--soil); }

.hero__art{ position:relative; align-self:stretch; }
.hero__imgwrap{
  position:relative; aspect-ratio:4/5; border-radius:18px 18px 0 0; overflow:hidden;
  background:linear-gradient(150deg, var(--paper-3), var(--paper-2));
}
.hero__imgwrap img{ width:100%; height:100%; object-fit:cover; object-position:top center; }
/* spinning seal */
.seal{
  position:absolute; top:-26px; left:-26px; width:128px; height:128px; z-index:3;
  animation:spin 18s linear infinite;
}
.seal text{ font-family:var(--font-mono); font-size:8.6px; letter-spacing:.32em; fill:var(--ink); font-weight:700; }
.seal__core{
  position:absolute; inset:0; display:grid; place-items:center; pointer-events:none;
}
.seal-badge{ position:absolute; top:6px; left:6px; width:128px; height:128px; z-index:4; display:grid; place-items:center; }
.seal-badge svg{ position:absolute; inset:0; }
.seal-badge .star{ width:34px; height:34px; fill:var(--red); }
@keyframes spin{ to{ transform:rotate(360deg); } }
.pricetag{
  position:absolute; right:-14px; bottom:34px; z-index:3; background:var(--red); color:var(--paper);
  font-family:var(--font-display); font-weight:800; padding:14px 20px; border-radius:14px;
  transform:rotate(-7deg); box-shadow:0 14px 30px rgba(0,0,0,.18); line-height:1;
}
.pricetag small{ display:block; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.18em; font-weight:700; opacity:.85; margin-bottom:3px; }
.pricetag b{ font-size:1.7rem; }

/* big ghost word behind */
.hero__ghost{
  position:absolute; right:calc(var(--gut) * -0.2); top:8%; z-index:-1;
  font-family:var(--font-display); font-weight:800; font-size:22vw; color:var(--paper-2);
  letter-spacing:-.04em; pointer-events:none; user-select:none; line-height:1;
}

/* ============================================================
   Section scaffolding
   ============================================================ */
section{ position:relative; }
.sec{ padding-block:clamp(56px,8vw,118px); }
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:42px; flex-wrap:wrap; }
.sec-head h2{
  font-family:var(--font-display); font-weight:800; line-height:.94;
  font-size:clamp(2rem,4.6vw,3.6rem); letter-spacing:-.025em; max-width:18ch; text-wrap:balance;
}
.sec-head p{ max-width:42ch; color:var(--ink-2); }

/* ============================================================
   Marquee band
   ============================================================ */
.band{ background:var(--red); color:var(--paper); padding:18px 0; overflow:hidden; white-space:nowrap; border-block:3px solid var(--ink); }
.band--ink{ background:var(--ink); color:var(--paper); }
.band__track{ display:inline-flex; animation:scroll-x 24s linear infinite; }
.band__track span{
  font-family:var(--font-display); font-weight:800; font-size:clamp(1.6rem,3.4vw,2.8rem);
  letter-spacing:-.01em; padding:0 .5em; display:inline-flex; align-items:center;
}
.band__track span.o{ -webkit-text-stroke:1.6px var(--paper); color:transparent; }
.band__track span::after{ content:"●"; font-size:.5em; margin:0 .7em; opacity:.7; }

/* ============================================================
   Product grid + cards
   ============================================================ */
.chips{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; font-weight:700;
  padding:10px 18px; border-radius:999px; border:1.5px solid color-mix(in srgb, var(--ink) 22%, transparent);
  background:transparent; color:var(--ink); transition:all .18s ease;
}
.chip:hover{ border-color:var(--ink); }
.chip.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,1.6vw,24px); }
.card{ position:relative; }
.card__media{
  display:block;
  position:relative; aspect-ratio:3/4; border-radius:14px; overflow:hidden;
  background:linear-gradient(160deg,var(--paper-3),var(--paper-2));
  isolation:isolate;
}
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.2,.7,.2,1); }
.card:hover .card__media img{ transform:scale(1.05); }
.card__badge{
  position:absolute; top:12px; left:12px; z-index:2; background:var(--ink); color:var(--paper);
  font-family:var(--font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  padding:6px 10px; border-radius:7px;
}
.card__badge.is-new{ background:var(--red); }
.card__fav{
  position:absolute; top:10px; right:10px; z-index:2; width:36px; height:36px; border-radius:50%;
  background:color-mix(in srgb,var(--paper) 80%,transparent); display:grid; place-items:center;
  backdrop-filter:blur(4px); transition:transform .15s ease, background .2s ease;
}
.card__fav:hover{ transform:scale(1.12); background:var(--paper); }
.card__fav svg{ width:18px; height:18px; stroke:var(--ink); stroke-width:1.7; fill:none; }
.card__add{
  position:absolute; left:12px; right:12px; bottom:12px; z-index:2;
  background:var(--ink); color:var(--paper); font-family:var(--font-mono); text-transform:uppercase;
  letter-spacing:.12em; font-size:.7rem; font-weight:700; padding:13px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transform:translateY(calc(100% + 14px)); opacity:0; transition:transform .3s cubic-bezier(.2,.7,.2,1), opacity .2s ease, background .2s ease;
}
.card:hover .card__add{ transform:translateY(0); opacity:1; }
.card__add:hover{ background:var(--red); }
.card__sizes{
  position:absolute; left:12px; bottom:12px; z-index:2; display:flex; gap:6px;
  opacity:0; transition:opacity .25s ease;
}
.card:hover .card__sizes{ opacity:0; } /* sizes hidden in favour of add btn; kept for variant */
.card__info{ padding:14px 2px 0; display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.card__info h3{ font-family:var(--font-body); font-weight:700; font-size:.98rem; line-height:1.2; }
.card__info .price{ font-family:var(--font-display); font-weight:800; font-size:1.05rem; white-space:nowrap; }
.card__info .price s{ color:var(--sage); font-weight:600; font-size:.8em; margin-right:6px; }
.card__sub{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--soil); margin-top:4px; }
.card__swatches{ display:flex; gap:5px; margin-top:9px; }
.card__swatches i{ width:13px; height:13px; border-radius:50%; border:1px solid rgba(0,0,0,.15); display:inline-block; }

/* ============================================================
   Editorial collage
   ============================================================ */
.edit{ display:grid; grid-template-columns:1.3fr 1fr; grid-template-rows:auto auto; gap:clamp(14px,1.6vw,22px); }
.edit__cell{ position:relative; border-radius:16px; overflow:hidden; background:var(--paper-3); }
.edit__cell img{ width:100%; height:100%; object-fit:cover; }
.edit__cell.tall{ grid-row:span 2; aspect-ratio:auto; }
.edit__cell.wide{ aspect-ratio:16/10; }
.edit__cap{
  position:absolute; left:20px; bottom:20px; right:20px; z-index:2; color:var(--paper);
}
.edit__cap .k{ font-family:var(--font-mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; opacity:.9; }
.edit__cap h3{ font-family:var(--font-display); font-weight:800; font-size:clamp(1.3rem,2.2vw,2rem); line-height:1; margin-top:8px; text-wrap:balance; }
.edit__cell::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,0) 55%); z-index:1; }

/* ============================================================
   Brand code (numbered, on ink)
   ============================================================ */
.code-sec{ background:var(--ink); color:var(--paper); }
.code-sec .eyebrow{ color:var(--sage-2); }
.code-sec .eyebrow::before{ background:var(--red); }
.code-sec h2{ color:var(--paper); }
.code-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,44px); margin-top:48px; }
.code-card{ border-top:2px solid color-mix(in srgb,var(--paper) 26%,transparent); padding-top:22px; }
.code-card .num{ font-family:var(--font-display); font-weight:800; font-size:3.4rem; line-height:.9; color:var(--red); }
.code-card h3{ font-family:var(--font-display); font-weight:700; font-size:1.4rem; margin:16px 0 10px; }
.code-card p{ color:color-mix(in srgb,var(--paper) 76%,transparent); max-width:34ch; }

/* ============================================================
   Moods
   ============================================================ */
.moods{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.4vw,18px); }
.mood{
  position:relative; aspect-ratio:3/4.2; border-radius:16px; overflow:hidden; display:flex;
  align-items:flex-end; padding:20px; color:var(--paper); isolation:isolate;
}
.mood img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition:transform .5s ease; }
.mood::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(to top, rgba(0,0,0,.7), rgba(0,0,0,.05) 60%); }
.mood:hover img{ transform:scale(1.06); }
.mood .num{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.18em; opacity:.85; }
.mood h3{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; line-height:1; margin-top:6px; }
.mood p{ font-size:.82rem; opacity:.9; margin-top:8px; max-width:24ch; }

/* ============================================================
   Promise strip
   ============================================================ */
.promise{ background:var(--paper-2); border-block:1px solid color-mix(in srgb,var(--ink) 12%,transparent); }
.promise__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.promise__cell{ padding:30px 22px; display:flex; gap:14px; align-items:flex-start; border-left:1px solid color-mix(in srgb,var(--ink) 12%,transparent); }
.promise__cell:first-child{ border-left:none; }
.promise__cell svg{ width:26px; height:26px; stroke:var(--soil); stroke-width:1.6; fill:none; flex:none; margin-top:2px; }
.promise__cell b{ font-family:var(--font-display); font-weight:700; font-size:1.05rem; display:block; }
.promise__cell span{ font-size:.82rem; color:var(--ink-2); }

/* ============================================================
   Footer
   ============================================================ */
.foot{ background:var(--ink); color:var(--paper); padding-top:clamp(56px,7vw,96px); }
.foot__word{ font-family:var(--font-display); font-weight:800; font-size:clamp(3rem,15vw,13rem); line-height:.8; letter-spacing:-.04em; color:transparent; -webkit-text-stroke:1.4px color-mix(in srgb,var(--paper) 40%,transparent); padding-bottom:.1em; }
.foot__word .deva{ font-family:var(--font-deva); -webkit-text-stroke:1.4px var(--red); color:transparent; }
.foot__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; padding-block:54px; border-bottom:1px solid color-mix(in srgb,var(--paper) 16%,transparent); }
.foot p.lede{ color:color-mix(in srgb,var(--paper) 76%,transparent); max-width:34ch; margin-top:18px; }
.foot h4{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.14em; font-size:.68rem; color:var(--sage-2); margin-bottom:16px; }
.foot ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot ul a{ font-size:.92rem; color:color-mix(in srgb,var(--paper) 82%,transparent); transition:color .2s ease; }
.foot ul a:hover{ color:var(--red); }
.news{ display:flex; border:1.5px solid color-mix(in srgb,var(--paper) 30%,transparent); border-radius:999px; overflow:hidden; margin-top:14px; }
.news input{ flex:1; background:transparent; border:none; padding:13px 18px; color:var(--paper); font-family:var(--font-body); font-size:.9rem; }
.news input::placeholder{ color:color-mix(in srgb,var(--paper) 50%,transparent); }
.news input:focus{ outline:none; }
.news button{ background:var(--red); color:var(--paper); font-family:var(--font-mono); font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; padding:0 22px; }
.foot__bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-block:26px; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:color-mix(in srgb,var(--paper) 60%,transparent); }
.foot__bottom a{ color:inherit; }

/* ============================================================
   Concept toggle (links between redesign + audit)
   ============================================================ */
.concept-link{
  position:fixed; right:18px; bottom:18px; z-index:200;
  background:var(--red); color:var(--paper); font-family:var(--font-mono); font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; font-size:.68rem; padding:13px 18px; border-radius:999px;
  display:inline-flex; align-items:center; gap:9px; box-shadow:0 10px 28px rgba(0,0,0,.25);
  transition:transform .18s ease, background .2s ease;
}
.concept-link:hover{ transform:translateY(-3px); background:var(--ink); }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1040px){
  .grid{ grid-template-columns:repeat(3,1fr); }
  .moods{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .head__row{ grid-template-columns:auto 1fr auto; height:72px; }
  .nav{ display:none; }
  .nav-toggle{ display:flex; }
  .brandmark__emblem{ height:30px; }
  .brandmark__txt{ font-size:1.02rem; }
  .hero__grid{ grid-template-columns:1fr; }
  .hero__art{ order:-1; }
  .hero__imgwrap{ aspect-ratio:1/1; border-radius:16px; }
  .hero__ghost{ display:none; }
  .code-grid{ grid-template-columns:1fr; gap:30px; }
  .edit{ grid-template-columns:1fr; }
  .edit__cell.tall{ grid-row:auto; aspect-ratio:3/4; }
  .promise__grid{ grid-template-columns:1fr 1fr; }
  .promise__cell:nth-child(3){ border-left:none; }
  .foot__top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .tools button[aria-label="Search"],.tools button[aria-label="Wishlist"]{ display:none; }
  .moods{ grid-template-columns:1fr; }
  .promise__grid{ grid-template-columns:1fr; }
  .promise__cell{ border-left:none; border-top:1px solid color-mix(in srgb,var(--ink) 12%,transparent); }
  .promise__cell:first-child{ border-top:none; }
  .foot__top{ grid-template-columns:1fr; }
  .card__add{ transform:translateY(0); opacity:1; } /* always visible on touch */
}

/* ============================================================
   Breadcrumb (shop + product)
   ============================================================ */
.crumb{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--soil); display:flex; gap:9px; align-items:center; }
.crumb a{ color:var(--soil); transition:color .2s ease; }
.crumb a:hover{ color:var(--red); }
.crumb span{ opacity:.5; }

/* ============================================================
   Collection hero banner (shop)
   ============================================================ */
.collhero{ background:var(--ink); color:var(--paper); padding-block:clamp(34px,5vw,66px); position:relative; overflow:hidden; }
.collhero .eyebrow{ color:var(--sage-2); }
.collhero h1{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.6rem,7vw,5.4rem); line-height:.88; letter-spacing:-.03em; margin:.18em 0 .3em; }
.collhero h1 .red{ color:var(--red); }
.collhero p{ max-width:52ch; color:color-mix(in srgb,var(--paper) 80%,transparent); }
.collhero__ghost{ position:absolute; right:-2%; top:-10%; font-family:var(--font-display); font-weight:800; font-size:20vw; color:transparent; -webkit-text-stroke:1.4px color-mix(in srgb,var(--paper) 12%,transparent); pointer-events:none; user-select:none; line-height:1; }

/* ============================================================
   Shop layout: sidebar + grid
   ============================================================ */
.shop{ display:grid; grid-template-columns:248px 1fr; gap:clamp(24px,3vw,52px); align-items:start; }
.toolbar{ display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:26px; flex-wrap:wrap; }
.toolbar .count{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--soil); }
.sortwrap{ display:flex; align-items:center; gap:10px; }
.sortwrap label{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--soil); }
.sortwrap select{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; font-weight:700; border:1.5px solid color-mix(in srgb,var(--ink) 22%,transparent); background:transparent; padding:10px 14px; border-radius:999px; color:var(--ink); cursor:pointer; }
.sortwrap select:focus{ outline:none; border-color:var(--ink); }

.filters-side{ position:sticky; top:84px; }
.fgroup{ border-top:2px solid var(--ink); padding:20px 0; }
.fgroup:first-child{ border-top:none; padding-top:0; }
.fgroup h4{ font-family:var(--font-display); font-weight:800; font-size:1.05rem; margin-bottom:14px; display:flex; justify-content:space-between; align-items:center; }
.fopt{ display:flex; align-items:center; gap:11px; padding:7px 0; cursor:pointer; font-size:.95rem; color:var(--ink-2); transition:color .15s ease; }
.fopt:hover{ color:var(--ink); }
.fopt input{ appearance:none; width:18px; height:18px; border:1.6px solid color-mix(in srgb,var(--ink) 35%,transparent); border-radius:5px; display:grid; place-items:center; cursor:pointer; transition:all .15s ease; flex:none; }
.fopt input:checked{ background:var(--red); border-color:var(--red); }
.fopt input:checked::after{ content:"✓"; color:var(--paper); font-size:.7rem; font-weight:800; }
.fopt .n{ margin-left:auto; font-family:var(--font-mono); font-size:.66rem; color:var(--sage); }
.fswatch{ display:flex; flex-wrap:wrap; gap:10px; }
.fswatch button{ width:30px; height:30px; border-radius:50%; border:2px solid transparent; box-shadow:0 0 0 1.5px color-mix(in srgb,var(--ink) 22%,transparent); transition:transform .15s ease; }
.fswatch button:hover{ transform:scale(1.12); }
.fswatch button.is-active{ box-shadow:0 0 0 2px var(--red); }
.fsize{ display:flex; flex-wrap:wrap; gap:8px; }
.fsize button{ min-width:42px; padding:9px 0; border:1.5px solid color-mix(in srgb,var(--ink) 22%,transparent); border-radius:8px; font-family:var(--font-mono); font-size:.72rem; font-weight:700; color:var(--ink); transition:all .15s ease; }
.fsize button:hover{ border-color:var(--ink); }
.fsize button.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.shop .grid{ grid-template-columns:repeat(3,1fr); }

.filters-toggle{ display:none; }

/* load more */
.loadmore{ display:flex; justify-content:center; margin-top:48px; }

/* ============================================================
   Product detail page
   ============================================================ */
.pdp{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,64px); align-items:start; padding-top:clamp(20px,3vw,36px); }
.gallery{ display:grid; grid-template-columns:84px 1fr; gap:16px; align-items:start; }
.gallery__thumbs{ display:flex; flex-direction:column; gap:12px; }
.gallery__thumbs button{ aspect-ratio:3/4; border-radius:10px; overflow:hidden; background:var(--paper-3); border:2px solid transparent; transition:border-color .15s ease; }
.gallery__thumbs button.is-active{ border-color:var(--ink); }
.gallery__thumbs img{ width:100%; height:100%; object-fit:cover; }
.gallery__main{ position:relative; aspect-ratio:3/4; border-radius:16px; overflow:hidden; background:linear-gradient(160deg,var(--paper-3),var(--paper-2)); }
.gallery__main img{ width:100%; height:100%; object-fit:cover; }
.gallery__main .card__badge{ font-size:.62rem; }

.pinfo{ position:sticky; top:84px; }
.pinfo .eyebrow{ margin-bottom:14px; }
.pinfo h1{ font-family:var(--font-display); font-weight:800; font-size:clamp(2rem,4vw,3rem); line-height:.95; letter-spacing:-.025em; }
.pinfo .price-row{ display:flex; align-items:center; gap:14px; margin:16px 0 8px; }
.pinfo .price-row .now{ font-family:var(--font-display); font-weight:800; font-size:1.8rem; }
.pinfo .price-row s{ color:var(--sage); font-size:1.1rem; }
.pinfo .price-row .save{ background:var(--red); color:var(--paper); font-family:var(--font-mono); font-size:.6rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:5px 9px; border-radius:6px; }
.pinfo .tax{ font-size:.82rem; color:var(--soil); }
.pinfo .rating{ display:flex; align-items:center; gap:8px; margin-top:12px; font-size:.88rem; color:var(--ink-2); }
.pinfo .rating .stars{ color:var(--red); letter-spacing:2px; }

.opt{ margin-top:26px; }
.opt__label{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--soil); display:flex; justify-content:space-between; margin-bottom:12px; }
.opt__label a{ color:var(--red); }
.swatch-row{ display:flex; gap:12px; }
.swatch-row button{ width:38px; height:38px; border-radius:50%; border:2px solid transparent; box-shadow:0 0 0 1.5px color-mix(in srgb,var(--ink) 22%,transparent); transition:transform .15s ease; }
.swatch-row button:hover{ transform:scale(1.1); }
.swatch-row button.is-active{ box-shadow:0 0 0 2px var(--ink); }
.size-row{ display:flex; gap:10px; flex-wrap:wrap; }
.size-row button{ min-width:52px; padding:13px 0; border:1.5px solid color-mix(in srgb,var(--ink) 24%,transparent); border-radius:10px; font-family:var(--font-mono); font-weight:700; font-size:.8rem; color:var(--ink); transition:all .15s ease; }
.size-row button:hover{ border-color:var(--ink); }
.size-row button.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.size-row button.is-out{ opacity:.35; text-decoration:line-through; cursor:not-allowed; }

.buy-row{ display:grid; grid-template-columns:auto 1fr; gap:12px; margin-top:30px; }
.qty{ display:flex; align-items:center; border:1.5px solid color-mix(in srgb,var(--ink) 24%,transparent); border-radius:999px; overflow:hidden; }
.qty button{ width:46px; height:54px; font-size:1.3rem; color:var(--ink); display:grid; place-items:center; }
.qty button:hover{ background:var(--paper-2); }
.qty span{ min-width:34px; text-align:center; font-family:var(--font-display); font-weight:800; font-size:1.1rem; }
.add-bag{ background:var(--ink); color:var(--paper); border-radius:999px; font-family:var(--font-mono); font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.8rem; display:flex; align-items:center; justify-content:center; gap:10px; transition:background .2s ease, transform .15s ease; }
.add-bag:hover{ background:var(--red); transform:translateY(-2px); }
.buy-now{ margin-top:12px; width:100%; border:2px solid var(--ink); border-radius:999px; padding:16px; font-family:var(--font-mono); font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.8rem; color:var(--ink); transition:all .2s ease; }
.buy-now:hover{ background:var(--ink); color:var(--paper); }

.trust-mini{ display:flex; gap:18px; flex-wrap:wrap; margin-top:24px; padding-top:22px; border-top:1px solid color-mix(in srgb,var(--ink) 12%,transparent); }
.trust-mini .t{ display:flex; align-items:center; gap:9px; font-size:.82rem; color:var(--ink-2); }
.trust-mini svg{ width:20px; height:20px; stroke:var(--soil); stroke-width:1.6; fill:none; }

/* accordion */
.acc{ margin-top:14px; }
.acc__item{ border-top:1px solid color-mix(in srgb,var(--ink) 14%,transparent); }
.acc__head{ width:100%; display:flex; justify-content:space-between; align-items:center; padding:18px 0; font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:var(--ink); }
.acc__head .pm{ font-size:1.3rem; transition:transform .2s ease; color:var(--red); }
.acc__item.open .acc__head .pm{ transform:rotate(45deg); }
.acc__panel{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.acc__panel-inner{ padding-bottom:18px; color:var(--ink-2); font-size:.95rem; max-width:52ch; }
.acc__panel-inner ul{ margin:6px 0 0 18px; display:flex; flex-direction:column; gap:6px; }

/* sticky mobile bar */
.sticky-buy{ display:none; }

@media (max-width:980px){
  .shop{ grid-template-columns:1fr; }
  .filters-side{ position:fixed; inset:0 0 0 auto; width:min(86vw,340px); background:var(--paper); z-index:120; padding:24px; overflow-y:auto; transform:translateX(100%); transition:transform .3s ease; box-shadow:-20px 0 50px rgba(0,0,0,.15); }
  .filters-side.open{ transform:translateX(0); }
  .filters-side__close{ display:flex !important; }
  .filters-toggle{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; font-weight:700; border:1.5px solid var(--ink); padding:10px 16px; border-radius:999px; }
  .shop .grid{ grid-template-columns:repeat(2,1fr); }
  .pdp{ grid-template-columns:1fr; }
  .pinfo{ position:static; }
  .gallery{ position:sticky; top:84px; }
}
.filters-side__close{ display:none; width:100%; justify-content:flex-end; margin-bottom:10px; }
.filters-side__close button{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; font-weight:700; }
.scrim{ position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:110; opacity:0; pointer-events:none; transition:opacity .3s ease; }
.scrim.show{ opacity:1; pointer-events:auto; }

@media (max-width:620px){
  .gallery{ grid-template-columns:1fr; }
  .gallery__thumbs{ flex-direction:row; order:2; }
  .gallery__thumbs button{ width:64px; flex:none; }
  .sticky-buy{ display:flex; position:fixed; left:0; right:0; bottom:0; z-index:90; background:var(--paper); border-top:1px solid color-mix(in srgb,var(--ink) 14%,transparent); padding:12px var(--gut); gap:12px; align-items:center; box-shadow:0 -10px 30px rgba(0,0,0,.08); }
  .sticky-buy .sp{ font-family:var(--font-display); font-weight:800; font-size:1.2rem; }
  .sticky-buy .add-bag{ flex:1; padding:15px; }
  body.pdp-page{ padding-bottom:78px; }
}
