
:root{
  --ground:#191510; --ground2:#1F1A13; --panel:#241D15;
  --bronze:#B0834A; --bronze-deep:#7E5C2F; --pale:#D9BD8C;
  --bone:#EDE4D0; --bone-dim:#BCB096; --faint:#8C8170;
  --hair:rgba(176,131,74,.30); --hair2:rgba(176,131,74,.15);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{background:var(--ground);color:var(--bone);font-family:'Lora',Georgia,serif;font-size:16px;line-height:1.74;-webkit-font-smoothing:antialiased;position:relative}
body::before{content:"";position:fixed;inset:0;background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScxNjAnIGhlaWdodD0nMTYwJz48ZmlsdGVyIGlkPSduJz48ZmVUdXJidWxlbmNlIHR5cGU9J2ZyYWN0YWxOb2lzZScgYmFzZUZyZXF1ZW5jeT0nMC45JyBudW1PY3RhdmVzPScyJy8+PGZlQ29sb3JNYXRyaXggdHlwZT0nc2F0dXJhdGUnIHZhbHVlcz0nMCcvPjwvZmlsdGVyPjxyZWN0IHdpZHRoPScxMDAlJyBoZWlnaHQ9JzEwMCUnIGZpbHRlcj0ndXJsKCNuKScgb3BhY2l0eT0nMC41Jy8+PC9zdmc+');opacity:.05;pointer-events:none;z-index:1}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:500;color:var(--bone)}
a{color:var(--pale);text-decoration:none}
a:hover{color:var(--bone)}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--bronze);outline-offset:3px}
.mono{font-family:'IBM Plex Mono',monospace;letter-spacing:.24em;text-transform:uppercase;font-size:.64rem;color:var(--bronze)}
.mono.dim{color:var(--faint)}
.wrap{max-width:1200px;margin:0 auto;padding:0 6vw;position:relative;z-index:2}
.frame,.frame2{position:fixed;pointer-events:none;z-index:70;border:1px solid var(--hair)}
.frame{inset:12px}.frame2{inset:17px;border-color:var(--hair2)}
.corner{position:fixed;width:9px;height:9px;border:1px solid var(--bronze);z-index:71;pointer-events:none;background:var(--ground)}
.c1{top:8px;left:8px}.c2{top:8px;right:8px}.c3{bottom:8px;left:8px}.c4{bottom:8px;right:8px}
@media(max-width:700px){.frame{inset:7px}.frame2{display:none}.corner{width:7px;height:7px}.c1{top:4px;left:4px}.c2{top:4px;right:4px}.c3{bottom:4px;left:4px}.c4{bottom:4px;right:4px}}
#progress{position:fixed;top:12px;left:12px;height:2px;background:var(--bronze);width:0;z-index:72;max-width:calc(100% - 24px)}
@media(max-width:700px){#progress{top:7px;left:7px;max-width:calc(100% - 14px)}}
.engrave{display:flex;align-items:center;gap:14px;margin:0 0 .2rem}
.engrave::before,.engrave::after{content:"";flex:1;height:3px;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair2)}
.engrave span{width:7px;height:7px;border:1px solid var(--bronze);transform:rotate(45deg)}
body>nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;justify-content:space-between;align-items:center;padding:20px 5vw 16px;background:rgba(25,21,16,.94);backdrop-filter:blur(6px);border-bottom:1px solid var(--hair2)}
body>nav .brand{font-family:'IBM Plex Mono',monospace;letter-spacing:.3em;font-size:.66rem;color:var(--pale)}
body>nav ul{display:flex;gap:24px;list-style:none}
body>nav ul li{position:relative}
body>nav ul a{font-family:'IBM Plex Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-dim)}
body>nav ul a:hover,nav ul a.active{color:var(--bronze)}
body>nav ul .dropdown-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:rgba(25,21,16,.98);backdrop-filter:blur(8px);border:1px solid var(--hair2);list-style:none;padding:10px 0;min-width:160px;z-index:100;box-shadow:0 8px 30px rgba(0,0,0,0.6);margin-top:10px}
body>nav ul .dropdown-menu::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);width:10px;height:10px;background:rgba(25,21,16,.98);border-left:1px solid var(--hair2);border-top:1px solid var(--hair2)}
body>nav ul .dropdown-menu::after{content:'';position:absolute;top:-15px;left:0;right:0;height:15px;background:transparent}
body>nav ul .dropdown-menu li{width:100%;text-align:center}
body>nav ul .dropdown-menu li a{display:block;padding:8px 16px;font-size:.56rem;letter-spacing:.15em;color:var(--bone-dim);transition:color .2s,background .2s}
body>nav ul .dropdown-menu li a:hover{color:var(--bronze);background:rgba(176,131,74,.08)}
body>nav ul .dropdown:hover .dropdown-menu,body>nav ul .dropdown:focus-within .dropdown-menu{display:block}
@media(max-width:920px){body>nav{position:absolute;flex-wrap:wrap;gap:.6rem}nav ul{flex-wrap:wrap;gap:.7rem 1.1rem}body>nav ul .dropdown-menu{position:static;transform:none;box-shadow:none;border:none;background:transparent;padding:4px 0 0 10px;min-width:0;margin-top:0;display:flex;gap:10px}body>nav ul .dropdown-menu::before{display:none}body>nav ul .dropdown-menu li{width:auto}body>nav ul .dropdown-menu li a{padding:4px 8px;font-size:.5rem}}
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end}
.hero .bg{position:absolute;inset:0;overflow:hidden}
.hero .bg img,.hero .bg video{width:100%;height:100%;object-fit:cover;object-position:50% 35%;filter:saturate(.6) brightness(.5) sepia(.15)}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--ground) 6%,rgba(25,21,16,.35) 55%,rgba(25,21,16,.55))}
.hero-inner{position:relative;z-index:3;padding:130px 6vw 8vh;max-width:1150px}
.hero h1{font-size:clamp(2.6rem,6.8vw,5.6rem);line-height:1.05;margin:1rem 0 1.1rem}
.hero h1 em{font-style:italic;color:var(--pale)}
.hero .lede{max-width:600px;color:var(--bone-dim);font-size:1.02rem}
.stats{display:flex;gap:0;margin-top:2.3rem;border:1px solid var(--hair);width:fit-content;flex-wrap:wrap;background:rgba(25,21,16,.55)}
.stats div{padding:.9rem 1.7rem;border-right:1px solid var(--hair2)}
.stats div:last-child{border-right:none}
.stats .n{font-family:'Cormorant Garamond',serif;font-size:2rem;line-height:1;color:var(--pale);display:block}
.stats .mono{display:block;margin-top:.45rem}
section{padding:8.5rem 0 4rem}
.sec-head{margin-bottom:3rem}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,3rem);margin:.7rem 0 1rem}
.prose{max-width:720px}
.prose p{color:var(--bone-dim);margin-bottom:1.1rem}
.prose p:first-child{font-family:'Cormorant Garamond',serif;font-size:1.35rem;line-height:1.55;color:var(--bone)}
/* lineage */
.lineage{border:1px solid var(--hair2);background:var(--ground2);padding:2rem 1.2rem 1rem;overflow-x:auto}
.lineage svg{width:100%;min-width:760px;height:auto;display:block}
.gen-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.2em;fill:var(--faint)}
.kin{stroke:var(--hair);stroke-width:1;fill:none}
.kin.dash{stroke-dasharray:3 4}
.lnode{cursor:pointer}
.lnode circle{fill:var(--panel);stroke:var(--bronze);stroke-width:1.2;transition:fill .2s}
.lnode:hover circle,.lnode:focus circle{fill:var(--bronze-deep)}
.lnode .nm{font-family:'Cormorant Garamond',serif;font-size:15px;fill:var(--bone)}
.lnode .role{font-family:'IBM Plex Mono',monospace;font-size:8px;letter-spacing:.14em;fill:var(--bronze);text-transform:uppercase}
.lnode .hd{font-family:'Lora',serif;font-style:italic;font-size:11px;fill:var(--bone-dim)}
.lnode .hook{font-family:'IBM Plex Mono',monospace;font-size:7.5px;letter-spacing:.1em;fill:var(--faint)}
.lin-note{margin-top:1rem;font-size:.84rem;color:var(--faint);font-style:italic;padding:0 .8rem 1rem}
/* tour map + timeline */
.atlas{position:relative;border:1px solid var(--hair2);background:var(--ground2);padding:1rem}
.atlas svg{width:100%;height:auto;display:block}
.land{fill:#241D15;stroke:rgba(176,131,74,.35);stroke-width:.6;pointer-events:none}
.grat{stroke:rgba(176,131,74,.10);stroke-width:.5;pointer-events:none}
.route{fill:none;stroke:var(--bronze);stroke-width:.8;stroke-dasharray:3 3;opacity:.9;pointer-events:none}
@media (prefers-reduced-motion: no-preference){.route{animation:dash 30s linear infinite}}
@keyframes dash{to{stroke-dashoffset:-300}}
.venue circle.dot{fill:var(--pale);stroke:var(--ground);stroke-width:1.5}
.venue circle.halo{fill:none;stroke:var(--bronze);stroke-width:1;opacity:.55}
.venue text{font-family:'IBM Plex Mono',monospace;font-size:6px;letter-spacing:.1em;fill:var(--bone-dim);text-transform:uppercase}
.venue text.when{font-size:4.6px;fill:var(--bronze)}
.tl{border:1px solid var(--hair2);padding:2rem 2rem 1.4rem;margin-top:2.5rem;position:relative}
.tl-grid{position:relative;height:96px}
.tl-year{position:absolute;top:0;bottom:24px;border-left:1px solid var(--hair2)}
.tl-year span{position:absolute;bottom:-22px;left:-13px;font-family:'IBM Plex Mono',monospace;font-size:.56rem;letter-spacing:.12em;color:var(--faint)}
.tl-bar{position:absolute;height:30px;top:16px;background:var(--panel);border:1px solid var(--hair)}
.tl-bar span{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-family:'IBM Plex Mono',monospace;font-size:.56rem;letter-spacing:.14em;color:var(--bone);text-transform:uppercase;white-space:nowrap}
.tl-mark{position:absolute;top:6px;bottom:18px;border-left:1px solid var(--hair)}
.tl-mark span{position:absolute;top:-14px;left:-4px;font-family:'IBM Plex Mono',monospace;font-size:.52rem;letter-spacing:.12em;color:var(--bone-dim);white-space:nowrap}
.tl-now{position:absolute;top:-2px;bottom:14px;border-left:1px solid var(--pale)}
.tl-now span{position:absolute;top:-16px;left:-12px;font-family:'IBM Plex Mono',monospace;font-size:.54rem;letter-spacing:.14em;color:var(--pale)}
/* ——— Chronos: chapters ——— */
.chapter{padding:5.5rem 0 0}
.chapter:first-of-type{padding-top:2rem}
.chap-open .co-kicker{display:flex;justify-content:space-between;align-items:baseline;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem}
.chap-open .co-kicker .ref{font-family:'IBM Plex Mono',monospace;font-size:.66rem;letter-spacing:.22em;color:var(--bronze);border:1px solid var(--hair);padding:.5rem .9rem}
.co-dates{display:block;font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.6rem,6vw,5rem);line-height:1;color:var(--pale);letter-spacing:.01em}
.co-dates .bc{font-size:.42em;color:var(--bronze);letter-spacing:.12em}
.co-era{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.5rem,2.6vw,2.2rem);color:var(--bone);margin:.5rem 0 0}
.datebig{display:block;overflow:hidden}
.datebig{line-height:1.05;padding-top:.12em}
.datebig .roll{display:inline-block;transform:translateY(110%);transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.in .roll,.reveal.in .roll{transform:none}
.patina img{filter:sepia(.55) saturate(.3) brightness(.78);transform:scale(1.03);transition:filter 1.5s ease .15s,transform 1.6s cubic-bezier(.2,.7,.2,1) .15s}
.patina.in img{filter:none;transform:none}
@media (prefers-reduced-motion: reduce){.datebig .roll{transform:none;transition:none}.patina img{filter:none;transform:none;transition:none}}
/* timeline spine */
#spine{position:fixed;right:22px;top:50%;transform:translateY(-50%);height:54vh;z-index:65;display:flex;flex-direction:column;align-items:center;opacity:0;pointer-events:none;transition:opacity .5s ease}
#spine.show{opacity:1;pointer-events:auto}
#spine .track{position:relative;flex:1;width:1px;background:var(--hair)}
#spine .fill{position:absolute;top:0;left:0;width:1px;height:0;background:var(--bronze)}
#spine .dot{position:absolute;left:50%;top:0;width:7px;height:7px;transform:translate(-50%,-50%) rotate(45deg);background:var(--pale);border:1px solid var(--ground)}
#spine .tick{position:absolute;left:50%;width:9px;height:9px;transform:translate(-50%,-50%) rotate(45deg);border:1px solid var(--bronze);background:var(--ground);display:block}
#spine .tick:hover,#spine .tick.on{background:var(--bronze)}
#spine .tick .tip{position:absolute;right:16px;top:50%;transform:translateY(-50%) rotate(-45deg);transform-origin:right center;white-space:nowrap;font-family:'IBM Plex Mono',monospace;font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim);background:rgba(25,21,16,.92);border:1px solid var(--hair2);padding:.35rem .6rem;opacity:0;pointer-events:none;transition:opacity .2s}
#spine .tick:hover .tip,#spine .tick:focus .tip{opacity:1}
#spine .yr{font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.16em;color:var(--pale);margin-bottom:.9rem;white-space:nowrap;border:1px solid var(--hair);background:rgba(25,21,16,.92);padding:.4rem .65rem;min-width:84px;text-align:center}
#spine .yl{font-family:'IBM Plex Mono',monospace;font-size:.5rem;letter-spacing:.2em;color:var(--faint);margin-top:.9rem;writing-mode:vertical-rl}
@media(max-width:1080px){#spine{display:none}}
#spinechip{position:fixed;bottom:16px;left:16px;z-index:65;font-family:'IBM Plex Mono',monospace;font-size:.58rem;letter-spacing:.16em;color:var(--pale);background:rgba(25,21,16,.92);border:1px solid var(--hair);padding:.45rem .7rem;opacity:0;pointer-events:none;transition:opacity .4s}
#spinechip.show{opacity:1}
@media(min-width:1081px){#spinechip{display:none}}
/* chapter seam */
.chapseam{display:flex;align-items:center;gap:1.4rem;margin:4.5rem 0 0;padding:2rem 0 0;border-top:1px solid var(--hair2)}
.chapseam .yfrom,.chapseam .yto{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--bone-dim);white-space:nowrap}
.chapseam .yto{color:var(--pale)}
.chapseam .seamline{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--bronze) 0 6px,transparent 6px 12px);background-size:200% 100%;opacity:.35}
.chapseam.in .seamline{opacity:.9;animation:seamflow 2.6s linear infinite}
@keyframes seamflow{to{background-position:-48px 0}}
@media (prefers-reduced-motion: reduce){.chapseam.in .seamline{animation:none}}
/* at-a-glance card */
.glance{border:1px solid var(--hair);background:var(--ground2);margin-top:3rem;padding:1.8rem 2rem 2rem}
.glance .gtitle{display:block;margin-bottom:1.2rem}
.glance .grows{display:grid;grid-template-columns:1fr 1fr;gap:.9rem 2.5rem}
@media(max-width:760px){.glance .grows{grid-template-columns:1fr}.glance{padding:1.3rem 1.3rem 1.5rem}}
.glance .gr{display:flex;flex-direction:column;gap:.25rem;border-left:1px solid var(--hair2);padding-left:1rem}
.glance .gk{font-family:'IBM Plex Mono',monospace;font-size:.54rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze)}
.glance .gv{font-size:.9rem;color:var(--bone)}
/* hero axis */
.heroaxis{margin-top:2.6rem;max-width:880px}
.heroaxis .axline{display:flex;align-items:baseline;gap:1rem;margin-bottom:1rem}
.heroaxis .axline .l{flex:1;height:1px;align-self:center;background:linear-gradient(90deg,var(--bronze),rgba(176,131,74,.15))}
#herocount{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.2em;color:var(--pale);min-width:92px}
.heroaxis .axend{font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.2em;color:var(--bronze)}
.axnodes{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem}
.axnode{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-decoration:none;opacity:0;transform:translateY(14px)}
.axnode img{width:54px;height:54px;object-fit:cover;object-position:50% 16%;border:1px solid var(--hair2);filter:saturate(.6) brightness(.9);transition:filter .25s,border-color .25s}
.axnode:hover img{filter:none;border-color:var(--bronze)}
.axnode .axd{font-family:'IBM Plex Mono',monospace;font-size:.5rem;letter-spacing:.14em;color:var(--bone-dim);text-align:center}
.axnode:hover .axd{color:var(--pale)}
@media (prefers-reduced-motion: no-preference){
.axnode{animation:axup .7s cubic-bezier(.2,.7,.2,1) forwards}
.axnode:nth-child(1){animation-delay:.25s}.axnode:nth-child(2){animation-delay:.4s}.axnode:nth-child(3){animation-delay:.55s}.axnode:nth-child(4){animation-delay:.7s}.axnode:nth-child(5){animation-delay:.85s}.axnode:nth-child(6){animation-delay:1s}
@keyframes axup{to{opacity:1;transform:none}}}
@media (prefers-reduced-motion: reduce){.axnode{opacity:1;transform:none}}
@media(max-width:700px){.axnodes{grid-template-columns:repeat(3,1fr)}.heroaxis{margin-top:1.8rem}}
.mediaband{display:block;margin-top:1.4rem}

.thumbgrid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:1rem}
@media(max-width:880px){.thumbgrid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.thumbgrid .detail{flex:none;aspect-ratio:1}
.dossier-old{padding:5rem 0 4.5rem}
.dossier-head{display:flex;justify-content:space-between;align-items:baseline;gap:2rem;margin-bottom:2.2rem;flex-wrap:wrap}
.filmpanel{margin-top:0!important;height:100%;aspect-ratio:auto;min-height:200px}
.dossier-head .ref{font-family:'IBM Plex Mono',monospace;font-size:.66rem;letter-spacing:.22em;color:var(--bronze);border:1px solid var(--hair);padding:.5rem .9rem}
.dgrid{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,6fr);gap:4rem;align-items:start}
@media(max-width:880px){.dgrid{grid-template-columns:1fr;gap:2rem}}
.imgcol{position:relative}
.loupe-wrap{position:relative;overflow:hidden;cursor:zoom-in;background:var(--ground2)}
.loupe-wrap img{width:100%;height:auto;display:block}
.lens{position:absolute;width:190px;height:190px;border:1px solid var(--pale);box-shadow:0 0 0 1px rgba(25,21,16,.8),0 8px 30px rgba(0,0,0,.5);pointer-events:none;display:none;background-repeat:no-repeat;z-index:5}
@media (pointer: coarse){.zoomhint{display:none}}
.zoomhint{position:absolute;bottom:10px;right:10px;z-index:4;font-family:'IBM Plex Mono',monospace;font-size:.54rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone);background:rgba(25,21,16,.78);padding:.45rem .7rem;border:1px solid var(--hair)}
.detailrow{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap}
.dgrid{margin-bottom:0}
.detail{position:relative;flex:0 0 124px;cursor:zoom-in;border:1px solid var(--hair2)}
.detail img{width:100%;height:100%;object-fit:cover;display:block}
.filmpanel{position:relative;margin-top:1rem;aspect-ratio:16/9;border:1px solid var(--hair);cursor:pointer;overflow:hidden;background:var(--ground2)}
.filmpanel img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.8) brightness(.8);transition:filter .3s}
.filmpanel:hover img{filter:saturate(1) brightness(.95)}
.filmpanel b{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:58px;height:58px;border:1px solid var(--pale);background:rgba(25,21,16,.84);color:var(--pale);display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:400;padding-left:3px;transition:background .2s}
.filmpanel:hover b{background:var(--bronze);color:var(--ground)}
.filmpanel .filmlabel{position:absolute;left:0;right:0;bottom:0;font-family:'IBM Plex Mono',monospace;font-size:.54rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone);background:rgba(25,21,16,.82);padding:.5rem .7rem}
.filmpanel iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.detail.filmtile b{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);width:34px;height:34px;border:1px solid var(--pale);background:rgba(25,21,16,.85);color:var(--pale);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:400;padding-left:2px}
.detail.filmtile:hover b{background:var(--bronze);color:var(--ground)}
.detail span{position:absolute;left:0;right:0;bottom:0;font-family:'IBM Plex Mono',monospace;font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);background:rgba(25,21,16,.82);padding:.3rem .45rem}
.dtext h3{font-size:clamp(1.8rem,2.8vw,2.5rem);line-height:1.1;margin:.2rem 0 .2rem}
.dtext .sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:var(--bone-dim);margin-bottom:1.3rem}
.refline{border-left:2px solid var(--bronze);padding:.55rem 0 .55rem 1.1rem;margin:1.2rem 0 1.4rem}
.refline .mono{display:block;margin-bottom:.3rem}
.refline .r{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;color:var(--pale)}
.dtext p{color:var(--bone-dim);font-size:.93rem;margin-bottom:.9rem}
.spec{border:1px solid var(--hair);margin-top:1.7rem}
.spec .srow{display:grid;grid-template-columns:140px 1fr;border-bottom:1px solid var(--hair2)}
.spec .srow:last-child{border-bottom:none}
.spec .sk{font-family:'IBM Plex Mono',monospace;font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze);padding:.8rem 1rem;border-right:1px solid var(--hair2);display:flex;align-items:center}
.spec .sv{padding:.7rem 1rem;font-size:.88rem;color:var(--bone)}
/* narrative elements */
.hero-cta{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap}
.welcome-pull{margin:2.8rem auto 0;max-width:820px;font-family:'Cormorant Garamond',serif;font-size:1.35rem;line-height:1.6;color:var(--bone);border-left:2px solid var(--bronze);padding-left:1.5rem}
.welcome-pull cite{display:block;margin-top:1rem;font-style:normal;font-size:.6rem}
.doc-cta{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:1.6rem;align-items:center;border:1px solid var(--hair2);margin-top:2.5rem;text-decoration:none;transition:border-color .2s,background .2s}
.doc-cta:hover{border-color:var(--bronze);background:var(--ground2)}
.doc-cta img{width:100%;display:block;filter:saturate(.85)}
.doc-meta{display:flex;flex-direction:column;gap:.5rem;padding:1.4rem 1.6rem 1.4rem 0}
.doc-meta .mono{font-size:.56rem;color:var(--bronze)}
.doc-meta b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.6rem;color:var(--pale)}
.doc-meta i{font-style:normal;font-size:.86rem;color:var(--bone-dim);line-height:1.6}
@media(max-width:700px){.doc-cta{grid-template-columns:1fr}.doc-meta{padding:0 1.2rem 1.4rem}}
.nextchap{display:flex;flex-direction:column;gap:.4rem;align-items:flex-start;margin-top:3rem;border:1px solid var(--hair);background:var(--ground2);padding:1.4rem 1.8rem;width:100%;cursor:pointer;text-align:left;text-decoration:none;transition:border-color .2s}
.nextchap:hover{border-color:var(--bronze)}
.nextchap b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.35rem;color:var(--bone)}
/* journey timeline */
.timeline{display:grid;grid-template-columns:repeat(6,1fr);gap:0;position:relative;border:1px solid var(--hair);background:var(--ground2)}
.timeline::before{content:"";position:absolute;left:3%;right:3%;top:86px;height:1px;background:linear-gradient(90deg,transparent,var(--bronze) 12%,var(--bronze) 88%,transparent)}
.tnode{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.6rem .8rem 1.4rem;background:none;border:none;border-right:1px solid var(--hair2);cursor:pointer;text-align:center}
.tnode:last-child{border-right:none}
.tnode:hover{background:rgba(176,131,74,.06)}
.tdate{font-size:.56rem;color:var(--bronze)}
.tdot{width:9px;height:9px;border:1px solid var(--bronze);background:var(--ground);transform:rotate(45deg);margin:.35rem 0 .8rem;z-index:1;transition:background .2s}
.tnode:hover .tdot{background:var(--bronze)}
.tnode img{width:64px;height:64px;object-fit:cover;object-position:50% 16%;border:1px solid var(--hair2);filter:saturate(.6) brightness(.85);transition:filter .25s,border-color .25s}
.tnode:hover img{filter:saturate(1) brightness(1);border-color:var(--bronze)}
.tera{font-family:'Cormorant Garamond',serif;font-size:1.05rem;line-height:1.2;color:var(--bone)}
.thead{font-size:.52rem}
.tcta{font-size:.52rem;color:var(--bronze);opacity:0;transition:opacity .2s}
.tnode:hover .tcta{opacity:1}
@media(max-width:880px){.timeline{grid-template-columns:repeat(2,1fr)}.timeline::before{display:none}.tnode{border-bottom:1px solid var(--hair2)}}
.pathways{margin-top:2.5rem}
.pathgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:880px){.pathgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pathgrid{grid-template-columns:1fr}}
.path{display:flex;flex-direction:column;gap:.45rem;border:1px solid var(--hair2);padding:1.2rem 1.2rem 1.4rem;text-decoration:none;transition:border-color .2s,background .2s}
.path:hover{border-color:var(--bronze);background:var(--ground2)}
.path .mono{font-size:.54rem;color:var(--bronze)}
.path b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.15rem;color:var(--bone)}
.path i{font-style:normal;font-size:.78rem;color:var(--bone-dim);line-height:1.55}
.catsub{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:var(--pale);margin:1.6rem 0 .5rem}
.pane-era p,.ebody p{color:var(--bone-dim);font-size:.92rem;margin-bottom:.9rem}
p.catlead{font-family:'Cormorant Garamond',serif;font-size:1.22rem;line-height:1.55;color:var(--bone)!important}
.refs{margin-top:1.6rem;border-top:1px solid var(--hair2);padding-top:1rem}
.refs ol{margin:.6rem 0 0 1.1rem}
.refs li{font-size:.72rem;color:var(--faint);margin-bottom:.4rem;line-height:1.5;word-break:break-word}
.words p{font-family:'Cormorant Garamond',serif;font-size:1.18rem;line-height:1.6;color:var(--bone);margin-bottom:1rem}
.words{border-left:2px solid var(--bronze);padding-left:1.3rem}
/* dossier bands */
.imgcol .filmpanel{margin-top:1rem!important;min-height:0;aspect-ratio:16/9;height:auto}
.wordsband{margin-top:3rem;border-top:1px solid var(--hair2);padding-top:1.6rem}
.wordsband .words{margin-top:1rem;max-width:820px}
.erachap{margin-top:3.5rem}
.chap-head{margin-bottom:2rem}
.chap-head .engrave{margin-bottom:1.2rem}
.chap-title{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:2rem;color:var(--pale);margin-top:.6rem}
.chap-dates{color:var(--bronze);font-size:1.3rem}
.chap-body{max-width:690px}
.chap-body p{color:var(--bone-dim);font-size:.97rem;margin-bottom:1.05rem;line-height:1.8}
.fig.figwide{margin:1.8rem 0}
.fig.figwide img{width:100%}
.fig.fig-right{float:right;width:280px;margin:0 0 1.4rem 2rem}
@media(max-width:767px){.fig.fig-right{float:none;width:100%;margin:1.4rem 0}}
/* catalog figures */
.figblock{margin-top:2.2rem;border-top:1px solid var(--hair2);padding-top:1.2rem}
.figgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem 1.2rem;margin-top:1rem}
@media(max-width:700px){.figgrid{grid-template-columns:1fr}}
.fig{margin:0;cursor:zoom-in}
.fig img{width:100%;height:auto;display:block;border:1px solid var(--hair2);filter:saturate(.92)}
.fig:hover img{border-color:var(--bronze)}
.fig figcaption{font-family:'IBM Plex Mono',monospace;font-size:.56rem;letter-spacing:.06em;color:var(--faint);margin-top:.45rem;line-height:1.6}
/* catalog essays */
.essays{border:1px solid var(--hair2)}
.essay{border-bottom:1px solid var(--hair2)}
.essay:last-child{border-bottom:none}
.essay summary{list-style:none;cursor:pointer;display:flex;flex-direction:column;gap:.35rem;padding:1.5rem 2rem;transition:background .2s}
.essay summary::-webkit-details-marker{display:none}
.essay summary:hover{background:var(--ground2)}
.essay .etitle{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--bone)}
.essay summary::after{content:"+";position:absolute;right:2.2rem;font-family:'IBM Plex Mono',monospace;color:var(--bronze);font-size:1rem;margin-top:.6rem}
.essay{position:relative}
.essay[open] summary::after{content:"−"}
.essay[open] summary{background:var(--ground2)}
.essay .ebody{padding:.5rem 2rem 2.4rem;max-width:780px}
@media(max-width:700px){.essay summary{padding:1.1rem 1.2rem}.essay .ebody{padding:.4rem 1.2rem 1.8rem}.essay summary::after{right:1.1rem}}
.instreg .irow{display:grid;grid-template-columns:3.2fr 1.6fr 1.2fr 3fr;gap:1.2rem;border-bottom:1px solid var(--hair2);padding:.6rem 0;align-items:baseline}
.instreg .iname{font-size:.88rem;color:var(--bone)}
.instreg .iwork{font-size:.82rem;color:var(--bone-dim)}
@media(max-width:880px){.instreg .irow{grid-template-columns:1fr 1fr}.instreg .icat{display:none}}
/* press */
.pressreg .prow{display:grid;grid-template-columns:90px 1fr 190px;gap:1.4rem;align-items:baseline;padding:.95rem 0;border-bottom:1px solid var(--hair2)}
.pressreg .pdate{font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.12em;color:var(--bronze)}
.pressreg .ptitle{font-size:.95rem;color:var(--bone)}
.pressreg .ptitle a{color:var(--bone)}
.pressreg .ptitle a:hover{color:var(--pale)}
.pressreg .poutlet{font-family:'IBM Plex Mono',monospace;font-size:.58rem;letter-spacing:.16em;color:var(--faint);text-align:right;text-transform:uppercase}
.pressreg .prow.hidden-press{display:none}
.pressreg.expanded .prow.hidden-press{display:grid}
@media(max-width:760px){.pressreg .prow{grid-template-columns:74px 1fr}.pressreg .poutlet{display:none}}
/* venice gallery */
.vgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
@media(max-width:760px){.vgrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.vgrid .detail.vg{flex:none;aspect-ratio:4/3}
/* documentary */
.docfeature{display:grid;grid-template-columns:7fr 5fr;gap:3rem;margin-top:3rem;align-items:center;border:1px solid var(--hair2);padding:2rem}
@media(max-width:880px){.docfeature{grid-template-columns:1fr;padding:1.2rem}}
.docembed{position:relative;aspect-ratio:16/9;border:1px solid var(--hair);display:block;overflow:hidden}
.docembed img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.8) brightness(.85);transition:filter .3s}
.docembed:hover img{filter:saturate(1) brightness(1)}
.playbtn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border:1px solid var(--pale);background:rgba(25,21,16,.82);color:var(--pale);display:flex;align-items:center;justify-content:center;font-size:1.3rem;padding-left:4px}
.docembed:hover .playbtn{background:var(--bronze);color:var(--ground)}
/* tours/cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--hair2)}
@media(max-width:880px){.cards{grid-template-columns:1fr}}
.cards article{padding:2.2rem;border-right:1px solid var(--hair2)}
.cards article:last-child{border-right:none}
@media(max-width:880px){.cards article{border-right:none;border-bottom:1px solid var(--hair2)}.cards article:last-child{border-bottom:none}}
.cards h3{font-size:1.4rem;margin:.9rem 0 .7rem}
.cards p{color:var(--bone-dim);font-size:.92rem;margin-bottom:1rem}
.btn{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--hair);padding:.7rem 1.3rem;color:var(--pale)}
.btn:hover{border-color:var(--bronze);color:var(--bone)}
.btn.solid{background:var(--bronze);color:var(--ground);border-color:var(--bronze)}
.btn.solid:hover{background:var(--pale)}
.bio{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem 4.5rem}
@media(max-width:880px){.bio{grid-template-columns:1fr}}
.bio h3{font-size:1.3rem;margin-bottom:.55rem}
.bio p{color:var(--bone-dim);font-size:.93rem;margin-bottom:.8rem}
.bio p:last-child{margin-bottom:0}
.bio-lede p{font-family:'Cormorant Garamond',serif;font-size:1.25rem;line-height:1.55;color:var(--bone)}
.feature{display:grid;grid-template-columns:5fr 7fr;gap:4rem;align-items:start}
@media(max-width:880px){.feature{grid-template-columns:1fr;gap:2rem}}

#lightbox{position:fixed;inset:0;background:rgba(15,12,8,.95);z-index:120;display:none;align-items:center;justify-content:center;flex-direction:column;gap:1rem;padding:4vh 4vw}
#lightbox.open{display:flex}
#lb-stage{overflow:hidden;max-width:90vw;max-height:78vh;border:1px solid var(--hair);cursor:grab;touch-action:none}
#lb-stage img{display:block;max-width:90vw;max-height:78vh;transform-origin:0 0;user-select:none;-webkit-user-drag:none}
#lightbox .cap{font-family:'IBM Plex Mono',monospace;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pale)}
#lightbox .hint{font-family:'IBM Plex Mono',monospace;font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
#lb-close{position:absolute;top:24px;right:28px;background:none;border:1px solid var(--hair);color:var(--pale);font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.2em;padding:.6rem 1rem;cursor:pointer}
#lb-close:hover{border-color:var(--bronze)}
.inquiry{border:1px solid var(--hair);padding:3rem;background:var(--ground2)}
@media(max-width:700px){.inquiry{padding:1.6rem}}
.iqgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.iqgrid textarea,.iqgrid #iq-org{grid-column:1/-1}
@media(max-width:700px){.iqgrid{grid-template-columns:1fr}}
.iqgrid input,.iqgrid textarea{font-family:'Lora',serif;font-size:.92rem;background:var(--ground);border:1px solid var(--hair2);color:var(--bone);padding:.85rem 1rem;resize:vertical}
.iqgrid input:focus,.iqgrid textarea:focus{outline:none;border-color:var(--bronze)}
.iqgrid ::placeholder{color:var(--faint)}
footer{border-top:1px solid var(--hair);margin-top:5rem;padding:5rem 0 4rem;background:var(--ground2);position:relative;z-index:2}
.fgrid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:3.5rem}
@media(max-width:880px){.fgrid{grid-template-columns:1fr}}
footer h3{font-size:1.35rem;margin-bottom:1.2rem}
footer p,footer li{font-size:.88rem;color:var(--bone-dim)}
footer ul{list-style:none}
footer li{margin-bottom:.85rem}
footer .t{color:var(--bone)}
.colophon{margin-top:4rem;border-top:1px solid var(--hair2);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
/* ——— Chronos multi-page components ——— */
/* chapter cards (home TOC) */
.chapcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:980px){.chapcards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.chapcards{grid-template-columns:1fr}}
.chapcard{display:flex;flex-direction:column;border:1px solid var(--hair2);background:var(--ground2);text-decoration:none;transition:border-color .25s,transform .25s}
.chapcard:hover{border-color:var(--bronze);transform:translateY(-3px)}
.cc-img{position:relative;display:block;aspect-ratio:4/3;overflow:hidden}
.cc-img img{width:100%;height:100%;object-fit:cover;object-position:50% 18%;filter:saturate(.7) brightness(.82);transition:filter .4s,transform .6s}
.chapcard:hover .cc-img img{filter:none;transform:scale(1.04)}
.cc-film{position:absolute;top:.7rem;right:.7rem;background:rgba(25,21,16,.85);border:1px solid var(--hair);color:var(--pale);padding:.3rem .55rem;font-size:.52rem}
.cc-body{display:flex;flex-direction:column;gap:.35rem;padding:1.3rem 1.4rem 1.5rem}
.cc-dates{color:var(--bronze);font-size:.6rem}
.cc-num{font-size:.5rem}
.cc-era{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.5rem;color:var(--bone);line-height:1.1}
.cc-head{font-size:.86rem;color:var(--bone-dim)}
.cc-cta{color:var(--bronze);font-size:.54rem;margin-top:.5rem;opacity:0;transition:opacity .25s}
.chapcard:hover .cc-cta{opacity:1}
/* head page */
.headmain{padding-top:7.5rem}
.hp-rail{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--hair2);padding-bottom:1rem;margin-bottom:2.2rem}
.hp-rail a{color:var(--bronze)}.hp-rail a:hover{color:var(--bone)}
.hp-rail-ref{color:var(--faint)}
.hp-open{margin-bottom:2.4rem;padding-top:.5rem}
.hp-era{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.8rem,3.2vw,2.6rem);color:var(--bone);margin:.4rem 0 0}
.hp-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--bone-dim);margin-top:.5rem}
.hp-grid{margin-top:2.5rem}
/* film hero (top of head page) */
.filmhero{position:relative;display:block;width:100%;aspect-ratio:16/9;border:1px solid var(--hair);overflow:hidden;cursor:pointer;background:var(--ground2);margin-bottom:.5rem}
.filmhero img{width:100%;height:100%;object-fit:cover;filter:saturate(.82) brightness(.7);transition:filter .4s,transform .8s}
.filmhero:hover img{filter:saturate(1) brightness(.85);transform:scale(1.03)}
.fh-scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(25,21,16,.88),rgba(25,21,16,.15) 55%,rgba(25,21,16,.35))}
.fh-meta{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;gap:.4rem;padding:1.6rem 1.8rem}
.fh-meta .mono{color:var(--pale)}
.fh-meta b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(1.3rem,2.4vw,2rem);color:var(--bone)}
.fh-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:78px;height:78px;border:1px solid var(--pale);border-radius:50%;background:rgba(25,21,16,.7);color:var(--pale);display:flex;align-items:center;justify-content:center;font-size:1.5rem;padding-left:5px;transition:background .25s,color .25s,transform .25s}
.filmhero:hover .fh-play{background:var(--bronze);color:var(--ground);transform:translate(-50%,-50%) scale(1.08)}
.fh-cta{position:absolute;top:1.4rem;right:1.6rem;color:var(--pale);background:rgba(25,21,16,.7);border:1px solid var(--hair);padding:.4rem .7rem;font-size:.54rem}
.filmhero iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:700px){.fh-play{width:60px;height:60px;font-size:1.2rem}}
/* page spine (static position indicator on head pages) */
#spine.pagespine{opacity:1;pointer-events:auto}
/* pager between head pages */
.pgnav-wrap{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:4rem;border-top:1px solid var(--hair2);padding-top:2.5rem}
@media(max-width:700px){.pgnav-wrap{grid-template-columns:1fr}}
.pgnav{display:flex;flex-direction:column;gap:.4rem;border:1px solid var(--hair2);background:var(--ground2);padding:1.3rem 1.6rem;text-decoration:none;transition:border-color .25s}
.pgnav:hover{border-color:var(--bronze)}
.pgnav.next{text-align:right;align-items:flex-end}
.pgnav b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.2rem;color:var(--bone)}
/* films index */
.filmgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.filmgrid.small{grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.2rem}
@media(max-width:880px){.filmgrid{grid-template-columns:1fr}.filmgrid.small{grid-template-columns:1fr}}
.filmcard{display:flex;flex-direction:column;border:1px solid var(--hair2);background:var(--ground2);text-decoration:none;cursor:pointer;transition:border-color .25s,transform .25s}
.filmcard:hover{border-color:var(--bronze);transform:translateY(-3px)}
.fc-img{position:relative;aspect-ratio:16/9;overflow:hidden}
.fc-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.78) brightness(.74);transition:filter .4s,transform .6s}
.filmcard:hover .fc-img img{filter:none;transform:scale(1.04)}
.fc-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border:1px solid var(--pale);border-radius:50%;background:rgba(25,21,16,.72);color:var(--pale);display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding-left:4px;transition:background .25s,color .25s}
.filmcard:hover .fc-play{background:var(--bronze);color:var(--ground)}
.fc-meta{display:flex;flex-direction:column;gap:.3rem;padding:1.2rem 1.3rem 1.4rem}
.fc-meta .mono{color:var(--bronze);font-size:.54rem}
.fc-meta b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.5rem;color:var(--bone)}
.fc-sub{font-size:.82rem;color:var(--bone-dim)}
.fc-link{color:var(--bronze);font-size:.54rem;margin-top:.4rem}
.filmcard iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.filmcard.small .fc-meta b{font-size:1.2rem}
.filmgrid .filmcard{grid-column:auto}
.fc-link{align-self:flex-start}

/* keep legacy filmpanel styles from hijacking new film containers */
.filmcard.filmpanel,.filmhero.filmpanel,.docembed.filmpanel{aspect-ratio:auto;min-height:0;margin-top:0;border:1px solid var(--hair2);height:auto}
.filmcard.filmpanel{display:flex;flex-direction:column}
.filmcard.filmpanel b,.filmhero.filmpanel b,.docembed.filmpanel b{display:none}
.filmhero.filmpanel{aspect-ratio:16/9}
.docembed.filmpanel{aspect-ratio:16/9;display:block}
.filmcard .fc-img,.filmhero{position:relative}
.filmcard.playing .fc-img{aspect-ratio:16/9}
/* when playing, iframe fills the media area only */
.filmcard.playing .fc-meta{display:none}
.filmcard.playing{aspect-ratio:16/9}

/* —— per-chapter accent (sampled from catalog separators) —— */
.headpage .co-dates,.headpage .datebig .bc{color:var(--chapter-lift)}
.headpage .hp-rail a{color:var(--chapter-lift)}
.headpage .refline{border-left-color:var(--chapter)}
.headpage .refline .r{color:var(--chapter-lift)}
.headpage .spec .sk{color:var(--chapter-lift)}
.headpage .chap-dates{color:var(--chapter-lift)}
.headpage .glance{border-color:var(--chapter)}
.headpage .glance .gtitle,.headpage .glance .gk{color:var(--chapter-lift)}
.headpage .glance .gr{border-left-color:var(--chapter)}
.headpage .words{border-left-color:var(--chapter)}
.headpage .wordsband .mono.dim{color:var(--chapter-lift)}
.headpage .chap-head .mono{color:var(--chapter-lift)}
.headpage .engrave span{border-color:var(--chapter)}
.headpage .filmhero{border-color:var(--chapter)}
.headpage .filmhero:hover .fh-play{background:var(--chapter);border-color:var(--chapter)}
.headpage .fh-cta{color:var(--chapter-lift);border-color:var(--chapter)}
.headpage .pgnav:hover{border-color:var(--chapter)}
.headpage .loupe-wrap:hover img,.headpage .detail:hover img,.headpage .fig:hover img{border-color:var(--chapter)}
.headpage a.mono:hover{color:var(--chapter-lift)}
/* spine on a head page takes the chapter color */
#spine.pagespine .fill{background:var(--chapter)}
#spine.pagespine .dot{background:var(--chapter-lift)}
#spine.pagespine .tick.on{background:var(--chapter);border-color:var(--chapter)}
#spine.pagespine .yr{color:var(--chapter-lift);border-color:var(--chapter)}
.chapcard .cc-dates{color:var(--chapter-lift)}
.chapcard:hover{border-color:var(--chapter)}
.chapcard:hover .cc-cta{color:var(--chapter-lift)}
.chapcard .cc-film{color:var(--chapter-lift)}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}.route{animation:none}}

/* Mobile Menu Style */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  z-index: 101;
  align-self: center;
}
.menu-toggle .bar {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--pale, #D9BD8C);
  margin: 5px auto;
  transition: all 0.3s;
}
@media(max-width: 920px) {
  .menu-toggle {
    display: block !important;
  }
  body>nav, nav {
    position: fixed !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    left: 0 !important;
    top: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
  body>nav > ul, nav > ul {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100vh !important;
    background: rgba(25, 21, 16, 0.98) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity 0.3s ease !important;
    z-index: 100 !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 24px !important;
  }
  body>nav.menu-open > ul, nav.menu-open > ul {
    opacity: 1 !important;
    pointer-events: auto !important;
  }
  body>nav.menu-open, nav.menu-open {
    background: transparent !important;
    border-bottom-color: transparent !important;
  }
  body>nav.menu-open .menu-toggle .bar:nth-child(1), nav.menu-open .menu-toggle .bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg) !important;
  }
  body>nav.menu-open .menu-toggle .bar:nth-child(2), nav.menu-open .menu-toggle .bar:nth-child(2) {
    opacity: 0 !important;
  }
  body>nav.menu-open .menu-toggle .bar:nth-child(3), nav.menu-open .menu-toggle .bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg) !important;
  }
  body>nav > ul > li > a, nav > ul > li > a {
    font-size: 1.2rem !important;
    padding: 10px !important;
  }
  
    body>nav ul .dropdown-menu, nav ul .dropdown-menu {
      flex-direction: column !important;
      align-items: center !important;
      gap: 8px !important;
      padding: 10px 0 !important;
    }
    body>nav ul .dropdown-menu li a, nav ul .dropdown-menu li a {
      font-size: 0.9rem !important;
    }
    
}