/* ═══════════════════════════════════════════════════════════════
   LION FORGE — design system (v2)
   #0A0A0B near-black · #F4F2ED bone · #FF6A1A forge-amber (one accent)
   Fraunces (display) · Inter (UI). No-JS rule: content visible by default;
   JS only adds motion.
   ═══════════════════════════════════════════════════════════════ */
:root{
  --bg:#F6F6F4; --bg-2:#FFFFFF; --bg-3:#FFFFFF;               /* gallery off-white + white cards */
  --bone:#16171B; --bone-dim:#56585F; --bone-faint:#74777F;   /* primary/secondary/faint INK (dark on light) */
  --amber:#FF6A1A; --amber-ink:#BD4E0C; --amber-dim:#ff6a1a40;/* amber=fills/CTA; amber-ink=amber TEXT (AA on white) */
  --steel:#2E7E92; --steel-dim:#E1E4E9;                       /* precision accent + light build-plate grid */
  --line:#E6E7EA; --line-2:#D8DADE;
  --display:"Fraunces", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --gutter:clamp(1.25rem,5vw,4.5rem); --max:1340px;
  --space-md:clamp(3rem,7vh,5rem); --space-lg:clamp(5rem,11vh,9rem); --space-xl:clamp(7rem,16vh,12rem);
  --e-rise:cubic-bezier(.16,1,.3,1); --e-silk:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:var(--bg)}
body{font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.6;color:var(--bone);background:var(--bg);overflow-x:hidden;
  /* kill Fraunces' swashy fi/ff/fl ligatures (the odd "f" glyphs) site-wide */
  font-feature-settings:"liga" 0,"dlig" 0,"clig" 0;-webkit-font-feature-settings:"liga" 0,"dlig" 0,"clig" 0;font-variant-ligatures:none}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
em{font-style:italic}
::selection{background:var(--amber);color:#10100f}

/* focus — visible everywhere; never suppressed */
:where(a,button,input,select,textarea,[tabindex]):focus-visible{outline:2px solid var(--amber);outline-offset:2px;border-radius:2px}
.skip{position:fixed;top:8px;left:8px;z-index:200;background:var(--bone);color:#10100f;padding:.6rem 1rem;font-size:13px;transform:translateY(-150%);transition:transform .2s}
.skip:focus{transform:none}
.lf-noscroll{overflow:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-faint);margin:0 0 1.3rem;display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:16px;height:1px;background:var(--amber);flex:none}
.display{font-family:var(--display);font-weight:400;font-size:clamp(1.9rem,4vw,3rem);line-height:1.05;letter-spacing:-.01em;color:var(--bone);margin:0}
.amber{color:var(--amber)}

.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:1rem 1.9rem;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;min-height:44px;will-change:transform;transition:background .3s var(--e-silk),color .3s var(--e-silk),border-color .3s}
.btn>span{display:inline-block;will-change:transform}
.btn:active{transform:translateY(1px)}
.btn-ghost{border:1px solid #6a6862;color:var(--bone)}
.btn-ghost:hover{background:var(--bone);color:#10100f;border-color:var(--bone)}
.btn-amber{background:var(--amber);color:#160a02}
.btn-amber:hover{background:#ff7d36}
.btn.lg{padding:1.25rem 2.6rem;font-size:13px}
.btn.wide{width:100%}
.hero-link{font-size:13px;letter-spacing:.04em;color:var(--bone-dim);transition:color .25s}
.hero-link:hover{color:var(--amber)}

/* GRAIN — desktop/hover only (compositor cost) */
.grain{display:none}
@media(hover:hover) and (min-width:768px){
  .grain{display:block;position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:160px}
}

/* CUSTOM CURSOR */
.cursor-dot,.cursor-ring{display:none}
@media(hover:hover) and (pointer:fine) and (min-width:768px){
  body.cursor-on *{cursor:none!important}
  .cursor-dot{display:block;position:fixed;top:0;left:0;width:7px;height:7px;margin:-3.5px;border-radius:50%;background:var(--bone);pointer-events:none;z-index:9999;mix-blend-mode:difference}
  .cursor-ring{display:block;position:fixed;top:0;left:0;width:34px;height:34px;margin:-17px;pointer-events:none;z-index:9998;mix-blend-mode:difference}
  .cursor-ring::before{content:"";position:absolute;inset:0;border:1px solid var(--bone);border-radius:50%;transition:transform .3s var(--e-silk),border-color .3s,background .3s}
  .cursor-ring.is-link::before{transform:scale(2.3);border-color:var(--amber);background:rgba(255,106,26,.06)}
}

/* LOADER */
.loader{position:fixed;inset:0;z-index:100;background:var(--bg);display:flex;align-items:center;justify-content:center}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:1.4rem}
.loader-mark{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);font-size:1.5rem;letter-spacing:.06em;color:var(--bone)}
.loader-line{width:min(60vw,300px);height:1px;background:var(--line-2);overflow:hidden}
.loader-line i{display:block;height:100%;width:0;background:var(--amber);box-shadow:0 0 14px var(--amber)}
.loader-pct{font-size:11px;letter-spacing:.2em;color:var(--bone-faint)}
body.loaded .loader{display:none}

/* ANNOUNCE */
.announce{position:relative;z-index:60;background:var(--bg-2);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;gap:1rem;padding:.55rem var(--gutter);overflow:hidden}
.announce p{margin:0;font-size:12px;letter-spacing:.04em;color:var(--bone-dim);padding-right:2.2rem}
.announce-x{position:absolute;right:calc(var(--gutter) - .6rem);color:var(--bone-dim);font-size:1.2rem;line-height:1;padding:10px;margin:-10px}
.announce.gone{display:none}

/* NAV */
.nav{position:sticky;top:0;z-index:55;padding-top:env(safe-area-inset-top);transition:background .4s,border-color .4s}
.nav.solid{background:rgba(10,10,11,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;max-width:var(--max);margin:0 auto;padding:1.05rem var(--gutter)}
.wordmark{display:inline-flex;align-items:center;gap:.62rem;color:var(--bone);text-decoration:none}
.wm-stack{display:flex;flex-direction:column;gap:.12rem;padding-left:.62rem;border-left:1px solid var(--line-2)}
.wm-kicker{font-family:var(--mono);font-size:.58rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--amber-ink);line-height:1}
.wm-name{font-family:var(--display);font-weight:500;font-size:1.5rem;letter-spacing:.005em;line-height:.84;color:var(--bone)}
.logo-mark{width:36px;height:auto;flex:none;display:block}
.logo-mark.lg{width:44px}
.nav-rails{display:flex;align-items:center;gap:2.1rem;font-size:13px;letter-spacing:.04em}
.nav-rails a{color:var(--bone-dim);transition:color .25s}
.nav-rails a:hover{color:var(--bone)}
.nav-cart{position:relative;display:flex;align-items:center;color:var(--bone)}
.cart-count{position:absolute;top:-7px;right:-10px;min-width:16px;height:16px;padding:0 4px;background:var(--amber);color:#160a02;border-radius:9px;font-size:10px;font-weight:600;display:grid;place-items:center;line-height:1}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:10px}
.nav-burger span{width:22px;height:1.5px;background:var(--bone);transition:transform .3s,opacity .3s}
.nav-burger.x span:nth-child(1){transform:translateY(3.25px) rotate(45deg)}
.nav-burger.x span:nth-child(2){transform:translateY(-3.25px) rotate(-45deg)}
.nav-sheet{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);z-index:54;background:var(--bg-2);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .4s var(--e-silk);display:flex;flex-direction:column;gap:.4rem;padding:6rem 2rem 2rem;visibility:hidden}
.nav-sheet.open{transform:none;visibility:visible}
.nav-sheet a{font-family:var(--display);font-size:1.5rem;color:var(--bone);padding:.7rem 0;border-bottom:1px solid var(--line)}

/* HERO */
.hero{position:relative}
.stage{position:relative;height:100svh;min-height:min(600px,100svh);background:radial-gradient(120% 95% at 68% 46%,#15181e 0%,var(--bg) 64%);display:flex;align-items:center;justify-content:center;overflow:hidden}
.stage::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--steel-dim) 1px,transparent 1px),linear-gradient(90deg,var(--steel-dim) 1px,transparent 1px);background-size:46px 46px;opacity:.13;-webkit-mask:radial-gradient(110% 85% at 68% 50%,#000,transparent 72%);mask:radial-gradient(110% 85% at 68% 50%,#000,transparent 72%);pointer-events:none}
#hero3d{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity .9s ease}
#hero3d.show3d{opacity:1}
.hero3d-fallback{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(52vh,420px);max-width:82vw;transition:opacity .9s ease;will-change:opacity}
.hero3d-fallback .gem{width:100%;height:auto}
.print-edge{position:absolute;left:50%;top:0;transform:translateX(-50%);width:min(46vh,440px);height:3px;background:linear-gradient(90deg,transparent,#fff8f0 35%,#fff 50%,#fff8f0 65%,transparent);box-shadow:0 0 20px 4px rgba(255,106,26,.7),0 0 6px 1px #fff;opacity:0}
.hero-copy{position:absolute;left:0;right:0;bottom:clamp(2.5rem,8vh,5rem);z-index:3;padding:0 var(--gutter);max-width:min(94vw,720px)}
.hero-title{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,8vw,6.2rem);line-height:.98;letter-spacing:-.02em;color:var(--bone);margin:0 0 1.3rem}
.hero-sub{font-size:clamp(1rem,1.4vw,1.18rem);color:var(--bone-dim);max-width:34ch;margin:0 0 2rem}
.hero-cta{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap}
.scrollcue{position:absolute;right:var(--gutter);bottom:2rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:.6rem;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--bone-faint)}
.scrollcue span{width:1px;height:42px;background:var(--bone-faint);transform-origin:top;animation:cue 2.4s var(--e-silk) infinite}
@keyframes cue{0%{transform:scaleY(0)}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

.js .reveal-line{opacity:0;transform:translateY(22px)}

/* MANIFESTO */
.manifesto{max-width:1100px;margin:0 auto;padding:var(--space-xl) var(--gutter)}
.manifesto-head{font-family:var(--display);font-weight:300;font-size:clamp(1.8rem,4.2vw,3.4rem);line-height:1.18;letter-spacing:-.01em;color:var(--bone);margin:0;max-width:24ch}
.manifesto-head span{display:block;overflow:hidden}
.manifesto-head em{font-style:normal;color:var(--amber)}
.js .manifesto-head [data-wipe]{clip-path:inset(0 100% 0 0)}

/* FLAGSHIP */
.flagship{position:relative;min-height:min(640px,100svh);display:flex;align-items:flex-end;background:radial-gradient(90% 80% at 58% 42%,#121419,#08090b 72%);overflow:hidden}
.flagship-stage{position:absolute;inset:0;display:grid;place-items:center}
.flagship-stage::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--steel-dim) 1px,transparent 1px),linear-gradient(90deg,var(--steel-dim) 1px,transparent 1px);background-size:44px 44px;opacity:.1;-webkit-mask:radial-gradient(66% 66% at 50% 44%,#000,transparent 76%);mask:radial-gradient(66% 66% at 50% 44%,#000,transparent 76%)}
.flagship-viz{position:relative;width:min(38vh,320px);height:min(56vh,460px);margin-top:-3rem;filter:drop-shadow(20px 18px 34px rgba(0,0,0,.5))}
.flagship-viz .pv{position:absolute;inset:0;width:100%;height:100%}
.flag-hud{position:absolute;z-index:3;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--bone-faint);text-transform:uppercase;display:flex;align-items:center;gap:.5rem}
.flag-hud-tl{top:clamp(5rem,13vh,8rem);left:var(--gutter);color:var(--amber)}
.flag-hud-tl .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);animation:pvpulse 1.6s ease-in-out infinite}
.flag-hud-br{top:clamp(5rem,13vh,8rem);right:var(--gutter);max-width:54vw;text-align:right}
.flag-blurb{color:var(--bone-dim);max-width:42ch;margin:1.1rem 0 0;font-size:1rem}
.flagship-copy{position:relative;z-index:2;padding:0 var(--gutter) clamp(3rem,9vh,6rem);display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;width:100%;max-width:var(--max);margin:0 auto;flex-wrap:wrap}
.flagship-copy h2{font-family:var(--display);font-weight:400;font-size:clamp(2.2rem,5.5vw,4.4rem);line-height:1;letter-spacing:-.02em;margin:0;color:var(--bone)}
.flagship-copy h2 span{display:inline-block}
.flagship-eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin:0 0 .6rem}

/* COLOR RANGE */
.colors{max-width:var(--max);margin:0 auto;padding:var(--space-lg) var(--gutter);border-top:1px solid var(--line)}
.colors-inner{max-width:920px}
.colors .display{max-width:20ch;margin:.6rem 0 0}
.swatches{list-style:none;padding:0;margin:2.4rem 0 1.4rem;display:flex;flex-wrap:wrap;gap:1.3rem 1.8rem}
.swatches li{display:flex;align-items:center;gap:.6rem;font-size:13px;color:var(--bone-dim)}
.swatches li span{width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,255,255,.12);flex:none;box-shadow:0 4px 10px rgba(0,0,0,.4)}
.colors-note{font-size:13px;color:var(--bone-faint);margin:0}

/* PROCESS */
.process{padding:var(--space-lg) 0;background:var(--bg)}
.process-head{max-width:var(--max);margin:0 auto;padding:0 var(--gutter) clamp(2rem,4vh,3rem)}
.process-head .display{max-width:16ch}
.proc-progress{display:flex;align-items:center;gap:1rem;margin-top:1.5rem}
.proc-counter{font-family:var(--display);font-style:italic;color:var(--amber);font-size:1rem}
.proc-rail{flex:1;max-width:260px;height:1px;background:var(--line-2);overflow:hidden}
.proc-rail i{display:block;height:100%;width:0;background:var(--amber)}
.process-viewport{overflow:hidden}
.process-track{display:flex;gap:clamp(1rem,2vw,1.8rem);padding:0 var(--gutter);will-change:transform}
.proc-card{position:relative;flex:0 0 auto;width:min(78vw,440px);background:var(--bg-3);border:1px solid var(--line)}
.proc-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:radial-gradient(120% 120% at 50% 30%,#16191f,#0c0d10)}
.proc-img::before{content:attr(data-ph);position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.36em;text-transform:uppercase;color:#37373b}
.js .proc-img::before{display:none}
.proc-img .pv{position:absolute;inset:0;width:100%;height:100%}
.pv-out{fill:none;stroke:var(--steel);stroke-width:1.5;stroke-opacity:.6;vector-effect:non-scaling-stroke}
.pv-facets line{stroke:var(--steel);stroke-width:.7;stroke-opacity:.3}
.pv-slices line{stroke:var(--steel);stroke-width:.8;stroke-opacity:.22}
.pv-modeled .pv-slices{display:none}
.pv-fill{fill:var(--bone);opacity:.88}
.pv-printed .pv-slices line,.pv-finished .pv-slices line{stroke:#0b0c0e;stroke-opacity:.3}
.pv-edge{stroke:var(--amber);stroke-width:2.4;filter:drop-shadow(0 0 5px var(--amber));animation:pvpulse 1.8s ease-in-out infinite}
@keyframes pvpulse{0%,100%{opacity:.65}50%{opacity:1}}
.pv-finished .pv-out{stroke:var(--bone);stroke-opacity:.4}
.pv-finished .pv-fill{opacity:.94}
.proc-cap{padding:1.5rem 1.6rem 1.8rem}
.proc-cap span{font-family:var(--display);font-style:italic;color:var(--amber);font-size:.95rem}
.proc-cap h3{font-family:var(--display);font-weight:500;font-size:1.5rem;margin:.3rem 0 .6rem;color:var(--bone)}
.proc-cap p{margin:0;font-size:.95rem;color:var(--bone-dim);max-width:34ch}

/* MARQUEE */
/* capability strip = a clean printer-readout ribbon (mono), not giant outline text */
.marquee-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:.95rem 0;background:var(--bg-2);position:relative}
.marquee-band::before{content:"";position:absolute;left:0;top:0;bottom:0;width:38px;background:linear-gradient(90deg,var(--bg-2),transparent);z-index:2}
.marquee-band::after{content:"";position:absolute;right:0;top:0;bottom:0;width:38px;background:linear-gradient(270deg,var(--bg-2),transparent);z-index:2}
.mq{overflow:hidden}
.mq+.mq{margin-top:.5rem}
.mq-track{display:flex;align-items:center;gap:1.4rem;white-space:nowrap;width:max-content;will-change:transform}
.mq-track span{font-family:var(--mono);font-weight:400;font-size:13px;color:var(--bone-dim);letter-spacing:.14em;text-transform:uppercase}
.mq-track b{color:var(--steel);font-size:11px}

/* SHOP */
.shop{max-width:var(--max);margin:0 auto;padding:var(--space-lg) var(--gutter)}
.shop-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:3rem}
.shop-filters{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{padding:.5rem 1rem;min-height:38px;border:1px solid var(--line-2);border-radius:40px;font-size:12px;letter-spacing:.04em;color:var(--bone-dim);transition:all .25s}
.chip.is-on,.chip:hover{background:var(--bone);color:#10100f;border-color:var(--bone)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.8rem)}
.card{background:var(--bg-3);border:1px solid var(--line);will-change:transform,opacity}
.card a{display:block}
.card-img{position:relative;aspect-ratio:1;overflow:hidden;background:linear-gradient(140deg,#1c1c20,#0e0e10)}
.specimen{position:absolute;inset:0;display:grid;place-items:center;transition:transform .6s var(--e-silk),filter .6s}
.card:hover .specimen{transform:translateY(-6px) rotate(1.2deg);filter:brightness(1.12)}
.spec-shape{width:46%;height:56%;border-radius:46% 46% 42% 42%/52% 52% 40% 40%;background:linear-gradient(100deg,#d9d6cd,#75736d 60%,#36352f);box-shadow:0 18px 40px rgba(0,0,0,.5);position:relative;overflow:hidden}
.spec-shape::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.14) 0 1px,transparent 1px 6px)}
.specimen-pet .spec-shape{border-radius:50%;width:52%;height:48%}
.specimen-desk .spec-shape{border-radius:8px;width:54%;height:40%}
.specimen-home .spec-shape{border-radius:6px 6px 2px 2px;width:40%;height:60%}
.card-tag{position:absolute;top:.7rem;left:.7rem;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-dim);background:rgba(10,10,11,.6);padding:.25rem .5rem;border:1px solid var(--line)}
.card-body{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:1.1rem 1.2rem 1.3rem}
.card-name{font-family:var(--display);font-weight:500;font-size:1.15rem;color:var(--bone);margin:0}
.card-price{font-size:1.02rem;color:var(--bone);white-space:nowrap}

/* DETAIL BREAK */
.detail-break{position:relative;height:74vh;min-height:420px;overflow:hidden;background:#0c0c0e}
.db-layer{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}
.db-layer::before{content:attr(data-ph);position:absolute;inset:0;display:grid;place-items:center;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:#2c2c30}
.db-bg{background:repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0 1px,transparent 1px 8px),radial-gradient(circle at 30% 40%,#1c1c20,#0c0c0e)}
.db-fg{background:radial-gradient(circle at 62% 74%,rgba(255,106,26,.07),transparent 52%)}

/* QUOTE */
.quote{max-width:var(--max);margin:0 auto;padding:var(--space-lg) var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.quote-copy .display{margin:0 0 1.2rem;max-width:14ch}
.quote-lede{color:var(--bone-dim);max-width:42ch;margin:0 0 1.6rem}
.quote-lede strong{color:var(--bone);font-weight:500}
.quote-facts{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.quote-facts li{font-size:13px;color:var(--bone-dim);padding-left:1.2rem;position:relative}
.quote-facts li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;background:var(--amber)}
.quote-form{background:var(--bg-3);border:1px solid var(--line);padding:1.6rem;display:flex;flex-direction:column;gap:1rem}
.dropzone{position:relative;display:grid;place-items:center;min-height:120px;border:1.5px dashed var(--line-2);cursor:pointer;text-align:center;transition:border-color .3s,background .3s}
.dropzone.idle{animation:dzpulse 2.4s ease-in-out infinite}
.dropzone.over,.dropzone.staged{border-style:solid;border-color:var(--amber)}
@keyframes dzpulse{0%,100%{border-color:var(--line-2)}50%{border-color:var(--amber-dim)}}
.dz-text{font-size:13px;color:var(--bone-dim);line-height:1.5}
.dz-text i{color:var(--bone-faint);font-size:12px}
.dz-staged{font-size:13px;color:var(--amber)}
.dz-staged.err{color:#ff8a6a}
.quote-form label{display:flex;flex-direction:column;gap:.4rem;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-faint)}
.qf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.quote-form input,.quote-form select{border:none;border-bottom:1px solid var(--line-2);background:transparent;padding:.6rem 0;font:inherit;font-size:15px;letter-spacing:normal;text-transform:none;color:var(--bone);border-radius:0;transition:border-color .25s}
.quote-form input::placeholder{color:var(--bone-faint)}
.quote-form input:focus,.quote-form select:focus{border-color:var(--amber);outline:none}
.quote-form select option{background:var(--bg-3)}
.form-ok{font-size:15px;color:var(--amber);margin:0;padding:1rem 0}

/* PROOF (honest) */
.proof{max-width:780px;margin:0 auto;padding:var(--space-md) var(--gutter);text-align:center;border-top:1px solid var(--line)}
.proof-line{font-family:var(--display);font-weight:300;font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.3;color:var(--bone);margin:0 0 .8rem}
.proof-sub{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-faint);margin:0}

/* FINAL */
.final{position:relative;text-align:center;padding:var(--space-xl) var(--gutter);overflow:hidden}
.final-head{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,8vw,5.6rem);line-height:1;letter-spacing:-.02em;margin:0 0 2.2rem;color:var(--bone)}
.final-head span{display:inline-block}
.final-cta{display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.final-note{margin:2rem 0 0;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint)}
.final-edge{position:absolute;left:50%;bottom:14%;transform:translateX(-50%);width:0;height:2px;background:linear-gradient(90deg,transparent,var(--amber),transparent);box-shadow:0 0 18px var(--amber)}

/* FOOTER */
.foot{background:var(--bg-2);border-top:1px solid var(--line);padding:clamp(3.5rem,7vh,5.5rem) var(--gutter) 2rem}
.foot-top{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.3fr 2fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--line)}
.foot-brand .wordmark{margin:0 0 .5rem}
.foot-brand .wm-name{font-size:1.75rem}
.foot-tag{font-size:13px;color:var(--bone-dim);margin:0 0 1.4rem;max-width:30ch}
.foot-mail{display:flex;border:1px solid var(--line-2);max-width:320px}
.foot-mail input{flex:1;background:transparent;border:none;outline:none;padding:.7rem .9rem;font:inherit;font-size:14px;color:var(--bone)}
.foot-mail input::placeholder{color:var(--bone-faint)}
.foot-mail button{padding:0 1.1rem;background:var(--bg-3);color:var(--bone);border-left:1px solid var(--line-2);font-size:1.1rem}
.foot-mail button:hover{color:var(--amber)}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.foot-cols h3{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint);margin:0 0 1rem;font-weight:500}
.foot-cols a{display:block;font-size:14px;color:var(--bone-dim);padding:.3rem 0;transition:color .2s}
.foot-cols a:hover{color:var(--amber)}
.foot-bottom{max-width:var(--max);margin:2rem auto 0;display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1.5rem}
.pay{display:flex;gap:.4rem;flex-wrap:wrap}
.pay-pill{font-size:9px;font-weight:600;letter-spacing:.06em;color:var(--bone-dim);border:1px solid var(--line-2);padding:.3rem .5rem;border-radius:3px;background:var(--bg-3)}
.foot-legal{flex:1 1 100%;font-size:12px;color:var(--bone-faint);margin:.4rem 0 0}
.foot-legal a:hover{color:var(--bone-dim)}
.foot-credit{flex:1 1 100%;font-size:12px;color:var(--bone-faint);margin:.2rem 0 0}
.foot-credit a{color:var(--amber)}

/* POPUP */
.popup{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;padding:1.5rem}
.popup.show{display:flex}
.popup-scrim{position:absolute;inset:0;background:rgba(5,5,6,.72);backdrop-filter:blur(3px);z-index:0}
.popup-card{position:relative;z-index:1;background:var(--bg-3);border:1px solid var(--line-2);max-width:420px;width:100%;padding:2.4rem 2.2rem;text-align:center}
.popup-x{position:absolute;top:.6rem;right:.8rem;font-size:1.4rem;color:var(--bone-dim);padding:10px;margin:-4px}
.popup-card h3{font-family:var(--display);font-weight:500;font-size:1.7rem;color:var(--bone);margin:.3rem 0 .6rem}
.popup-card p{font-size:14px;color:var(--bone-dim);margin:0 0 1.4rem}
.popup-form{display:flex;gap:.5rem}
.popup-form input{flex:1;background:var(--bg);border:1px solid var(--line-2);outline:none;padding:.7rem .9rem;font:inherit;font-size:14px;color:var(--bone)}
.popup-form input:focus{border-color:var(--amber)}

/* CART DRAWER */
.cart-scrim{position:fixed;inset:0;z-index:80;background:rgba(5,5,6,.6);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.cart-scrim.show{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;z-index:81;width:min(92vw,400px);background:var(--bg-2);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .4s var(--e-silk);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}
.cart-drawer.open{transform:none}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:1.4rem var(--gutter);border-bottom:1px solid var(--line)}
.cart-head h2{font-family:var(--display);font-weight:500;font-size:1.4rem;margin:0;color:var(--bone)}
.cart-x{font-size:1.6rem;color:var(--bone-dim);padding:10px;margin:-10px}
.cart-ship{padding:1rem var(--gutter);border-bottom:1px solid var(--line)}
.cart-ship p{margin:0 0 .5rem;font-size:12px;letter-spacing:.04em;color:var(--bone-dim)}
.cart-ship .ship-on{color:var(--amber)}
.ship-bar{height:2px;background:var(--line-2);overflow:hidden}
.ship-bar i{display:block;height:100%;background:var(--amber);transition:width .4s}
.cart-lines{flex:1;overflow-y:auto;list-style:none;margin:0;padding:.5rem var(--gutter)}
.cart-empty{color:var(--bone-faint);font-size:14px;padding:2rem 0;text-align:center}
.cart-line{display:grid;grid-template-columns:48px 1fr auto;gap:.9rem;align-items:start;padding:1rem 0;border-bottom:1px solid var(--line)}
.ln-thumb{width:48px;height:48px;background:var(--bg-3);display:grid;place-items:center;overflow:hidden}
.ln-thumb .spec-shape{width:60%;height:60%;box-shadow:none}
.ln-name{font-family:var(--display);font-size:1.05rem;color:var(--bone);margin:0}
.ln-var{font-size:11px;color:var(--bone-faint);margin:.15rem 0}
.ln-qty{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;font-size:13px;color:var(--bone-dim)}
.ln-qty button{width:30px;height:30px;border:1px solid var(--line-2);color:var(--bone-dim)}
.ln-rm{width:auto!important;border:none!important;color:var(--bone-faint);font-size:11px;text-decoration:underline;padding:8px;margin:-8px -8px -8px .2rem}
.ln-price{font-size:14px;color:var(--bone)}
.cart-foot{padding:1.2rem var(--gutter) 1.4rem;border-top:1px solid var(--line)}
.cart-sub{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim)}
.cart-sub b{font-family:var(--display);font-size:1.3rem;color:var(--bone)}
.cart-note{font-size:11px;color:var(--bone-faint);margin:.7rem 0 0;text-align:center}

/* RESPONSIVE */
@media(max-width:920px){
  .quote{grid-template-columns:1fr;gap:2.5rem}
  .foot-top{grid-template-columns:1fr;gap:2.5rem}
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:767px){
  body{font-size:16px}
  .nav-rails{display:none}
  .nav-burger{display:flex}
  .shop-head{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .shop-head .display{font-size:clamp(2.1rem,10vw,2.8rem)}
  .flagship-copy{flex-direction:column;align-items:flex-start;gap:1.4rem}
  .process-track{flex-direction:column;padding:0 var(--gutter)}
  .proc-card{width:100%}
  .proc-progress{display:none}
  .detail-break{height:58vh}
  .foot-cols{grid-template-columns:1fr 1fr}
  .qf-row{grid-template-columns:1fr}
}
@media(max-width:480px){ .grid{grid-template-columns:1fr} .foot-bottom{flex-direction:column;align-items:flex-start} }
@media(max-height:640px){ .stage,.flagship{min-height:0} }

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  .js .reveal-line,.js .manifesto-head [data-wipe],.wd{opacity:1!important;transform:none!important;clip-path:none!important}
  .scrollcue span,.dropzone.idle{animation:none}
  .cursor-dot,.cursor-ring{display:none!important}
  *{scroll-behavior:auto!important}
}

/* ════════════════ LIGHT THEME overrides (David 2026-06-14) ════════════════ */
.grain{display:none!important}
.nav.solid{background:rgba(255,255,255,.86);border-bottom:1px solid var(--line)}
/* amber as TEXT needs the deeper amber-ink for contrast on white */
.amber,.manifesto-head em,.flag-hud-tl,.proc-cap span,.proc-counter,.foot-credit a,.foot-cols a:hover,.hero-link:hover{color:var(--amber-ink)}
.stage{background:radial-gradient(120% 95% at 68% 46%,#fff 0%,var(--bg) 66%)}
.flagship{background:radial-gradient(90% 80% at 58% 42%,#fff,var(--bg) 74%)}
.proc-img{background:linear-gradient(135deg,#f1f1ef,#fff)}
/* layer lines sit on the now-dark object fill → light strokes */
.pv-printed .pv-slices line,.pv-finished .pv-slices line{stroke:#fff;stroke-opacity:.34}
.card-img{background:linear-gradient(140deg,#f1f1ef,#fff)}
.card-tag{background:rgba(255,255,255,.8);color:var(--bone-dim);border-color:var(--line)}
.chip.is-on,.chip:hover{background:#16171b;color:#fbfbfa;border-color:#16171b}
.btn-ghost{border-color:#cdced2;color:var(--bone)}
.btn-ghost:hover{background:#16171b;color:#fbfbfa;border-color:#16171b}
.swatches li span{border-color:rgba(0,0,0,.12)}
.foot{background:#fbfbf9}
.spec-shape{background:linear-gradient(100deg,#42434a,#74767e 60%,#aeb0b7)}
