/* =====================================================================
   PHOEBE K — "The House" · a scrolling exhibition  (v2)
   Bone gallery walls, espresso ink, antique-gold. Fraunces at scale.
   Adds: colour-journey ground, dark interludes, texture loupe,
   index wall, knitting progress thread, kinetic marquees.
   ===================================================================== */
:root{
  --bone:#F2ECDE; --bone-2:#E9DFCC; --paper:#FBF7F0; --sand:#E3D8C2;
  --ink:#211B15; --ink-2:#5A4E42; --ink-3:#9B8C79;
  --line:#D6C9B2; --line-2:#C8B999;
  --gold:#A87B3C; --gold-2:#C99A55; --gold-deep:#7C5523;
  --mocha:#1E1813; --blush:#C98B7A;
  --ground:#F2ECDE; /* driven by JS colour-journey */
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",ui-sans-serif,system-ui,sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --ease-2:cubic-bezier(.65,.05,.36,1);
  --gut:clamp(20px,5vw,90px);
  --rail:84px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bone);color:var(--ink);line-height:1.55;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--gold);color:#fff}

/* colour-journey ground (behind everything) */
.ground{position:fixed;inset:0;z-index:-2;background:var(--ground);transition:background-color 1.1s var(--ease)}
.atmos{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(70% 55% at 82% 0%,rgba(201,154,85,.16),transparent 60%),
             radial-gradient(60% 50% at 0% 100%,rgba(201,139,122,.10),transparent 60%)}
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ===== top bar ===== */
.topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--gut);mix-blend-mode:difference;color:#fff}
.topbar .wm{font-family:var(--serif);font-weight:400;letter-spacing:.42em;text-transform:uppercase;font-size:.95rem;padding-left:.42em}
.topbar .tools{display:flex;align-items:center;gap:20px}
.topbar .meta{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;opacity:.85}
.idx-btn{display:inline-flex;align-items:center;gap:9px;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:#fff;opacity:.9}
.idx-btn .ic{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;width:15px;height:15px}
.idx-btn .ic i{background:#fff;border-radius:1px}
.idx-btn:hover{opacity:1}
@media(max-width:760px){.topbar .meta{display:none}}

/* chapter rail */
.rail{position:fixed;top:0;left:0;height:100vh;width:var(--rail);z-index:35;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:30px;mix-blend-mode:difference}
.rail a{writing-mode:vertical-rl;transform:rotate(180deg);font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;
  color:#fff;opacity:.5;transition:opacity .5s var(--ease);position:relative;padding:8px 0}
.rail a .dot{position:absolute;left:50%;top:-14px;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:#fff;opacity:0;transition:opacity .5s}
.rail a.active{opacity:1}.rail a.active .dot{opacity:1}.rail a:hover{opacity:.9}
@media(max-width:980px){.rail{display:none}}

/* knitting progress thread */
.progress{position:fixed;top:0;left:0;right:0;height:8px;z-index:50;pointer-events:none}
.progress svg{width:100%;height:100%}
.progress .thread-bg{stroke:rgba(124,85,35,.16);stroke-width:2;fill:none}
.progress .thread-fg{stroke:var(--gold-deep);stroke-width:2.2;fill:none;stroke-dasharray:7 6;stroke-linecap:round}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px var(--gut);z-index:2}
.hero .logo{width:128px;height:128px;border-radius:50%;overflow:hidden;mix-blend-mode:multiply;margin-bottom:26px;
  opacity:0;animation:rise 1.3s var(--ease) .1s forwards}
.hero .logo video{width:100%;height:100%;object-fit:cover}
.hero .eyebrow{font-size:.74rem;letter-spacing:.46em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;opacity:0;animation:rise 1.1s var(--ease) .35s forwards}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(3.4rem,15vw,12rem);line-height:.86;letter-spacing:-.02em;margin:.12em 0 .04em;font-optical-sizing:auto;opacity:0;animation:rise 1.3s var(--ease) .5s forwards}
.hero h1 em{font-style:italic;font-weight:300}
.hero .sub{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.1rem,3vw,1.9rem);color:var(--ink-2);opacity:0;animation:rise 1.2s var(--ease) .72s forwards}
.hero .rule{width:1px;height:64px;background:linear-gradient(var(--gold),transparent);margin-top:38px;opacity:0;animation:rise 1.4s var(--ease) .95s forwards}
.hero .cue{position:absolute;bottom:26px;left:0;right:0;text-align:center;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);opacity:0;animation:rise 1s var(--ease) 1.2s forwards}
.hero .cue::after{content:"";display:block;width:1px;height:30px;background:var(--ink-3);margin:10px auto 0;animation:cue 2.4s var(--ease) infinite}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ===== CHAPTER COVER ===== */
.chapter{position:relative;z-index:2}
.cover{position:relative;height:100svh;overflow:hidden;display:flex;align-items:flex-end;border-top:1px solid var(--line)}
.cover .bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}
.cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,.34) 0%,rgba(20,16,12,.04) 32%,rgba(20,16,12,.10) 60%,rgba(20,16,12,.74) 100%)}
.cover .cap{position:relative;z-index:2;color:#fff;padding:0 var(--gut) clamp(40px,7vh,90px);width:100%}
.cover .numeral{font-family:var(--serif);font-style:italic;font-weight:300;font-size:.95rem;letter-spacing:.3em;opacity:.85}
.cover .numeral::before{content:"";display:inline-block;width:46px;height:1px;background:var(--gold-2);vertical-align:middle;margin-right:16px}
.cover h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.8rem,9vw,8rem);line-height:.92;letter-spacing:-.02em;margin:.1em 0}
.cover .desc{max-width:46ch;color:rgba(255,255,255,.82);font-size:clamp(.95rem,1.6vw,1.15rem)}

/* ===== MARQUEE divider ===== */
.marquee{position:relative;overflow:hidden;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:transparent}
.marquee .track{display:inline-flex;gap:.6em;white-space:nowrap;will-change:transform}
.marquee span{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.4rem,3.4vw,2.6rem);color:var(--ink);opacity:.5}
.marquee span .star{color:var(--gold);font-style:normal;padding:0 .3em}

/* ===== PRODUCT ===== */
.product{position:relative;padding:clamp(60px,11vh,150px) 0}
.product-hero{display:grid;gap:clamp(22px,4vw,60px);align-items:center;padding:0 var(--gut);position:relative;grid-template-columns:0.82fr 1.18fr}
.product.flip .product-hero{grid-template-columns:1.18fr 0.82fr}
.product.flip .placard{order:2}.product.flip .hero-shot{order:1}
.ghost{position:absolute;font-family:var(--serif);font-weight:300;font-style:italic;color:transparent;-webkit-text-stroke:1px var(--line-2);
  font-size:clamp(9rem,26vw,24rem);line-height:.7;top:-.18em;right:var(--gut);z-index:0;pointer-events:none;user-select:none;opacity:.5;will-change:transform}
.product.flip .ghost{right:auto;left:var(--gut)}
.placard{position:relative;z-index:2;align-self:stretch;display:flex;flex-direction:column;justify-content:space-between;align-items:center;
  gap:clamp(22px,5vh,60px);padding:clamp(8px,3vh,52px) 0;text-align:center}
.placard .p-top,.placard .p-mid{display:flex;flex-direction:column;align-items:center}
.placard .p-mid{gap:clamp(16px,2.4vh,26px)}
.placard .no{font-size:.96rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.placard h3{font-family:var(--serif);font-weight:300;font-size:clamp(3.2rem,8.4vw,7.6rem);line-height:.9;letter-spacing:-.015em;margin:0}
.placard .swatch{display:inline-flex;align-items:center;gap:14px;font-size:1.12rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
.placard .swatch i{width:18px;height:18px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.15)}
.placard .ct{font-size:.96rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;justify-content:center;gap:13px}
.placard .ct::before{content:"";width:40px;height:1px;background:var(--line-2)}

/* editorial hero — filled crop, framed to favour the bag */
.hero-shot{position:relative;z-index:1}
.hero-shot figure{position:relative;overflow:hidden;border-radius:4px;background:var(--bone-2);box-shadow:0 40px 80px -40px rgba(50,34,18,.55);
  aspect-ratio:4/5;max-height:88vh;cursor:zoom-in}
.hero-shot img{width:100%;height:100%;object-fit:cover;object-position:center 60%;display:block;transition:transform 1.4s var(--ease)}
.hero-shot figure:hover img{transform:scale(1.035)}
.hero-shot .tag{position:absolute;left:14px;bottom:14px;z-index:3;color:#fff;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;background:rgba(20,16,12,.5);backdrop-filter:blur(4px);padding:5px 10px;border-radius:100px}
/* texture loupe */
.loupe{position:absolute;width:200px;height:200px;border-radius:50%;border:2px solid rgba(255,255,255,.7);box-shadow:0 14px 40px -10px rgba(0,0,0,.55),inset 0 0 0 1px rgba(0,0,0,.1);
  pointer-events:none;opacity:0;transition:opacity .25s var(--ease);z-index:4;background-repeat:no-repeat;transform:translate(-50%,-50%) scale(.85);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.hero-shot figure.loupe-on .loupe{opacity:1;transform:translate(-50%,-50%) scale(1)}
.loupe::after{content:"loupe";position:absolute;left:50%;bottom:-26px;transform:translateX(-50%);font-size:.5rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.8);text-shadow:0 1px 4px #000}
@media(hover:none){.loupe{display:none}}

/* ===== FILMSTRIP ===== */
.strip-wrap{margin-top:clamp(26px,4vh,60px);position:relative}
.strip-head{display:flex;align-items:center;justify-content:space-between;padding:0 var(--gut);margin-bottom:16px}
.strip-head .label{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:10px}
.strip-head .label .drag{color:var(--gold-deep)}
.strip-nav{display:flex;gap:8px}
.strip-nav button{width:42px;height:42px;border:1px solid var(--line-2);border-radius:50%;color:var(--ink-2);display:grid;place-items:center;transition:.4s var(--ease)}
.strip-nav button:hover{background:var(--ink);color:var(--bone);border-color:var(--ink);transform:translateY(-2px)}
.strip{display:flex;gap:clamp(12px,1.4vw,22px);overflow-x:auto;scroll-snap-type:none;-webkit-overflow-scrolling:touch;padding:6px var(--gut) 22px;scrollbar-width:none;cursor:grab;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%)}
.strip::-webkit-scrollbar{display:none}
.strip.drag{cursor:grabbing;scroll-snap-type:none}
.strip figure{flex:0 0 auto;position:relative;overflow:hidden;border-radius:3px;background:var(--bone-2);box-shadow:0 24px 50px -34px rgba(50,34,18,.5)}
.strip img{height:clamp(360px,66vh,720px);width:auto;max-width:none;object-fit:cover;display:block;cursor:zoom-in;transition:transform 1.2s var(--ease)}
.strip figure:hover img{transform:scale(1.04)}
/* drag-scrubber */
.scrub{position:relative;height:3px;margin:12px var(--gut) 0;background:var(--line);border-radius:3px;cursor:pointer}
.scrub-thumb{position:absolute;top:50%;left:0;transform:translateY(-50%);height:3px;min-width:40px;background:var(--gold-deep);border-radius:3px;transition:height .25s var(--ease),background .25s var(--ease)}
.scrub:hover .scrub-thumb,.scrub-thumb:active{height:5px;background:var(--gold)}
.scrub.hidden{display:none}

/* ===== DARK INTERLUDE ===== */
.interlude{position:relative;height:clamp(70vh,86vh,900px);overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--mocha)}
.interlude .bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;opacity:.5;will-change:transform}
.interlude::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 80% at 50% 50%,rgba(30,24,19,.35),rgba(20,16,12,.86))}
.interlude .line{position:relative;z-index:2;color:var(--bone);padding:0 var(--gut);max-width:20ch}
.interlude .line .eyebrow{display:block;font-size:.66rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-2);margin-bottom:20px}
.interlude .line p{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(1.8rem,5vw,3.6rem);line-height:1.08}

/* ===== SPECTRUM ===== */
.spectrum{position:relative;padding:clamp(70px,12vh,170px) var(--gut);text-align:center;border-top:1px solid var(--line)}
.spectrum .eyebrow{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.spectrum h2{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(2.2rem,6vw,4.6rem);line-height:1;margin:.2em auto .7em}
.spectrum-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(8px,1vw,16px);max-width:1500px;margin:0 auto}
.sg-tile{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:3/4;background:var(--bone-2);box-shadow:0 24px 50px -34px rgba(50,34,18,.45);cursor:pointer}
.sg-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.sg-tile:hover img{transform:scale(1.06)}
.sg-tile figcaption{position:absolute;left:11px;bottom:11px;color:#fff;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:8px;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.sg-tile figcaption i{width:10px;height:10px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.spectrum .cap{margin-top:26px;font-family:var(--serif);font-style:italic;color:var(--ink-2);font-size:1.1rem}
@media(max-width:760px){.spectrum-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== SIGN-OFF ===== */
.signoff{position:relative;background:var(--mocha);color:var(--bone);text-align:center;padding:clamp(80px,14vh,200px) var(--gut);overflow:hidden}
.signoff .marks{display:flex;gap:34px;justify-content:center;margin-bottom:34px}
.signoff .marks .m{width:120px;height:120px;border-radius:50%;overflow:hidden;background:#fff}
.signoff .marks video{width:100%;height:100%;object-fit:cover}
.signoff .eyebrow{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.signoff h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,7vw,5rem);margin:.18em 0;line-height:.96}
.signoff h2 em{font-style:italic}
.signoff p{color:#cdbfa9;max-width:48ch;margin:14px auto 0}
.signoff .foot{margin-top:60px;font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:#8d7f6b;display:flex;gap:18px;justify-content:center;flex-wrap:wrap}

/* ===== INDEX WALL ===== */
.indexwall{position:fixed;inset:0;z-index:80;background:rgba(28,22,17,.86);backdrop-filter:blur(16px);opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;overflow-y:auto}
.indexwall.on{opacity:1;visibility:visible}
.iw-head{display:flex;align-items:center;justify-content:space-between;padding:24px var(--gut);position:sticky;top:0;color:var(--bone)}
.iw-head .t{font-family:var(--serif);font-style:italic;font-size:1.3rem}
.iw-head .x{font-size:2rem;line-height:1;color:var(--bone);opacity:.8}
.iw-head .x:hover{opacity:1;transform:rotate(90deg);transition:.3s}
.iw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;padding:0 var(--gut) 60px;max-width:1500px;margin:0 auto}
.iw-tile{position:relative;aspect-ratio:3/4;border-radius:4px;overflow:hidden;cursor:pointer;background:#322a22;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.indexwall.on .iw-tile{opacity:1;transform:none}
.iw-tile img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .5s}
.iw-tile:hover img{transform:scale(1.07);filter:brightness(1.08)}
.iw-tile figcaption{position:absolute;inset:auto 0 0 0;padding:18px 12px 12px;background:linear-gradient(transparent,rgba(20,16,12,.82));color:#fff;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;display:flex;align-items:center;gap:7px}
.iw-tile figcaption i{width:9px;height:9px;border-radius:50%}
.iw-tile .col{display:block;font-size:.56rem;color:var(--gold-2);letter-spacing:.2em;margin-top:3px}

/* ===== LIGHTBOX ===== */
.lb{position:fixed;inset:0;z-index:100;background:rgba(18,14,10,.95);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.lb.on{opacity:1;visibility:visible}
.lb .stage{max-width:92vw;max-height:88vh;position:relative}
.lb .stage img{max-width:92vw;max-height:88vh;border-radius:4px;box-shadow:0 50px 120px -30px #000}
.lb .cap{position:absolute;left:0;bottom:-32px;color:#cdbfa9;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase}
.lb .count{position:absolute;right:0;bottom:-32px;color:#8d7f6b;font-size:.7rem;letter-spacing:.24em}
.lb .x{position:fixed;top:24px;right:30px;color:#fff;font-size:2.4rem;line-height:1;opacity:.8;transition:.3s}
.lb .x:hover{opacity:1;transform:rotate(90deg)}
.lb .nav{position:fixed;top:50%;transform:translateY(-50%);width:56px;height:56px;border:1px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;display:grid;place-items:center;font-size:1.2rem;transition:.3s var(--ease)}
.lb .nav:hover{background:#fff;color:#000}
.lb .prev{left:24px}.lb .next{right:24px}
@media(max-width:760px){.lb .nav{width:44px;height:44px}.lb .prev{left:8px}.lb .next{right:8px}}

/* ===== LOADER / curtain ===== */
.loader{position:fixed;inset:0;z-index:999;background:var(--bone);display:flex;align-items:center;justify-content:center;will-change:transform}
.loader::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 50% at 50% 42%,rgba(201,154,85,.12),transparent 70%)}
.loader.done{transform:translateY(-101%);transition:transform 1.05s cubic-bezier(.85,0,.15,1)}
.loader-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:20px;opacity:0;animation:rise 1s var(--ease) .1s forwards}
.loader.done .loader-inner{opacity:0;transition:opacity .45s var(--ease)}
.loader-mark{width:104px;height:104px;border-radius:50%;overflow:hidden;mix-blend-mode:multiply}
.loader-mark video{width:100%;height:100%;object-fit:cover}
.loader-wm{font-family:var(--serif);font-weight:300;font-size:1.7rem;letter-spacing:.42em;text-transform:uppercase;color:var(--ink);padding-left:.42em}
.loader-thread{position:relative;width:190px;height:1px;background:var(--line);overflow:hidden}
.loader-thread span{position:absolute;inset:0 auto 0 0;width:0;background:var(--gold-deep);animation:thread 1.45s var(--ease) .25s forwards}
.loader-cap{font-size:.62rem;letter-spacing:.36em;text-transform:uppercase;color:var(--ink-3)}
@keyframes thread{to{width:100%}}

/* ===== reveals ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ===== responsive ===== */
@media(max-width:980px){
  :root{--gut:clamp(16px,5vw,40px)}
  .product-hero,.product.flip .product-hero{grid-template-columns:1fr;gap:22px}
  .product.flip .placard{order:0}.product.flip .hero-shot{order:0}
  .hero-shot figure,.hero-shot img{max-height:70vh}
  .ghost{font-size:34vw;top:-.1em;opacity:.4}
  .placard{align-self:auto;justify-content:flex-start;gap:18px;padding:0}
  .placard h3{font-size:clamp(2.8rem,12vw,4.4rem)}
}
@media(max-width:560px){.strip img{height:52vh}.signoff .marks .m{width:88px;height:88px}}

/* ===== reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .cover .bg,.interlude .bg{inset:0}
  .marquee .track{transform:none!important}
  .loader-inner{opacity:1}
  .loader-thread span{width:100%}
}

/* ===== chapter nav in top bar (relocated from side rail) ===== */
.chapnav{display:flex;align-items:center;gap:clamp(14px,2.2vw,34px)}
.chapnav a{position:relative;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:#fff;opacity:.55;padding:6px 0;transition:opacity .4s var(--ease)}
.chapnav a .dot{display:none}
.chapnav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;opacity:.75;transition:right .45s var(--ease)}
.chapnav a:hover{opacity:.85}
.chapnav a.active{opacity:1}
.chapnav a.active::after{right:0}
@media(max-width:860px){.chapnav{display:none}}

/* ===== product series — static row, full uncropped frames (no carousel) ===== */
.series{padding:clamp(26px,4vh,62px) var(--gut) 0}
.series-head{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:clamp(18px,2.6vh,34px);
  font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--ink-3);letter-spacing:.03em}
.series-head::before,.series-head::after{content:"";height:1px;width:min(90px,13vw);background:var(--line-2)}
.series-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:clamp(12px,1.5vw,22px);max-width:1560px;margin:0 auto}
.series-grid figure{position:relative;overflow:hidden;border-radius:3px;background:var(--bone-2);box-shadow:0 24px 50px -34px rgba(50,34,18,.5);cursor:zoom-in}
.series-grid img{height:clamp(320px,50vh,540px);width:auto;max-width:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease)}
.series-grid figure:hover img{transform:scale(1.04)}
@media(max-width:560px){.series-grid img{height:46vh}}

/* divider between products */
.prod-divider{display:flex;align-items:center;justify-content:center;gap:22px;padding:0 var(--gut);margin:clamp(54px,9vh,120px) 0 0}
.prod-divider::before,.prod-divider::after{content:"";height:1px;width:min(170px,24vw);background:linear-gradient(90deg,transparent,var(--line-2) 35%,var(--line-2) 65%,transparent)}
.prod-divider .mark{color:var(--gold);font-size:.85rem;opacity:.85}

/* Ember hero — trim a thin dark edge on the left */
#p-LE-Ember .hero-shot img{width:104%;max-width:none;margin-left:-2%}
