/* future3.ai — "Instrument" design system (shared by overview + strategy reports) */
:root{
  color-scheme: dark;
  /* warm-charcoal surfaces, brand hue ~75 (ochre) */
  --bg:        oklch(0.176 0.012 75);
  --bg-raised: oklch(0.208 0.013 75);
  --bg-sunken: oklch(0.142 0.010 75);
  --ink:       oklch(0.915 0.014 80);
  --ink-2:     oklch(0.715 0.013 80);
  --ink-3:     oklch(0.560 0.012 80);
  --line:      oklch(0.330 0.013 75);
  --line-2:    oklch(0.262 0.011 75);
  /* one accent + two coded channel hues */
  --ochre:     oklch(0.795 0.118 78);
  --ochre-2:   oklch(0.640 0.095 76);
  --steel:     oklch(0.730 0.058 236);
  --terra:     oklch(0.690 0.120 47);

  --display:"Archivo","Arial Narrow",sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,SFMono-Regular,monospace;

  --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px;
  --wrap:1080px;
}
*{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink);
  font:400 16px/1.72 var(--body);
  letter-spacing:.005em;
  background-image:
    repeating-linear-gradient(to right, transparent 0 47px, oklch(0.795 0.118 78 / .022) 47px 48px),
    repeating-linear-gradient(to bottom, transparent 0 47px, oklch(0.795 0.118 78 / .015) 47px 48px),
    radial-gradient(120% 70% at 84% -8%, oklch(0.795 0.118 78 / .10), transparent 60%);
  background-repeat:repeat, repeat, no-repeat;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(20px,5vw,56px)}
.exp{font-family:var(--display);font-stretch:125%;font-variation-settings:"wdth" 125}
.mono{font-family:var(--mono)}
.tnum{font-variant-numeric:tabular-nums}

/* reveal on load */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rise{animation:rise .9s cubic-bezier(.16,1,.3,1) both}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.21s}.d4{animation-delay:.29s}
@media(prefers-reduced-motion:reduce){.rise{animation:none}}

/* ---------- faceplate masthead ---------- */
.face{border-bottom:1px solid var(--line)}
.face .wrap{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);
  padding-block:14px;flex-wrap:wrap}
.brand{font-family:var(--display);font-stretch:125%;font-weight:800;font-size:18px;
  letter-spacing:.02em;text-transform:uppercase;color:var(--ink);text-decoration:none;border:0}
.brand sup{color:var(--ochre);font-size:.6em;font-weight:700;top:-.7em}
.face-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3)}
.face-meta b{color:var(--ink-2);font-weight:500}

/* ---------- hero ---------- */
.hero{padding-block:clamp(44px,8vw,96px) clamp(28px,4vw,52px)}
.tagline{font-family:var(--mono);font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ochre);display:flex;align-items:center;gap:14px}
.tagline::before{content:"";width:34px;height:1px;background:var(--ochre)}
.wordmark{font-family:var(--display);font-stretch:125%;font-weight:800;
  font-size:clamp(62px,13.5vw,176px);line-height:.86;letter-spacing:-.025em;
  text-transform:uppercase;margin-top:var(--s-5)}
.wordmark sup{color:var(--ochre);font-size:.36em;font-weight:700;top:-.96em;letter-spacing:0}
.wordmark .dim{color:var(--ink-3);font-stretch:100%;font-weight:500;font-size:.34em;
  text-transform:lowercase;letter-spacing:-.01em;margin-left:.05em}
.thesis{font-family:var(--display);font-stretch:100%;font-weight:500;
  font-size:clamp(20px,2.5vw,27px);line-height:1.4;max-width:24ch;margin-top:var(--s-6);
  color:var(--ink)}
.thesis b{color:var(--ochre);font-weight:600}
.subhead{font-size:clamp(15px,1.6vw,17px);color:var(--ink-2);max-width:62ch;margin-top:var(--s-4);line-height:1.66}

/* hero readout band (faceplate, NOT metric cards) */
.band{display:flex;flex-wrap:wrap;border:1px solid var(--line);margin-top:clamp(34px,5vw,52px)}
.band > div{flex:1 1 160px;padding:18px 22px;border-right:1px solid var(--line)}
.band > div:last-child{border-right:0}
.band dt{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.band dd{font-family:var(--display);font-stretch:115%;font-weight:700;font-size:clamp(22px,2.6vw,30px);
  margin-top:10px;letter-spacing:-.01em;font-variant-numeric:tabular-nums;line-height:1.05}
.band dd small{font-size:.5em;color:var(--ink-2);font-weight:600;margin-left:1px}
.band em{font-style:normal;display:block;font-family:var(--body);font-size:12px;color:var(--ink-2);
  margin-top:8px;line-height:1.45}
.withhold{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);
  margin-top:var(--s-4);line-height:1.7;max-width:78ch}
.withhold b{color:var(--ink-2);font-weight:500}

/* ---------- sections ---------- */
section{padding-block:clamp(48px,6.5vw,86px) 0}
.sec-no{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ochre)}
h2{font-family:var(--display);font-stretch:118%;font-weight:700;
  font-size:clamp(28px,4vw,46px);line-height:1.05;letter-spacing:-.02em;text-transform:uppercase;
  margin-top:var(--s-3);max-width:18ch}
.lede{font-size:clamp(16px,1.8vw,18.5px);color:var(--ink-2);max-width:66ch;margin-top:var(--s-5);line-height:1.7}
.lede b{color:var(--ink);font-weight:600}
p{margin-top:var(--s-4);max-width:68ch;line-height:1.72}
a{color:var(--ochre);text-decoration:none;border-bottom:1px solid color-mix(in oklch,var(--ochre),transparent 60%)}
a:hover{border-bottom-color:var(--ochre)}

/* ---------- strategy spec entries (overview) ---------- */
.entry{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(26px,4.5vw,64px);
  padding-block:clamp(30px,4vw,46px);border-top:1px solid var(--line);align-items:start}
.entry:first-of-type{border-top:1px solid var(--ink-3)}
.entry .idx{font-family:var(--display);font-stretch:125%;font-weight:800;font-size:13px;
  color:var(--ochre);letter-spacing:.06em}
.tags{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.tags .ch{color:var(--ch,var(--ochre))}
.entry h3{font-family:var(--display);font-stretch:118%;font-weight:700;text-transform:uppercase;
  font-size:clamp(22px,2.7vw,31px);line-height:1.04;letter-spacing:-.015em;margin-top:10px}
.entry h3 small{display:block;font-family:var(--body);font-stretch:100%;font-weight:500;
  text-transform:none;font-size:15px;color:var(--ink-2);letter-spacing:0;margin-top:7px}
.entry .thesis-s{font-size:15.5px;color:var(--ink);margin-top:var(--s-4);max-width:52ch;line-height:1.66}
.entry .how{font-size:13.5px;color:var(--ink-2);margin-top:var(--s-3);max-width:54ch;line-height:1.66}
.entry .how b{color:var(--ink);font-weight:600}
.entry .how.note{color:var(--ch,var(--ochre));opacity:.92}
.more{font-family:var(--mono);font-size:12px;letter-spacing:.04em;display:inline-block;margin-top:var(--s-4)}

.ch-ochre{--ch:var(--ochre)} .ch-steel{--ch:var(--steel)} .ch-terra{--ch:var(--terra)}

/* readout (small instrument chart, overview) */
.readout{border:1px solid var(--line);background:
  linear-gradient(180deg, oklch(0.20 0.013 75), oklch(0.165 0.011 75))}
.readout svg{display:block;width:100%;height:auto}
.r-grid{stroke:var(--line-2);stroke-width:1}
.r-fill{fill:var(--ch,var(--ochre));opacity:.10}
.r-line{fill:none;stroke:var(--ch,var(--ochre));stroke-width:1.7;stroke-linejoin:round;stroke-linecap:round}
.r-base{stroke:var(--ink-3);stroke-width:.8;stroke-dasharray:1 4}
.r-datum{font-family:var(--mono);font-size:8px;fill:var(--ink-3);letter-spacing:.04em}
.r-tick{font-family:var(--mono);font-size:9px;fill:var(--ink-3);letter-spacing:.06em}
.readout figcaption{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;
  text-transform:uppercase;color:var(--ink-3);line-height:1.6;padding:10px 14px;border-top:1px solid var(--line)}
.readout figcaption b{color:var(--ch,var(--ochre));font-weight:500}

/* qualitative spec list */
.spec{border:1px solid var(--line)}
.spec > div{display:flex;justify-content:space-between;gap:16px;align-items:baseline;
  padding:14px 16px;border-top:1px solid var(--line-2)}
.spec > div:first-child{border-top:0}
.spec dt{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);flex:0 0 auto}
.spec dd{font-family:var(--display);font-stretch:108%;font-weight:600;font-size:15px;text-align:right}
.spec dd span{display:block;font-family:var(--body);font-stretch:100%;font-weight:400;font-size:11px;color:var(--ink-2);margin-top:2px}

.flag{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  display:inline-block;margin-top:var(--s-3);padding:5px 11px;border:1px solid var(--line);color:var(--ink-2)}
.flag.live{color:var(--ochre);border-color:color-mix(in oklch,var(--ochre),transparent 55%)}
.flag.pilot{color:var(--terra);border-color:color-mix(in oklch,var(--terra),transparent 55%)}
.flag.fwd{color:var(--steel);border-color:color-mix(in oklch,var(--steel),transparent 55%)}

@media(max-width:760px){.entry{grid-template-columns:1fr;gap:var(--s-5)}}

/* ---------- diversification map ---------- */
.map{background:var(--bg-sunken);border-block:1px solid var(--line);
  margin-top:clamp(40px,5vw,68px);padding-block:clamp(34px,4.5vw,58px)}
.map svg.plot{display:block;width:100%;height:auto;margin-top:var(--s-5)}
.mg{stroke:var(--line-2);stroke-width:1}
.max{font-family:var(--mono);font-size:11px;fill:var(--ink-3);letter-spacing:.04em}
.maxb{font-family:var(--mono);font-size:11px;fill:var(--ink-2);letter-spacing:.12em;text-transform:uppercase}
.mlbl{font-family:var(--display);font-stretch:112%;font-weight:700;text-transform:uppercase;fill:var(--ink)}
.mlbl2{font-family:var(--mono);font-size:10px;fill:var(--ink-3);letter-spacing:.05em}
.leg{display:flex;gap:26px;flex-wrap:wrap;margin-top:var(--s-5);
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
.leg span{display:inline-flex;align-items:center;gap:9px}
.leg .sw{width:9px;height:9px;border-radius:50%}

/* ---------- spec table ---------- */
.tbl-wrap{overflow-x:auto;margin-top:var(--s-5)}
table{border-collapse:collapse;width:100%;min-width:560px;font-family:var(--mono);font-size:12px}
caption{caption-side:top;text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:var(--s-4)}
thead th{font-weight:500;text-align:right;color:var(--ink-3);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;padding:12px 14px;border-bottom:1px solid var(--ink-3)}
thead th:first-child{text-align:left}
tbody td{text-align:right;padding:15px 14px;border-bottom:1px solid var(--line-2);color:var(--ink-2)}
tbody th{text-align:left;padding:15px 14px;border-bottom:1px solid var(--line-2);
  font-family:var(--display);font-stretch:108%;font-weight:600;font-size:15px;color:var(--ink)}
tbody th span{display:block;font-family:var(--mono);font-weight:400;font-size:10px;color:var(--ink-3);
  letter-spacing:.04em;margin-top:3px;text-transform:uppercase}
tbody tr:hover td,tbody tr:hover th{background:oklch(0.795 0.118 78 / .04)}
.cn{color:var(--ochre)} .cd{color:var(--terra)}
table td.tl,table th.tl{text-align:left}

/* ---------- build principles ---------- */
.builds{margin-top:var(--s-6);border-top:1px solid var(--line)}
.build{display:grid;grid-template-columns:auto 1fr;gap:clamp(18px,4vw,52px);
  padding-block:clamp(22px,3vw,34px);border-bottom:1px solid var(--line)}
.build .bn{font-family:var(--display);font-stretch:125%;font-weight:800;font-size:clamp(30px,4vw,46px);
  color:var(--ochre);line-height:.9;letter-spacing:-.01em}
.build h4{font-family:var(--display);font-stretch:115%;font-weight:700;text-transform:uppercase;
  font-size:19px;letter-spacing:-.01em}
.build p{margin-top:10px;color:var(--ink-2);font-size:14.5px;max-width:62ch}
.build p b{color:var(--ink);font-weight:600}

/* withhold note block — full border, leading marker (NO side-stripe) */
.note-block{border:1px solid var(--line);background:var(--bg-raised);padding:clamp(22px,3vw,30px);margin-top:var(--s-7)}
.note-block h3{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ochre);display:flex;align-items:center;gap:12px}
.note-block h3::before{content:"";width:7px;height:7px;background:var(--ochre);border-radius:50%}
.note-block ul{list-style:none;margin-top:var(--s-4)}
.note-block li{padding:13px 0;border-top:1px solid var(--line-2);font-size:14px;color:var(--ink);line-height:1.62;max-width:80ch}
.note-block li:first-child{border-top:0;padding-top:0}
.note-block li b{font-weight:600}

/* ---------- footer ---------- */
footer{margin-top:clamp(56px,7vw,96px);border-top:1px solid var(--line);padding-block:var(--s-7) var(--s-9)}
.foot-top{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-4);flex-wrap:wrap}
.foot-brand{font-family:var(--display);font-stretch:125%;font-weight:800;font-size:22px;text-transform:uppercase}
.foot-brand sup{color:var(--ochre);font-size:.6em;font-weight:700}
.foot-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.disc{font-family:var(--mono);font-size:11px;line-height:1.8;color:var(--ink-3);margin-top:var(--s-5);max-width:none}
.disc b{color:var(--ink-2);font-weight:500}
.disc p{margin-top:12px;max-width:none}

/* =========================================================
   REPORT EXTENSIONS (strategy detail pages)
   ========================================================= */
.back{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:0}
.back::before{content:"← ";color:var(--ochre)}
.r-title{font-family:var(--display);font-stretch:122%;font-weight:800;text-transform:uppercase;
  font-size:clamp(34px,6.6vw,78px);line-height:.92;letter-spacing:-.025em;margin-top:var(--s-5);max-width:15ch}
.r-title .x{color:var(--ochre)}
.formula{font-family:var(--mono);font-size:clamp(12px,1.4vw,14px);color:var(--ink);
  border:1px solid var(--line);background:var(--bg-raised);padding:16px 20px;margin-top:var(--s-5);
  letter-spacing:.02em;max-width:none}
.formula b{color:var(--ochre);font-weight:600}
.subh{font-family:var(--display);font-stretch:114%;font-weight:700;text-transform:uppercase;
  font-size:clamp(17px,2vw,23px);letter-spacing:-.01em;margin-top:var(--s-6);color:var(--ink)}
.run{color:var(--ink-2);max-width:70ch}
.run b{color:var(--ink);font-weight:600}

/* big instrument chart */
.chart{border:1px solid var(--line);margin-top:var(--s-5);
  background:linear-gradient(180deg, oklch(0.205 0.013 75), oklch(0.162 0.011 75))}
.chart svg{display:block;width:100%;height:auto}
.c-grid{stroke:var(--line-2);stroke-width:1}
.c-base{stroke:var(--ink-3);stroke-width:.8;stroke-dasharray:1 5}
.c-fill{fill:var(--ch,var(--ochre));opacity:.08}
.c-line{fill:none;stroke:var(--ch,var(--ochre));stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
.c-bench{fill:none;stroke:var(--ink-3);stroke-width:1.4;stroke-dasharray:5 4;opacity:.85}
.c-tick{font-family:var(--mono);font-size:10px;fill:var(--ink-3);letter-spacing:.06em}
.c-datum{font-family:var(--mono);font-size:9px;fill:var(--ink-3)}
.chart figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--ink-3);padding:11px 16px;border-top:1px solid var(--line);display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.chart figcaption .k{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2)}
.chart figcaption .k::before{content:"";width:18px;border-top:2px solid var(--ch,var(--ochre))}
.chart figcaption .k.b::before{border-top:1.4px dashed var(--ink-3)}
.chart figcaption .w{margin-left:auto;color:var(--ink-3)}

/* mechanism diagram */
.mech{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--s-4);align-items:stretch;margin-top:var(--s-5)}
.mech .box{border:1px solid var(--line);background:var(--bg-raised);padding:20px 22px}
.mech .op{align-self:center;font-family:var(--display);font-stretch:120%;font-weight:800;font-size:24px;
  color:var(--ochre);text-align:center;line-height:1}
.mech .lab{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.mech .ttl{font-family:var(--display);font-stretch:112%;font-weight:700;text-transform:uppercase;font-size:17px;margin-top:8px}
.mech .desc{font-size:13px;color:var(--ink-2);margin-top:9px;line-height:1.55}
.yield{border:1px solid color-mix(in oklch,var(--ochre),transparent 58%);background:oklch(0.795 0.118 78 / .05);
  padding:16px 20px;margin-top:var(--s-4);font-size:14px;color:var(--ink);max-width:none}
.yield b{color:var(--ochre);font-weight:600}
@media(max-width:680px){.mech{grid-template-columns:1fr}.mech .op{transform:rotate(90deg);margin-block:-6px}}

/* key/value (terms, capacity) */
.kv{border:1px solid var(--line);margin-top:var(--s-5)}
.kv > div{display:grid;grid-template-columns:210px 1fr;gap:18px;padding:14px 18px;border-top:1px solid var(--line-2)}
.kv > div:first-child{border-top:0}
.kv dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.kv dd{font-size:14px;color:var(--ink);line-height:1.55}
@media(max-width:600px){.kv > div{grid-template-columns:1fr;gap:4px}}
