/* ─── Google Translate suppression ──────────────────────────────────── */
.goog-te-banner-frame,.goog-te-ftab-float,.goog-te-balloon-frame,
#goog-gt-tt,.goog-tooltip,.goog-tooltip-card,
.VIpgJd-ZVi9od-ORHb-OEVmcd,.VIpgJd-yAWNEb-hvhgNd{display:none!important}
body{top:0!important}
.skiptranslate iframe{display:none!important}

/* ─── JT Atelier — base ─────────────────────────────────────────────── */
.filter-scroll::-webkit-scrollbar { display: none; }
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{overflow-x:hidden}
body{
  font-family:var(--font-body,'DM Sans'),system-ui,sans-serif;
  background:var(--bg,#0A0A0A);
  color:var(--fg,#FAFAFA);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background .4s ease,color .4s ease;
}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}
a{color:inherit;text-decoration:none}
select{color-scheme:inherit;background:var(--bg);color:var(--fg)}
select option{background:var(--bg);color:var(--fg)}

:root{
  --bg:#0A0A0A;
  --fg:#FAFAFA;
  --fg-2:rgba(250,250,250,.62);
  --fg-3:rgba(250,250,250,.38);
  --line:rgba(250,250,250,.10);
  --line-2:rgba(250,250,250,.18);
  --surf:#141414;
  --surf-2:#1A1A1A;
  --accent:#FAFAFA;
  --accent-fg:#0A0A0A;
  --crimson:#A31620;
  --crimson-bright:#C4182A;
  --gradient: linear-gradient(110deg,#FAFAFA 0%,#C8C8CC 32%,#6E6E74 62%,#FAFAFA 100%);
  --gradient-soft: linear-gradient(110deg,rgba(250,250,250,.95),rgba(180,180,186,.6) 50%,rgba(250,250,250,.95));
  --font-display:'GFS Didot','Bodoni Moda',serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --grain:.5;
  color-scheme: dark;
}

body.light{
  --bg:#F4F1EC;
  --fg:#0A0A0A;
  --fg-2:rgba(10,10,10,.62);
  --fg-3:rgba(10,10,10,.38);
  --line:rgba(10,10,10,.10);
  --line-2:rgba(10,10,10,.20);
  --surf:#EAE6DF;
  --surf-2:#E1DCD3;
  --accent:#0A0A0A;
  color-scheme: light;
  --accent-fg:#FAFAFA;
  --gradient: linear-gradient(110deg,#0A0A0A 0%,#4A4A4A 35%,#9A9A9A 60%,#0A0A0A 100%);
  --gradient-soft: linear-gradient(110deg,rgba(10,10,10,.95),rgba(80,80,82,.55) 50%,rgba(10,10,10,.95));
}

/* ─── Marble catalog ─────────────────────────────────────────────────
   Catalog/collection pages: white-marble background with a light,
   dark-on-bright treatment. Scoped token overrides flip every
   token-driven descendant (cards, filter bars, lines, text) to light
   without touching the global dark theme. */
.marble-catalog{
  --bg:#F7F5F1;
  --fg:#1A1A1A;
  --fg-2:rgba(26,26,26,.64);
  --fg-3:rgba(26,26,26,.42);
  --line:rgba(26,26,26,.12);
  --line-2:rgba(26,26,26,.20);
  --surf:rgba(255,255,255,.62);
  --surf-2:rgba(255,255,255,.74);
  --surface:rgba(255,255,255,.55);
  --accent:#1A1A1A;
  --accent-fg:#FAFAFA;
  /* Elegant cream for the sticky filter/sort bar */
  --cream-bar:rgba(232,222,202,.86);
  --cream-line:rgba(26,26,26,.14);
  color:var(--fg);
  min-height:100vh;
  position:relative;
  z-index:0;            /* stacking context so the fixed ::before sits behind content */
  background:transparent;
}
/* Fixed marble layer — avoids background-attachment:fixed (broken on iOS Safari).
   Lighter wash = the marble's natural tone shows through (a touch darker). */
.marble-catalog::before{
  content:'';
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    linear-gradient(rgba(248,244,236,.16),rgba(248,244,236,.16)),
    url('assets/marble-bg.jpg') center top / cover no-repeat,
    #ECE6DA;
}
/* Frost the product-card image wells so marble doesn't bleed through gaps */
.marble-catalog .product-card-media,
.marble-catalog [data-screen-label] img{ background:rgba(255,255,255,.5); }

/* ─── Home deck (horizontal scroll-scrub) ───────────────────────────── */
.deck-mobile::-webkit-scrollbar{ display:none; }

/* Category label-bars — angled banners from opposite corners (diagonal pair).
   Top-left = black/light; bottom-right = colour-flipped white/dark + covers the
   de-logo'd corner. Both link to the category. */
.deck-bar{
  position:absolute; z-index:5; cursor:pointer; border:none;
  display:flex; flex-direction:column;
  transition:filter .2s ease, transform .2s ease;
}
.deck-bar:hover{ filter:brightness(1.07); }
.deck-bar-title{ font-family:var(--font-display); font-style:italic; font-weight:600; line-height:.9; }
.deck-bar-view{ font-family:var(--font-mono); font-size:11px; letter-spacing:.22em; margin-top:10px; opacity:.8; }
/* Intro panel: brand/CTA bars (no big category) — compact mono label */
.deck-bar-label{ font-family:var(--font-mono); font-size:clamp(11px,1.2vw,15px); letter-spacing:.24em; }
.deck-bar-tl.deck-bar-intro{ padding:clamp(72px,11vh,122px) clamp(40px,4.5vw,72px) clamp(18px,2vh,28px) clamp(28px,5vw,72px); }
.deck-bar-br.deck-bar-intro{ padding:clamp(20px,2.6vh,34px) clamp(30px,5vw,66px) clamp(18px,2.4vh,30px) clamp(56px,7vw,120px); }
.deck-bar-tl{
  top:0; left:0; text-align:left; align-items:flex-start;
  background:#0A0A0A; color:#F4F1EC;
  padding:clamp(78px,12vh,140px) clamp(64px,7vw,130px) clamp(22px,3vh,42px) clamp(28px,5vw,72px);
  clip-path:polygon(0 0, 100% 0, calc(100% - 40px) 100%, 0 100%);
  box-shadow:18px 18px 50px rgba(0,0,0,.4);
}
.deck-bar-tl .deck-bar-title{ font-size:clamp(40px,7vw,118px); }
.deck-bar-br{
  bottom:0; right:0; text-align:right; align-items:flex-end; justify-content:flex-end;
  background:#F4F1EC; color:#0A0A0A;
  min-height:clamp(150px,21vh,250px); min-width:clamp(200px,18vw,360px);
  padding:clamp(18px,2.6vh,34px) clamp(28px,5vw,72px) clamp(18px,2.6vh,34px) clamp(64px,7vw,130px);
  clip-path:polygon(40px 0, 100% 0, 100% 100%, 0 100%);
  box-shadow:-18px -18px 50px rgba(0,0,0,.3);
}
.deck-bar-br .deck-bar-title{ font-size:clamp(26px,4.4vw,64px); }
.deck-bar-br .deck-bar-view{ opacity:.6; }
/* Intro "Enter →" — centered inside the white box, larger */
.deck-bar-br.deck-bar-enter{ align-items:center; justify-content:center; text-align:center; }
.deck-bar-enter .deck-bar-title{ font-size:clamp(44px,6vw,100px); }
@media (max-width:768px){
  .deck-bar-tl{ padding:clamp(54px,8vh,74px) 32px 11px 16px; }
  .deck-bar-tl .deck-bar-title{ font-size:clamp(24px,7vw,38px); }
  .deck-bar-tl .deck-bar-view{ margin-top:5px; }
  .deck-bar-br{ padding:13px 18px 13px 46px; min-height:0; min-width:0; }
  .deck-bar-br .deck-bar-title{ font-size:clamp(22px,8vw,42px); }
  .deck-bar-enter .deck-bar-title{ font-size:clamp(26px,9vw,46px); }
  .deck-bar-tl.deck-bar-intro{ padding:clamp(46px,7vh,62px) 54px 9px 12px; }
  .deck-bar-br.deck-bar-intro{ padding:11px 16px 11px 40px; }
  .deck-bar-intro .deck-bar-label{ font-size:10px; letter-spacing:.18em; }
  .deck-bar .deck-bar-view{ font-size:9.5px; margin-top:7px; }
}
@media (max-width:768px){
  /* left progress rail tucked closer to the edge on mobile */
  .deck-rail{ left:6px !important; }
  /* final footer panel: scroll from the top + tighter so it fits the screen */
  .deck-footer-panel{ align-items:flex-start !important; padding:14px 10px !important; }
  .deck-footer-card{ padding:22px 16px !important; width:100% !important; }
}
/* soft cinematic darkening of the bottom-right corner — masks the de-logo'd
   watermark patch so it reads as intentional vignetting */
.deck-vignette{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    /* even cinematic edge darkening — frames the footage like film */
    radial-gradient(120% 120% at 50% 50%, transparent 55%, rgba(0,0,0,.30) 82%, rgba(0,0,0,.66) 100%),
    /* extra weight in the bottom-right to bury the de-logo'd corner */
    radial-gradient(58% 58% at 100% 100%, rgba(0,0,0,.55) 0%, rgba(0,0,0,.22) 40%, transparent 62%);
  box-shadow:inset 0 0 170px 28px rgba(0,0,0,.42);
}
/* Film grain ON THE VIDEO CARDS ONLY (scoped inside each panel, over the
   footage). Global .grain is disabled on the deck home so the black background
   stays clean. */
.deck-grain{
  position:absolute; top:-50%; left:-50%; width:200%; height:200%;
  z-index:2; pointer-events:none; will-change:transform;
  opacity:.6; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='2' seed='7'/><feColorMatrix values='0 0 0 0 .55 0 0 0 0 .55 0 0 0 0 .55 0 0 0 .9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  animation:grainShift .5s steps(1,end) infinite;
}
@media (prefers-reduced-motion:reduce){ .deck-grain{animation:none} }
.deck-footer-panel{
  background:
    linear-gradient(rgba(248,244,236,.2),rgba(248,244,236,.2)),
    url('assets/marble-bg.jpg') center top / cover no-repeat,
    #ECE6DA;
}
/* Footer columns sit in a cream card with dark, legible text */
.deck-footer-card{
  --fg:#1A1A1A;
  --fg-2:rgba(26,26,26,.66);
  --fg-3:rgba(26,26,26,.46);
  --line:rgba(26,26,26,.14);
  --line-2:rgba(26,26,26,.20);
  --surf:rgba(255,255,255,.6);
  color:var(--fg);
}
.deck-footer-card footer{ border-top:none!important; padding:0!important; margin-top:0!important; }

/* Brand crimson accent — used for italic/emphasis display text */
.gradient-text{
  color:var(--crimson);
  -webkit-text-fill-color:var(--crimson);
}

/* ─── Type ──────────────────────────────────────────────────────────── */
.display{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:-.04em;
  line-height:.90;
  font-optical-sizing:auto;
}
.display em{font-style:italic;font-weight:400}
.mono{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.eyebrow{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--fg-2);
}

/* ─── Layout ────────────────────────────────────────────────────────── */
.shell{
  min-height:100vh;
  position:relative;
  isolation:isolate;
  overflow-x:hidden;
}
.grain{
  position:fixed;top:-50%;left:-50%;width:200%;height:200%;
  pointer-events:none;z-index:200;will-change:transform;
  opacity:calc(.26 * var(--grain));
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 .55 0 0 0 0 .55 0 0 0 0 .55 0 0 0 .85 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  animation:grainShift .5s steps(1,end) infinite;
}
/* stylized film flicker — shift the noise each step so it shimmers like film */
@keyframes grainShift{
  0%  {transform:translate(0,0)}
  10% {transform:translate(-6%,-4%)}
  20% {transform:translate(-3%,6%)}
  30% {transform:translate(5%,-6%)}
  40% {transform:translate(-7%,3%)}
  50% {transform:translate(4%,5%)}
  60% {transform:translate(-4%,-7%)}
  70% {transform:translate(6%,4%)}
  80% {transform:translate(-5%,-3%)}
  90% {transform:translate(3%,-5%)}
  100%{transform:translate(0,0)}
}
@media (prefers-reduced-motion:reduce){ .grain{animation:none} }
/* grain off on catalog + product detail (clean shopping surfaces) */
.grain.grain-off{display:none}
.container{
  max-width:1480px;
  margin:0 auto;
  padding:0 40px;
}
@media (max-width:720px){ .container{padding:0 20px} }

/* ─── Nav + Announcement ────────────────────────────────────────────── */
.announce{
  position:relative;z-index:50;
  background:var(--bg);
  border-bottom:.5px solid var(--line);
  overflow:hidden;
  height:30px;
}
.announce-track{
  display:flex;align-items:center;
  width:max-content;            /* size to content so translateX(-50%) = exactly one copy */
  height:30px;
  animation:marquee 24s linear infinite;
  white-space:nowrap;
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--fg-2);
}
/* Two identical copies tile seamlessly: internal gap + a trailing gap (padding-right)
   so the seam between copy 1 and copy 2 matches the internal spacing. With the track
   at content width, the -50% keyframe lands copy 2 exactly where copy 1 began = infinite loop. */
.announce-copy{display:flex;align-items:center;gap:80px;padding-right:80px;flex:0 0 auto}
.announce-track svg{opacity:.6}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.announce--sale{
  background:#C9A233;
  border-bottom:.5px solid #a07a10;
}
.announce--sale .announce-track{
  color:#1a1000;
  animation-duration:26s;   /* matched to ~58px/s like the default bar (wider sale copy) */
}
.nav{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border-bottom:.5px solid var(--line);
  transition:background .3s ease;
}
.nav-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  height:64px;
  padding:0 40px;
}
@media (max-width:720px){ .nav-inner{padding:0 20px} }
.nav-links{
  display:flex;gap:34px;justify-self:start;
}
.nav-link{
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--fg-2);
  position:relative;
  padding:6px 0;
  transition:color .2s;
}
.nav-link:hover,.nav-link.active{color:var(--fg)}
.nav-link.active::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;
  height:1px;background:var(--fg);
}
.brand{
  font-family:'GFS Didot','Bodoni Moda',serif;
  font-weight:400;
  font-size:22px;
  letter-spacing:.12em;
  display:flex;align-items:center;gap:10px;
}
.wordmark{
  font-family:'GFS Didot','Bodoni Moda',serif;
  font-weight:400;
  letter-spacing:.06em;
}
.wordmark em,.wordmark i,
.wordmark [style*="italic"]{
  font-family:'GFS Didot','Bodoni Moda',serif;
  font-style:italic;
}
.brand-mark{
  width:24px;height:24px;border-radius:50%;
  background:radial-gradient(circle at 32% 28%,#e6e6e8,#3a3a3c 55%,#050505 100%);
  box-shadow:inset 0 0 0 .5px rgba(255,255,255,.35),0 0 18px rgba(255,255,255,.10);
}
body.light .brand-mark{
  background:radial-gradient(circle at 32% 28%,#fafafa,#9a9a9c 55%,#0a0a0a 100%);
  box-shadow:inset 0 0 0 .5px rgba(0,0,0,.25),0 0 18px rgba(0,0,0,.06);
}
.nav-actions{
  display:flex;gap:22px;justify-self:end;align-items:center;
}
.icon-btn{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--fg);position:relative;
}
.icon-btn{transition:opacity .2s}
.icon-btn:hover{opacity:.6}
.cart-count{
  position:absolute;top:6px;right:4px;
  min-width:14px;height:14px;padding:0 3px;
  background:var(--fg);color:var(--bg);
  border-radius:999px;
  font-family:var(--font-mono);font-size:9px;font-weight:600;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:0;
}

/* ─── Buttons ───────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 30px;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  border:.5px solid var(--fg);
  background:var(--fg);color:var(--bg);
  transition:transform .25s cubic-bezier(.3,.7,.4,1),background .25s,color .25s,filter .25s;
  cursor:pointer;
  position:relative;overflow:hidden;
}
.btn:hover{background:transparent;color:var(--fg);border-color:var(--fg)}
.btn.ghost{background:transparent;color:var(--fg);border-color:var(--line-2)}
.btn.ghost:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.btn.sm{padding:12px 20px;font-size:10px}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* ─── Editorial image placeholder ───────────────────────────────────── */
.ed{
  position:relative;
  width:100%;
  background:#0d0a0b;
  overflow:hidden;
  isolation:isolate;
}
body.light .ed{background:#dcd5c9}
.ed::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,
    rgba(255,255,255,.018) 0 2px,
    transparent 2px 5px);
  z-index:0;
}
.ed::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' seed='5'/><feColorMatrix values='0 0 0 0 .6 0 0 0 0 .6 0 0 0 0 .6 0 0 0 .55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
  opacity:.55;
  z-index:1;
}
.ed-glow{
  position:absolute;inset:0;z-index:0;
  background:radial-gradient(60% 70% at var(--glow-x,50%) var(--glow-y,40%),
    rgba(255,200,180,.18),
    rgba(255,80,120,.06) 35%,
    transparent 70%);
}
body.light .ed-glow{
  background:radial-gradient(60% 70% at var(--glow-x,50%) var(--glow-y,40%),
    rgba(255,255,255,.45),
    rgba(180,160,140,.12) 35%,
    transparent 70%);
}
.ed-label{
  position:absolute;
  font-family:var(--font-mono);font-size:9.5px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--fg-2);
  z-index:3;
  display:flex;align-items:center;gap:8px;
}
.ed-label.tl{top:14px;left:14px}
.ed-label.tr{top:14px;right:14px}
.ed-label.bl{bottom:14px;left:14px}
.ed-label.br{bottom:14px;right:14px}
.ed-mark{
  position:absolute;width:10px;height:10px;z-index:3;
  border-color:var(--fg-3);
}
.ed-mark.tl{top:8px;left:8px;border-top:.5px solid;border-left:.5px solid}
.ed-mark.tr{top:8px;right:8px;border-top:.5px solid;border-right:.5px solid}
.ed-mark.bl{bottom:8px;left:8px;border-bottom:.5px solid;border-left:.5px solid}
.ed-mark.br{bottom:8px;right:8px;border-bottom:.5px solid;border-right:.5px solid}

/* hover lift on product cards */
.card{
  position:relative;
  cursor:pointer;
  transition:transform .5s cubic-bezier(.2,.7,.3,1);
}
.card:hover{transform:translateY(-6px)}
.card .ed{transition:filter .4s}
.card:hover .ed{filter:saturate(1.1) brightness(1.05)}
.card .meta{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 0 0;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.06em;
}
.card .name{color:var(--fg);font-weight:500;text-transform:uppercase;letter-spacing:.14em}
.card .price{color:var(--fg-2)}
.card .status{
  font-family:var(--font-mono);font-size:9.5px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--fg-3);padding-top:4px;
}
.card .status.soldout{color:var(--fg);font-style:italic;font-family:var(--font-display);font-size:13px;letter-spacing:.02em;text-transform:none;opacity:.85}

/* divider */
.rule{height:.5px;background:var(--line);width:100%}

/* fade-up on scroll */
.fade-up{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.7,.3,1),transform 1s cubic-bezier(.2,.7,.3,1);
}
.fade-up.in{opacity:1;transform:none}

/* particles container — used only on hero */
.particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.particle{
  position:absolute;
  width:2px;height:2px;border-radius:50%;
  background:var(--fg);
  opacity:0;
  animation:rise var(--dur,18s) linear infinite;
  animation-delay:var(--delay,0s);
  filter:blur(.3px);
}
@keyframes rise{
  0%   {transform:translateY(20px) translateX(0);opacity:0}
  10%  {opacity:.5}
  90%  {opacity:.5}
  100% {transform:translateY(-120vh) translateX(var(--dx,30px));opacity:0}
}

/* scroll cue */
.scroll-cue{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:1px;height:60px;overflow:hidden;
  background:var(--line-2);
}
.scroll-cue::after{
  content:'';position:absolute;left:0;right:0;top:-60px;height:30px;
  background:var(--fg);
  animation:trickle 2.4s cubic-bezier(.6,.0,.4,1) infinite;
}
@keyframes trickle{
  0%   {top:-30px}
  100% {top:60px}
}

/* drawer + modal */
.scrim{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.scrim.on{opacity:1;pointer-events:auto}

.drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:310;
  width:460px;max-width:100vw;
  background:var(--bg);
  border-left:.5px solid var(--line-2);
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.4,.0,.2,1);
  display:flex;flex-direction:column;
}
.drawer.on{transform:none}
.drawer-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 28px;border-bottom:.5px solid var(--line);
}
.drawer-body{flex:1;overflow-y:auto;padding:0 28px}
.drawer-foot{padding:24px 28px;border-top:.5px solid var(--line)}

.modal{
  position:fixed;inset:0;z-index:320;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
  padding:24px;
}
.modal.on{opacity:1;pointer-events:auto}
.modal-card{
  background:var(--bg);
  border:.5px solid var(--line-2);
  width:580px;max-width:100%;
  padding:48px 48px 40px;
  position:relative;
  transform:translateY(12px);
  transition:transform .4s cubic-bezier(.4,.0,.2,1);
}
.modal.on .modal-card{transform:none}
.close-x{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  color:var(--fg-2);
}
.close-x:hover{color:var(--fg)}

/* form */
.field{
  display:flex;align-items:center;gap:0;
  border:.5px solid var(--line-2);
}
.field input{
  flex:1;height:54px;padding:0 18px;
  background:transparent;border:0;outline:none;
  color:var(--fg);
  font-family:var(--font-body);font-size:13px;
}
.field input::placeholder{color:var(--fg-3)}
.field button{
  height:54px;padding:0 24px;
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.22em;text-transform:uppercase;
  background:var(--fg);color:var(--bg);
  transition:background .2s,color .2s;
}
.field button:hover{background:transparent;color:var(--fg);box-shadow:inset 0 0 0 .5px var(--fg)}

/* Editorial image-slot integration — slots layer over our gradient placeholder.
   The dropped image takes over visually; the empty-state hint shows a subtle
   plus icon on hover so the user knows the frame is fillable. */
.ed image-slot{
  position:absolute;inset:0;width:100%;height:100%;
  display:block;z-index:5;
}
.ed image-slot::part(frame){background:transparent}
.ed image-slot::part(ring){
  border:.5px dashed rgba(250,250,250,.18);
  transition:border-color .25s,border-style .25s;
}
.ed:hover image-slot:not([data-filled])::part(ring){
  border-color:rgba(250,250,250,.55);
}
body.light .ed image-slot::part(ring){border-color:rgba(10,10,10,.2)}
body.light .ed:hover image-slot:not([data-filled])::part(ring){border-color:rgba(10,10,10,.6)}
.ed image-slot::part(empty){
  opacity:0;transition:opacity .25s;
  background:rgba(0,0,0,.65);color:#fafafa;
  font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;
  font-size:10px;
}
.ed:hover image-slot:not([data-filled])::part(empty){opacity:1}
.ed:has(image-slot[data-filled]) .ed-glow{display:none}
.ed:has(image-slot[data-filled]) .ed-label,
.ed:has(image-slot[data-filled]) .ed-mark{opacity:0;transition:opacity .3s}
.ed:has(image-slot[data-filled]):hover .ed-label.tl,
.ed:has(image-slot[data-filled]):hover .ed-label.br{opacity:.85}

/* Drop-zone teaching banner — small fixed corner badge */
.dropzone-help{
  position:fixed;bottom:24px;left:24px;z-index:80;
  background:rgba(20,20,20,.92);
  border:.5px solid rgba(250,250,250,.22);
  color:#fafafa;
  padding:14px 18px 14px 16px;
  display:flex;align-items:center;gap:12px;
  max-width:340px;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.06em;text-transform:none;
  line-height:1.5;
  animation:dzIn .5s cubic-bezier(.2,.7,.3,1) .8s both;
}
body.light .dropzone-help{background:rgba(244,241,236,.95);color:#0a0a0a;border-color:rgba(10,10,10,.2)}
.dropzone-help svg{flex-shrink:0}
.dropzone-help b{font-weight:500;letter-spacing:.14em;text-transform:uppercase;font-size:9.5px;display:block;margin-bottom:4px;color:var(--fg-2)}
.dropzone-help button{
  position:absolute;top:6px;right:6px;
  width:18px;height:18px;color:var(--fg-3);
  display:flex;align-items:center;justify-content:center;
}
.dropzone-help button:hover{color:var(--fg)}
@keyframes dzIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ─── WhatsApp float button ──────────────────────────────────────────── */
.wa-btn{
  position:fixed;left:calc(50% + 7px);right:auto;bottom:36px;z-index:280;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 24px rgba(37,211,102,.45),0 1px 6px rgba(0,0,0,.25);
  transition:transform .25s cubic-bezier(.3,.7,.4,1),box-shadow .25s;
  cursor:pointer;text-decoration:none;
}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,.6)}
.wa-btn svg{width:28px;height:28px;fill:#fff}
.wa-tooltip{
  position:absolute;right:66px;top:50%;transform:translateY(-50%);
  background:var(--bg);color:var(--fg);
  border:.5px solid var(--line);
  padding:7px 12px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.wa-btn:hover .wa-tooltip{opacity:1}

/* ─── Mobile nav hamburger ───────────────────────────────────────────── */
.nav-hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;color:var(--fg)}

/* ─── Mobile full-screen menu ───────────────────────────────────────── */
.mobile-menu{
  position:fixed;top:64px;left:0;right:0;bottom:0;z-index:98;
  background:var(--bg);overflow-y:auto;
  display:flex;flex-direction:column;
  animation:mobileIn .28s cubic-bezier(.4,0,.2,1);
}
@keyframes mobileIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mobile-nav-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:.5px solid var(--line);
  font-family:var(--font-display);font-size:38px;font-weight:400;line-height:1;
  color:var(--fg);cursor:pointer;
}
.mobile-nav-link em{font-style:italic}
.mobile-nav-link:hover{color:var(--fg-2)}
.mobile-nav-link span.arrow{font-family:var(--font-body);font-size:20px;color:var(--fg-3)}
.mobile-menu-foot{
  margin-top:auto;padding:28px 24px;
  border-top:.5px solid var(--line);
  display:flex;flex-direction:column;gap:16px;
}

/* ─── Prevent any child from stretching past the viewport ───────────── */
/* Grid children default to min-width:auto which lets them overflow.    */
.email-capture-grid>*,.featured-grid>*,.footer-links-grid>*,
.product-detail-grid>*,.search-results-grid>*,.about-story-grid>*,
.contact-form-grid>*,.contact-blocks-grid>*,.recently-viewed-grid>*,
.hero-split-grid>*{min-width:0}

/* ─── Responsive breakpoints ─────────────────────────────────────────── */
@media(max-width:768px){
  /* Nav */
  .nav-links{display:none!important}
  .nav-hamburger{display:flex!important}
  .nav-inner{grid-template-columns:auto 1fr auto;padding:0 20px}
  .brand{font-size:16px;letter-spacing:.08em;gap:7px}
  .brand>img{width:28px!important;height:28px!important}
  /* Hide currency & account on mobile — keep search + cart */
  .nav-hide-mobile{display:none!important}

  /* Drawer full-width */
  .drawer{width:100vw}
  .drawer-body{padding:0 20px}
  .drawer-head{padding:18px 20px}
  .drawer-foot{padding:20px}

  /* Modal full-screen */
  .modal{padding:0;align-items:flex-start}
  .modal-card{width:100%!important;max-width:100%!important;min-height:100svh;
    border:none;padding:24px 20px!important}

  /* Product detail — stack image above buy column */
  .product-detail-grid{grid-template-columns:1fr!important;gap:24px!important}
  .product-buy-sticky{position:static!important;top:auto!important}

  /* Hero split — single column, hide product image */
  .hero-split-grid{grid-template-columns:1fr!important;gap:0!important}
  .hero-split-img{display:none!important}

  /* Email capture — stack vertically */
  .email-capture-grid{grid-template-columns:1fr!important;gap:40px!important}

  /* Featured grid — 2 cols */
  .featured-grid{grid-template-columns:1fr 1fr!important;gap:16px!important}

  /* Collection filter bar — horizontal scroll */
  .collection-filter-bar{height:auto!important;padding:12px 0!important;flex-wrap:nowrap!important;overflow-x:auto}

  /* WhatsApp button */
  .wa-btn{left:auto;right:10px;bottom:40px;width:50px;height:50px}
  .wa-btn svg{width:24px;height:24px}
  .wa-tooltip{display:none}

  /* Buttons */
  .btn{padding:16px 20px}

  /* Search results — 2 cols */
  .search-results-grid{grid-template-columns:1fr 1fr!important}

  /* Footer masthead — wrap logo + wordmark on narrow screens */
  .footer-masthead{flex-wrap:wrap!important;gap:16px!important;margin-bottom:48px!important}
  .footer-masthead>img{width:clamp(60px,16vw,110px)!important}
  .wordmark{font-size:clamp(36px,11vw,64px)!important}

  /* Home page section grids — stack to 1 column */
  .bespoke-grid{grid-template-columns:1fr!important;gap:48px!important}
  .home-about-grid{grid-template-columns:1fr!important;gap:40px!important}
  .reviews-quote-grid{grid-template-columns:1fr!important;gap:32px!important}
  .product-story-grid{grid-template-columns:1fr!important;gap:32px!important}

  /* Footer — stack vertically */
  .footer-links-grid{grid-template-columns:1fr 1fr!important;gap:32px!important}

  /* Collection filter bar */
  .collection-filter-bar{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Sticky bar full width */
  .sticky-atc-bar{left:0!important;right:0!important;border-radius:0!important}

  /* About page grids */
  .about-story-grid{grid-template-columns:1fr!important;gap:40px!important}
  .about-story-sticky{position:static!important}
  .about-values-grid{grid-template-columns:1fr 1fr!important}

  /* Contact page grids */
  .contact-blocks-grid{grid-template-columns:1fr!important}
  .contact-form-grid{grid-template-columns:1fr!important;gap:40px!important}
  .contact-social-grid{grid-template-columns:1fr 1fr!important}

  /* Recently viewed */
  .recently-viewed-grid{grid-template-columns:1fr 1fr!important}
}

/* ─── Light mode: force readable text inside dark hero photo ─────────── */
body.light .hero-section{
  --fg:#FAFAFA;
  --fg-2:rgba(250,250,250,.72);
  --fg-3:rgba(250,250,250,.42);
  --line:rgba(250,250,250,.12);
  --line-2:rgba(250,250,250,.22);
}
/* Increase overlay opacity in light mode so text stays readable */
body.light .hero-bg-overlay{
  background:
    radial-gradient(ellipse 58% 56% at 50% 46%,rgba(0,0,0,.28) 0%,rgba(0,0,0,.88) 100%),
    linear-gradient(180deg,rgba(0,0,0,.40) 0%,rgba(0,0,0,.72) 100%)!important;
}

@media(max-width:480px){
  .brand{font-size:14px;gap:5px}
  .brand>img{width:22px!important;height:22px!important}
  .mobile-nav-link{font-size:30px;padding:18px 20px}
  .featured-grid{grid-template-columns:1fr!important}
}

/* utility for marquees inside hero */
.float-y{animation:floaty 9s ease-in-out infinite}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%   {transform:translateY(-14px)}
}

/* ─── Filter bottom-sheet animations ────────────────────────────────── */
@keyframes sheetUp{
  from{transform:translateY(100%)}
  to{transform:translateY(0)}
}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}

/* ─── Bespoke overlay ───────────────────────────────────────────────── */
.bespoke-overlay{
  position:fixed;inset:0;z-index:350;
  background:var(--bg);
  overflow-y:auto;
  display:flex;flex-direction:column;
  animation:commIn .3s ease;
}
.bespoke-head{
  position:sticky;top:0;z-index:5;
  background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(20px);
  border-bottom:.5px solid var(--line);
}
.bespoke-head-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;gap:16px;
}
.bespoke-context{border-top:.5px solid var(--line-2);background:color-mix(in srgb,var(--fg) 3%,transparent)}
.bespoke-context-inner{
  display:flex;align-items:center;gap:14px;height:52px;flex-wrap:wrap;overflow:hidden;
}

/* Step pills */
.bespoke-pills{
  display:flex;gap:4px;align-items:center;overflow-x:auto;scrollbar-width:none;flex:1;justify-content:center;
}
.bespoke-pills::-webkit-scrollbar{display:none}
.bespoke-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;
  border:.5px solid var(--line-2);
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:.10em;text-transform:uppercase;
  color:var(--fg-3);white-space:nowrap;
  transition:all .2s;
}
.bespoke-pill.active{border-color:var(--fg);color:var(--fg);background:color-mix(in srgb,var(--fg) 6%,transparent)}
.bespoke-pill.done{color:var(--fg-2)}
.bespoke-pill-num{font-size:9px}
.bespoke-pill-label{display:none}
@media(min-width:560px){.bespoke-pill-label{display:inline}}

/* Body + step */
.bespoke-body{flex:1;padding:60px 0 140px}
.bespoke-step{max-width:1100px;margin:0 auto;padding:20px 40px}
@media(max-width:720px){.bespoke-step{padding:20px}}

/* Product selection grid (Step 1) */
.bespoke-product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
  gap:10px;
}
.bespoke-product-card{
  background:transparent;border:.5px solid var(--line-2);
  cursor:pointer;text-align:left;padding:0;
  transition:border-color .2s;
}
.bespoke-product-card:hover{border-color:var(--fg-2)}
.bespoke-product-card.on{border-color:var(--fg)}
.bespoke-product-img{
  aspect-ratio:3/4;overflow:hidden;
  background:var(--surface);position:relative;
  display:flex;align-items:center;justify-content:center;
}
.bespoke-product-label{
  padding:8px 8px 8px;
  font-family:var(--font-mono);font-size:9px;
  letter-spacing:.10em;text-transform:uppercase;
  color:var(--fg-2);line-height:1.4;
}
.bespoke-product-card.on .bespoke-product-label{color:var(--fg)}

/* ─── Commission wizard ─────────────────────────────────────────────── */
.commission-overlay{
  position:fixed;inset:0;z-index:340;
  background:var(--bg);
  display:flex;flex-direction:column;
  overflow-y:auto;
  animation:cwIn .35s cubic-bezier(.2,.7,.3,1);
}
@keyframes cwIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:none}
}
.commission-head{
  position:sticky;top:0;z-index:5;
  background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:.5px solid var(--line);
}
.commission-head-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;gap:24px;
}
.commission-back,.commission-close{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--fg-2);
  transition:color .2s;
}
.commission-back:hover,.commission-close:hover{color:var(--fg)}
.commission-progress{
  display:flex;gap:6px;align-items:center;
}
.commission-progress span{
  height:2px;background:var(--line-2);
  transition:width .3s,background .3s;
  display:block;
}

.commission-body{flex:1;padding:60px 0 120px}
.commission-step{max-width:1100px;margin:0 auto;padding:20px 40px}
@media (max-width:720px){.commission-step{padding:20px}}

.commission-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
}
.commission-card{
  text-align:left;
  padding:24px 22px;
  border:.5px solid var(--line-2);
  background:transparent;color:var(--fg);
  cursor:pointer;
  transition:border-color .2s,background .2s,transform .2s;
}
.commission-card:hover{border-color:var(--fg-2)}
.commission-card.on{
  border-color:var(--fg);
  background:color-mix(in srgb,var(--fg) 4%,transparent);
}
.commission-card-name{
  font-size:24px;line-height:1.05;margin-bottom:8px;
  font-style:normal;
}
.commission-card-name em{font-style:italic}
.commission-card-sub{
  color:var(--fg-3);font-size:10.5px;
  letter-spacing:.06em;text-transform:none;
  line-height:1.5;
}

.commission-finishes{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;
}
.commission-finish{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  border:.5px solid var(--line-2);
  background:transparent;color:var(--fg);
  cursor:pointer;
  transition:border-color .2s,background .2s;
  text-align:left;
}
.commission-finish:hover{border-color:var(--fg-2)}
.commission-finish.on{
  border-color:var(--fg);
  background:color-mix(in srgb,var(--fg) 4%,transparent);
}
.commission-finish .display{font-size:18px}
.commission-swatch{
  width:32px;height:32px;
  border:.5px solid var(--line-2);
  flex-shrink:0;
}

.commission-detail{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:24px 0;
  border-bottom:.5px solid var(--line);
}
.commission-detail:last-child{border-bottom:0}

.commission-input,.commission-textarea{
  width:100%;
  background:transparent;
  border:.5px solid var(--line-2);
  color:var(--fg);
  font-family:var(--font-body);font-size:14px;
  padding:12px 14px;
  outline:none;
  transition:border-color .2s;
}
.commission-input{height:48px}
.commission-input:focus,.commission-textarea:focus{border-color:var(--fg)}
.commission-textarea{
  min-height:96px;resize:vertical;
  margin-top:20px;
  line-height:1.5;
  font-family:var(--font-body);
}

.commission-toggle{
  width:48px;height:28px;border-radius:999px;
  background:var(--line-2);
  position:relative;flex-shrink:0;
  transition:background .2s;
  cursor:pointer;
}
.commission-toggle.on{background:var(--fg)}
.commission-toggle span{
  position:absolute;top:3px;left:3px;
  width:22px;height:22px;border-radius:50%;
  background:var(--bg);
  transition:transform .2s;
}
.commission-toggle.on span{transform:translateX(20px)}

.commission-review{
  display:flex;flex-direction:column;
  border-top:.5px solid var(--line);
}
.commission-review-row{
  display:grid;grid-template-columns:200px 1fr;
  gap:24px;padding:18px 0;
  border-bottom:.5px solid var(--line);
}

.commission-foot{
  position:sticky;bottom:0;z-index:5;
  background:color-mix(in srgb,var(--bg) 94%,transparent);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:.5px solid var(--line);
}
.commission-foot-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;gap:24px;
}
.commission-summary{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.commission-chip{
  display:inline-flex;align-items:center;
  padding:6px 12px;
  border:.5px solid var(--line-2);
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--fg);
}
.commission-foot .btn[disabled]{pointer-events:none}

/* Custom silhouette refinement block */
.commission-custom{
  margin-top:32px;padding:28px;
  border:.5px solid var(--line-2);
  background:color-mix(in srgb,var(--fg) 2%,transparent);
}
.commission-custom-head{
  color:var(--fg-2);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:18px;
}
.commission-custom .commission-textarea{margin-top:0;min-height:120px}
.commission-custom-row{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  margin-top:20px;
}
@media (max-width:720px){.commission-custom-row{grid-template-columns:1fr}}
.commission-custom-field{display:flex;flex-direction:column}
.commission-photo-drop{
  display:flex;align-items:center;gap:14px;
  width:100%;
  padding:18px 20px;
  border:.5px dashed var(--line-2);
  background:transparent;color:var(--fg-2);
  cursor:pointer;
  transition:border-color .2s,background .2s;
  text-align:left;
}
.commission-photo-drop:hover,.commission-photo-drop.on{
  border-color:var(--fg);
  background:color-mix(in srgb,var(--fg) 5%,transparent);
  color:var(--fg);
}
.commission-photo-drop svg{flex-shrink:0;opacity:.6}
.commission-photo-drop:hover svg,.commission-photo-drop.on svg{opacity:1}
.commission-photo-filled{
  display:flex;align-items:center;gap:16px;
  padding:12px;
  border:.5px solid var(--line-2);
  background:color-mix(in srgb,var(--fg) 3%,transparent);
}
.commission-photo-filled img{
  width:64px;height:80px;object-fit:cover;
  flex-shrink:0;
}
.commission-photo-meta{
  flex:1;display:flex;flex-direction:column;gap:4px;
  font-size:12px;line-height:1.4;
  overflow:hidden;
}
.commission-photo-meta .mono{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%    {transform:translateY(-14px)}
}

/* ════════════════ PHASE 1 · MOTION SYSTEM ════════════════ */
:root{
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-spring: cubic-bezier(.16,1,.3,1);
}

/* refined scroll reveal + per-element stagger (--d set by JS) */
.fade-up{
  transition: opacity .9s var(--ease-spring), transform .9s var(--ease-spring);
  transition-delay: var(--d, 0s);
}

/* image blur-up: photos resolve in instead of popping */
img[data-fade=""]{
  opacity:0; filter:blur(10px);
  transition: opacity .9s var(--ease), filter 1.1s var(--ease);
}
img[data-fade=""].is-loaded{ opacity:1; filter:none; }

/* product card: hover image zoom (wrapper already clips) + smoother lift */
.card img{ transition: transform .9s var(--ease-spring), filter .4s var(--ease); }
.card:hover img{ transform: scale(1.05); }

/* buttons: lift, arrow nudge, press */
.btn{ transition: transform .35s var(--ease-spring), background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), box-shadow .4s var(--ease), opacity .3s var(--ease); }
.btn:hover{ transform: translateY(-2px); }
.btn:active{ transform: translateY(0) scale(.985); }
.btn .arrow{ display:inline-block; transition: transform .45s var(--ease-spring); }
.btn:hover .arrow{ transform: translateX(6px); }

/* nav links: smoother colour ease */
.nav-link{ transition: color .3s var(--ease); }

/* accessibility: honour reduced-motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; }
  .fade-up{ opacity:1!important; transform:none!important; }
  img[data-fade=""]{ opacity:1!important; filter:none!important; }
  .card:hover, .card:hover img{ transform:none!important; }
  /* announcement bar must keep scrolling continuously even under reduced-motion
     (it's informational ticker content, not decorative motion) */
  .announce-track{ animation-name:marquee!important; animation-duration:24s!important; animation-timing-function:linear!important; animation-iteration-count:infinite!important; }
  .announce--sale .announce-track{ animation-duration:26s!important; }
}

/* ════════════════ PHASE 2 · HERO + NAV ════════════════ */
/* hero background: cinematic scale + scroll parallax (--py driven by JS) */
.hero-section [style*="background-image"]{
  will-change: transform;
  transform: translate3d(0, var(--py, 0px), 0) scale(1.12);
}
/* hero wordmark entrance — rise + de-blur, staggered */
@keyframes heroRise{
  from{ opacity:0; transform:translateY(46px); filter:blur(7px); }
  to  { opacity:1; transform:none; filter:none; }
}
.hero-section h1{ animation: heroRise 1.2s var(--ease-spring) both; }
.hero-section h1 + div{ animation: heroRise 1.2s var(--ease-spring) .18s both; }
.hero-section .scroll-cue{ animation: heroCue 1s var(--ease) 1.05s both; }
@keyframes heroCue{ from{opacity:0} to{opacity:1} }

/* nav: shrink + gain presence on scroll */
.nav-inner{ transition: height .4s var(--ease); }
.nav.is-scrolled{
  background: color-mix(in srgb, var(--bg) 94%, transparent);
  box-shadow: 0 1px 0 var(--line), 0 14px 44px rgba(0,0,0,.20);
}
.nav.is-scrolled .nav-inner{ height: 54px; }

@media (prefers-reduced-motion: reduce){
  .hero-section [style*="background-image"]{ transform: scale(1.06)!important; }
  .hero-section h1, .hero-section h1 + div, .hero-section .scroll-cue{ animation:none!important; opacity:1!important; filter:none!important; }
}

/* WhatsApp + cookie badges now live ONLY inside the side menu (below Affiliate
   Portal). Hide the floating versions; keep the CookieYes button in the DOM
   off-screen so the menu badge can trigger it programmatically. */
.wa-btn{ display:none !important; }
.cky-btn-revisit-wrapper{ position:fixed !important; left:-9999px !important; right:auto !important; top:auto !important; bottom:0 !important; opacity:0 !important; pointer-events:none !important; }
.menu-badge{ width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:none; cursor:pointer; color:#fff; text-decoration:none; box-shadow:0 4px 18px rgba(0,0,0,.3); transition:transform .2s; }
.menu-badge:hover{ transform:scale(1.08); }
.menu-badge svg{ width:24px; height:24px; fill:#fff; }

/* ════════════════ PHASE 3 · PRODUCT ════════════════ */
/* gallery main image: crossfade on switch (img remounts on key) + hover zoom */
@keyframes galFade{ from{opacity:0} to{opacity:1} }
.gallery-img{ animation: galFade .5s var(--ease); transition: transform .9s var(--ease-spring); }
.gallery-img:hover{ transform: scale(1.06); }
/* thumbnails: subtle hover scale (wrapper clips) */
.gallery-thumb img{ transition: transform .5s var(--ease-spring); }
.gallery-thumb:hover img{ transform: scale(1.08); }
/* cart badge: bump when the count changes (span remounts via key) */
@keyframes cartBump{ 0%{transform:scale(1)} 35%{transform:scale(1.5)} 70%{transform:scale(.92)} 100%{transform:scale(1)} }
.cart-count{ animation: cartBump .5s var(--ease-spring); }

@media (prefers-reduced-motion: reduce){
  .gallery-img, .cart-count{ animation:none!important; }
  .gallery-img:hover, .gallery-thumb:hover img{ transform:none!important; }
}

/* ════════════════ PHASE 4 · STORY LAYER ════════════════ */
/* thin scroll-progress bar (on-brand crimson) */
#scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0; z-index:9999; pointer-events:none;
  background:linear-gradient(90deg, var(--crimson), var(--crimson-bright));
  box-shadow:0 0 14px var(--crimson);
}
/* story imagery drifts with scroll (scale overscan keeps edges covered) */
.parallax-img{ transform: translateY(var(--py,0px)) scale(1.12); will-change: transform; }

@media (prefers-reduced-motion: reduce){
  #scroll-progress{ display:none; }
  .parallax-img{ transform: scale(1.04)!important; }
}

/* ════════════════ PHASE 5 · BESPOKE + FINISH ════════════════ */
/* bespoke step transition — content slides/fades in on each step (key remount) */
@keyframes bStepIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
.bstep-anim{ animation: bStepIn .5s var(--ease-spring) both; }

/* footer masthead reveal — self-contained, degrades to fully visible if unsupported */
@supports (animation-timeline: view()){
  .footer-masthead{
    animation: mastheadIn linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 55%;
  }
  @keyframes mastheadIn{ from{ opacity:0; transform:translateY(44px); } to{ opacity:1; transform:none; } }
}

/* finishing touch: refined focus ring for keyboard users */
:focus-visible{ outline:1.5px solid color-mix(in srgb, var(--fg) 55%, transparent); outline-offset:2px; border-radius:2px; }

@media (prefers-reduced-motion: reduce){
  .bstep-anim{ animation:none!important; }
  @supports (animation-timeline: view()){ .footer-masthead{ animation:none!important; opacity:1!important; transform:none!important; } }
}

/* ─── CookieYes consent button — match WhatsApp size, sit beside it ─────── */
.cky-btn-revisit-wrapper{
  position:fixed !important;left:calc(50% - 63px) !important;right:auto !important;bottom:36px !important;
  width:56px !important;height:56px !important;z-index:280 !important;
}
.cky-btn-revisit-wrapper .cky-btn-revisit,.cky-btn-revisit{
  width:56px !important;height:56px !important;border-radius:50% !important;
  display:flex !important;align-items:center !important;justify-content:center !important;
  box-shadow:0 4px 24px rgba(0,0,0,.25),0 1px 6px rgba(0,0,0,.25) !important;margin:0 !important;
}
.cky-btn-revisit img,.cky-btn-revisit svg{width:28px !important;height:28px !important;}
@media(max-width:768px){
  .cky-btn-revisit-wrapper{left:auto !important;right:70px !important;bottom:40px !important;width:50px !important;height:50px !important;}
  .cky-btn-revisit-wrapper .cky-btn-revisit,.cky-btn-revisit{width:50px !important;height:50px !important;}
  .cky-btn-revisit img,.cky-btn-revisit svg{width:24px !important;height:24px !important;}
}

/* Deck intro wordmark sizing. DESKTOP = 2/3 of the earlier 3x size; MOBILE
   unchanged. .deck-jt !important beats the global .wordmark mobile cap. */
.deck-jt{ font-size:clamp(144px,24vw,400px) !important; }
@media (max-width:768px){ .deck-jt{ font-size:clamp(120px,34vw,220px) !important; } }
.deck-atelier{ font-size:clamp(40px,8vw,120px); }
@media (max-width:768px){ .deck-atelier{ font-size:clamp(60px,12vw,180px); } }
