/* ===========================================================================
   horizon.css — forecast4 shared design system (Horizon skin)
   One source of truth: tokens, type, shell, and every component.
   Dark default; :root[data-theme="light"] overrides. Render-only.
   =========================================================================== */
:root{
  --bg:#1c1a17;--bg-glow:#221f1a;--card:#26231e;--elev:#211e1a;--bg-input:#211e19;
  --border:#3a352d;--border-soft:#3b362d;--edge-line:#4a443a;
  --ink:#f3efe7;--ink-2:#cdc8c0;--ink-3:#a39a8d;--ink-card:#cdc8c0;
  --teal:#33b394;--teal-bg:rgba(51,179,148,.16);--live:#33b394;
  --clay:#e0975a;--clay-bg:rgba(224,151,90,.16);
  --coral:#e0695c;--coral-bg:rgba(224,105,92,.16);--on-accent:#0c1f1a;
  --opt:#46d6a6;--scenario:var(--teal);
  --link:var(--ink-2);--link-hover:var(--teal);
  --halo:0 0 0 1px rgba(255,255,255,.14),0 22px 48px rgba(0,0,0,.62),0 0 40px 2px rgba(120,200,180,.10),inset 0 1px 0 rgba(255,255,255,.10);
  --ring:0 0 0 1px rgba(255,255,255,.12),0 6px 20px rgba(0,0,0,.55),0 0 22px 1px rgba(120,200,180,.07),inset 0 1px 0 rgba(255,255,255,.06);
  --sidebar-edge:4px 0 24px rgba(0,0,0,.42),1px 0 0 var(--edge-line);--sidebar-bg:var(--elev);--r:13px;
  --hover:rgba(127,127,127,.07);--track:rgba(127,127,127,.18);--knob:#fbf8f1;
  --glow-clay:0 0 14px rgba(224,151,90,.55);--glow-clay-soft:0 0 18px rgba(224,151,90,.38);
  --f-ui:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --f-data:'IBM Plex Sans',system-ui,sans-serif;
  --f-disp:'Newsreader',Georgia,serif;
}
:root[data-theme="light"]{
  --bg:#f1ece1;--bg-glow:#f7f1e5;--card:#fbf8f1;--elev:#f3eee3;--bg-input:#ffffff;
  --border:#e2dac9;--border-soft:#e3dac7;--edge-line:#d0c4ac;
  --ink:#2a2620;--ink-2:#6b6456;--ink-3:#8a8170;
  --teal:#0a5d4f;--teal-bg:rgba(10,93,79,.10);--live:#0a5d4f;--ink-card:#5e574a;
  --clay:#b5642b;--clay-bg:rgba(181,100,43,.12);
  --coral:#bb4b3f;--coral-bg:rgba(187,75,63,.10);--on-accent:#ffffff;
  --opt:#0c8f62;
  --halo:0 2px 5px rgba(40,34,20,.10),0 16px 36px rgba(40,34,20,.16);
  --ring:0 5px 16px rgba(40,34,20,.13),0 1px 3px rgba(40,34,20,.09);
  --sidebar-edge:3px 0 16px rgba(40,34,20,.08),1px 0 0 var(--edge-line);--sidebar-bg:var(--card);
  --hover:rgba(40,34,20,.05);--track:rgba(40,34,20,.12);--knob:#ffffff;
  --glow-clay:0 0 0 2px color-mix(in srgb,var(--clay) 45%,transparent);--glow-clay-soft:0 0 0 3px color-mix(in srgb,var(--clay) 24%,transparent);
}
/* stress-reactive accent — follows the active return scenario (Conservative/Expected/Optimistic) */
:root[data-scenario="low"]{--scenario:var(--clay)}
:root[data-scenario="mid"]{--scenario:var(--teal)}
:root[data-scenario="high"]{--scenario:var(--opt)}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--f-ui);-webkit-font-smoothing:antialiased}
body{background-image:radial-gradient(130% 80% at 50% -10%,var(--bg-glow),var(--bg) 55%);min-height:100vh}
.num{font-family:var(--f-data);font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"ss01"}
a{color:inherit;text-decoration:none}

/* ── SHELL ── */
.app{display:grid;grid-template-columns:208px 1fr;min-height:100vh}
.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--edge-line);box-shadow:var(--sidebar-edge);padding:18px 14px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:5}
.brandrow{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.brand{font-family:var(--f-disp);font-weight:600;font-size:19px;color:var(--teal);letter-spacing:-.01em}
.brand .four{color:var(--ink-3);font-size:13px}
.who{font-size:11px;color:var(--ink-3);margin-top:3px;margin-bottom:16px}
.navgrp{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin:14px 0 6px;padding:0 8px}
.nav{display:flex;flex-direction:column;gap:1px}
.nav a{font-size:12.5px;color:var(--ink-2);padding:7px 10px;border-radius:8px;display:flex;align-items:center;gap:9px;font-weight:500}
.nav a:hover{background:var(--card);color:var(--ink)}
.nav a.on{background:var(--teal-bg);color:var(--teal);font-weight:600}
.nav a .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.nav a .dot.warn{background:var(--clay)}.nav a .dot.risk{background:var(--coral)}.nav a .dot.ok{background:transparent}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:14px;padding:14px 26px;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--border-soft);flex-wrap:nowrap}
.topbar .pt{font-family:var(--f-disp);font-weight:600;font-size:19px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .pmeta{font-size:13px;color:var(--ink-2)}

.topbar .sp{flex:1}
.topbar .tbtitle{min-width:0}
.topbar .pmeta{font-size:13px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
/* Fixed header layout: title shrinks (ellipsis); control cluster (scenario + theme) never wraps/squishes.
   The Live engine-status pill is moved OUT of the header and pinned to the BOTTOM of the sidebar
   (.engstatus-side) to keep the header uncrowded. Header slots: [title left] ......... [scenario + theme right]. */
.topbar .tbtitle{flex:0 1 auto;min-width:110px}
.topbar .pmeta{display:none}
.topbar .engstatus{flex-shrink:0}
.sidebar{display:flex;flex-direction:column}
.sidebar .engstatus-side{margin:auto -14px -18px;align-self:stretch;justify-content:flex-start;position:sticky;bottom:0;border:0;border-top:1px solid var(--edge-line);border-radius:0;padding:12px 16px;background:var(--sidebar-bg)}
.scen{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden;background:var(--card);box-shadow:var(--ring)}
.scen button{font-family:var(--f-ui);font-size:12px;font-weight:600;padding:7px 13px;border:none;background:transparent;color:var(--ink-3);cursor:pointer}
.scen button.on{background:var(--teal);color:var(--on-accent)}
.scen button:not(.on):hover{color:var(--ink)}
.scen-host{display:flex;align-items:center;gap:12px;margin:0 0 14px;flex-wrap:wrap}
.topbar .scen-host.topbar-scen{margin:0;flex-wrap:nowrap}
.topbar .scen-host.topbar-scen .scen button{padding:6px 11px}
@media(max-width:720px){.topbar .scen-host.topbar-scen .scen-legend{display:none}}
@media(max-width:520px){.topbar .scen-host.topbar-scen .scen button{padding:6px 9px;font-size:11px}.topbar .pmeta{display:none}}
.scen-legend{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em}
.iconbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--border);background:var(--card);color:var(--ink-2);cursor:pointer;box-shadow:var(--ring);font-size:14px}
.iconbtn:hover{color:var(--ink);border-color:var(--teal)}
.content{padding:24px 26px 60px;width:100%;max-width:1440px}
/* ── Layout width tiers (stamped by shell.js per surface; see LAYOUT map) ───────────────
   reading   — prose / single-column: keep a comfortable measure.
   workspace — decision/work surfaces (DEFAULT): use the available width minus sidebar/gutters.
   wide      — timeline+inspector dashboards & wide tables: near-full viewport.
   Mode-agnostic: Household, Nomad, and future Planner pages all inherit from one place. */
.content[data-layout="reading"]{max-width:820px}
.content[data-layout="workspace"]{max-width:1440px}
.content[data-layout="wide"]{max-width:1880px}
/* Keep prose legible inside wide surfaces — constrain the TEXT, never the card/table/timeline. */
.content .prose,.content .measure{max-width:74ch}
@media(max-width:1100px){.content{padding-left:20px;padding-right:20px}}
@media(max-width:560px){.content{padding-left:15px;padding-right:15px}}

/* ── Live engine status pill + recompute cue ── */
.engstatus{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:.01em;color:var(--ink-2);border:1px solid var(--border);border-radius:30px;padding:5px 11px;background:var(--card);box-shadow:var(--ring);white-space:nowrap}
.engstatus .ed{width:7px;height:7px;border-radius:50%;background:var(--ink-3);flex-shrink:0}
.engstatus.dot-ok{color:var(--live);border-color:color-mix(in srgb,var(--live) 40%,var(--border))}
.engstatus.dot-ok .ed{background:var(--live);box-shadow:0 0 7px color-mix(in srgb,var(--live) 70%,transparent)}
.engstatus.dot-load{color:var(--clay)}.engstatus.dot-load .ed{background:var(--clay);animation:f4pulse 1s infinite}
.engstatus.dot-run{color:var(--clay)}.engstatus.dot-run .ed{background:var(--clay);animation:f4pulse .7s infinite}
.engstatus.dot-err{color:var(--coral);border-color:var(--coral)}.engstatus.dot-err .ed{background:var(--coral)}
@keyframes f4pulse{0%,100%{opacity:1}50%{opacity:.3}}
body.f4-running .strip .sv,body.f4-running .lv-out{opacity:.4;transition:opacity .12s}
.exptools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.derived{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:14px;padding-top:13px;border-top:1px dashed var(--border)}
@media(max-width:780px){.derived{grid-template-columns:repeat(2,1fr)}}
.derived .d .dl{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600}
.derived .d .dv{font-family:var(--f-data);font-variant-numeric:tabular-nums;font-size:15px;font-weight:600;margin-top:3px;color:var(--ink)}
.derived .d .dv.c{color:var(--teal)}

.menubtn{display:none}

/* ── Continuity briefing ── */
.brief{background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--halo),0 0 0 2px color-mix(in srgb,var(--brief-ring,var(--scenario)) 48%,transparent),0 0 24px color-mix(in srgb,var(--brief-ring,var(--scenario)) 16%,transparent);padding:20px 22px;margin-bottom:18px;transition:box-shadow .25s ease}
.brief.gap{--brief-ring:var(--coral)}.brief.dep{--brief-ring:var(--clay)}
.brief .ey{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.brief .verdict{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin:5px 0 2px}
.brief .verdict .v{font-family:var(--f-disp);font-weight:600;font-size:23px;letter-spacing:-.01em;color:var(--teal);line-height:1.1;white-space:nowrap}
.brief.gap .verdict .v{color:var(--coral)}.brief.dep .verdict .v{color:var(--clay)}
.brief .verdict .sub{font-size:13px;color:var(--ink-2)}.brief .verdict .sub b{color:var(--ink);font-family:var(--f-data);font-weight:700}
/* IRE_05 verdict basis — calm, subordinate, causal (never alarmist) */
.brief .verdict .vbasis{flex-basis:100%;font-size:12px;color:var(--ink-2);line-height:1.4;margin-top:3px;font-style:normal}
.brief .sgp{margin:14px 0 4px;border-top:1px solid var(--border-soft);padding-top:13px;display:flex;flex-direction:column;gap:8px}
.brief .sgp .ln{display:flex;gap:10px;font-size:12.5px;line-height:1.5;color:var(--ink-2)}
.brief .sgp .ln .k{flex-shrink:0;font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);width:66px;padding-top:1px}
.brief .sgp .ln .k.live{color:var(--coral)}
.brief .metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:15px;padding-top:14px;border-top:1px solid var(--border-soft)}
.brief .metrics .m .ml{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:600}
.brief .metrics .m .mv{font-family:var(--f-data);font-variant-numeric:tabular-nums;font-size:18px;font-weight:600;margin-top:3px}
.brief .metrics .m .mv.g{color:var(--teal)}.brief .metrics .m .mv.c{color:var(--coral)}
.brief .metrics .m .ms{font-size:11px;color:var(--ink-2);margin-top:2px}

/* ── Section card + fields ── */
.scard{background:var(--card);border:1px solid var(--border);border-top:3px solid var(--teal);border-radius:var(--r);box-shadow:var(--ring);padding:16px 18px;margin-bottom:12px}
/* R040 P2 — washed L&R semantic-color tokens (replace inline border-top-color + page-local .effcard/.advtoggle). Shared, reusable. */
.scard-edit{border-top-color:var(--live)}
.scard-arming{border-top-color:var(--clay)}
.scard-error{border-top-color:var(--coral)}
.fi-readout{display:flex;align-items:center;color:var(--ink-2);font-family:var(--f-data);font-variant-numeric:tabular-nums;background:var(--bg-input);cursor:default}
.scard .st{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.scard .st h3{font-family:var(--f-disp);font-weight:600;font-size:16px}
.scard .st .pill{font-size:11px;font-weight:600;color:var(--ink-3);border:1px solid var(--border);border-radius:20px;padding:2px 9px}
.scard .sd{font-size:12.5px;color:var(--ink-card);margin-top:4px;line-height:1.55}
.fieldgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:14px}
.fieldgrid.two{grid-template-columns:1fr 1fr}
.fl{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:600;margin-bottom:5px}
.fi{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:9px;padding:10px 12px;color:var(--ink);font-family:var(--f-data);font-variant-numeric:tabular-nums;font-feature-settings:"ss01";font-size:14px;font-weight:600}
.fi:focus{outline:none;border-color:var(--teal)}
.fi.flag{border-color:var(--coral)}
.seg{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden;background:var(--bg-input)}
.seg button{font-family:var(--f-ui);font-size:12px;font-weight:600;padding:8px 13px;border:none;background:transparent;color:var(--ink-3);cursor:pointer}
.seg button.on{background:var(--teal);color:var(--on-accent)}

/* ── Status pills, tags, relation chips ── */
.pillrow{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:5px 13px;border-radius:30px;background:var(--teal-bg);color:var(--teal)}
.pill .d{width:8px;height:8px;border-radius:50%;background:currentColor}
.pill.warn{background:var(--clay-bg);color:var(--clay)}.pill.risk{background:var(--coral-bg);color:var(--coral)}
.tag{font-size:11px;color:var(--ink-3);border:1px solid var(--border);border-radius:20px;padding:3px 11px;background:var(--card)}
.livetag{font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--live);margin-left:8px;text-transform:uppercase;vertical-align:middle;white-space:nowrap}

/* ── List rows (mobile-safe) ── */
.lrow{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--ring);padding:13px 15px;margin-bottom:9px;flex-wrap:wrap}
.lrow.breached{border-color:var(--coral);box-shadow:0 0 0 1px var(--coral),var(--ring)}
.lrow .ico{width:30px;height:30px;border-radius:8px;background:var(--teal-bg);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.lrow .body{flex:1 1 200px;min-width:0}
.lrow .body .nm{font-family:var(--f-disp);font-weight:600;font-size:15px;line-height:1.15}
.lrow .body .mt{font-size:11px;color:var(--ink-3);margin-top:2px}
.lrow .draw{flex-shrink:0;font-family:var(--f-data);font-variant-numeric:tabular-nums;font-size:12.5px;font-weight:600;color:var(--clay);white-space:nowrap}
.lrow .acts{display:flex;gap:6px;flex-shrink:0}
.lrow .acts button{width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--ink-3);cursor:pointer;font-size:13px}
.lrow .acts button:hover{border-color:var(--coral);color:var(--coral)}
.addrow{border:2px dashed color-mix(in srgb,var(--teal) 45%,var(--border));border-radius:var(--r);padding:13px;text-align:center;font-size:12.5px;font-weight:600;color:var(--teal);cursor:pointer;background:transparent;transition:border-color .15s,background .15s}
.addrow:hover{background:var(--teal-bg);border-color:var(--teal)}
.addrow.alt{border-color:color-mix(in srgb,var(--clay) 50%,var(--border));color:var(--clay)}
.addrow.alt:hover{background:var(--clay-bg);border-color:var(--clay)}

/* ── Affordability (inline toggle + pop) ── */
.aff-anchor{position:relative;grid-column:1/-1}
.aff-toggle{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-ui);font-size:12.5px;font-weight:600;color:var(--ink-2);background:transparent;border:1px solid var(--border);border-radius:30px;padding:6px 13px;cursor:pointer;margin-top:10px}
.aff-toggle:hover{border-color:var(--teal);color:var(--ink)}
.aff-toggle .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.d-ok{background:var(--teal)}.d-tight{background:var(--clay)}.d-over{background:var(--coral)}
.pop{position:absolute;top:calc(100% + 8px);left:0;width:min(380px,92vw);background:var(--card);border-radius:var(--r);box-shadow:var(--halo);padding:16px 18px;z-index:30;display:none}
.pop.open{display:block}
.pop .ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.pop .ph .t{font-family:var(--f-disp);font-weight:600;font-size:15px}
.pop .x{background:none;border:none;color:var(--ink-3);font-size:15px;cursor:pointer}
.verdict-pill{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;padding:4px 11px;border-radius:30px}
.vp-ok{background:var(--teal-bg);color:var(--teal)}.vp-tight{background:var(--clay-bg);color:var(--clay)}.vp-over{background:var(--coral-bg);color:var(--coral)}
.pop .read{font-size:13px;line-height:1.5;margin-top:8px;color:var(--ink-2)}.pop .read b{font-family:var(--f-data);color:var(--ink)}
.bar{margin-top:12px;height:12px;border-radius:7px;background:var(--track);position:relative;overflow:hidden}
.bar .fill{position:absolute;left:0;top:0;bottom:0;border-radius:7px}
.pop .caveat{font-size:11px;color:var(--ink-3);font-style:italic;margin-top:10px;padding-top:9px;border-top:1px dashed var(--border);line-height:1.4}

/* ── Buttons ── */
.btn{font-family:var(--f-ui);font-size:13px;font-weight:600;border-radius:9px;padding:10px 16px;cursor:pointer;border:1px solid transparent;display:inline-block;box-shadow:var(--ring);transition:box-shadow .15s,transform .15s}
.btn:hover{transform:translateY(-1px)}
.btn.pri{background:var(--teal);color:var(--on-accent);box-shadow:0 6px 18px color-mix(in srgb,var(--teal) 34%,transparent),var(--ring)}
.btn.sec{background:var(--card);color:var(--ink);border-color:var(--border)}
.btn.sec:hover{border-color:var(--teal);color:var(--teal)}
.btnrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* ── Plaid import stub (shared) ── */
.plaidbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.plaidnote{font-size:11.5px;color:var(--ink-card);line-height:1.55;background:var(--elev);border:1px dashed var(--border);border-radius:11px;padding:12px 14px;margin-bottom:14px;display:none}
.plaidnote.on{display:block}.plaidnote b{color:var(--ink)}

/* ── Sliding-dot switch (e.g. “becomes primary”) ── */
.swt{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:11px;font-weight:600;letter-spacing:.01em;color:var(--ink-3);user-select:none;white-space:nowrap}
.swt:hover{color:var(--ink-2)}
.swt .sw{width:34px;height:19px;border-radius:20px;background:var(--border);position:relative;transition:background .18s;flex-shrink:0}
.swt .sw::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:var(--knob);box-shadow:0 1px 3px rgba(0,0,0,.45);transition:transform .18s}
.swt.on{color:var(--teal)}
.swt.on .sw{background:var(--teal)}
.swt.on .sw::after{transform:translateX(15px)}

/* ── Metric strip ── */
.stripwrap{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;background:var(--elev);margin-top:16px}
.strip{display:flex;overflow-x:auto}
.strip .s{flex:1 0 auto;min-width:128px;padding:11px 16px;border-right:1px solid var(--border)}
.strip .s:last-child{border-right:none}
.strip .sl{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:600}
.strip .sv{font-family:var(--f-data);font-variant-numeric:tabular-nums;font-size:16px;font-weight:600;margin-top:3px}
.strip .sv.g{color:var(--teal)}

.sectionhead{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin:24px 0 12px}

/* ── responsive ── */
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;z-index:40;transform:translateX(-100%);transition:transform .2s;height:100vh}
  .sidebar.open{transform:none;box-shadow:var(--halo)}
  .menubtn{display:inline-flex;align-items:center;justify-content:center}
  .fieldgrid,.fieldgrid.two{grid-template-columns:1fr}
  .brief .metrics{grid-template-columns:1fr 1fr}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:35}
  .scrim.on{display:block}
}
@media(min-width:821px){.scrim{display:none}}

/* ── Terrain views (dashboard) ── */
.viewtog{display:inline-flex;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--elev)}
.viewtog button{font-family:var(--f-ui);font-size:13px;font-weight:600;padding:8px 15px;border:none;background:transparent;color:var(--ink-3);cursor:pointer;display:flex;align-items:center;gap:7px}
.viewtog button.on{background:var(--teal);color:var(--on-accent)}
.viewtog button:not(.on):hover{color:var(--ink)}
.terstage{display:grid;grid-template-columns:1fr 348px;gap:20px;align-items:stretch;margin-top:16px}
@media(max-width:980px){.terstage{grid-template-columns:1fr}}
.substrate{background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--halo);padding:18px 20px 14px;height:var(--stageH,560px);overflow:hidden}
.substrate .sh{font-family:var(--f-disp);font-weight:500;font-size:17px}
.substrate .scap{font-size:13px;line-height:1.55;color:var(--ink-2);margin:3px 0 16px}.substrate .scap b{color:var(--ink)}
.viewbody{display:none}.viewbody.on{display:block}
.timeline{position:relative;padding:6px 0 2px}
/* R014A TILE STRUCTURE: each phase is a distinct rounded tile that owns its own
   border + radius, so the selected state renders clean corners (no white outline
   clipped by a rounded/overflow-hidden container). Widths unchanged (inline %),
   flush via -1px overlap so the R013 coverage stays byte-exact. Existing tokens only. */
.phases{display:flex;height:58px}
.phase{position:relative;display:flex;flex-direction:column;justify-content:center;padding:0 11px;cursor:pointer;box-sizing:border-box;border:1px solid var(--border);border-radius:8px}
.phase+.phase{margin-left:-1px}
.phase:hover{filter:brightness(1.12)}
.phase .pn{font-family:var(--f-disp);font-weight:600;font-size:12.5px;color:#fff;line-height:1.05;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.phase.sel{border:2px solid var(--clay);border-radius:8px;z-index:2}
.inlink{color:var(--teal);font-weight:600;text-decoration:underline;text-underline-offset:2px}.inlink:hover{opacity:.8}
.track{position:relative;height:118px;margin-top:8px}
.evt{position:absolute;top:0;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;cursor:pointer;width:0}
.evt .stem{width:1.5px;background:var(--border)}
.evt .edot{width:12px;height:12px;border-radius:50%;background:var(--elev);border:2px solid var(--clay)}
.evt .lbl{position:relative;white-space:nowrap;font-size:10px;font-weight:600;color:var(--ink-2);margin-top:5px;background:var(--elev);border:1px solid var(--border);border-radius:20px;padding:2px 8px}
.evt .lbl .lbl-tag{display:inline-block}
.evt .lbl .lbl-full{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%);display:none;white-space:nowrap;font-size:10px;font-weight:600;color:var(--ink);background:var(--elev);border:1px solid var(--clay);border-radius:6px;padding:3px 8px;z-index:20;box-shadow:0 4px 14px rgba(0,0,0,.35);pointer-events:none}
.evt:hover .lbl .lbl-full,.evt.sel .lbl .lbl-full{display:block}
.evt:hover{z-index:21}
.evt:hover .lbl{color:var(--clay);border-color:var(--clay)}
.evt.sel .edot{background:var(--clay);box-shadow:var(--glow-clay)}
.evt.sel .lbl{background:var(--clay);border-color:var(--clay);color:var(--on-accent)}.evt.sel .stem{background:var(--clay)}
.canvas{position:relative;width:100%;height:360px}
.canvas svg.links{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.node{position:absolute;transform:translate(-50%,-50%);background:var(--elev);border:1.5px solid var(--border);border-radius:11px;padding:9px 12px;cursor:pointer;text-align:center;min-width:92px;transition:all .14s;z-index:2}
.node:hover{border-color:var(--clay)}
.node .nn{font-family:var(--f-disp);font-weight:600;font-size:13.5px;line-height:1}
.node .ns{font-size:9px;margin-top:3px;font-weight:600}
.node .ns.ok{color:var(--teal)}.node .ns.warn{color:var(--clay)}.node .ns.risk{color:var(--coral)}
.node.sel{border-color:var(--clay);background:var(--clay-bg);box-shadow:var(--glow-clay-soft)}
.node.rel{border-color:var(--teal)}.node.dim{opacity:.4}
.inspector{position:sticky;top:78px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--halo);height:var(--stageH,560px);display:flex;flex-direction:column;overflow:hidden}
.insp-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 24px;color:var(--ink-3)}
.insp-empty .big{font-size:26px;margin-bottom:10px;opacity:.5}.insp-empty p{font-size:12.5px;line-height:1.55;max-width:220px}
.insp{display:none;flex-direction:column;flex:1}.insp.on{display:flex}
.trailbar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-soft);background:var(--elev)}
.backbtn{width:25px;height:25px;flex-shrink:0;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--ink-2);cursor:pointer;font-size:12px}
.backbtn:hover:not(:disabled){border-color:var(--teal);color:var(--teal)}.backbtn:disabled{opacity:.35;cursor:default}
.trail{flex:1;min-width:0;display:flex;align-items:center;gap:4px;flex-wrap:wrap;font-size:10.5px}
.trail .crumb{color:var(--ink-3);cursor:pointer;white-space:nowrap}.trail .crumb.cur{color:var(--clay);font-weight:700;cursor:default}
.trail .sep{color:var(--ink-3);opacity:.5}
.closebtn{width:25px;height:25px;border:none;background:transparent;color:var(--ink-3);cursor:pointer;font-size:14px}.closebtn:hover{color:var(--ink)}
.insp-body{padding:15px 17px;overflow-y:auto;flex:1}
.itt{font-family:var(--f-disp);font-weight:600;font-size:19px;letter-spacing:-.01em;line-height:1.12}
.iph{font-size:11px;color:var(--clay);font-weight:600;margin-top:3px}
.istat{font-size:11px;font-weight:600;margin-top:4px}.istat.ok{color:var(--teal)}.istat.warn{color:var(--clay)}.istat.risk{color:var(--coral)}
.kind{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--border);border-radius:5px;padding:2px 7px;margin-top:9px}
.iblk{margin-top:14px}.iblk .bh{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:5px}
.iblk p{font-size:12.5px;line-height:1.5;color:var(--ink-2)}
.money{background:var(--elev);border:1px solid var(--border-soft);border-radius:10px;padding:11px 12px}
.money .mh{font-size:11px;color:var(--ink-3);margin-bottom:8px}.money .mh b{color:var(--ink-2)}
.spark{height:58px}.spark svg{display:block;width:100%;height:100%}
.money .delta{margin-top:8px;font-size:11.5px;color:var(--ink-2);line-height:1.4}.money .delta b{font-family:var(--f-data)}.money .delta .dn{color:var(--coral);font-weight:700}.money .delta .up{color:var(--teal);font-weight:700}
.related{display:flex;gap:7px;flex-wrap:wrap}
.relchip{font-size:11px;font-weight:600;color:var(--teal);border:1px solid var(--teal);background:transparent;border-radius:20px;padding:5px 11px;cursor:pointer}.relchip:hover{background:var(--teal-bg)}
.ideps{font-size:11.5px;color:var(--ink-2);margin-top:7px;line-height:1.5}
.insp-foot{border-top:1px solid var(--border-soft);padding:10px 17px}
.editlink{font-size:12px;font-weight:600;color:var(--ink-3);background:transparent;border:none;cursor:pointer}.editlink:hover{color:var(--teal)}

/* ── Accounts & Returns cards (MOD_31 / MOD_31A) ── */
/* ── MOD_31 contribution-timing UI ── */
.acct-intro .acct-introlist{margin:8px 0 0;padding-left:18px;font-size:12.5px;color:var(--ink-2);line-height:1.7}
.acct-intro .acct-introlist b{color:var(--ink)}
.acct-introhint{font-size:12px;color:var(--ink-3);line-height:1.55;margin-top:10px;padding-top:9px;border-top:1px dashed var(--border)}
.acct-timing{margin-top:2px;align-items:end}
.acct-prov{font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;border-radius:5px;padding:1px 6px;margin-left:6px;background:var(--elev);color:var(--ink-3);border:1px solid var(--border-soft);vertical-align:middle}
.acct-prov.spec{background:var(--teal-bg);color:var(--teal);border-color:transparent}
.acct-timing-side{display:flex;align-items:center;min-height:38px}
.acct-timing-note{font-size:12px;color:var(--ink-3);line-height:1.45}
.acct-reset{font-size:11.5px;font-weight:600;border:1px solid var(--border);background:transparent;color:var(--ink-2);border-radius:7px;padding:6px 11px;cursor:pointer}
.acct-reset:hover{border-color:var(--teal);color:var(--teal)}
.acct-valid{font-size:11.5px;color:var(--coral);background:var(--coral-bg);border-radius:7px;padding:6px 10px;margin-top:8px;line-height:1.45}
.acct-foot{font-size:11.5px;color:var(--ink-2);line-height:1.55;margin-top:10px;padding-top:11px;border-top:1.5px dashed color-mix(in srgb, var(--ink-3) 78%, transparent)}
.acct-foot b{font-family:var(--f-data);color:var(--ink)}
.acct-foot-pend{color:var(--ink-3)}

/* ── MOD_31A card layout ── */
.acct-head{align-items:center;gap:10px;flex-wrap:wrap}
.acct-typebadge{font-size:10px;font-weight:600;letter-spacing:.02em;color:var(--ink-2);border:1px solid var(--border-soft);border-radius:6px;padding:2px 8px;background:var(--elev)}
.ownseg.head button{padding:5px 10px;font-size:11.5px}
.acct-baltag{margin-right:4px}
.acct-ownhint{font-size:11px;color:var(--ink-3);line-height:1.45;margin:2px 2px 10px}
.acct-r1{margin-top:2px}.acct-r2{margin-top:13px}
.acct-hint{font-size:11px;color:var(--ink-3);line-height:1.4;margin-top:5px}
.acct-timing-foot{margin-top:8px}
.acct-foot-upd{color:var(--ink-3)}
/* ── MOD_32 funding review (read-only) ── */
.acct-funding-note{font-size:11px;color:var(--ink-3);line-height:1.5;margin-top:9px;padding-top:8px;border-top:1px dashed var(--border)}
.acct-fundrev{display:flex;align-items:baseline;gap:8px;margin:9px 0 0;padding:7px 10px;border-radius:8px;background:var(--elev);border:1px solid var(--border-soft);font-size:11.5px;line-height:1.45}
.acct-fundrev .acct-fundrev-tag{flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}
.acct-fundrev .acct-fundrev-msg{color:var(--ink-2)}
.acct-fundrev.sev-review{border-color:color-mix(in srgb,var(--clay) 35%,var(--border-soft))}
.acct-fundrev.sev-review .acct-fundrev-tag{color:var(--clay)}
.acct-fundrev.sev-caution{border-color:color-mix(in srgb,var(--coral) 40%,var(--border-soft));background:var(--coral-bg)}
.acct-fundrev.sev-caution .acct-fundrev-tag{color:var(--coral)}

/* ── MOD_32 returns row (5 fields, cash far right) ── */
.fieldgrid.ret5{grid-template-columns:repeat(5,minmax(0,1fr))}
@media(max-width:760px){.fieldgrid.ret5{grid-template-columns:repeat(2,1fr)}}
.acct-owntype{font-size:11.5px;color:var(--ink-3);line-height:1.5;margin-top:10px;padding-top:9px;border-top:1px dashed var(--border)}

/* ── Savings & contributions (collapsible) ── */
.acct-intro-head{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;cursor:pointer;padding:0;text-align:left;color:var(--ink)}
.acct-intro-head h3{margin:0;font-family:var(--f-disp);font-weight:600;font-size:16px;color:var(--ink)}
.acct-intro-tri{color:var(--ink-3);font-size:12px;line-height:1}
.acct-intro-body{margin-top:8px}

/* ── MOD_31B: live status lives only in the sidebar pill; hide in-page "● Live · …" badges ── */
.livetag{display:none}

/* ── HH_10Ba Location Appendix (token-neutral; reuses existing tokens) ───────── */
.f4-appendix{margin-top:14px;border-top:1px solid var(--border);padding-top:10px}
.f4-appendix-sum{cursor:pointer;font-size:12.5px;color:var(--ink-2);list-style:none}
.f4-appendix-sum::-webkit-details-marker{display:none}
.f4-appendix-sum::before{content:"▸ ";color:var(--ink-3)}
.f4-appendix[open] .f4-appendix-sum::before{content:"▾ "}
.f4-appendix-body{margin-top:8px}
.f4-appendix-row{font-size:12.5px;line-height:1.55;color:var(--ink-2);padding:3px 0}
.f4-appendix-rows{margin-top:6px}
.f4-appendix-kv{display:flex;justify-content:space-between;gap:12px;padding:2px 0}
.f4-appendix-drawer{display:inline-block;margin-top:8px;font-size:12px;color:var(--teal);text-decoration:none}
/* ── end HH_10Ba ─────────────────────────────────────────────────────────────── */

/* ── HH_12 Residence Timeline prototype (corrected tokens; readable in light + dark) ──
   Background surfaces use --card/--elev/--bg-input (true surface tokens), NOT --ink-card
   (which is a TEXT shade). Text uses --ink / --ink-2 / --ink-3. Focus = teal. */
.rt-axis{position:relative;height:16px;margin:8px 0 2px}
.rt-axis-lbl{position:absolute;font-size:10px;color:var(--ink-3)}
.rt-band{position:relative;height:64px;background:var(--track);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;overflow:visible}
.rt-period{position:absolute;top:4px;bottom:4px;background:var(--card);border:1px solid var(--edge-line);border-radius:6px;padding:5px 7px;overflow:hidden;cursor:pointer;box-sizing:border-box;transition:border-color .12s}
.rt-period:hover{border-color:var(--ink-3)}
.rt-period.is-selected{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-bg)}
.rt-period-lbl{font-size:11.5px;color:var(--ink);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rt-period-meta{font-size:10px;color:var(--ink-3)}
.rt-period-basis{font-size:10px;color:var(--ink-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rt-seam{position:absolute;top:-2px;bottom:-2px;width:0;transform:translateX(-50%);cursor:ew-resize;z-index:5}
.rt-seam-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;transform:translateX(-50%);background:var(--teal);border-radius:2px}
.rt-seam.dragging .rt-seam-handle,.rt-seam:focus .rt-seam-handle{box-shadow:0 0 0 3px var(--teal-bg);outline:none}
.rt-seam-yr{position:absolute;top:-16px;left:50%;transform:translateX(-50%);font-size:10px;color:var(--teal);background:var(--elev);padding:0 3px;border-radius:3px;white-space:nowrap}
.rt-gap{position:absolute;top:4px;bottom:4px;background:var(--coral-bg);border:1px dashed var(--coral);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--coral);box-sizing:border-box}
.rt-basis-head,.rt-basis-edit-h{font-size:11px;color:var(--ink-3);margin:8px 0 4px;text-transform:uppercase;letter-spacing:.05em}
.rt-basis-band{position:relative;height:22px;margin-bottom:4px}
.rt-basis-seg{position:absolute;top:0;bottom:0;background:var(--bg-input);border:1px solid var(--border-soft);border-radius:4px;font-size:10px;color:var(--ink-3);display:flex;align-items:center;padding:0 6px;overflow:hidden;white-space:nowrap;box-sizing:border-box}
.rt-btn{font-size:12px;padding:5px 11px;border:1px solid var(--border);background:var(--bg-input);color:var(--ink);border-radius:6px;cursor:pointer}
.rt-btn:hover{border-color:var(--teal)}
.rt-btn.primary{background:var(--teal);color:var(--on-accent);border-color:var(--teal)}
.rt-btn.ghost{background:transparent;color:var(--ink-2)}
.rt-chip{font-size:11px;padding:3px 8px;margin:0 4px 4px 0;border:1px solid var(--border);background:var(--bg-input);color:var(--ink);border-radius:5px;cursor:pointer}
.rt-chip:hover{border-color:var(--teal);color:var(--teal)}
.rt-gapwrap{margin:8px 0}
.rt-gapcard{font-size:12px;color:var(--ink);padding:8px;border:1px dashed var(--coral);border-radius:6px;margin-bottom:6px;background:var(--coral-bg)}
.rt-card{margin-top:10px;padding:11px;border:1px solid var(--border);border-radius:8px;background:var(--card)}
.rt-card.is-focused{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-bg)}
.rt-card-h{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);margin-bottom:8px}
.rt-row{display:flex;align-items:center;gap:10px;margin:6px 0}
.rt-row label{font-size:11.5px;color:var(--ink-3);width:110px;flex:none}
.rt-row .fi,.rt-row select.fi{background:var(--bg-input);color:var(--ink);border:1px solid var(--border)}
.rt-note{font-size:11px;color:var(--ink-3);margin:4px 0 6px}
.rt-basis-edit{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.rt-preview{margin-top:10px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--card)}
.rt-preview.is-focused{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-bg)}
.rt-preview.rt-drag{display:flex;gap:14px;align-items:center;font-size:12px;color:var(--ink-2)}
.rt-preview .rt-d{color:var(--ink);font-weight:600}
.rt-preview-h{font-size:12.5px;color:var(--ink);margin-bottom:8px}
.rt-preview-grid{display:flex;gap:24px}
.rt-preview-grid>div{display:flex;flex-direction:column}
.rt-preview-grid span{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em}
.rt-preview-grid b{font-size:16px;color:var(--ink)}
.rt-preview-grid i{font-size:11px;color:var(--ink-2);font-style:normal}
.rt-warn{font-size:11.5px;color:var(--coral);margin-top:8px}
.rt-commit-row{display:flex;gap:8px;margin-top:10px}
/* R040 P2 — EI1: draft-controls zone, visually fenced from the read-only preview readout above it. */
.rt-draftctl{margin-top:12px;padding-top:10px;border-top:1px dashed var(--clay)}
.rt-draftctl-h{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:8px}
.rt-review{margin-top:10px;padding:9px 11px;border:1px solid var(--clay);border-radius:8px;font-size:12px;color:var(--ink);background:var(--clay-bg)}
.rt-review ul{margin:6px 0 0;padding-left:18px}
.rt-empty-hint{font-size:11.5px;color:var(--ink-2);margin:6px 0 0;padding:8px;border:1px dashed var(--border);border-radius:6px;background:var(--hover)}
/* ── end HH_12 ───────────────────────────────────────────────────────────────────── */
/* R040 P2A — retirement-timing readout: independent derived fact under the brief (washed token). */
.rt-timing{margin-top:10px;padding-top:9px;border-top:1px solid var(--border);font-size:12.5px;color:var(--ink-2);line-height:1.5}
.rt-timing b{color:var(--ink)}

/* ── UI_01 — SHARED BI-CARD GRAMMAR (single source of truth) ──────────────────────────
   Promoted VERBATIM from the accepted Dashboard inspect-card definition
   (dashboard-inspect-cards_R038B.js, the fullest R038A-current grammar). This is now the
   ONE definition of the .twocard/.inspcard bi-card; the former inline copy in summary.html
   and the JS-string copy in dashboard-inspect-cards_R038B.js are removed, and Pressure &
   Confidence's .pc-bicard/.pc-enclosure fork is retired in favour of this. No paraphrase,
   no value changes — accepted surfaces render identically.
   Nested panels are SUBORDINATE to a parent .substrate/card surface: recessed --elev
   background + soft border, no top-accent — they read as panels, not page cards. */
.twocard{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}
@media(max-width:720px){.twocard{grid-template-columns:1fr}}
.inspcard{border:1px solid var(--border-soft);border-radius:11px;background:var(--elev);padding:16px 18px}
/* R038A — card HEADER: the .ck kicker is promoted to the serif title token (was teal 10.5px). */
.inspcard .ck{font-family:var(--f-disp);font-size:19px;font-weight:600;letter-spacing:-.01em;color:var(--ink);text-transform:none;margin:0 0 12px;line-height:1.12}
.inspcard .ctitle{font-family:var(--f-disp);font-size:19px;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin:0 0 12px;line-height:1.12}
/* R038A — selected-item meta line: small gray subtext (was uppercase). */
.inspcard .cmeta{font-size:13px;color:var(--ink-3);text-transform:none;letter-spacing:0;line-height:1.5}
/* R038A — SUBSECTION header: teal uppercase caps (the token the kicker used to use). */
.inspcard .cbh{font-size:10.5px;font-weight:700;letter-spacing:.63px;text-transform:uppercase;color:var(--teal);margin:14px 0 4px}
/* R038A — all descriptive body copy: ONE small gray subtext token, both cards. */
.inspcard .cbody{font-size:13px;color:var(--ink-3);line-height:1.5}
.inspcard .cmuted{font-size:13px;color:var(--ink-3);line-height:1.5}
.inspcard .cchip{display:inline-block;font-size:12px;font-weight:400;color:var(--ink-3);margin:0 14px 4px 0;cursor:pointer;text-decoration:none}
.inspcard .cchip:hover,.inspcard .cchip:focus{color:var(--link-hover);text-decoration:underline}
/* R038A — link: gray + arrow at rest, teal underline on hover (matches "Edit in Properties →"). */
.inspcard .cedit{font-size:12px;color:var(--ink-3);text-decoration:none;display:inline-block;margin-top:14px;cursor:pointer}
.inspcard .cedit:hover,.inspcard .cedit:focus{color:var(--link-hover);text-decoration:underline}
.inspcard .cstat{display:inline-block;margin-right:28px}
.inspcard .cstat .cv{font-family:var(--f-data);font-variant-numeric:tabular-nums lining-nums;font-size:15px;font-weight:600;color:var(--teal)}
.inspcard .arow{display:flex;justify-content:space-between;gap:8%;padding:8px 0;border-top:1px solid var(--border)}
.inspcard .arow:first-child{border-top:0}
.inspcard .alft{width:46%}
.inspcard .argt{width:46%;text-align:right;font-family:var(--f-data);font-variant-numeric:tabular-nums lining-nums;font-size:15px;font-weight:600;color:var(--teal)}
/* R038A — audit row LEFT label: teal caps subsection style (was gray). */
.inspcard .al{font-size:10.5px;letter-spacing:.63px;text-transform:uppercase;font-weight:700;color:var(--teal);margin-bottom:2px}
.inspcard .ax{font-size:13px;color:var(--ink-3);line-height:1.5;font-weight:400}
.inspcard .cmodel{color:var(--teal)}
.inspcard .cscen{color:var(--scenario);font-weight:600}
.inspcard .op{color:var(--ink-3);font-weight:500;margin-right:2px}
.inspcard .csublink{display:block;margin-top:3px;font-size:12px;font-weight:400;color:var(--ink-3);text-decoration:none;font-variant-numeric:normal}
.inspcard .csublink:hover,.inspcard .csublink:focus{color:var(--link-hover);text-decoration:underline}
.inspcard .csubnote{display:block;margin-top:3px;font-size:13px;font-weight:400;color:var(--ink-3);font-variant-numeric:normal}
.inspcard .cstatus{font-family:var(--f-ui);font-size:13px;font-weight:600;color:var(--ink-2);font-variant-numeric:normal}
/* R023: inline explanatory note inside the value column reads small/quiet, not value scale */
.inspcard .argt .cmuted{font-family:var(--f-ui);font-size:12px;font-weight:400;color:var(--ink-3)}
.inspcard .areminder{font-size:12px;color:var(--ink-3);font-style:italic;margin-top:10px;padding-top:9px;border-top:1px dashed var(--border)}
/* ── end UI_01 bi-card grammar ─────────────────────────────────────────────────────── */
