/* ============================================================
   FOLIO · DESIGN SYSTEM
   Quarterly-review typography with archive furniture.
   Same palette as v1 — refined nuance, not new colors.
============================================================ */
:root{
  /* paper + ink */
  --p:#EDE5D0;
  --pd:#E0D8C3;
  --pl:#F4EEDB;
  --bg:#faf9f5;
  --ink:#111008;
  --ash:#55504A;
  --gh:#7A766E;
  --acc:#3D3A33;
  --go:#B8922A;
  --go-d:#8E6F1E;
  --sl:#1C1C18;
  --sl2:#26241F;
  --good:#2A6E2A;
  --hair:rgba(17,16,8,.10);
  --hair-d:rgba(237,229,208,.10);

  /* fonts */
  --serif:'EB Garamond',Georgia,serif;
  --mono:'JetBrains Mono','Courier New',Courier,monospace;

  /* metrics */
  --pad:56px;
  --pad-tight:32px;
  --rule:1px solid var(--hair);
  --rule-thick:1px solid rgba(17,16,8,.18);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif);
  font-size:17px;
  line-height:1.65;
  font-feature-settings:"kern" 1, "liga" 1, "onum" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font:inherit;color:inherit}
em{font-style:italic;font-weight:inherit}
::selection{background:var(--ink);color:var(--p)}

/* utility view toggle */
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============================================================
   RUNNING HEAD (the journal masthead)
============================================================ */
.runhead{
  background:var(--p);
  border-bottom:var(--rule);
  padding:18px var(--pad) 14px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:end;
  gap:24px;
}
.runhead-l, .runhead-r{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ash);line-height:1.6}
.runhead-r{text-align:right}
.runhead-l b, .runhead-r b{color:var(--ink);font-weight:600}
.runhead-c{text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}
.runhead-mark{
  display:grid;place-items:center;
  position:relative;
  background:transparent;
}
.runhead-mark .mono{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:22px;line-height:1;letter-spacing:.01em;color:var(--ink);
  font-feature-settings:"kern" 1, "liga" 1;
}
.runhead-wm{font-family:var(--serif);font-style:italic;font-weight:500;font-size:22px;letter-spacing:-.005em;color:var(--ink);line-height:1}
.runhead-sub{font-family:var(--mono);font-size:8.5px;letter-spacing:.32em;color:var(--ash);text-transform:uppercase}

/* ============================================================
   NAVIGATION
============================================================ */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(237,229,208,.93);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:var(--rule);
  padding:0 var(--pad);
  height:52px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:32px;
}
.nav-wordmark{
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink);cursor:pointer;background:none;border:none;font-weight:600;
  display:flex;align-items:center;gap:10px;
}
.nav-wordmark .nav-mono{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:16px;line-height:1;letter-spacing:.01em;color:var(--ink);
  text-transform:none;
}
.nav-wordmark svg{width:16px;height:16px}
.nav-links{display:flex;gap:30px;list-style:none;align-items:center;justify-content:center}
.nav-links button,.nav-links a{
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ash);background:none;border:none;cursor:pointer;padding:0;
  transition:color .15s;position:relative;
}
.nav-links button::before{
  content:attr(data-idx);
  font-size:7px;color:var(--gh);margin-right:7px;letter-spacing:.1em;
}
.nav-links button:hover,.nav-links a:hover,.nav-links .is-active{color:var(--ink)}
.nav-links .is-active::after{
  content:'';position:absolute;left:0;right:0;bottom:-18px;height:2px;background:var(--ink);
}
.nav-cta{
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  background:transparent;color:var(--ink);border:1px solid var(--ink);padding:7px 18px;cursor:pointer;
  transition:background .15s,color .15s;display:inline-flex;align-items:center;gap:8px;
}
.nav-cta::after{content:'↗';font-size:11px;letter-spacing:0}
.nav-cta:hover{background:var(--ink);color:var(--p)}

/* ============================================================
   HERO — folio composition with marginalia
============================================================ */
.hero{
  padding:120px var(--pad) 88px;
  border-bottom:var(--rule);
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) 280px;
  gap:64px;
  align-items:start;
  background:
    linear-gradient(to bottom, rgba(237,229,208,.0), rgba(237,229,208,.35));
}
#view-caligula .hero{padding-top:96px;padding-bottom:48px}

.hero-folio{
  position:absolute;top:24px;left:var(--pad);right:var(--pad);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gh);pointer-events:none;
}
.hero-folio .dot{width:4px;height:4px;background:var(--go);transform:rotate(45deg);margin:0 10px;display:inline-block}

.hero-kicker{
  font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ash);margin-bottom:40px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.hero-kicker .marker{
  font-family:var(--mono);font-size:9px;color:var(--p);background:var(--ink);
  padding:3px 8px;letter-spacing:.2em;
}
.hero-kicker::before{content:'';width:48px;height:1px;background:var(--ink);flex:none}

.hero-title{
  font-size:clamp(46px,7.4vw,104px);
  line-height:.96;
  letter-spacing:-.022em;
  color:var(--ink);
  margin-bottom:42px;
  font-weight:500;
  text-wrap:balance;
}
.hero-title em{
  font-style:italic;font-weight:400;color:var(--ink);
  position:relative;
}
.hero-title sup{
  font-family:var(--mono);font-size:.22em;font-weight:500;color:var(--go);
  vertical-align:super;letter-spacing:0;margin-left:.08em;font-style:normal;
}
.hero-body{
  font-size:20px;line-height:1.7;color:var(--ash);max-width:600px;margin-bottom:48px;
  font-weight:400;text-wrap:pretty;
}
.hero-body .drop{
  float:left;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:74px;line-height:.85;margin:6px 12px -4px 0;color:var(--ink);
}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* hero right column — colophon card */
.hero-card{
  border:var(--rule);
  background:rgba(244,238,219,.6);
  padding:24px;
  position:relative;
}
.hero-card::before{
  content:'';position:absolute;inset:6px;border:1px solid var(--hair);pointer-events:none;
}
.hero-card-hdr{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gh);padding-bottom:10px;margin-bottom:14px;border-bottom:1px dashed var(--hair);
  display:flex;justify-content:space-between;
}
.hero-card-hdr span:last-child{color:var(--go);font-weight:600}
.hero-card dl{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-bottom:18px}
.hero-card dt{font-family:var(--mono);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:var(--gh);margin-bottom:3px}
.hero-card dd{font-family:var(--serif);font-size:14px;color:var(--ink);line-height:1.35;font-weight:500}
.hero-card dd em{font-style:italic;font-weight:400;color:var(--ash)}
.hero-card-foot{
  padding-top:14px;border-top:1px dashed var(--hair);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ash);
}
.hero-card-foot .status{
  color:var(--go);display:inline-flex;align-items:center;gap:6px;
}
.hero-card-foot .status::before{
  content:'';width:6px;height:6px;background:var(--go);border-radius:50%;
  box-shadow:0 0 0 3px rgba(184,146,42,.18);
}
.hero-card-foot .status.live::before{
  animation:beat 2.4s ease-in-out infinite;
}
@keyframes beat{0%,100%{opacity:.7;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}

/* hero abstract — short marginalia stamp */
.hero-stamp{
  position:absolute;
  bottom:32px;right:var(--pad);
  font-family:var(--mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gh);text-align:right;line-height:1.7;
}
.hero-stamp b{color:var(--ink);font-weight:600}

/* ============================================================
   BUTTONS
============================================================ */
.btn{
  height:48px;padding:0 28px;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  cursor:pointer;border:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .15s;
}
.btn:active{transform:translateY(1px)}
.btn-ink{background:var(--ink);color:var(--p);transition:background .2s}
.btn-ink:hover{background:var(--acc)}
.btn-ink::after{content:'→';font-size:13px;letter-spacing:0}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink);transition:background .2s,color .2s}
.btn-outline:hover{background:var(--ink);color:var(--p)}
.btn-outline::after{content:'↗';font-size:13px;letter-spacing:0;color:var(--go)}
.btn-outline:hover::after{color:var(--p)}

/* ============================================================
   SEARCH (Caligula)
============================================================ */
.search-wrap{
  display:flex;max-width:640px;width:100%;
  border:1px solid var(--ink);background:var(--bg);
  margin-bottom:10px;position:relative;
}
.search-wrap::before{
  content:'⌕';position:absolute;left:18px;top:50%;transform:translateY(-50%);
  font-family:var(--serif);font-size:20px;color:var(--ash);pointer-events:none;
}
.search-wrap input{
  flex:1;height:54px;border:none;background:transparent;padding:0 18px 0 48px;
  font-family:var(--mono);font-size:13px;color:var(--ink);outline:none;letter-spacing:.06em;
}
.search-wrap input::placeholder{color:var(--gh);font-family:var(--serif);font-size:16px;font-style:italic;letter-spacing:0}
.search-wrap button{
  height:54px;padding:0 26px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;background:var(--ink);color:var(--p);border:none;cursor:pointer;
  transition:background .2s;font-weight:600;
}
.search-wrap button:hover{background:var(--acc)}
.search-err{font-family:var(--mono);font-size:11px;color:var(--go);min-height:20px;letter-spacing:.04em;margin-top:6px}

/* ============================================================
   SECTIONS — page furniture
============================================================ */
section{
  padding:104px var(--pad);
  border-bottom:var(--rule);
  position:relative;
}
section::before{
  /* page numeral in margin */
  content:attr(data-folio);
  position:absolute;top:32px;right:var(--pad);
  font-family:var(--mono);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--gh);
}
.sec-label{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ash);margin-bottom:56px;display:flex;align-items:center;gap:18px;
}
.sec-label::before{
  content:attr(data-num);
  color:var(--go);font-weight:600;letter-spacing:.18em;
}
.sec-label::after{content:'';flex:1;height:1px;background:var(--hair)}

/* ============================================================
   APPROACH / TWO-COL EDITORIAL
============================================================ */
.approach-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;
  position:relative;
}
.approach-grid::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:var(--hair);transform:translateX(-36px);
}
.approach-col h2{
  font-size:36px;color:var(--ink);margin-bottom:22px;line-height:1.1;
  font-weight:500;letter-spacing:-.012em;
}
.approach-col h2 em{font-style:italic;font-weight:400}
.approach-col h2 .num{
  font-family:var(--mono);font-size:13px;color:var(--go);letter-spacing:.18em;
  display:block;margin-bottom:14px;font-weight:600;
}
.approach-col p{font-size:17px;line-height:1.85;color:var(--ash);margin-bottom:18px;text-wrap:pretty}
.approach-col p:first-of-type::first-letter{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:48px;line-height:.85;float:left;
  padding:6px 10px 0 0;color:var(--ink);
}
.approach-col p strong{color:var(--ink);font-weight:500;font-style:italic;background:linear-gradient(transparent 60%, rgba(184,146,42,.22) 60%);padding:0 2px}
.footnote{
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--gh);
  margin-top:28px;border-top:1px solid var(--hair);padding-top:14px;
  text-transform:uppercase;
}

/* ============================================================
   CELL GRIDS — findings
============================================================ */
.cell-grid{display:grid;gap:1px;background:var(--hair)}
.cell-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.cell-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.cell-grid.cols-5{grid-template-columns:repeat(5,1fr)}
.cell{
  background:var(--p);padding:36px 30px;transition:background .2s;
  position:relative;display:flex;flex-direction:column;gap:8px;
}
.cell::before{
  content:'';position:absolute;top:0;left:0;width:0;height:2px;background:var(--go);
  transition:width .3s ease;
}
.cell:hover{background:var(--pd)}
.cell:hover::before{width:100%}
.cell-num{
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--go);
  margin-bottom:18px;font-weight:600;display:flex;justify-content:space-between;align-items:center;
}
.cell-num .sep{flex:1;height:1px;background:var(--hair);margin:0 12px}
.cell-num em{color:var(--gh);font-style:normal;font-weight:400;letter-spacing:.14em}
.cell-code{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ink);
  margin-bottom:10px;font-weight:700;
}
.cell-title{font-size:21px;color:var(--ink);margin-bottom:12px;line-height:1.22;font-weight:500;letter-spacing:-.005em}
.cell-title em{font-style:italic;font-weight:400}
.cell-body{font-size:14.5px;line-height:1.75;color:var(--ash)}
.cell-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;color:var(--ink);margin-top:auto;padding-top:18px;font-weight:600;text-transform:uppercase}
.cell-tag::before{content:'· '}

/* ============================================================
   DARK SOURCES — library catalog
============================================================ */
.sources-dark{
  background:var(--sl);padding:104px var(--pad);
  border-bottom:1px solid rgba(255,255,255,.05);position:relative;
}
.sources-dark::before{
  content:attr(data-folio);
  position:absolute;top:32px;right:var(--pad);
  font-family:var(--mono);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:rgba(237,229,208,.4);
}
.sources-dark .sec-label{color:rgba(237,229,208,.5)}
.sources-dark .sec-label::after{background:rgba(237,229,208,.1)}
.sources-dark .sec-label::before{color:var(--go)}
.sources-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(255,255,255,.06);
}
.source-cell{
  background:var(--sl);padding:36px 30px;transition:background .15s;
  position:relative;display:flex;flex-direction:column;gap:8px;
}
.source-cell::after{
  content:'';position:absolute;left:30px;top:30px;width:42px;height:42px;
  border:1px solid rgba(237,229,208,.18);pointer-events:none;
}
.source-cell:hover{background:#222220}
.src-type{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(160,152,144,.65);margin-bottom:60px;display:flex;justify-content:space-between;
}
.src-type .id{color:var(--go)}
.src-name{font-size:19px;color:var(--p);line-height:1.22;margin-bottom:12px;font-weight:500;letter-spacing:-.005em}
.src-name em{font-style:italic;font-weight:400;color:var(--go)}
.src-desc{font-size:13.5px;line-height:1.75;color:rgba(237,229,208,.6)}

/* ============================================================
   PROJECT PLATES
============================================================ */
.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair)}
.project{
  background:var(--p);padding:48px 42px 42px;
  transition:background .15s;display:flex;flex-direction:column;
  position:relative;min-height:560px;
}
.project:not(.dark):hover{background:var(--pd)}
.project.dark{background:var(--sl)}
.project.dark:hover{background:#222220}
.project.dark{color:var(--p)}

.pj-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:32px;padding-bottom:18px;border-bottom:1px dashed var(--hair);
}
.project.dark .pj-head{border-bottom-color:rgba(237,229,208,.14)}
.pj-roman{font-family:var(--mono);font-size:10px;letter-spacing:.26em;color:var(--gh);font-weight:600}
.project.dark .pj-roman{color:rgba(160,152,144,.55)}
.pj-stamp{
  font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--go);border:1px solid var(--go);padding:3px 8px;
}
.pj-title{font-size:38px;color:var(--ink);line-height:1.04;margin-bottom:10px;font-weight:500;letter-spacing:-.018em}
.pj-title em{font-style:italic;font-weight:400}
.pj-title-dk{font-size:38px;color:var(--p);line-height:1.04;margin-bottom:10px;font-weight:500;letter-spacing:-.018em}
.pj-title-dk em{font-style:italic;font-weight:400;color:var(--go)}
.pj-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash);margin-bottom:24px;line-height:1.7}
.project.dark .pj-tag{color:rgba(160,152,144,.6)}
.pj-body{font-size:16px;line-height:1.82;color:var(--ash);max-width:460px;margin-bottom:28px}
.pj-body-dk{font-size:16px;line-height:1.82;color:rgba(237,229,208,.68);max-width:460px;margin-bottom:28px}
.pj-link{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--go);text-decoration:none;display:inline-flex;align-items:center;gap:10px;
  background:none;border:none;cursor:pointer;padding:0;align-self:flex-start;
  font-weight:600;transition:gap .2s;
}
.pj-link::after{content:'→';font-size:14px;transition:transform .2s}
.pj-link:hover{gap:14px}
.pj-stats{
  display:flex;gap:0;margin-top:auto;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
}
.project:not(.dark) .pj-stats{border-top-color:var(--hair)}
.pj-stat{flex:1;padding-right:14px}
.pj-stat:not(:last-child){border-right:1px solid rgba(255,255,255,.08);padding-right:14px;margin-right:14px}
.project:not(.dark) .pj-stat:not(:last-child){border-right-color:var(--hair)}
.pj-stat-val{font-family:var(--serif);font-size:28px;color:var(--go);line-height:1;margin-bottom:6px;font-weight:500;font-feature-settings:"tnum" 1}
.project:not(.dark) .pj-stat-val{color:var(--ink)}
.pj-stat-key{font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:rgba(160,152,144,.7);line-height:1.3}
.project:not(.dark) .pj-stat-key{color:var(--gh)}

/* sparkline strip on the projects */
.pj-spark{height:38px;margin:18px 0 -4px;display:block}

/* ============================================================
   IMPACT BIG NUMBERS
============================================================ */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:var(--rule);border-left:var(--rule)}
.impact-stat{
  border-right:var(--rule);border-bottom:var(--rule);
  padding:36px 32px;background:var(--p);
  display:flex;flex-direction:column;gap:8px;
  position:relative;
}
.impact-stat::before{
  content:attr(data-stat);
  position:absolute;top:14px;right:18px;
  font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;color:var(--gh);
}
.impact-val{font-family:var(--serif);font-size:78px;color:var(--ink);line-height:1;margin-bottom:6px;font-weight:500;letter-spacing:-.025em;font-feature-settings:"tnum" 1}
.impact-val em{font-style:italic;color:var(--go);font-weight:400}
.impact-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin-bottom:10px;font-weight:600}
.impact-desc{font-size:15px;line-height:1.7;color:var(--ash);margin-bottom:auto}
.impact-cite{font-family:var(--mono);font-size:8.5px;letter-spacing:.14em;color:var(--gh);margin-top:18px;padding-top:14px;border-top:1px dashed var(--hair);text-transform:uppercase}

/* ============================================================
   TABLES — ledger
============================================================ */
.results-wrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  border:var(--rule);background:var(--p);
}
table{width:100%;border-collapse:collapse;font-feature-settings:"tnum" 1, "onum" 0}
thead{background:rgba(17,16,8,.04)}
th{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ash);text-align:left;padding:12px 18px;
  border-bottom:1px solid var(--hair);font-weight:600;white-space:nowrap;
}
td{
  font-size:15px;color:var(--ink);padding:14px 18px;
  border-bottom:1px solid var(--hair);
  font-variant-numeric:tabular-nums;
}
tbody tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(184,146,42,.05)}
.td-sub{font-family:var(--mono);font-size:11px;color:var(--ash);letter-spacing:.04em}
.td-good{color:var(--good);font-weight:600}
.td-warn{color:var(--go);font-weight:600}
.td-risk{color:var(--ink)}

/* pill rendering inside tier cell */
.tier-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;font-weight:600;
  padding:3px 9px;border:1px solid currentColor;
}

/* ============================================================
   STAT STRIP (numbers row)
============================================================ */
.stat-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);
  margin-top:36px;
}
.stat-cell{
  background:var(--p);padding:26px 24px;border-left:2px solid var(--go);
  display:flex;flex-direction:column;gap:6px;position:relative;
}
.stat-cell::after{
  content:attr(data-id);
  position:absolute;top:10px;right:14px;
  font-family:var(--mono);font-size:8px;letter-spacing:.22em;color:var(--gh);
}
.stat-num{font-family:var(--serif);font-size:36px;color:var(--ink);line-height:1;margin-bottom:6px;font-weight:500;letter-spacing:-.012em;font-feature-settings:"tnum" 1}
.stat-num em{font-style:italic;color:var(--go);font-weight:400}
.stat-key{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash)}

/* ============================================================
   PULL QUOTES
============================================================ */
.pull{
  margin:64px auto;max-width:920px;padding:0 var(--pad);
  text-align:center;position:relative;
}
.pull::before, .pull::after{
  content:'';position:absolute;left:50%;width:80px;height:1px;background:var(--ink);transform:translateX(-50%);
}
.pull::before{top:-18px}
.pull::after{bottom:-18px}
.pull blockquote{
  font-family:var(--serif);font-style:italic;font-size:clamp(28px,3vw,40px);
  line-height:1.25;color:var(--ink);letter-spacing:-.01em;font-weight:500;
  text-wrap:balance;
}
.pull blockquote::before{content:'“';font-size:1.4em;line-height:0;color:var(--go);margin-right:.04em;vertical-align:-.15em}
.pull blockquote::after{content:'”';font-size:1.4em;line-height:0;color:var(--go);margin-left:.04em;vertical-align:-.15em}
.pull cite{
  display:block;margin-top:22px;
  font-family:var(--mono);font-size:9px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ash);font-style:normal;
}

/* ============================================================
   EDITORIAL SPLIT (caligula subviews etc.)
============================================================ */
.editorial-split{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start}

.loader-wrap{display:none;text-align:center;padding:48px 0}
.loader-text{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--go);animation:pulse 1.5s infinite ease-in-out;
}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

.chart-box{
  border:var(--rule);background:var(--p);padding:28px;margin-bottom:32px;
  display:flex;justify-content:center;align-items:center;min-height:340px;
  position:relative;
}
.chart-box::before{
  content:'';position:absolute;top:10px;left:10px;width:18px;height:18px;
  border-top:1px solid var(--ink);border-left:1px solid var(--ink);
}
.chart-box::after{
  content:'';position:absolute;bottom:10px;right:10px;width:18px;height:18px;
  border-bottom:1px solid var(--ink);border-right:1px solid var(--ink);
}
.chart-box svg{width:100%;max-width:560px;height:auto}

/* segment controls used inside Caligula backtest toggle */
.seg-wrap{
  display:inline-flex;border:1px solid var(--ink);margin-bottom:36px;
}
.seg-wrap button{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:600;padding:11px 22px;background:transparent;color:var(--ink);
  border:none;cursor:pointer;transition:background .15s, color .15s;
}
.seg-wrap button:not(:last-child){border-right:1px solid var(--ink)}
.seg-wrap button.on{background:var(--ink);color:var(--p)}

/* audit trail card grid */
.audit-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--hair);border-bottom:none;
}
.audit-card{
  padding:26px 24px 30px;border-bottom:1px solid var(--hair);border-right:1px solid var(--hair);
}
.audit-card:nth-child(3n){border-right:none}
.audit-num{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--go);margin-bottom:14px;
}
.audit-card h3{
  font-size:19px;font-weight:500;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink);
}
.audit-card p{
  font-size:14px;line-height:1.7;color:var(--ash);text-wrap:pretty;
}
@media(max-width:860px){
  .audit-grid{grid-template-columns:1fr}
  .audit-card{border-right:none}
}

/* validation gate log */
.gate-log{
  border:1px solid var(--hair);font-family:var(--mono);
}
.gate-row{
  display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:12px;
  padding:11px 18px;border-bottom:1px solid var(--hair);
}
.gate-row:last-child{border-bottom:none}
.gate-mark{color:var(--go);font-size:13px;text-align:center}
.gate-name{font-size:12px;letter-spacing:.06em;color:var(--ink)}
.gate-state{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ash)}

/* narrative card */
.narrative-card{
  background:rgba(184,146,42,.04);border:1px solid rgba(184,146,42,.18);
  padding:28px 30px;margin-bottom:48px;position:relative;
}
.narrative-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--go);
}
.narrative-hdr{
  font-family:var(--mono);font-size:10px;font-weight:600;color:var(--go);
  margin-bottom:14px;letter-spacing:.2em;text-transform:uppercase;
}
.narrative-body{font-family:var(--serif);font-size:17px;line-height:1.75;color:var(--ink)}

/* ============================================================
   CONTACT
============================================================ */
.contact{
  padding:96px var(--pad);
  display:grid;grid-template-columns:1.2fr 1fr;gap:80px;
  border-top:var(--rule);position:relative;
  background:linear-gradient(to bottom, rgba(237,229,208,.0), rgba(237,229,208,.5));
}
.contact::before{
  content:'COR · RES';position:absolute;top:32px;right:var(--pad);
  font-family:var(--mono);font-size:9px;letter-spacing:.3em;color:var(--gh);
}
.contact-left h2{
  font-size:46px;line-height:1.05;margin-bottom:22px;font-weight:500;letter-spacing:-.018em;
}
.contact-left h2 em{font-style:italic;font-weight:400}
.contact-left h2 .num{
  font-family:var(--mono);font-size:13px;color:var(--go);letter-spacing:.18em;
  display:block;margin-bottom:14px;font-weight:600;
}
.contact-left p{font-size:17px;line-height:1.8;color:var(--ash);max-width:520px;text-wrap:pretty}
.contact-right{padding-top:8px}
.contact-label{font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--ash);margin-bottom:14px}
.contact-email{
  font-size:22px;color:var(--ink);display:inline-block;margin-bottom:14px;
  border-bottom:1px solid var(--ink);padding-bottom:4px;transition:color .15s;
  word-break:break-all;font-weight:500;
}
.contact-email:hover{color:var(--go);border-bottom-color:var(--go)}
.contact-note{font-size:14.5px;font-style:italic;color:var(--ash);line-height:1.75;margin-top:18px}
.contact-card{
  margin-top:36px;border:var(--rule);padding:20px 22px;background:rgba(244,238,219,.4);
}
.contact-card dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px}
.contact-card dt{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gh);align-self:center}
.contact-card dd{font-size:14px;color:var(--ink);font-weight:500}
.contact-card dd em{font-style:italic;font-weight:400;color:var(--ash)}

/* ============================================================
   COLOPHON FOOTER
============================================================ */
.colophon{
  background:var(--sl);color:var(--p);
  padding:64px var(--pad) 28px;
}
.colo-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:64px;
  padding-bottom:48px;border-bottom:1px solid rgba(237,229,208,.12);
}
.colo-brand{display:flex;flex-direction:column;gap:14px}
.colo-mark{
  display:grid;place-items:center;
  position:relative;
}
.colo-mark .mono{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:28px;line-height:1;letter-spacing:.01em;color:var(--p);
}
.colo-wm{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:32px;line-height:1;color:var(--p);
}
.colo-wm small{font-family:var(--mono);font-style:normal;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(237,229,208,.55);display:block;margin-top:8px;font-weight:500}
.colo-blurb{
  font-size:14px;line-height:1.75;color:rgba(237,229,208,.68);max-width:360px;
}
.colo-col h4{
  font-family:var(--mono);font-size:9px;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(237,229,208,.45);font-weight:600;margin-bottom:18px;
}
.colo-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.colo-col li{font-size:14px;color:var(--p);font-family:var(--serif)}
.colo-col li em{font-style:italic;color:rgba(237,229,208,.68)}
.colo-col li button,
.colo-col li a{
  background:none;border:none;padding:0;cursor:pointer;color:var(--p);
  font-family:var(--serif);font-size:14px;transition:color .15s;
}
.colo-col li button:hover,
.colo-col li a:hover{color:var(--go)}

.colo-base{
  padding-top:24px;display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:18px;
  font-family:var(--mono);font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(237,229,208,.42);
}
.colo-base b{color:var(--p);font-weight:600}
.colo-base .legal{max-width:680px;line-height:1.7;text-align:right;text-transform:none;letter-spacing:.06em}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1100px){
  .approach-grid::before{display:none}
  .impact-grid{grid-template-columns:repeat(2,1fr)}
  .cell-grid.cols-5{grid-template-columns:repeat(3,1fr)}
  .cell-grid.cols-4,.sources-grid{grid-template-columns:repeat(2,1fr)}
  .hero{grid-template-columns:1fr}
  .hero-card{max-width:520px}
  .hero-stamp{display:none}
  .colo-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  :root{--pad:22px}
  .nav-links{display:none}
  .runhead{grid-template-columns:1fr}
  .runhead-l,.runhead-r{text-align:left}
  .hero{padding:84px var(--pad) 56px}
  .hero-folio{display:none}
  section{padding:72px var(--pad)}
  .approach-grid,.impact-grid,.contact,.editorial-split{grid-template-columns:1fr;gap:48px}
  .cell-grid.cols-3,.cell-grid.cols-4,.cell-grid.cols-5,.sources-grid,.projects,.stat-strip{grid-template-columns:1fr}
  .colo-grid{grid-template-columns:1fr;gap:32px}
  .colo-base{flex-direction:column;align-items:flex-start}
  .colo-base .legal{text-align:left}
}

/* ============================================================
   PRINT
============================================================ */
@media print{
  nav,.hero-actions,.nav-cta,.seg-wrap{display:none}
  body{background:#fff}
  .view{display:block!important}
}
