/* ========================================================================
   PATCH — design tokens
   ======================================================================== */
:root{
  --ink:        #0A0A0A;
  --ink-2:      #1F1F1F;
  --mute:       #6B6B6B;
  --line:       #E4DFD4;
  --cream:      #F4F0E8;
  --paper:      #FAF7F1;
  --white:      #FFFFFF;

  /* Patchwork palette — overridden per theme via JS (see themes.js) */
  --patch-c1: #a9b2ce;
  --patch-c2: #dfb8bc;
  --patch-c3: #997595;
  --patch-c4: #ebc569;

  --accent: var(--patch-c4);

  --font-display: 'Anton', Impact, sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --pad-x:  clamp(20px, 5vw, 80px);
  --gap:    clamp(20px, 3vw, 40px);

  --tx:     200ms cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition: background-color 600ms cubic-bezier(.4,0,.2,1);
}
/* Sections that read --cream or --paper smoothly follow theme changes */
.drop,
.pdp__media,
.trust,
.ethos__item,
.pdp__preorder-note,
.auth__hint,
.nav{
  transition: background-color 600ms cubic-bezier(.4,0,.2,1);
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }

/* ========================================================================
   Typography
   ======================================================================== */
.display{
  font-family:var(--font-display);
  font-weight:400;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.005em;
  font-size:clamp(40px, 7vw, 96px);
  margin:0 0 .2em;
}
.eyebrow{
  display:inline-block;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--mute);
  margin-bottom:18px;
}
.lede{ font-size:18px; color:var(--ink-2); max-width:46ch; }

/* ========================================================================
   Buttons
   ======================================================================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:16px 26px;
  font-size:13px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  border:1px solid var(--ink); background:var(--ink); color:var(--paper);
  transition:transform var(--tx), background var(--tx), color var(--tx);
}
.btn:hover{ background:var(--paper); color:var(--ink); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); }
.btn--block{ width:100%; }

/* ========================================================================
   Navigation
   ======================================================================== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad-x);
  background:rgba(250,247,241,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom:1px solid var(--line);
}
.nav__logo{
  font-family:var(--font-display);
  font-size:30px;
  letter-spacing:.05em;
  line-height:1;
}
.nav__links{ display:flex; gap:34px; }
.nav__links a{
  font-size:13px; text-transform:uppercase; letter-spacing:.12em;
  color:var(--ink-2); transition:color var(--tx);
}
.nav__links a:hover, .nav__links a.active{ color:var(--ink); }
.nav__account a{
  font-size:13px; text-transform:uppercase; letter-spacing:.12em;
  padding:10px 14px; border:1px solid var(--ink); color:var(--ink);
  transition:background var(--tx), color var(--tx);
}
.nav__account a:hover{ background:var(--ink); color:var(--paper); }

/* Theme picker (injected in nav by JS) */
.theme-picker{ display:flex; gap:6px; align-items:center; }
.theme-chip{
  display:flex; align-items:center; gap:8px;
  padding:6px 10px;
  background:transparent;
  border:1px solid transparent;
  transition:border-color var(--tx), background var(--tx);
}
.theme-chip:hover{ border-color:var(--line); }
.theme-chip.active{ border-color:var(--ink); }
.theme-chip__swatches{ display:flex; gap:2px; }
.theme-chip__swatches i{
  display:block; width:10px; height:10px; border-radius:50%;
  border:1px solid rgba(0,0,0,.08);
}
.theme-chip__label{
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--mute); font-weight:500;
}
.theme-chip.active .theme-chip__label{ color:var(--ink); }

@media (max-width:980px){
  .theme-chip__label{ display:none; }
}
@media (max-width:720px){
  .nav__links{ display:none; }
}

/* ========================================================================
   HERO
   ======================================================================== */
.hero{
  position:relative;
  height:88vh; min-height:560px;
  overflow:hidden;
  color:var(--paper);
}
.hero__img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
}
.hero__overlay{
  position:absolute; inset:0;
  padding:40px var(--pad-x);
  display:flex; flex-direction:column; justify-content:space-between;
  background: linear-gradient(180deg, rgba(0,0,0,.0) 30%, rgba(0,0,0,.5) 100%);
}
.hero__top{ display:flex; justify-content:flex-end; }
.badge{
  display:inline-block;
  background:var(--accent); color:var(--ink);
  padding:8px 14px;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
}
.hero__title{
  font-family: var(--font-hero, var(--font-display));
  font-weight: var(--font-hero-weight, 400);
  font-style:  var(--font-hero-style, normal);
  letter-spacing: var(--font-hero-tracking, 0);
  font-size:clamp(110px, 24vw, 360px);
  line-height:.85;
  margin:0;
  display:flex; align-items:flex-end; gap:.1em;
  /* fade-cross when font swaps */
  transition: opacity 360ms cubic-bezier(.4,0,.2,1);
}
body.theme-shifting .hero__title{ opacity:0; }
.hero__title-sub{
  font-size:clamp(20px, 2.4vw, 36px);
  letter-spacing:.2em;
  padding-bottom:.6em;
  opacity:.9;
}
.hero__meta{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
  margin-top:18px;
}
.hero__tag{
  max-width:38ch; font-size:16px; line-height:1.5; margin:0;
}
.hero .btn--primary{ background:var(--paper); color:var(--ink); border-color:var(--paper); }
.hero .btn--primary:hover{ background:transparent; color:var(--paper); }

/* ========================================================================
   Ethos strip (pre-order, delivery, atelier)
   ======================================================================== */
.ethos{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border-bottom:1px solid var(--line);
}
.ethos__item{
  background:var(--paper);
  padding: clamp(36px, 5vw, 56px) clamp(28px, 4vw, 48px);
  display:flex; flex-direction:column; gap:10px;
}
.ethos__item h3{
  font-family:var(--font-display);
  text-transform:uppercase;
  font-size:clamp(24px, 2.6vw, 34px);
  line-height:1;
  letter-spacing:.01em;
  margin:0;
}
.ethos__item p{ font-size:14px; color:var(--ink-2); margin:0; max-width:42ch; }
@media (max-width:820px){ .ethos{ grid-template-columns:1fr; } }

/* PDP pre-order note */
.pdp__preorder-note{
  border-left:3px solid var(--patch-c4);
  padding:14px 18px;
  background:var(--cream);
}
.pdp__preorder-note p{ margin:6px 0 0; font-size:14px; color:var(--ink-2); line-height:1.55; }
.pdp__preorder-note strong{ color:var(--ink); font-weight:500; }

/* ========================================================================
   Manifesto
   ======================================================================== */
.manifesto{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:var(--gap);
  padding: clamp(80px, 12vw, 160px) var(--pad-x);
  border-bottom:1px solid var(--line);
}
.manifesto__body p{ font-size:18px; line-height:1.65; color:var(--ink-2); max-width:54ch; }
.manifesto__body p + p{ margin-top:1em; }
@media (max-width:820px){ .manifesto{ grid-template-columns:1fr; } }

/* ========================================================================
   Drop / Product card
   ======================================================================== */
.drop{
  padding: clamp(60px, 9vw, 120px) var(--pad-x);
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.drop__header{ margin-bottom:60px; }

.drop__product{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:60px;
  align-items:center;
}
.drop__visual{
  position:relative;
  display:block;
  background:var(--white);
  overflow:hidden;
}
.drop__visual img{
  width:100%; aspect-ratio: 1/1.1; object-fit:cover;
  transition:transform 600ms cubic-bezier(.2,.7,.2,1);
}
.drop__visual:hover img{ transform:scale(1.03); }
.drop__swatches{
  position:absolute; left:24px; bottom:24px;
  display:flex; gap:6px;
}
.drop__swatches span{ width:22px; height:22px; border-radius:50%; border:1px solid rgba(0,0,0,.1); }

.drop__name{
  font-family:var(--font-display);
  font-size:clamp(34px, 4.4vw, 56px);
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:.95;
  margin:0 0 28px;
}

.spec{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.spec li{
  display:flex; justify-content:space-between; gap:24px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  font-size:14px;
}
.spec li span:first-child{ color:var(--mute); text-transform:uppercase; letter-spacing:.1em; font-size:12px; }
.spec--bordered{ border-top:none; }

.drop__cta{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  margin-top:32px;
}
.price{
  font-family:var(--font-display);
  font-size:40px;
  line-height:1;
}

@media (max-width:820px){ .drop__product{ grid-template-columns:1fr; gap:32px; } }

/* ========================================================================
   Timeline
   ======================================================================== */
.timeline{
  padding: clamp(80px, 12vw, 160px) var(--pad-x);
  background:var(--ink);
  color:var(--paper);
}
.timeline .eyebrow{ color:var(--patch-c4); }
.timeline__head{ max-width:760px; margin-bottom:60px; }
.timeline__head .lede{ color:rgba(244,240,232,.7); }
.timeline__steps{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns: repeat(3, 1fr); gap:1px;
  background:rgba(244,240,232,.15);
  border:1px solid rgba(244,240,232,.15);
}
.timeline__steps li{
  background:var(--ink);
  padding:36px 28px;
  min-height:200px;
  display:flex; flex-direction:column; justify-content:space-between;
}
.timeline__n{
  font-family:var(--font-display);
  font-size:64px; line-height:.9;
  color:var(--patch-c4);
}
.timeline__steps h4{ font-size:18px; margin:24px 0 6px; font-weight:500; }
.timeline__steps p{ font-size:14px; color:rgba(244,240,232,.65); margin:0; }
@media (max-width:900px){ .timeline__steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .timeline__steps{ grid-template-columns:1fr; } }

/* ========================================================================
   Newsletter
   ======================================================================== */
.news{
  padding: clamp(80px, 12vw, 140px) var(--pad-x);
  background: var(--patch-c2);
  border-bottom:1px solid var(--line);
}
.news__inner{ max-width:760px; }
.news__form{ display:flex; gap:12px; margin-top:24px; max-width:520px; }
.news__form input{
  flex:1; background:transparent; border:none; border-bottom:1px solid var(--ink);
  padding:14px 4px; font-size:16px; color:var(--ink); outline:none;
}
.news__form input::placeholder{ color:rgba(10,10,10,.5); }

/* ========================================================================
   Footer
   ======================================================================== */
.foot{
  background:var(--ink); color:var(--paper);
  padding: 60px var(--pad-x) 30px;
}
.foot__logo{
  font-family:var(--font-display);
  font-size:clamp(80px, 14vw, 200px);
  line-height:.9;
  letter-spacing:.02em;
  margin-bottom:60px;
}
.foot__cols{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:40px;
  padding-bottom:50px;
  border-bottom:1px solid rgba(244,240,232,.15);
}
.foot__cols h5{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--patch-c4); margin:0 0 14px; font-weight:500; }
.foot__cols a{ display:block; padding:5px 0; color:rgba(244,240,232,.75); font-size:14px; }
.foot__cols a:hover{ color:var(--paper); }
.foot__base{
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding-top:24px;
  font-size:12px; letter-spacing:.06em; color:rgba(244,240,232,.5);
}
.foot__base a{ color:rgba(244,240,232,.8); }
@media (max-width:720px){ .foot__cols{ grid-template-columns:1fr 1fr; } }

/* ========================================================================
   PDP — product page
   ======================================================================== */
.pdp{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap:0;
  border-bottom:1px solid var(--line);
}
.pdp__media{
  background:var(--cream);
  padding: 40px;
  position:relative;
}
.pdp__media > img{
  width:100%; aspect-ratio: 4/5; object-fit:cover;
}
.pdp__thumbs{ display:flex; gap:10px; margin-top:14px; }
.pdp__thumb{
  width:70px; height:88px; padding:0; background:none; border:1px solid var(--line);
  overflow:hidden; opacity:.6; transition:opacity var(--tx), border-color var(--tx);
}
.pdp__thumb.active{ opacity:1; border-color:var(--ink); }
.pdp__thumb img{ width:100%; height:100%; object-fit:cover; }

.pdp__info{
  padding: clamp(40px, 6vw, 80px) var(--pad-x);
  display:flex; flex-direction:column; gap:24px;
  align-self:start;
  position:sticky; top:80px;
}
.pdp__title{
  font-family:var(--font-display);
  text-transform:uppercase;
  font-size:clamp(48px, 6.5vw, 92px);
  line-height:.9;
  margin:0;
}
.pdp__price{ display:flex; align-items:baseline; gap:18px; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.pdp__price-note{ font-size:13px; color:var(--mute); }
.pdp__lede{ font-size:16px; color:var(--ink-2); margin:0; }
.pdp__details{ border-top:1px solid var(--line); padding-top:18px; }
.pdp__details summary{ font-size:12px; text-transform:uppercase; letter-spacing:.14em; cursor:pointer; padding:8px 0; }

@media (max-width:980px){
  .pdp{ grid-template-columns:1fr; }
  .pdp__info{ position:static; }
}

/* ========================================================================
   Forms
   ======================================================================== */
.form{ display:flex; flex-direction:column; gap:18px; }
.form__row{ display:flex; flex-direction:column; gap:10px; }
.form__row label{ font-size:11px; text-transform:uppercase; letter-spacing:.16em; color:var(--mute); font-weight:500; }
.form__row--inline input{
  background:transparent; border:none; border-bottom:1px solid var(--ink);
  padding:10px 0; font-size:16px; color:var(--ink); outline:none;
  font-family:inherit;
}
.form__note{ font-size:12px; color:var(--mute); margin:0; }

.chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  padding:10px 14px;
  background:transparent; color:var(--ink);
  border:1px solid var(--line);
  font-size:13px; letter-spacing:.06em;
  transition:border-color var(--tx), background var(--tx), color var(--tx);
}
.chip:hover{ border-color:var(--ink); }
.chip.selected{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.chip.swatch{ padding:8px; display:flex; gap:4px; }
.chip.swatch i{ width:18px; height:18px; display:block; border-radius:50%; border:1px solid rgba(0,0,0,.1); }
.chip.swatch.selected{ background:var(--paper); }
.chip.swatch.selected i{ border-color:var(--ink); }

/* Variant chips on PDP — each chip shows 4 swatches + variant name */
.chips--variants{ gap:10px; }
.chip-variant{
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:14px 18px;
  background:transparent;
  border:1px solid var(--line);
  color:var(--ink);
  min-width:100px;
  transition: border-color var(--tx), background var(--tx), color var(--tx);
}
.chip-variant:hover{ border-color:var(--ink); }
.chip-variant.selected{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
.chip-variant__swatches{ display:flex; gap:3px; }
.chip-variant__swatches i{
  display:block;
  width:16px; height:16px;
  border-radius:50%;
  border:1px solid rgba(0,0,0,.1);
}
.chip-variant.selected .chip-variant__swatches i{ border-color:rgba(255,255,255,.18); }
.chip-variant__name{
  font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
}

.qty{
  display:inline-flex; align-items:center; border:1px solid var(--line); width:fit-content;
}
.qty button{ width:44px; height:44px; background:transparent; border:none; font-size:18px; }
.qty input{ width:44px; height:44px; text-align:center; border:none; background:transparent; font-size:15px; }

/* ========================================================================
   Trust strip
   ======================================================================== */
.trust{
  display:grid; grid-template-columns:repeat(4, 1fr);
  padding: clamp(40px, 6vw, 80px) var(--pad-x);
  gap:40px;
  background:var(--cream);
}
.trust h4{ font-size:18px; margin:14px 0 6px; font-weight:500; }
.trust p{ font-size:14px; color:var(--mute); margin:0; }
@media (max-width:820px){ .trust{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .trust{ grid-template-columns:1fr; } }

/* ========================================================================
   Account — Auth
   ======================================================================== */
.auth{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height: calc(100vh - 76px);
}
.auth__cover{ position:relative; overflow:hidden; }
.auth__cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.auth__cover-text{
  position:absolute; inset:0;
  padding: 50px;
  background: linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.55));
  color:var(--paper);
  display:flex; flex-direction:column; justify-content:flex-end;
}
.auth__cover-text .eyebrow{ color:var(--patch-c4); }
.auth__cover-text p{ max-width:36ch; }

.auth__form{
  padding: clamp(40px, 6vw, 80px) clamp(30px, 6vw, 80px);
  display:flex; flex-direction:column; justify-content:center;
}
.auth__tabs{ display:flex; gap:0; border-bottom:1px solid var(--line); margin-bottom:30px; }
.auth__tab{
  background:none; border:none; padding:14px 4px; margin-right:24px;
  font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--mute);
  border-bottom:2px solid transparent; transform:translateY(1px);
}
.auth__tab.active{ color:var(--ink); border-bottom-color:var(--ink); }

.auth__heading{
  font-family:var(--font-display);
  text-transform:uppercase; letter-spacing:.005em;
  font-size:clamp(28px, 3.4vw, 44px); line-height:1;
  margin:0 0 8px;
}
.auth__sub{
  color:var(--ink-2); font-size:15px; margin:0 0 24px; max-width:42ch;
}
.auth__hint{
  margin-top:18px;
  padding:14px 16px;
  border:1px solid var(--line);
  background:var(--cream);
  font-size:13px; color:var(--ink-2); line-height:1.55;
}
.auth__hint strong{ color:var(--ink); font-weight:500; display:block; margin-bottom:4px; }
.auth__hint .link{ display:inline; font-size:13px; }

.auth__error{
  margin-top:14px;
  padding:14px 16px;
  border-left:3px solid var(--ink);
  background:#FFF5F0;
  display:flex; flex-direction:column; gap:8px;
  font-size:13px;
}
.auth__error-msg{ color:var(--ink); }
.auth__error .link{ align-self:flex-start; }

@media (max-width:820px){
  .auth{ grid-template-columns:1fr; }
  .auth__cover{ min-height:300px; }
}

/* ========================================================================
   Account — Dashboard
   ======================================================================== */
.dash{ padding: clamp(40px, 6vw, 80px) var(--pad-x); }
.dash__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:50px; }
.dash__title{ font-size:clamp(48px, 7vw, 96px); margin:0; }

.dash__empty{
  border:1px dashed var(--line);
  padding:80px 40px;
  text-align:center;
}

/* Dashboard sidebar layout */
.dash__layout{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:60px;
  align-items:start;
}
.dash__sidebar{ position:sticky; top:24px; }
.dash-nav{ display:flex; flex-direction:column; gap:2px; border-left:1px solid var(--line); }
.dash-nav__item{
  appearance:none; background:none; border:none;
  font:inherit; cursor:pointer; text-align:left;
  padding:12px 18px;
  color:var(--mute);
  font-size:14px;
  letter-spacing:.02em;
  border-left:2px solid transparent;
  margin-left:-1px;
  transition: color .15s, border-color .15s, background .15s;
}
.dash-nav__item:hover{ color:var(--ink); }
.dash-nav__item.active{
  color:var(--ink);
  border-left-color:var(--ink);
  font-weight:500;
}
.dash-nav__item--logout{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:var(--mute);
}
.dash-nav__item--logout:hover{ color:var(--ink); }

.dash__content{ min-width:0; }
.dash__section{ display:block; }
.dash__section[hidden]{ display:none; }
.dash__section-head{ margin-bottom:30px; }
.dash__section-head .display{ font-size:clamp(36px, 4vw, 56px); margin:4px 0 8px; line-height:1.05; }
.dash__section-head p{ color:var(--mute); font-size:14px; margin:0; }

/* Profile section */
.profile-form{ max-width:560px; display:grid; gap:18px; }
.profile-divider{ border:none; border-top:1px solid var(--line); margin:50px 0 30px; }
.profile-sub{ font-size:clamp(28px, 3vw, 36px); }

.form__grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form--inline{ display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap; max-width:560px; }
.form--inline .form__row{ flex:1; min-width:200px; }
.form--inline .btn{ height:46px; padding:0 24px; }

.form__check{
  display:flex; gap:10px; align-items:flex-start;
  font-size:13px; color:var(--text); line-height:1.5;
  cursor:pointer;
}
.form__check input[type="checkbox"]{
  margin-top:3px;
  flex-shrink:0;
  width:16px; height:16px;
  accent-color:var(--ink);
  cursor:pointer;
}

/* Invoices section */
.invoices{ display:grid; gap:14px; }
.invoice{
  display:grid;
  grid-template-columns: 1fr auto auto;
  gap:24px;
  align-items:center;
  background:var(--white);
  border:1px solid var(--line);
  padding: 20px 28px;
}
.invoice__id{
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute);
  display:block; margin-bottom:4px;
}
.invoice__meta{ font-size:14px; color:var(--text); margin:0; }
.invoice__amount{ font-family:var(--font-display); font-size:22px; }

@media (max-width: 860px){
  .dash__layout{ grid-template-columns:1fr; gap:30px; }
  .dash__sidebar{ position:static; }
  .dash-nav{ flex-direction:row; flex-wrap:wrap; border-left:none; border-bottom:1px solid var(--line); }
  .dash-nav__item{ border-left:none; border-bottom:2px solid transparent; padding:12px 16px; margin:0; }
  .dash-nav__item.active{ border-left-color:transparent; border-bottom-color:var(--ink); }
  .dash-nav__item--logout{ margin-top:0; padding-top:12px; border-top:none; margin-left:auto; }
  .form__grid{ grid-template-columns:1fr; }
  .invoice{ grid-template-columns:1fr; gap:12px; }
}

/* Auth signup block on /account */
.auth__divider{ border:none; border-top:1px solid var(--line); margin:36px 0 30px; }
.auth__forgot{
  display:inline-block; margin-top:16px;
  font-size:13px; color:var(--mute);
  text-align:left;
}
.auth__forgot:hover{ color:var(--ink); }
.auth__signup .eyebrow{ display:block; margin-bottom:8px; }
.auth__signup-title{
  font-family:var(--font-display);
  font-size:clamp(24px, 2.5vw, 32px);
  margin:0 0 10px;
  line-height:1.1;
}
.auth__signup p{ font-size:14px; color:var(--text); margin:0 0 20px; }

/* Signup modal */
.modal{
  display:none;
  position:fixed; inset:0;
  z-index:1000;
  align-items:center; justify-content:center;
  padding:24px;
}
.modal.is-open{ display:flex; }
.modal__overlay{
  position:absolute; inset:0;
  background:rgba(20, 20, 22, 0.5);
}
.modal__card{
  position:relative;
  background:var(--white);
  width:100%; max-width:480px;
  max-height:90vh; overflow-y:auto;
  padding:40px 36px;
  animation: modal-in .25s ease-out;
}
@keyframes modal-in {
  from { transform:translateY(16px); opacity:0; }
  to   { transform:translateY(0);    opacity:1; }
}
.modal__close{
  position:absolute; top:14px; right:14px;
  appearance:none; background:none; border:none;
  width:36px; height:36px;
  font-size:24px; line-height:1;
  cursor:pointer; color:var(--mute);
  display:flex; align-items:center; justify-content:center;
  transition:color .15s;
}
.modal__close:hover{ color:var(--ink); }
.modal__card .auth__heading{ margin:8px 0 6px; }
.modal__card .auth__sub{ margin:0 0 24px; }
.modal__card .form{ display:grid; gap:14px; }

/* Nav initials when signed in */
.nav__account-initials{
  width:40px; height:40px;
  border-radius:50%;
  display:flex !important;
  align-items:center; justify-content:center;
  padding:0 !important;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:500;
}

/* /account: show auth or dashboard based on the anti-FOUC flag set on <html> */
body[data-page="account"] #dash{ display:none; }
html[data-auth-state="in"] body[data-page="account"] #dash{ display:block; }
html[data-auth-state="in"] body[data-page="account"] #auth{ display:none; }

/* Orders */
.orders{ display:grid; gap:30px; }
.order{
  background:var(--white);
  border:1px solid var(--line);
  padding: clamp(28px, 3vw, 44px);
}
.order__head{
  display:flex; justify-content:space-between; align-items:flex-start; gap:24px; flex-wrap:wrap;
  padding-bottom:24px; border-bottom:1px solid var(--line);
}
.order__id{
  display:inline-block;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute);
  margin-bottom:8px;
}
.order__name{
  font-family:var(--font-display);
  font-size:clamp(28px, 3vw, 44px); line-height:1;
  text-transform:uppercase; margin:0 0 8px;
}
.order__meta{ font-size:13px; color:var(--mute); margin:0; }
.order__colors{ display:flex; gap:4px; margin-top:10px; }
.order__colors i{ width:14px; height:14px; border-radius:50%; border:1px solid rgba(0,0,0,.08); display:block; }

/* Order payment status pill */
.order__status{
  display:inline-block;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  padding:4px 10px;
  margin-left:10px;
  border:1px solid var(--line);
  border-radius:999px;
  vertical-align:middle;
}
.order__status[data-status="paid"]{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
}
.order__status[data-status="pending"]{
  background:var(--patch-c4); color:var(--ink); border-color:var(--patch-c4);
}
.order__status[data-status="cancelled"]{
  opacity:.55; text-decoration:line-through;
}

/* Auth state — controlled via <html data-auth-state="in|out"> set in head before paint */
[data-auth-state="in"]  #auth { display: none; }
[data-auth-state="out"] #dash { display: none; }

/* Pending order — distinct from paid */
.order--pending{
  border-color: var(--patch-c4);
  background: var(--cream);
}
.order--pending .order__progress,
.order--pending .steps{ display: none; }

.order__pending-msg{
  margin: 22px 0 24px;
  padding: 16px 18px;
  background: var(--paper);
  border-left: 3px solid var(--patch-c4);
}
.order__pending-msg p{
  margin: 6px 0 0;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.55;
}

/* Small button variant for inline actions */
.btn--small{
  padding: 12px 18px;
  font-size: 12px;
}

/* ========================================================================
   Vestiaire (collection listing)
   ======================================================================== */
.vest-hero{
  padding: clamp(80px, 12vw, 160px) var(--pad-x) clamp(40px, 6vw, 80px);
  border-bottom: 1px solid var(--line);
}
.vest-hero__inner{ max-width: 920px; }
.vest-hero .lede{ margin-top: 24px; max-width: 56ch; }

.vest-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border-bottom: 1px solid var(--line);
}
@media (max-width: 980px){ .vest-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 680px){ .vest-grid{ grid-template-columns: 1fr; } }

.vest-card{ background: var(--paper); display: flex; }
.vest-card__link{
  display: flex; flex-direction: column;
  width: 100%;
  text-decoration: none; color: inherit;
}

.vest-card__media{
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/5;
  background: var(--cream);
}
.vest-card__media img{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
}
.vest-card:hover .vest-card__media img{ transform: scale(1.04); }

.vest-card__info{
  padding: clamp(24px, 3vw, 36px);
  display: flex; flex-direction: column; gap: 14px;
  flex: 1;
}
.vest-card__swatches{ display: flex; gap: 4px; }
.vest-card__swatches i{
  display: block;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.08);
}
.vest-card__name{
  margin: 0;
  font-size: clamp(34px, 3.6vw, 52px);
  line-height: .92;
  text-transform: uppercase;
  letter-spacing: .005em;
  /* font-family/weight/style injected by JS per variant */
}
.vest-card__tag{
  margin: 0;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mute);
}
.vest-card__meta{
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
}
.vest-card__price{
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1;
}
.vest-card__cta{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 500;
  transition: transform var(--tx);
}
.vest-card:hover .vest-card__cta{ transform: translateX(4px); }

/* Footer trio under the grid */
.vest-foot{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--ink);
  padding-bottom: 1px;
}
.vest-foot__col{
  background: var(--ink);
  color: var(--paper);
  padding: clamp(36px, 5vw, 56px) clamp(28px, 4vw, 48px);
}
.vest-foot__col .eyebrow{ color: var(--patch-c4); }
.vest-foot__col h3{
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1;
  letter-spacing: .01em;
  margin: 14px 0 12px;
}
.vest-foot__col p{
  font-size: 14px;
  color: rgba(244,240,232,.7);
  margin: 0;
  max-width: 38ch;
}
@media (max-width:820px){ .vest-foot{ grid-template-columns: 1fr; } }

/* Success page */
.success{
  padding: clamp(80px, 12vw, 160px) var(--pad-x);
  min-height: 70vh;
}
.success__inner{ max-width: 760px; }
.success .lede{ margin: 18px 0 0; }
.success__order{
  margin: 50px 0 40px;
  padding: clamp(24px, 3vw, 36px);
  background: var(--cream);
  border: 1px solid var(--line);
}
.success__order-title{
  font-family: var(--font-display);
  text-transform: uppercase; letter-spacing:.01em;
  font-size: 22px; line-height: 1;
  margin: 0 0 18px;
}
.success__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top: 14px; }
.order__price{
  font-family:var(--font-display);
  font-size:30px;
}

.order__progress{ padding:24px 0; }
.order__bar{
  height:6px; background:var(--line); position:relative; overflow:hidden;
}
.order__bar span{
  position:absolute; left:0; top:0; bottom:0; width:0;
  background: linear-gradient(90deg, var(--patch-c3), var(--patch-c4));
  transition: width 600ms cubic-bezier(.2,.7,.2,1);
}
.order__bar-label{ display:flex; justify-content:space-between; margin-top:10px; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--mute); }
.order__stage{ color:var(--ink); }

.steps{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(6, 1fr);
  position:relative;
}
.steps::before{
  content:""; position:absolute; left:6%; right:6%; top:14px;
  height:1px; background:var(--line); z-index:0;
}
.steps li{ position:relative; padding-top:34px; text-align:center; z-index:1; }
.steps__dot{
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:14px; height:14px; border-radius:50%;
  background:var(--paper); border:1px solid var(--line);
  transition:background var(--tx), border-color var(--tx), transform var(--tx);
}
.steps li.done .steps__dot{ background:var(--ink); border-color:var(--ink); }
.steps li.current .steps__dot{ background:var(--accent); border-color:var(--accent); transform:translateX(-50%) scale(1.4); box-shadow:0 0 0 4px rgba(232,180,71,.2); }
.steps h5{ font-size:11px; margin:0 0 2px; font-weight:500; text-transform:uppercase; letter-spacing:.08em; color:var(--mute); padding:0 4px; }
.steps li.done h5, .steps li.current h5{ color:var(--ink); }
.steps time{ font-size:11px; color:var(--mute); display:block; }

@media (max-width:780px){
  .steps{ grid-template-columns:1fr; gap:14px; }
  .steps::before{ left:14px; right:auto; top:14px; bottom:14px; width:1px; height:auto; }
  .steps li{ padding-top:0; padding-left:34px; text-align:left; }
  .steps__dot{ left:14px; top:4px; transform:none; }
  .steps li.current .steps__dot{ transform:scale(1.4); }
}

.order__foot{
  margin-top:20px; padding-top:20px; border-top:1px solid var(--line);
  display:flex; gap:24px; flex-wrap:wrap;
}
.link{
  background:none; border:none; padding:0;
  color:var(--ink-2); text-decoration:underline; text-underline-offset:4px;
  font-size:13px;
}
.link:hover{ color:var(--ink); }

/* ========================================================================
   Theme transitions (color + image swap smoothness)
   ======================================================================== */
img[data-theme-image]{
  transition: opacity 380ms cubic-bezier(.4,0,.2,1);
  will-change: opacity;
}
img[data-theme-image].is-swapping{ opacity: 0; }

.badge,
.news,
.timeline__n,
.foot__cols h5,
.timeline .eyebrow,
.auth__cover-text .eyebrow,
.drop__swatches span,
.theme-chip__swatches i,
.combo-active .theme-chip__swatches i,
.order__colors i,
.order__bar span,
.steps li.current .steps__dot,
.pdp__preorder-note{
  transition:
    background-color 520ms cubic-bezier(.4,0,.2,1),
    color 520ms cubic-bezier(.4,0,.2,1),
    border-color 520ms cubic-bezier(.4,0,.2,1),
    box-shadow 520ms cubic-bezier(.4,0,.2,1);
}

/* Picker chip pulse on activation */
@keyframes patch-chip-pulse{
  0%   { transform: scale(1); }
  50%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}
.theme-chip.active .theme-chip__swatches{
  animation: patch-chip-pulse 420ms cubic-bezier(.4,0,.2,1);
}

@media (prefers-reduced-motion: reduce){
  img[data-theme-image]{ transition:none; }
  .theme-chip.active .theme-chip__swatches{ animation:none; }
  .badge,.news,.timeline__n,.foot__cols h5,.timeline .eyebrow,
  .auth__cover-text .eyebrow,.drop__swatches span,.theme-chip__swatches i,
  .combo-active .theme-chip__swatches i,.order__colors i,.order__bar span,
  .steps li.current .steps__dot,.pdp__preorder-note{ transition:none; }
}

/* ========================================================================
   Toast
   ======================================================================== */
.toast{
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--ink); color:var(--paper);
  padding:14px 20px;
  font-size:13px; letter-spacing:.08em; text-transform:uppercase;
  opacity:0; transition:opacity var(--tx), transform var(--tx);
  z-index:200;
}
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ========================================================================
   Legal pages (CGU, CGV, Confidentialité, Mentions légales)
   ======================================================================== */
.legal{
  padding: clamp(60px, 8vw, 110px) var(--pad-x) clamp(60px, 6vw, 100px);
  max-width: 820px;
  margin: 0 auto;
}
.legal__head{
  margin-bottom: clamp(40px, 5vw, 70px);
  padding-bottom: 30px;
  border-bottom: 1px solid var(--line);
}
.legal__head .display{
  font-size: clamp(44px, 6vw, 84px);
  line-height: 0.95;
  margin: 12px 0 18px;
}
.legal__updated{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0;
}
.legal__body{
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
}
.legal__body h2{
  font-family: var(--font-display);
  font-size: clamp(22px, 2.5vw, 28px);
  line-height: 1.15;
  margin: 50px 0 16px;
  color: var(--ink);
  font-weight: 400;
}
.legal__body h2:first-child{ margin-top: 0; }
.legal__body p{ margin: 0 0 14px; }
.legal__body ul, .legal__body ol{
  margin: 0 0 14px;
  padding-left: 22px;
}
.legal__body li{ margin-bottom: 8px; }
.legal__body strong{ color: var(--ink); font-weight: 500; }
.legal__body em{ color: var(--mute); font-style: normal; background: rgba(255, 220, 100, .25); padding: 1px 6px; border-radius: 2px; }
.legal__body a{
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.legal__body a:hover{ text-decoration-thickness: 2px; }

.legal__table{
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0 20px;
  font-size: 13px;
  line-height: 1.5;
}
.legal__table th,
.legal__table td{
  text-align: left;
  vertical-align: top;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
}
.legal__table th{
  background: var(--cream);
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--ink);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .12em;
}
.legal__table td:first-child{ font-weight: 500; color: var(--ink); }

.legal__back{
  display: inline-block;
  margin-top: 50px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--mute);
  letter-spacing: .04em;
  text-decoration: none;
}
.legal__back:hover{ color: var(--ink); }

@media (max-width: 640px){
  .legal__table{ font-size: 12px; }
  .legal__table th, .legal__table td{ padding: 10px 8px; }
}

/* ========================================================================
   Pre-order contact modal (temporary, while Stripe is being activated)
   ======================================================================== */
.preorder-summary{
  margin: 18px 0 8px;
  padding: 18px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: grid; gap: 10px;
}
.preorder-summary .eyebrow{ font-size: 11px; }
.preorder-summary .spec{ margin: 0; }
.preorder-success{ text-align: left; display: grid; gap: 16px; }
.preorder-success .auth__heading{ margin: 8px 0 6px; }

.form__row textarea{
  width: 100%;
  border: 1px solid var(--line);
  background: var(--white);
  padding: 12px 14px;
  font: inherit;
  color: var(--ink);
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
}
.form__row textarea:focus{
  outline: none;
  border-color: var(--ink);
}
.form__note--inline{
  display: inline;
  font-size: 11px;
  color: var(--mute);
  text-transform: none;
  letter-spacing: 0;
  margin-left: 4px;
}
