/* ============================================================
   THE COORDINATION LAYER — Shared Atlas stylesheet
   Systems Change Atlas · Edition 01
   ============================================================ */
:root{
  --ink:#0C2438; --ink2:#11304F; --ink3:#0a1c2e;
  --paper:#F2EAD9; --paper2:#E9DDC4; --paper3:#fbf6ec;
  --blue:#1C66A0; --crim:#C8324E; --rust:#C5512B; --gold:#C99A3F; --sage:#6E8B4E;
  --mut:#5C6675; --mutd:#A9BDD2; --line:#C9BCA0; --lined:#26405b;
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"Fraunces",Georgia,serif; color:var(--ink); background:var(--paper);
  font-optical-sizing:auto; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
::selection{background:var(--crim);color:#fff}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---- type helpers ---- */
.disp{font-family:"Anton",sans-serif;font-weight:400;letter-spacing:.01em;line-height:.92;text-transform:uppercase}
.mono{font-family:"Space Mono",monospace}
.kick{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.22em;font-weight:700;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6em}
.kick::before{content:"";width:.55em;height:.55em;background:var(--crim);display:inline-block}
.serif-it{font-style:italic}

/* ---- blueprint grid bg ---- */
.grid-bg{position:relative}
.grid-bg::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(var(--gl) 1px,transparent 1px),linear-gradient(90deg,var(--gl) 1px,transparent 1px);
  background-size:38px 38px;
}
section.paper{--gl:rgba(28,58,92,.055)}
section.ink{--gl:rgba(150,185,220,.05)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px);position:relative;z-index:1}

/* ---- registration ticks ---- */
.ticks::before,.ticks::after{content:"";position:absolute;width:18px;height:18px;z-index:2;pointer-events:none}
.ticks::before{top:22px;left:22px;border-top:1px solid var(--tc);border-left:1px solid var(--tc)}
.ticks::after{bottom:22px;right:22px;border-bottom:1px solid var(--tc);border-right:1px solid var(--tc)}
section.paper{--tc:rgba(28,58,92,.35)}
section.ink{--tc:rgba(150,185,220,.4)}

/* ---- nav ---- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(20px,5vw,40px);
  background:rgba(12,36,56,.0);transition:background .4s,backdrop-filter .4s;mix-blend-mode:normal}
header.nav.solid{background:rgba(9,26,42,.92);backdrop-filter:blur(8px)}
header.nav.opaque{background:rgba(9,26,42,.96);backdrop-filter:blur(8px)}
.nav .brand{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:1rem;letter-spacing:.02em;color:#fff;line-height:1}
.nav .brand b{color:var(--crim)}
.nav .links{display:flex;gap:24px;align-items:center}
.nav .links>a,.nav .drop>button{font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#d6e2ee;opacity:.82;transition:opacity .25s,color .25s;background:none;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.nav .links>a:hover,.nav .drop:hover>button,.nav .drop:focus-within>button,.nav .links>a.active{opacity:1;color:#fff}
.nav .links>a.active::after{content:"";display:inline-block;width:5px;height:5px;background:var(--crim);margin-left:7px}
.nav .ed{font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.18em;color:#9fb7ce}
/* dropdown */
.nav .drop{position:relative}
.nav .drop>button .car{font-size:.6em;opacity:.7;transform:translateY(1px)}
.nav .drop .menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:226px;background:rgba(9,26,42,.98);border:1px solid var(--lined);backdrop-filter:blur(10px);
  padding:8px;opacity:0;visibility:hidden;transition:opacity .22s,transform .22s;z-index:120}
.nav .drop .menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.nav .drop:hover .menu,.nav .drop:focus-within .menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav .drop .menu a{display:block;padding:10px 12px;font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;color:#cfdcea;border-left:2px solid transparent;transition:.2s}
.nav .drop .menu a:hover{background:rgba(200,50,78,.12);border-left-color:var(--crim);color:#fff}
.nav .drop .menu a small{display:block;font-family:"Fraunces",serif;text-transform:none;letter-spacing:0;font-size:.78rem;color:#8aa2bb;margin-top:3px;font-style:italic}
.menubtn{display:none;background:none;border:1px solid rgba(255,255,255,.3);color:#fff;padding:7px 12px;font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer}
.progress{position:fixed;top:0;left:0;height:2px;background:var(--crim);width:0;z-index:101}
@media(max-width:980px){
  .nav .links{display:none;position:absolute;top:100%;right:0;left:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(9,26,42,.98);padding:10px clamp(20px,5vw,40px) 22px;border-top:1px solid var(--lined)}
  .nav.menu-open .links{display:flex}
  .nav .links>a,.nav .drop>button{padding:13px 0;opacity:1;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav .drop{width:100%}
  .nav .drop .menu{position:static;transform:none;opacity:1;visibility:visible;background:none;border:0;padding:0 0 8px 12px;min-width:0;backdrop-filter:none}
  .nav .drop .menu a small{display:none}
  .nav .ed{display:none}
  .menubtn{display:inline-block}
}

/* ---- hero (home) ---- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
.hero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;
  transform:scale(1.08);animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero .scrim{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(8,22,36,.96) 2%,rgba(8,22,36,.55) 32%,rgba(8,22,36,.05) 62%),
  linear-gradient(to right,rgba(8,22,36,.7),rgba(8,22,36,0) 55%)}
.hero .topbar{position:absolute;top:64px;left:0;right:0;z-index:3;display:flex;justify-content:space-between;
  padding:0 clamp(20px,5vw,72px);max-width:var(--maxw);margin:0 auto}
.hero .topbar span{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.24em;color:#d8e2ee;text-transform:uppercase}
.hero .inner{position:relative;z-index:3;width:100%;padding-bottom:clamp(40px,7vh,90px)}
.hero h1{color:#fff;font-size:clamp(3.4rem,12vw,11rem);margin:.18em 0 .12em;letter-spacing:0}
.hero .sub{font-size:clamp(1.05rem,1.9vw,1.5rem);max-width:30ch;color:#eaf0f6;line-height:1.45;font-weight:340}
.hero .kick{color:#e7c97a}.hero .kick::before{background:var(--gold)}
.hero .plate{position:absolute;right:0;bottom:clamp(40px,7vh,90px);text-align:right;font-family:"Space Mono",monospace;
  font-size:.7rem;letter-spacing:.2em;color:#bfd0e0;line-height:1.7;text-transform:uppercase}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.3em;color:#cfe0f0;text-transform:uppercase;opacity:.85;
  display:flex;flex-direction:column;align-items:center;gap:8px;animation:bob 2.4s ease-in-out infinite}
.scrollcue i{width:1px;height:34px;background:linear-gradient(#cfe0f0,transparent)}
@keyframes bob{50%{transform:translate(-50%,8px)}}

/* ---- page hero (sub-pages) ---- */
.phero{position:relative;min-height:74svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink3)}
.phero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 34%;
  transform:scale(1.06);animation:heroZoom 16s ease-out forwards}
.phero .scrim{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(8,22,36,.97) 4%,rgba(8,22,36,.6) 38%,rgba(8,22,36,.18) 78%),
  linear-gradient(to right,rgba(8,22,36,.72),rgba(8,22,36,0) 62%)}
.phero .inner{position:relative;z-index:3;width:100%;padding:0 0 clamp(40px,7vh,84px)}
.phero .crumb{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:#aebfd2;display:flex;gap:10px;align-items:center;margin-bottom:22px;flex-wrap:wrap}
.phero .crumb a{opacity:.8;transition:.2s}.phero .crumb a:hover{opacity:1;color:#fff}
.phero .crumb span{color:#e7c97a}
.phero h1{color:#fff;font-size:clamp(2.6rem,8vw,6.4rem);margin:.04em 0 .26em;max-width:16ch}
.phero .sub{font-size:clamp(1.05rem,1.7vw,1.4rem);max-width:50ch;color:#eaf0f6;line-height:1.5;font-weight:340}
.phero .kick{color:#e7c97a}.phero .kick::before{background:var(--gold)}
.phero .runon{position:absolute;right:0;bottom:clamp(40px,7vh,84px);text-align:right;font-family:"Space Mono",monospace;
  font-size:.68rem;letter-spacing:.2em;color:#bfd0e0;line-height:1.8;text-transform:uppercase}
@media(max-width:860px){.phero .runon{display:none}}

/* ---- section sub-nav (sticky in-page) ---- */
.subnav{position:sticky;top:0;z-index:60;background:var(--ink);border-bottom:1px solid var(--lined)}
.subnav .wrap{display:flex;gap:6px;overflow-x:auto;padding-top:0;padding-bottom:0;scrollbar-width:none}
.subnav .wrap::-webkit-scrollbar{display:none}
.subnav a{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;
  color:#9fb7ce;padding:16px 16px;white-space:nowrap;border-bottom:2px solid transparent;transition:.2s}
.subnav a:hover,.subnav a.active{color:#fff;border-bottom-color:var(--crim)}

/* ---- section frame ---- */
section{position:relative;padding:clamp(70px,9vh,130px) 0}
section.ink{background:var(--ink);color:var(--paper)}
section.paper{background:var(--paper)}
.shead{display:flex;flex-direction:column;gap:14px;margin-bottom:clamp(34px,5vh,64px)}
.shead .kick{color:var(--mut)}
section.ink .shead .kick{color:#e7c97a}
section.ink .kick::before{background:var(--gold)}
.shead h2{font-size:clamp(2rem,5.2vw,4.2rem);max-width:18ch}
section.ink .shead h2{color:#fff}
.lede{font-size:clamp(1.05rem,1.5vw,1.35rem);line-height:1.55;max-width:62ch;color:var(--ink)}
section.ink .lede{color:var(--mutd)}
.lede.tint{color:var(--mut)}

/* layout utils */
.cols2{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start}
.cols2.rev{grid-template-columns:1fr 1.1fr}
.cols2.even{grid-template-columns:1fr 1fr}
@media(max-width:860px){.cols2,.cols2.rev,.cols2.even{grid-template-columns:1fr;gap:34px}}
.prose p{font-size:1.02rem;line-height:1.62;color:var(--ink);margin-bottom:1.1em;max-width:62ch}
section.ink .prose p{color:var(--mutd)}
.prose p.first::first-letter{font-family:"Anton",sans-serif;float:left;font-size:3.6em;line-height:.78;padding:.04em .12em 0 0;color:var(--crim)}
.prose strong{color:var(--ink);font-weight:600}
section.ink .prose strong{color:#fff}

/* numbered legend list */
.legend{display:flex;flex-direction:column}
.legend .row{display:grid;grid-template-columns:2.4em 1fr;gap:14px;padding:15px 0;border-top:1px solid var(--line)}
section.ink .legend .row{border-color:var(--lined)}
.legend .row:last-child{border-bottom:1px solid var(--line)}
section.ink .legend .row:last-child{border-bottom-color:var(--lined)}
.legend .n{font-family:"Space Mono",monospace;font-weight:700;color:var(--crim);font-size:.95rem;padding-top:.15em}
.legend .h{font-family:"Space Mono",monospace;font-size:.95rem;line-height:1.5;color:inherit}
.legend .b{font-size:.95rem}

/* cards */
.cards{display:grid;gap:18px}
.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g3,.g4,.g2{grid-template-columns:1fr}}
.card{background:var(--paper3);border:1px solid var(--line);padding:26px 24px 28px;position:relative;
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ac,var(--crim))}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -22px rgba(12,36,56,.5)}
section.ink .card{background:var(--ink2);border-color:var(--lined)}
.card .num{font-family:"Space Mono",monospace;font-size:.8rem;color:var(--ac,var(--crim));font-weight:700;letter-spacing:.1em}
.card h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;font-size:1.35rem;letter-spacing:.01em;margin:.4em 0 .3em;line-height:1.05}
section.ink .card h3{color:#fff}
.card p{font-size:.93rem;color:var(--mut);line-height:1.5}
section.ink .card p{color:var(--mutd)}
.card ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:7px}
.card ul li{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.06em;color:var(--mut);padding-left:16px;position:relative;line-height:1.5}
section.ink .card ul li{color:var(--mutd)}
.card ul li::before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;background:var(--ac,var(--crim))}

/* media frames */
.media{position:relative;border:1px solid var(--line);overflow:hidden}
section.ink .media{border-color:var(--lined)}
.media img{width:100%;height:100%;object-fit:cover}
.media .plate{position:absolute;left:0;bottom:0;background:rgba(9,26,42,.82);color:#cfe0f0;
  font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.2em;padding:7px 12px;text-transform:uppercase}

/* figure with caption (atlas plate) */
.figure{position:relative}
.figure .frame{position:relative;border:1px solid var(--line);overflow:hidden;background:#06121e}
section.ink .figure .frame{border-color:var(--lined)}
.figure img{width:100%;height:100%;object-fit:cover;display:block}
.figure figcaption{display:flex;justify-content:space-between;gap:16px;margin-top:12px;
  font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mut)}
section.ink .figure figcaption{color:var(--mutd)}
.figure figcaption b{color:var(--crim);font-weight:700}
.figure .tag{position:absolute;top:0;left:0;background:rgba(9,26,42,.85);color:#e7c97a;
  font-family:"Space Mono",monospace;font-size:.6rem;letter-spacing:.2em;padding:6px 11px;text-transform:uppercase;z-index:2}

/* image gallery / mosaic */
.gallery{display:grid;gap:14px}
.gallery.g-mosaic{grid-template-columns:repeat(4,1fr);grid-auto-rows:200px}
.gallery.g-mosaic .gi{position:relative;overflow:hidden;border:1px solid var(--line)}
section.ink .gallery .gi{border-color:var(--lined)}
.gallery .gi img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.gallery .gi:hover img{transform:scale(1.05)}
.gallery .gi .cap{position:absolute;left:0;bottom:0;background:rgba(9,26,42,.82);color:#cfe0f0;
  font-family:"Space Mono",monospace;font-size:.58rem;letter-spacing:.16em;padding:6px 10px;text-transform:uppercase}
.gi.tall{grid-row:span 2}.gi.wide{grid-column:span 2}.gi.big{grid-column:span 2;grid-row:span 2}
@media(max-width:860px){.gallery.g-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.gi.big{grid-column:span 2}}

/* feature block — alternating image + text */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;
  padding:clamp(40px,6vh,80px) 0;border-top:1px solid var(--line)}
section.ink .feature{border-color:var(--lined)}
.feature.rev .ftext{order:2}
.feature .fimg{position:relative;overflow:hidden;border:1px solid var(--line);background:#06121e}
section.ink .feature .fimg{border-color:var(--lined)}
.feature .fimg img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.feature .fimg .tag{position:absolute;top:0;left:0;background:rgba(9,26,42,.85);color:#e7c97a;
  font-family:"Space Mono",monospace;font-size:.6rem;letter-spacing:.2em;padding:6px 11px;text-transform:uppercase}
.feature .lab{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--crim);font-weight:700}
.feature h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.02;margin:.3em 0 .4em}
section.ink .feature h3{color:#fff}
.feature p{font-size:1rem;line-height:1.6;color:var(--mut);margin-bottom:1em;max-width:54ch}
section.ink .feature p{color:var(--mutd)}
@media(max-width:860px){.feature{grid-template-columns:1fr;gap:26px}.feature.rev .ftext{order:0}}

/* aside / callout */
.callout{border:1px solid var(--line);border-left:4px solid var(--gold);background:var(--paper3);padding:26px 28px;margin:8px 0}
section.ink .callout{background:var(--ink2);border-color:var(--lined);border-left-color:var(--gold)}
.callout .ck{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:block}
.callout p{font-size:1.04rem;line-height:1.55;color:var(--ink)}
section.ink .callout p{color:#eaf0f6}
.callout.crim{border-left-color:var(--crim)}.callout.crim .ck{color:var(--crim)}
.callout.blue{border-left-color:var(--blue)}.callout.blue .ck{color:var(--blue)}

/* big number row */
.bignums{display:grid;grid-template-columns:repeat(4,1fr);gap:0 clamp(24px,4vw,48px)}
@media(max-width:780px){.bignums{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.bignums{grid-template-columns:1fr}}
.bignum{padding:22px 0;border-top:1px solid var(--line)}
section.ink .bignum{border-color:var(--lined)}
.bignum .v{font-family:"Anton",sans-serif;font-size:clamp(2.4rem,5vw,3.6rem);line-height:.9;color:var(--crim)}
section.ink .bignum .v{color:#fff}
.bignum .l{font-family:"Space Mono",monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mut);margin-top:10px;line-height:1.5}
section.ink .bignum .l{color:var(--mutd)}

/* pull quote */
.pquote{background:var(--ink);color:#fff;padding:clamp(34px,5vw,60px);position:relative;overflow:hidden}
.pquote.grid-bg::before{--gl:rgba(150,185,220,.06)}
.pquote .kick{color:#e7c97a;margin-bottom:18px}.pquote .kick::before{background:var(--crim)}
.pquote q{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;quotes:none;
  font-size:clamp(1.5rem,3.4vw,2.9rem);line-height:1.04;display:block;letter-spacing:.005em}
.pquote .src{font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.2em;color:var(--mutd);margin-top:20px;text-transform:uppercase}

/* role rows */
.roles{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(30px,5vw,64px)}
@media(max-width:780px){.roles{grid-template-columns:1fr}}
.role{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:20px 0;border-top:1px solid var(--line);align-items:start}
.role .ix{font-family:"Space Mono",monospace;font-size:.72rem;color:var(--crim);font-weight:700;letter-spacing:.12em}
.role h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;font-size:1.3rem;line-height:1.05;margin:.15em 0 .25em}
.role p{font-size:.92rem;color:var(--mut);font-style:italic;line-height:1.45}
.role .dot{width:30px;height:30px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-top:2px}
.role .dot span{width:9px;height:9px;background:var(--ac,var(--crim))}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--cc,var(--line));padding:9px 14px;display:inline-flex;align-items:center;gap:9px;color:inherit}
.chip::before{content:"";width:.5em;height:.5em;background:var(--cc,var(--crim))}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;padding:14px 24px;border:1px solid var(--crim);background:var(--crim);color:#fff;cursor:pointer;transition:.25s}
.btn:hover{background:transparent;color:var(--crim)}
section.ink .btn:hover{color:#fff;border-color:#fff}
.btn.ghost{background:transparent;border-color:currentColor}
.btn.ghost{color:var(--ink)}section.ink .btn.ghost{color:#eaf0f6}
.btn.ghost:hover{background:rgba(200,50,78,.1);border-color:var(--crim);color:var(--crim)}
section.ink .btn.ghost:hover{color:#fff}
.btn .ar{transition:transform .25s}.btn:hover .ar{transform:translateX(4px)}

/* map split */
.mapsplit{display:grid;grid-template-columns:1fr 1fr;min-height:78vh}
@media(max-width:860px){.mapsplit{grid-template-columns:1fr}}
.mapsplit .visual{position:relative;background:#06121e}
.mapsplit .visual img{width:100%;height:100%;object-fit:cover;min-height:42vh}
.mapsplit .panel{padding:clamp(40px,6vw,84px) clamp(24px,4vw,64px);display:flex;flex-direction:column;justify-content:center}

/* chart */
.chartwrap{padding:6px 0}
.bars{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,3vw,40px);align-items:end;height:300px;
  border-bottom:1px solid var(--line);padding-bottom:0}
.bar{display:flex;flex-direction:column-reverse;align-items:stretch;position:relative;transform-origin:bottom;
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.js .bar{transform:scaleY(0)}
.in .bar{transform:scaleY(1)}
.bar span{display:block}
.bar .yr{position:absolute;bottom:-26px;left:0;right:0;text-align:center;font-family:"Space Mono",monospace;font-size:.74rem;color:var(--mut)}
.axis{font-family:"Space Mono",monospace;font-size:.7rem;color:var(--mut)}
.clegend{display:flex;flex-wrap:wrap;gap:18px;margin-top:40px}
.clegend b{display:inline-flex;align-items:center;gap:8px;font-family:"Space Mono",monospace;font-size:.72rem;font-weight:400;letter-spacing:.08em;color:var(--mut)}
.clegend b i{width:12px;height:12px;display:inline-block}

/* timeline */
.timeline{position:relative;padding-left:42px}
.timeline::before{content:"";position:absolute;left:13px;top:8px;bottom:8px;width:2px;background:var(--crim);opacity:.5}
.phase{position:relative;padding:18px 0 28px}
.phase .node{position:absolute;left:-35px;top:22px;width:16px;height:16px;border-radius:50%;background:var(--ac);box-shadow:0 0 0 4px var(--paper)}
section.ink .phase .node{box-shadow:0 0 0 4px var(--ink)}
.phase .pk{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.2em;color:var(--ac);font-weight:700;text-transform:uppercase}
.phase h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;font-size:1.5rem;margin:.2em 0 .3em}
section.ink .phase h3{color:#fff}
.phase p{color:var(--mut);font-size:.95rem;line-height:1.5;max-width:60ch}
section.ink .phase p{color:var(--mutd)}

/* stat grid */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0 clamp(24px,4vw,54px)}
@media(max-width:780px){.stats{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.stats{grid-template-columns:1fr}}
.stat{padding:24px 0;border-top:1px solid var(--lined)}
.stat .sk{display:flex;align-items:center;gap:10px}
.stat .sk i{width:11px;height:11px;background:var(--crim)}
.stat h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;font-size:1.5rem;color:#fff;letter-spacing:.02em}
.stat p{color:var(--mutd);font-size:.9rem;margin-top:6px;line-height:1.45}

/* band */
.band{position:relative;min-height:62vh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band .sc{position:absolute;inset:0}
.band.warm .sc{background:linear-gradient(90deg,rgba(8,22,36,.86),rgba(8,22,36,.28) 58%,rgba(120,50,20,.12))}
.band.cool .sc{background:linear-gradient(90deg,rgba(8,22,36,.9),rgba(8,22,36,.4) 60%,rgba(8,22,36,.2))}
.band .inner{position:relative;z-index:2;width:100%}
.band .bq{color:#fff;font-size:clamp(1.7rem,4.4vw,3.6rem);max-width:20ch;line-height:1.04;margin-top:14px}
.band .kick{color:#e7c97a}.band .kick::before{background:var(--gold)}

/* big closing */
.closing{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.closing .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 60%}
.closing .scrim{position:absolute;inset:0;background:linear-gradient(to right,rgba(8,22,36,.92),rgba(8,22,36,.55) 60%,rgba(8,22,36,.3))}
.closing .inner{position:relative;z-index:2;width:100%}
.closing h2{color:#fff;font-size:clamp(3rem,11vw,9rem);margin:.1em 0}
.closing .man{font-size:clamp(1.1rem,1.9vw,1.5rem);max-width:46ch;color:#eaf0f6;line-height:1.5}
.closing .kick{color:#e7c97a}.closing .kick::before{background:var(--gold)}

/* related pages (cross-link cards) */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--lined)}
@media(max-width:860px){.related{grid-template-columns:1fr}}
.related a{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:280px;overflow:hidden;background:var(--ink2)}
.related a img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.4;transition:transform .8s cubic-bezier(.2,.7,.2,1),opacity .5s}
.related a:hover img{transform:scale(1.06);opacity:.55}
.related a .ra{position:relative;z-index:2;padding:28px 26px}
.related a .rk{font-family:"Space Mono",monospace;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#e7c97a}
.related a h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-weight:400;color:#fff;font-size:1.6rem;line-height:1.02;margin:.4em 0 .3em}
.related a p{font-size:.88rem;color:var(--mutd);line-height:1.45;max-width:30ch}
.related a .go{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-top:14px;display:inline-flex;gap:8px;align-items:center}
.related a:hover .go .ar{transform:translateX(4px)}.related a .go .ar{transition:transform .25s}

/* footer */
footer{background:var(--ink3);color:var(--mutd);padding:54px 0 40px}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
@media(max-width:860px){footer .wrap{grid-template-columns:1fr 1fr}}
@media(max-width:520px){footer .wrap{grid-template-columns:1fr}}
footer .fb{font-family:"Anton",sans-serif;text-transform:uppercase;color:#fff;font-size:1.3rem;line-height:1.05}
footer .fb b{color:var(--crim)}
footer .ftag{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;margin-top:14px;line-height:1.8;color:#7d93ac}
footer .fcol h4{font-family:"Space Mono",monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#e7c97a;margin-bottom:14px}
footer .fcol a{display:block;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#aebfd2;padding:6px 0;transition:.2s}
footer .fcol a:hover{color:#fff}
footer .frule{grid-column:1/-1;border-top:1px solid var(--lined);margin-top:18px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:"Space Mono",monospace;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#6d839c}

/* reveal */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}.hero .bg,.phero .bg{animation:none;transform:scale(1)}
  .bar{transform:scaleY(1);transition:none}.scrollcue{animation:none}
}
.eyebrow-strip{display:flex;gap:26px;flex-wrap:wrap;font-family:"Space Mono",monospace;font-size:.7rem;letter-spacing:.16em;color:var(--mut);text-transform:uppercase;border-top:1px solid var(--line);padding-top:18px;margin-top:30px}
section.ink .eyebrow-strip{color:var(--mutd);border-color:var(--lined)}
