/* =========================================================================
   GEFI — styles.css  ·  Terra Vita Global family (matched to tvg-design.css)
   Navy ink on warm paper · Fraunces / DM Sans / JetBrains Mono · angular
   ========================================================================= */
:root{
  --ink:#0a2a43; --ink-deep:#051a2c; --ink-700:#0f3a5e;
  --ink-soft:rgba(10,42,67,.65); --ink-faint:rgba(10,42,67,.15); --rule-soft:rgba(10,42,67,.15);
  --paper:#f9f5e9; --paper-pure:#fefcf3; --paper-warm:#f1ead7; --cream:#fffdf6;
  --accent:#2d4a3e; --accent-warm:#8b6b3f;
  --gold:#C9A86A; --ev-blue:#2A4E6E; --fail:#B94A48; --integ:#3C7A5B;
  --deep:#0B3D2E; --deep-20:rgba(11,61,46,.20);
  --serif:"Fraunces",ui-serif,Georgia,serif; --sans:"DM Sans",ui-sans-serif,system-ui,sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
  --track:.18em; --container:1120px; --ease:cubic-bezier(.2,.7,.2,1); --r:0;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;font-optical-sizing:auto;font-variation-settings:"opsz" 96,"SOFT" 30;letter-spacing:-.5px;line-height:1.05;color:var(--deep)}
em{font-style:italic;font-weight:400;color:var(--accent)}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--cream)}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:.02em}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:28px;
  padding:14px clamp(20px,5vw,40px);background:rgba(254,252,243,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--rule-soft)}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{width:40px;height:40px;object-fit:contain;display:block;flex:0 0 auto}
.brand-mark{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.01em;color:var(--ink)}
.brand-sub{display:flex;flex-direction:column;font-size:11px;line-height:1.3;color:var(--ink-soft)}
.brand-sub i{font-style:normal;color:var(--ink-soft);opacity:.7;font-family:var(--mono);font-size:9.5px;letter-spacing:var(--track);text-transform:uppercase}
.nav{display:flex;gap:2px;margin-left:auto;flex-wrap:wrap;justify-content:center}
.nav a{position:relative;font-size:12.5px;font-weight:500;letter-spacing:.01em;padding:8px 12px;color:var(--ink);transition:color 200ms var(--ease)}
.nav a::after{content:"";position:absolute;left:12px;right:12px;bottom:3px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform 360ms var(--ease)}
.nav a:hover{color:var(--accent)} .nav a:hover::after,.nav a.active::after{transform-origin:left;transform:scaleX(1)}
.nav a.active{color:var(--accent)}
.navchip{display:flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--ink-faint);font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);color:var(--ink-soft);white-space:nowrap}
.navchip-code{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:0}

/* ---------- view routing + fade load ---------- */
.view{display:none;max-width:var(--container);margin:0 auto;padding:clamp(40px,6vw,72px) clamp(20px,5vw,40px) 96px}
.view.active{display:block}
body.loaded .view.active>*{animation:fade .5s var(--ease) backwards}
body.loaded .view.active>*:nth-child(2){animation-delay:.05s}
body.loaded .view.active>*:nth-child(3){animation-delay:.1s}
body.loaded .view.active>*:nth-child(4){animation-delay:.15s}
body.loaded .view.active>*:nth-child(5){animation-delay:.2s}
@keyframes fade{from{opacity:0}to{opacity:1}}

.eyebrow{font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);color:var(--ink-soft)}
.kicker{font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);color:var(--accent);display:block;margin-bottom:14px}
.muted{color:var(--ink-soft)}
.narrow{max-width:64ch}

/* ---------- hero (grid texture + glow signature) ---------- */
.hero{position:relative;overflow:hidden;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;padding:48px 0 72px;border-bottom:1px solid var(--rule-soft)}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.06;
  background-image:linear-gradient(to right,var(--ink) 1px,transparent 1px),linear-gradient(to bottom,var(--ink) 1px,transparent 1px);background-size:120px 120px}
.hero::after{content:"";position:absolute;top:-180px;right:-160px;width:560px;height:560px;pointer-events:none;
  background:radial-gradient(circle,rgba(45,74,62,.16) 0%,transparent 60%)}
.hero-copy,.hero-dial{position:relative;z-index:1}
.hero h1{font-size:clamp(36px,5.6vw,64px);line-height:1.02;letter-spacing:-.025em;margin:20px 0 26px;text-wrap:balance}
.lede{font-size:17px;line-height:1.55;color:rgba(10,42,67,.85);max-width:56ch;text-wrap:pretty}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:32px 0 22px}
.btn{display:inline-flex;align-items:center;gap:10px;font:500 12px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);cursor:pointer;border-radius:0;font-family:var(--mono);transition:all 220ms var(--ease)}
.btn-primary{padding:13px 22px;background:var(--ink);color:var(--cream);border:1px solid var(--ink);box-shadow:0 14px 30px -18px rgba(10,42,67,.45)}
.btn-primary:hover{background:var(--ink-deep);transform:translateY(-1px);box-shadow:0 18px 36px -16px rgba(10,42,67,.55)}
.btn-ghost{padding:12px 20px;border:1px solid var(--ink-faint);background:transparent;color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--cream)}
.link-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14px;color:var(--ink);border-bottom:2px solid var(--gold);padding-bottom:3px;transition:color 200ms var(--ease)}
.link-cta:hover{color:var(--accent)}
.hero-foot{font-size:14px;color:rgba(10,42,67,.78);border-left:3px solid var(--accent);background:rgba(255,253,246,.55);padding:14px 18px;margin-top:10px}
.hero-foot b{color:var(--ink);font-weight:600}
.hero-dial{display:flex;flex-direction:column;align-items:center;gap:8px;padding:38px;border:1px solid var(--ink-faint);background:var(--paper-pure)}
.dial-label{font:600 11px/1.3 var(--mono);letter-spacing:var(--track);text-transform:uppercase;color:var(--deep);text-align:center}
.dial-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px 30px;margin-top:24px;width:100%}
.dial-stats div{display:flex;flex-direction:column}
.dial-stats span{font-family:var(--serif);font-weight:500;font-size:36px;color:var(--ev-blue);line-height:1}
.dial-stats small{font:500 10px/1.3 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-top:7px}
.gauge{display:block}
.gauge-num{font-family:var(--serif);font-weight:700;fill:#2A4E6E;color:#2A4E6E}
.gauge-grade{fill:var(--ink-soft);font-family:var(--mono);font-weight:500}

/* ---------- strip ---------- */
.strip{display:flex;flex-wrap:wrap;gap:6px 18px;align-items:baseline;margin:44px 0;padding:26px 30px;border:1px solid var(--ink-faint);border-left:3px solid var(--accent);background:var(--paper-pure)}
.strip span{color:var(--ink-soft);font-size:15px}
.strip b{font-family:var(--serif);font-weight:500;font-size:clamp(18px,2vw,23px);color:var(--ink)}

/* ---------- generic block + ink-gap grids ---------- */
.block{margin:96px 0;border-top:1px solid var(--deep-20);padding-top:56px}
.block-head{margin-bottom:34px}
.block h2,.view-head h2{font-size:clamp(25px,3.2vw,38px);line-height:1.06;max-width:26ch}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.two-col h2{font-size:clamp(22px,2.6vw,30px);margin-bottom:16px}
.two-col p{margin-top:14px;line-height:1.55}
.checklist{list-style:none;display:flex;flex-direction:column;gap:16px}
.checklist li{position:relative;padding-left:26px;color:rgba(10,42,67,.85);line-height:1.5}
.checklist li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:1px;background:var(--accent);box-shadow:0 4px 0 var(--accent),0 -4px 0 var(--accent)}
.checklist b{color:var(--ink)}

.pillar-mini,.deploy,.pillar-cards,.layer-cards,.workflow{display:grid;gap:1px;background:var(--ink-faint);border:1px solid var(--ink-faint)}
.pillar-mini{grid-template-columns:repeat(3,1fr)}
.pm{background:var(--paper-pure);padding:30px}
.pm span{font:500 12px/1 var(--mono);letter-spacing:var(--track);color:var(--accent)}
.pm h3{font-size:20px;margin:12px 0 10px}
.pm p{font-size:13.5px;color:var(--ink-soft);line-height:1.5}

.who{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 48px}
.who span{font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--ink);padding:10px 15px;border:1px solid var(--ink-faint)}
.deploy{grid-template-columns:repeat(3,1fr)}
.dep{padding:30px;background:var(--paper-pure);cursor:pointer}
.dep:nth-child(2){background:var(--paper-warm)}
.dep span{font:500 12px/1 var(--mono);letter-spacing:var(--track);color:var(--accent)}
.dep h3{font-size:22px;margin:14px 0 8px}
.dep p{font-size:13.5px;color:var(--ink-soft)}
.dep a{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.5px;text-transform:none;color:#0B3D2E;text-decoration:underline;text-decoration-color:#C9A86A;text-underline-offset:3px;position:static}
.dep a::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform 360ms var(--ease)}


/* (A) Evidence-stack triad — Deep Green dividers, institutional rhythm */
.deploy.stack-grid{display:block;gap:0;background:none;border:none}
.deploy.stack-grid .dep{background:none;padding:0;border:none}
.deploy.stack-grid .dep + .dep{margin-top:64px;border-top:1px solid rgba(11,61,46,.2);padding-top:48px}


/* (B,C) governed text link — Deep Green text, gold underline-slide */
.gov-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.5px;text-transform:none;color:#0B3D2E;text-decoration:underline;text-decoration-color:#C9A86A;text-underline-offset:3px;background:none;padding:0;border:none}



/* navy band (status / CTA) */
.cta-block{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:center;margin:96px 0;padding:clamp(36px,5vw,64px);background:var(--ink);border-top:1px solid var(--ink)}
.cta-block .kicker{color:var(--accent-warm)}
.cta-block h2{color:var(--cream);margin:14px 0;font-size:clamp(25px,3vw,36px)}
.cta-block .muted{color:rgba(255,253,246,.72)}
.cta-card{padding:30px;background:var(--paper-pure);display:flex;flex-direction:column;gap:16px}
.cta-card p{font-size:15px;color:var(--ink);font-weight:500}
.cta-card .btn-primary{justify-content:center}
.cta-card .btn-ghost{justify-content:center}

/* ---------- view head + dividers ---------- */
.view-head{max-width:72ch;margin-bottom:38px}
.view-head p{margin-top:14px;line-height:1.55}
.sec-title{font-size:25px;margin:76px 0 24px;padding-top:36px;border-top:1px solid var(--deep-20)}
.sub-h{font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);color:var(--accent);margin:28px 0 14px}

/* ---------- map ---------- */
.map-legend{display:flex;align-items:center;gap:12px;margin-bottom:16px;font:500 10.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}
.legend-bar{flex:0 0 220px;height:8px;background:linear-gradient(90deg,#B94A48,#6E445C,#2A4E6E,#33645B,#3C7A5B)}
.legend-bar+span{margin-right:auto}
.map-legend em{font-style:normal;color:var(--ink);letter-spacing:.16em}
.map-grid{display:grid;grid-template-columns:1fr 300px;gap:24px}
.map-panel{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:10px;position:relative;overflow:hidden}
#map{position:relative;width:100%;min-height:340px}
.worldmap{width:100%;height:auto;display:block}
.country{stroke:var(--paper);stroke-width:.6;cursor:pointer;transition:opacity 200ms var(--ease)}
.country:hover{opacity:.78}
.country.sel{stroke:var(--ink);stroke-width:1.4}
.map-status{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:30px;color:var(--ink-soft);font-size:14px}
.map-tip{position:absolute;pointer-events:none;opacity:0;transform:translate(-50%,-130%);background:var(--ink);color:var(--cream);border:1px solid var(--ink);padding:8px 11px;font-size:12px;white-space:nowrap;transition:opacity 120ms var(--ease);z-index:5}
.map-tip b{display:block;font-family:var(--serif);font-size:13px;margin-bottom:2px;color:var(--cream)}
.map-tip span{color:rgba(255,253,246,.7);font-family:var(--mono);font-size:11px}
.map-side{display:flex;flex-direction:column;gap:12px;min-width:0}
.search{width:100%;padding:12px 14px;background:var(--cream);border:1px solid var(--ink-faint);color:var(--ink);font-family:var(--sans);font-size:14px;outline:none;border-radius:0;transition:border-color 200ms var(--ease)}
.search:focus{border-color:var(--accent)}
.country-index{display:flex;flex-direction:column;max-height:440px;overflow-y:auto}
.ci-row{display:grid;grid-template-columns:10px 1fr auto auto;align-items:center;gap:12px;padding:10px;background:none;border:none;border-bottom:1px solid var(--rule-soft);cursor:pointer;text-align:left;color:var(--ink);width:100%;transition:background 200ms var(--ease)}
.ci-row:hover{background:var(--paper-warm)}
.ci-row.active{background:var(--paper-warm);box-shadow:inset 3px 0 var(--accent)}
.ci-dot{width:10px;height:10px}
.ci-name{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-grade{font-family:var(--mono);font-weight:600;font-size:13px}
.ci-score{font-family:var(--mono);font-size:12px;color:var(--ink-soft);min-width:22px;text-align:right}

/* ---------- dossier ---------- */
.dossier{margin-top:24px;border:1px solid var(--ink-faint);background:var(--paper-pure);padding:clamp(24px,3vw,40px)}
.dossier:empty{display:none}
.dossier-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.dossier-head h3{font-size:clamp(28px,3.5vw,42px);line-height:1;margin:8px 0 12px}
.dossier-tags{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;font:500 10.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:#C9A86A;border:1px solid #C9A86A;background:none;border-radius:0}
.chip b{font-family:var(--serif);font-weight:600;color:var(--c);font-size:15px;letter-spacing:0}
.tag{font:500 10px/1 var(--mono);letter-spacing:var(--track);text-transform:uppercase;color:var(--accent);border:1px solid var(--ink-faint);padding:6px 9px}
.tag-muted{color:var(--ink-soft)}
.dossier-gauge{flex:0 0 auto}
.layer-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink-faint);border:1px solid var(--ink-faint);margin:24px 0}
.layer{padding:16px 18px;background:var(--paper-pure);display:flex;flex-direction:column;gap:5px}
.layer-v{font-family:var(--serif);font-weight:500;font-size:30px;line-height:1}
.layer-k{font:500 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink-faint);border:1px solid var(--ink-faint);margin:10px 0 6px}
.metric{padding:18px 20px;background:var(--paper-pure);display:flex;flex-direction:column;gap:6px}
.metric-v{font-family:var(--serif);font-weight:500;font-size:36px;line-height:1;color:var(--ev-blue)}
.metric-k{font:500 10px/1.2 var(--mono);letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase}
.dossier-split{display:grid;grid-template-columns:1fr 260px;gap:36px;align-items:center}
.bars{display:flex;flex-direction:column;gap:16px}
.bar-row{display:flex;flex-direction:column;gap:7px}
.bar-top{display:flex;justify-content:space-between;align-items:baseline;font-size:13px}
.bar-lbl{color:var(--ink)}
.bar-lbl i{font-style:normal;font-family:var(--mono);color:var(--ink-soft);font-size:10px;margin-right:8px;letter-spacing:.06em}
.bar-val{color:var(--ink-soft);font-family:var(--mono);font-size:13px}
.bar-track{height:6px;background:var(--ink-faint);overflow:hidden}
.bar-fill{display:block;height:100%;transition:width .8s var(--ease)}
.radar{width:100%;height:auto}
.radar-lbl{fill:var(--ink);font-family:var(--mono);font-weight:500;font-size:9.5px;letter-spacing:.06em}
.narrative{display:flex;flex-direction:column;gap:12px;max-width:84ch}
.narrative p{font-size:14.5px;line-height:1.6;color:rgba(10,42,67,.85)}
.narrative b{color:var(--ink)}
.narrative .corr{color:var(--accent);font-weight:500}

/* ---------- sectors ---------- */
.sector-chart{display:flex;flex-direction:column;border:1px solid var(--ink-faint)}
.sec-row{display:grid;grid-template-columns:minmax(220px,1.1fr) 2fr auto;gap:26px;align-items:center;padding:20px 26px;background:var(--paper-pure);border-bottom:1px solid var(--rule-soft)}
.sec-row:last-child{border-bottom:none}
.sec-row:nth-child(even){background:var(--paper-warm)}
.sec-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.sec-name{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--ink)}
.sec-note{font-size:12.5px;color:var(--ink-soft);line-height:1.4}
.sec-track{height:8px;background:var(--ink-faint);overflow:hidden}
.sec-fill{display:block;height:100%;transition:width 1s var(--ease)}
.sec-score{display:flex;align-items:center;gap:14px;justify-self:end}
.sec-num{font-family:var(--serif);font-weight:500;font-size:27px}

/* ---------- programmes table ---------- */
.table-wrap{border:1px solid var(--ink-faint);overflow-x:auto}
.prog-table{width:100%;border-collapse:collapse;min-width:780px;background:var(--paper-pure)}
.prog-table th{font:500 10.5px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:16px 20px;background:var(--paper-warm);cursor:pointer;user-select:none;white-space:nowrap;border-bottom:1px solid var(--ink-faint)}
.prog-table th.th-c{text-align:center}
.prog-table th.sort-asc::after{content:" ▲";color:var(--accent)}
.prog-table th.sort-desc::after{content:" ▼";color:var(--accent)}
.prog-table td{padding:15px 20px;border-bottom:1px solid var(--rule-soft);font-size:13.5px;vertical-align:middle}
.prog-table tr:last-child td{border-bottom:none}
.prog-table tr:hover td{background:var(--paper-warm)}
.td-name{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:15px}
.td-mut{color:var(--ink-soft)}
.td-c{text-align:center}
.collapse-cell{display:flex;align-items:center;gap:10px}
.collapse-cell .mono{font-weight:500}
.collapse-meter{flex:1;height:6px;min-width:60px;background:var(--ink-faint);overflow:hidden}
.collapse-meter i{display:block;height:100%}

/* ---------- scoring sheet ---------- */
.score-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
.score-sheet{display:flex;flex-direction:column;gap:18px}
.score-pillar{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:24px}
.sp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--rule-soft)}
.sp-tag{font:500 11px/1 var(--mono);letter-spacing:var(--track);color:var(--accent)}
.sp-head h4{font-size:19px;margin-top:4px}
.sp-score{text-align:right}
.sp-score .mono{font-family:var(--serif);font-weight:600;font-size:24px}
.sp-score small{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-soft)}
.ind-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:8px 0}
.ind-lbl{font-size:13.5px;color:var(--ink)}
.seg{display:flex;gap:6px;flex:0 0 auto}
.seg-btn{width:34px;height:30px;border:1px solid var(--ink-faint);background:none;color:var(--ink-soft);font-family:var(--mono);font-weight:500;font-size:13px;cursor:pointer;transition:all 200ms var(--ease);border-radius:0}
.seg-btn:hover{border-color:var(--ink)}
.seg-btn.on{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.score-readout{display:flex;flex-direction:column;gap:20px;position:sticky;top:90px}
.readout-card{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:24px}
.readout-gauge,.readout-class,.readout-map{display:flex;justify-content:center;margin:6px 0}

/* ---------- methodology ---------- */
.pillar-cards{grid-template-columns:repeat(3,1fr)}
.pillar-card{background:var(--paper-pure);padding:28px;border:1px solid var(--ink-faint)}
.pillar-top{display:flex;justify-content:space-between;align-items:center;font:500 12px/1 var(--mono);letter-spacing:var(--track);color:var(--accent);margin-bottom:14px}
.pillar-abbr{color:var(--ink-soft)}
.pillar-card h4{font-size:21px;margin-bottom:10px}
.pillar-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;margin-bottom:16px}
.pillar-card:hover h4{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:4px}
.indicators{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.indicators li{font-size:12.5px;color:var(--ink);padding-left:16px;position:relative}
.indicators li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:var(--accent)}
.pillar-w{font:500 10.5px/1 var(--mono);color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase}
.layer-cards{grid-template-columns:repeat(3,1fr)}
.layer-card{background:var(--paper-pure);border-left:3px solid var(--accent);padding:28px}
.layer-no{font:500 13px/1 var(--mono);color:var(--accent)}
.layer-card h4{font-size:21px;margin:8px 0 10px}
.layer-card p{font-size:14px;color:var(--ink-soft)}
.grade-ladder{border:1px solid var(--ink-faint)}
.ladder-row{display:grid;grid-template-columns:54px 90px 180px 1fr;gap:18px;align-items:center;padding:15px 22px;background:var(--paper-pure);border-bottom:1px solid var(--rule-soft)}
.ladder-row:last-child{border-bottom:none}
.ladder-row:nth-child(even){background:var(--paper-warm)}
.ladder-code{font-family:var(--serif);font-size:23px;font-weight:600}
.ladder-range{font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.ladder-band{font-size:14px;font-weight:500;color:var(--ink)}
.ladder-note{font-size:13px;color:var(--ink-soft)}
.workflow{grid-template-columns:repeat(4,1fr)}
.wf{background:var(--paper-pure);padding:24px 22px}
.wf-wk{font:500 11px/1 var(--mono);letter-spacing:.08em;color:var(--accent)}
.wf h4{font-size:17px;margin:10px 0 8px}
.wf p{font-size:12.5px;color:var(--ink-soft);line-height:1.45}

/* ---------- intake form ---------- */
.intake{display:flex;flex-direction:column;gap:24px;max-width:940px}
.hidden-field{display:none}
.intake fieldset{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:30px 30px 32px}
.intake legend{font:500 12px/1 var(--mono);letter-spacing:var(--track);text-transform:uppercase;color:var(--ink);padding:0 10px;display:flex;align-items:center;gap:10px}
.intake legend .mono{color:var(--accent)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.intake label{display:flex;flex-direction:column;gap:8px;font:500 11px/1.3 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-top:18px}
.intake fieldset>label:first-of-type,.grid2 label{margin-top:0}
.grid2+label{margin-top:18px}
.intake input,.intake select,.intake textarea{background:var(--cream);border:1px solid var(--ink-faint);padding:12px 13px;color:var(--ink);font-family:var(--sans);font-size:14.5px;font-weight:400;text-transform:none;letter-spacing:0;outline:none;transition:border-color 200ms var(--ease);width:100%;border-radius:0}
.intake textarea{resize:vertical;line-height:1.5}
.intake input:focus,.intake select:focus,.intake textarea:focus{border-color:var(--accent)}
.intake select{appearance:none;cursor:pointer}
.req{color:var(--accent)}
.intake label.file{margin-top:18px}
.intake .check{flex-direction:row;align-items:flex-start;gap:10px;font-family:var(--sans);font-size:13px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--ink);margin-top:14px;line-height:1.45}
.intake .check input{width:auto;margin-top:2px;accent-color:var(--ink)}
.btn-submit{align-self:flex-start;padding:16px 30px}

/* ---------- footer ---------- */
.foot{max-width:var(--container);margin:0 auto;padding:56px clamp(20px,5vw,40px) 48px;border-top:1px solid var(--ink);display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .brand-mark{font-size:20px}
.foot p{font-size:12.5px;color:var(--ink-soft);margin-top:8px;max-width:44ch}
.foot-meta{text-align:right}
.foot-meta p{margin-top:5px}
.foot-meta a{color:var(--accent);font-weight:500;border-bottom:1px solid var(--ink-faint)}
.foot-email{margin-top:14px;padding-top:14px;border-top:1px solid var(--deep-20)}
.foot-spec{margin-top:14px}
.foot-spec a{color:var(--deep);border-bottom:2px solid var(--gold)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero{grid-template-columns:1fr;gap:36px}
  .pillar-mini,.deploy,.pillar-cards,.layer-cards{grid-template-columns:1fr 1fr}
  .two-col,.cta-block{grid-template-columns:1fr;gap:32px}
  .map-grid,.dossier-split,.score-layout{grid-template-columns:1fr}
  .radar-wrap{max-width:280px;margin:0 auto}
  .score-readout{position:static}
  .workflow{grid-template-columns:repeat(2,1fr)}
  .block{margin:72px 0}
}
@media(max-width:620px){
  .nav{display:none}
  .pillar-mini,.deploy,.pillar-cards,.layer-cards,.workflow,.grid2,.metric-grid,.layer-row{grid-template-columns:1fr}
  .ladder-row{grid-template-columns:40px 70px 1fr;gap:10px}
  .ladder-note{display:none}
  .sec-row{grid-template-columns:1fr;gap:14px}
  .sec-score{justify-self:start}
  .foot{flex-direction:column}.foot-meta{text-align:left}
}

/* =========================================================================
   BRIDGE LAYER
   ========================================================================= */
.stack-foot{margin-top:64px;font-size:14px;color:var(--ink-soft);padding-top:48px;border-top:1px solid rgba(11,61,46,.2)}
.stack-foot b{color:var(--ink)}
.br-loop{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:14px;margin-bottom:8px}
.loop-svg{width:100%;height:auto;display:block}
.loop-node{stroke-width:1.3}
.loop-ft{fill:var(--paper-warm);stroke:var(--accent-warm)}
.loop-hub{fill:#eef2ee;stroke:var(--accent)}
.loop-gefi{fill:#eaeff4;stroke:var(--ev-blue)}
.loop-name{font-family:var(--serif);font-weight:500;font-size:15px;fill:var(--ink)}
.loop-sub{font-family:var(--mono);font-size:9px;fill:var(--ink-soft);letter-spacing:.04em}
.loop-arc{stroke:rgba(10,42,67,.3);stroke-width:1.2;transition:stroke .2s}
.loop-arc.on{stroke:var(--accent);stroke-width:2.4}
.loop-arc-lbl{font-family:var(--mono);font-size:9.5px;fill:var(--ink-soft);letter-spacing:.04em}
.loop-arc-lbl.on{fill:var(--accent);font-weight:500}

.br-steps{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.br-step{display:flex;flex-direction:column;gap:4px;align-items:flex-start;padding:10px 14px;border:1px solid var(--ink-faint);background:var(--paper-pure);cursor:pointer;font-family:var(--sans);font-size:12.5px;color:var(--ink);transition:all 200ms var(--ease)}
.br-step .mono{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.br-step:hover{border-color:var(--ink)}
.br-step.done{border-color:var(--accent)} .br-step.done .mono{color:var(--accent)}
.br-step.on{background:var(--ink);color:var(--cream)} .br-step.on .mono{color:rgba(255,253,246,.7)}
.br-run{display:grid;grid-template-columns:1fr;gap:16px}
.br-detail{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:26px}
.br-detail-head{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.br-detail-head h4{font-size:20px}
.br-sys{font:500 10px/1 var(--mono);text-transform:uppercase;letter-spacing:var(--track);padding:8px 12px;border:1px solid}
.br-sys-fieldtrace{color:var(--accent-warm);border-color:var(--accent-warm);background:var(--paper-warm)}
.br-sys-hub{color:var(--accent);border-color:var(--accent);background:#eef2ee}
.br-sys-gefi{color:var(--ev-blue);border-color:var(--ev-blue);background:#eaeff4}
.br-nav{display:flex;gap:12px;justify-content:flex-end}
.kv{display:flex;flex-direction:column;border:1px solid var(--rule-soft);margin-top:6px}
.kv-row{display:grid;grid-template-columns:160px 1fr;gap:14px;padding:9px 14px;border-bottom:1px solid var(--rule-soft)}
.kv-row:last-child{border-bottom:none}
.kv-k{font:500 10px/1.4 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.kv-v{font-size:12.5px;color:var(--ink);word-break:break-all}
.art-tag{display:inline-block;font:500 10px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--ink);border:1px solid var(--ink-faint);padding:7px 11px;margin:6px 0 4px}
.art-tag.art-ok{color:var(--accent);border-color:var(--accent);background:#eef2ee}
.art-tag b{color:var(--accent)}
.art-note{font-size:13px;color:var(--ink-soft);font-style:italic;margin-top:10px;line-height:1.5}
.art-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:8px}
.art-list li{position:relative;padding-left:18px;font-size:13.5px;color:var(--ink);line-height:1.45}
.art-list li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:var(--accent)}
.art-list li.art-loop{color:var(--accent);font-weight:500}
.art-list b{color:var(--ink)}
.br-score{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:6px}
.br-score-side{flex:1;min-width:200px}
.br-legs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--ink-faint);border:1px solid var(--ink-faint)}
.br-leg{background:var(--paper-pure);padding:26px;border-left:3px solid var(--accent)}
.br-leg-feedback{border-left:3px dashed var(--accent-warm)}
.br-leg-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.br-leg-id{font-size:16px;font-weight:500;color:var(--accent)}
.br-leg-route{font-size:11px;color:var(--ink);letter-spacing:.04em}
.br-leg-dir{margin-left:auto;font:500 9px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);border:1px solid var(--ink-faint);padding:4px 7px}
.br-leg h4{font-size:19px;margin-bottom:8px}
.br-leg-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px}
.br-leg-cols .sub-h{margin:0 0 8px}
.br-leg-cols .art-list li{font-size:12.5px}
.br-model{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-faint);border:1px solid var(--ink-faint)}
.br-table{background:var(--paper-pure);padding:20px}
.br-table h4{font-size:13px;color:var(--ink);letter-spacing:.04em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--rule-soft)}
.br-table ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.br-table li{font-size:12px;color:var(--ink-soft)}
.br-api{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.br-api-group .sub-h{margin:0 0 12px}
.br-endpoint{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--rule-soft)}
.br-endpoint .mono{font-size:12px;color:var(--ink);word-break:break-all}
.br-method{font:500 9px/1 var(--mono);letter-spacing:.06em;padding:4px 7px;color:#fff;flex:0 0 auto}
.br-post{background:var(--accent)} .br-get{background:var(--ev-blue)}

/* =========================================================================
   NAE + ERS  (baseline styling — paused build, kept presentable)
   ========================================================================= */
.nae-layout,.ers-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
.nae-controls{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.nae-srclbl{display:flex;flex-direction:column;gap:8px;font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.nae-fields{display:flex;flex-wrap:wrap;gap:8px}
.nae-toggle{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border:1px solid var(--ink-faint);background:var(--paper-pure);font-family:var(--sans);font-size:12.5px;color:var(--ink-soft);cursor:pointer;transition:all 200ms var(--ease)}
.nae-toggle:hover{border-color:var(--ink)}
.nae-toggle.on{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.nae-mark{font-family:var(--mono)}
.nae-chain{display:flex;flex-wrap:wrap;align-items:stretch;gap:10px}
.chain-node{flex:1;min-width:150px;border:1px solid var(--ink-faint);border-top:3px solid var(--c);background:var(--paper-pure);padding:16px;display:flex;flex-direction:column;gap:6px}
.cn-k{font-family:var(--serif);font-weight:500;font-size:16px;color:var(--ink)}
.cn-sub{font-size:11.5px;color:var(--ink-soft)}
.cn-sc{font-family:var(--serif);font-weight:600;font-size:26px;color:var(--c);margin-top:4px}
.chain-arr{display:flex;align-items:center;font-family:var(--mono);color:var(--ink-soft);font-size:18px}
.nae-readoutcol,.ers-outcome{display:flex;flex-direction:column;gap:20px;position:sticky;top:90px}
.nae-conf{font-size:13px;color:var(--ink-soft);margin-top:10px}
.nae-feed{font-size:12.5px;color:var(--ink-soft);margin-top:10px}
.gap-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.gap-list li{position:relative;padding-left:18px;font-size:13px;color:var(--ink);line-height:1.45}
.gap-list li::before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;background:var(--fail)}
.ers-controls{margin-bottom:24px}
.ers-scenarios{display:flex;flex-wrap:wrap;gap:8px}
.ers-sc{padding:10px 15px;border:1px solid var(--ink-faint);background:var(--paper-pure);font-family:var(--sans);font-size:12.5px;color:var(--ink);cursor:pointer;transition:all 200ms var(--ease)}
.ers-sc:hover{border-color:var(--ink)}
.ers-sc.on{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.ers-desc{margin:14px 0 18px;font-size:14px;color:var(--ink-soft);font-style:italic}
.ers-sliders{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ers-slider{display:flex;flex-direction:column;gap:10px;font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.ers-slider b{color:var(--ev-blue);font-size:14px}
.ers-slider input[type=range]{width:100%;accent-color:var(--ink)}
.ers-spinewrap{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:18px}
.spine-svg{width:100%;height:auto;display:block}
.spine-lbl{font-family:var(--mono);font-size:8.5px;fill:var(--ink)}
.spine-legend{display:flex;gap:18px;margin-top:14px;font:500 10px/1 var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.spine-legend i{display:inline-block;width:10px;height:10px;margin-right:6px;vertical-align:middle}
.ers-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.ers-metrics span{font-family:var(--serif);font-weight:500;font-size:24px;display:block}
.ers-metrics small{font:500 9px/1.2 var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);display:block;margin-top:5px}

@media(max-width:980px){
  .nae-layout,.ers-layout{grid-template-columns:1fr}
  .nae-readoutcol,.ers-outcome{position:static}
  .br-legs,.br-model,.br-api{grid-template-columns:1fr}
  .ers-sliders{grid-template-columns:1fr}
  .br-leg-cols{grid-template-columns:1fr}
  .kv-row{grid-template-columns:120px 1fr}
}

/* ---- Bridge: governance rules ---- */
.br-rules{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.rule{display:flex;gap:16px;background:var(--paper-pure);border:1px solid var(--ink-faint);border-left:3px solid var(--accent);padding:22px}
.rule-no{font-size:15px;font-weight:500;color:var(--accent);flex:0 0 auto}
.rule h4{font-size:17px;margin-bottom:6px}
.rule p{font-size:13px;color:var(--ink-soft);line-height:1.5}

/* ---- Bridge: operator console ---- */
.br-operator{display:flex;flex-direction:column;gap:8px}
.op-table{width:100%;border-collapse:collapse;background:var(--paper-pure);min-width:820px}
.op-table th{font:500 10px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:14px 16px;background:var(--paper-warm);border-bottom:1px solid var(--ink-faint);white-space:nowrap}
.op-table th.th-c{text-align:center}
.op-table td{padding:13px 16px;border-bottom:1px solid var(--rule-soft);font-size:13px;vertical-align:middle}
.op-table tr:last-child td{border-bottom:none}
.op-table tr:hover td{background:var(--paper-warm)}
.op-chip{display:inline-block;font:500 9.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.06em;padding:5px 8px;border:1px solid}
.op-ok{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,transparent);background:#eef2ee}
.op-warn{color:var(--accent-warm);border-color:color-mix(in srgb,var(--accent-warm) 45%,transparent);background:var(--paper-warm)}
.op-bad{color:var(--fail);border-color:color-mix(in srgb,var(--fail) 45%,transparent);background:#f7ecea}
.op-gefi{display:inline-flex;align-items:baseline;gap:8px}
.op-gefi b{font-family:var(--serif);font-size:16px}
.op-gefi .mono{font-size:12px;color:var(--ink-soft)}
.br-queue{display:flex;flex-direction:column;border:1px solid var(--ink-faint);background:var(--paper-pure)}
.q-item{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--rule-soft)}
.q-item:last-child{border-bottom:none}
.q-target{font:500 9.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.06em;padding:5px 9px;flex:0 0 auto}
.q-hub{color:var(--accent);border:1px solid var(--accent)}
.q-ft{color:var(--accent-warm);border:1px solid var(--accent-warm)}
.q-txt{flex:1;font-size:13px;color:var(--ink)}
.q-txt b{color:var(--ink)}
.q-actions{display:flex;gap:8px}
.q-act{font:500 10px/1 var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--ink-faint);padding:6px 10px}

/* ---- Bridge: API reference ---- */
.br-api{display:block}
.api-group{margin-bottom:28px}
.api-group-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:12px}
.api-group-head .sub-h{margin:0}
.api-base{font-size:12px;color:var(--ink-soft)}
.api-ep{border:1px solid var(--ink-faint);background:var(--paper-pure);padding:18px 20px;margin-bottom:10px}
.api-ep-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.api-path{font-size:13.5px;color:var(--ink);word-break:break-all}
.api-purpose{font-size:13px;color:var(--ink-soft);margin-bottom:12px}
.api-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.api-lbl{font:500 9.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--accent);display:block;margin-bottom:8px}
.api-ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.api-ul li{font-size:12px;color:var(--ink);padding-left:12px;position:relative;word-break:break-all}
.api-ul li::before{content:"";position:absolute;left:0;top:7px;width:4px;height:4px;background:var(--ink-faint)}

@media(max-width:980px){ .br-rules{grid-template-columns:1fr} .api-cols{grid-template-columns:1fr;gap:14px} }

/* ---- Bridge: live connected pipeline ---- */
.br-live{border:1px solid var(--ink-faint);border-left:3px solid var(--accent);background:var(--paper-pure);padding:24px;margin:8px 0 28px}
.br-live-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:10px}
.br-live p{font-size:13.5px;margin-bottom:14px}
.br-health{font:500 10.5px/1 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);white-space:nowrap}
.br-health.ok{color:var(--accent)}
.br-health.warn{color:var(--accent-warm)}
.br-health.off{color:var(--ink-soft);opacity:.7}
.br-live-out{margin-top:16px}
.br-live-out:empty{display:none}
.br-live-score{display:flex;align-items:center;gap:20px;margin:10px 0}

/* live programmes (from DB) */
.prog-live:empty{display:none}
.prog-live{margin:0 0 28px}
.live-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--deep-20)}
.live-sub{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}

/* supabase config row */
.sb-cfg{display:flex;gap:8px;flex-wrap:wrap;margin:4px 0 14px}
.sb-cfg input{flex:1;min-width:180px;font:13px/1.4 var(--sans);color:var(--ink);background:var(--paper);border:1px solid var(--ink-faint);border-radius:0;padding:9px 11px}
.sb-cfg .btn{white-space:nowrap}


/* (2) kill any residual slide-underline pseudo on links */
.dep a::after,.gov-link::after{display:none!important}
/* (4) governance-grade break before 'How GEFI plugs into Terra Vita' */
.block--major{padding-top:64px}
/* (5) footer structure */
.footer-email{margin-top:32px;display:block}
.footer-spec{margin-top:48px;display:block}
.footer-spec a{color:#0B3D2E;text-decoration:underline;text-decoration-color:#C9A86A;border-bottom:none}
/* (8) 24px spacing between pillar cards */
.pillar-cards{background:none;border:none;gap:24px}
/* (6) body copy in charcoal */
p,li{color:#1A1A1A;line-height:1.45}
.muted{color:var(--ink-soft)}

/* awaiting-assessment headline */
.awaiting{width:248px;height:248px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--deep-20);border-radius:50%;margin:0 auto}
.aw-dash{font:600 64px/1 var(--serif);color:var(--ink-soft)}
.aw-text{font:600 12px/1.4 var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--deep);text-align:center;margin-top:8px}

/* live programmes: score action + panel */
.score-btn{font:500 11px/1 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:#0B3D2E;background:none;border:1px solid var(--deep-20);padding:6px 10px;cursor:pointer;white-space:nowrap}
.score-btn:hover{border-color:var(--deep);background:rgba(11,61,46,.05)}
.prog-score:empty{display:none}
.prog-score{margin-top:20px}
.ps-card{background:var(--paper-pure);border:1px solid var(--faint,rgba(10,42,67,.14));border-left:3px solid var(--accent);padding:22px}
.ps-head{display:flex;align-items:center;justify-content:space-between;font:600 13px/1 var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--deep);margin-bottom:16px}
.ps-x{cursor:pointer;color:var(--ink-soft);font-size:14px}
.ps-row{display:flex;align-items:center;gap:14px;margin-bottom:9px}
.ps-row label{flex:0 0 240px;font:400 13px/1.3 var(--sans);color:#1A1A1A}
.ps-row input[type=range]{flex:1}
.ps-row b{flex:0 0 46px;text-align:right;font-family:var(--mono);color:#2A4E6E}
.ps-out{margin-top:12px}.ps-out:empty{display:none}
.ps-note{font-size:12.5px;color:var(--ink-soft);margin:0 0 14px;line-height:1.4}

/* ===== unified global surface nav (matches the stack pages) + GEFI section sub-nav ===== */
.topwrap{position:sticky;top:0;z-index:100;background:rgba(254,252,243,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--rule-soft)}
.topwrap .topbar{position:static;background:transparent;backdrop-filter:none;border-bottom:1px solid var(--rule-soft)}
/* surface nav — identical look to .nav on the stack pages */
.snav{display:flex;gap:2px;margin-left:auto;flex-wrap:wrap;justify-content:center}
.snav a{position:relative;font-size:12.5px;font-weight:500;letter-spacing:.01em;padding:8px 12px;color:var(--ink);transition:color 200ms var(--ease)}
.snav a::after{content:"";position:absolute;left:12px;right:12px;bottom:3px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform 360ms var(--ease)}
.snav a:hover{color:var(--accent)} .snav a:hover::after,.snav a.active::after{transform-origin:left;transform:scaleX(1)}
.snav a.active{color:var(--accent)}
/* section sub-nav — secondary tier, muted, gold active underline */
.subnav{margin-left:0;justify-content:flex-start;gap:2px;padding:6px clamp(20px,5vw,40px) 7px;flex-wrap:wrap}
.subnav a{font-size:12px;font-weight:500;padding:7px 11px;color:var(--ink-soft)}
.subnav a::after{display:none}
.subnav a:hover{color:var(--accent)}
.subnav a.active{color:var(--accent)}
.subnav a.active::before{content:"";position:absolute;}
.subnav a{position:relative}
.subnav a.active{box-shadow:inset 0 -2px 0 var(--gold)}
@media(max-width:620px){
  .snav,.subnav{display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .snav::-webkit-scrollbar,.subnav::-webkit-scrollbar{display:none}
  .snav{margin-left:0;width:100%;justify-content:flex-start}
}
