
/* Polytraders Dev Guide — internal */

/* Self-hosted Inter — no Google Fonts third-party request. */
@font-face{
  font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap;
  src:url('fonts/inter/inter-400.woff2') format('woff2');
}
@font-face{
  font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap;
  src:url('fonts/inter/inter-500.woff2') format('woff2');
}
@font-face{
  font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap;
  src:url('fonts/inter/inter-600.woff2') format('woff2');
}
@font-face{
  font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap;
  src:url('fonts/inter/inter-700.woff2') format('woff2');
}

:root{
  --radius:10px; --radius-sm:6px;
  --mono:'JetBrains Mono','SFMono-Regular',Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,system-ui,sans-serif;
  --max:1240px;
  --accent:#2e7df6; --accent-2:#25d4c2;
  --green:#3ecf8e; --amber:#f0b400; --red:#f25b6d;
  --layer-disc:#8b5cf6; --layer-risk:#f25b6d; --layer-exec:#2e7df6;
  --layer-strat:#25d4c2; --layer-intel:#f0b400; --layer-sec:#f97316;
  --layer-gov:#6f7991;
}
:root[data-theme="light"]{
  --bg:#fafbfc; --bg-elev:#f1f3f6; --bg-card:#ffffff; --bg-code:#f6f8fa;
  --fg:#1a1f2b; --fg-dim:#5b6371; --fg-mute:#8a93a3; --fg-strong:#0a0c11;
  --line:#e3e7ee; --line-strong:#cdd3dd;
  --topbar-bg: rgba(255,255,255,.88);
  --code-text:#1a1f2b;
  --hover-bg: rgba(0,0,0,.025);
  --internal-bg:#fde8eb; --internal-fg:#a3142a; --internal-border:#f3b9c2;
  /* Layer pill text colors (darker for light bg) */
  --layer-disc-text:#5b32c9;
  --layer-risk-text:#b8233a;
  --layer-exec-text:#1a5fcc;
  --layer-strat-text:#0e8a7e;
  --layer-intel-text:#8a6500;
  --layer-sec-text:#b85410;
  --layer-gov-text:#4a5468;
}
:root[data-theme="dark"]{
  --bg:#0a0c11; --bg-elev:#11141b; --bg-card:#141822; --bg-code:#0e1117;
  --fg:#e7ebf2; --fg-dim:#9aa3b2; --fg-mute:#6b7280; --fg-strong:#fff;
  --line:#1d2230; --line-strong:#2a3142;
  --topbar-bg: rgba(10,12,17,.92);
  --code-text:#dce3ee;
  --hover-bg: rgba(255,255,255,.025);
  --internal-bg:#3a1a1f; --internal-fg:#ffb1ba; --internal-border:#5a2630;
  /* Layer pill text colors (lighter for dark bg) */
  --layer-disc-text:#c4b1ff;
  --layer-risk-text:#ff9aa7;
  --layer-exec-text:#9bc2ff;
  --layer-strat-text:#7eebdf;
  --layer-intel-text:#ffd560;
  --layer-sec-text:#ffb88a;
  --layer-gov-text:#cdd3df;
}
/* Smooth theme transition */
html{scroll-behavior:smooth}
body, .topbar, .bot-card, .view-card, .class-card, .decision-card, pre.code, .tbl, .tbl-wrap, .badge-internal, .pill, code.mono, .btn, .theme-toggle {
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code,.mono{font-family:var(--mono);font-size:.92em;word-break:break-all;overflow-wrap:anywhere}
.small{font-size:.86em}
.dim{color:var(--fg-dim)}
.empty{color:var(--fg-mute);font-style:italic}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.container.narrow{max-width:920px}
em{font-style:normal;color:var(--accent-2)}
h1,h2,h3,h4{color:var(--fg-strong);line-height:1.25;margin:1.4em 0 .5em}
h1{font-size:2.0rem;font-weight:700;letter-spacing:-.01em}
h2{font-size:1.4rem;font-weight:600;letter-spacing:-.005em}
h3{font-size:1.1rem;font-weight:600}
h4{font-size:.95rem;font-weight:600;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.04em;margin:1em 0 .3em}
p{margin:.6em 0}
hr{border:0;border-top:1px solid var(--line);margin:2em 0}

/* Topbar */
.topbar{position:sticky;top:0;z-index:50;background:var(--topbar-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:24px;padding:10px 24px}
.brand{display:flex;align-items:center;gap:10px;color:var(--fg-strong);font-weight:600}
.brand:hover{text-decoration:none}
.brand-mark{width:18px;height:18px;border-radius:5px;background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.brand-text em{color:var(--fg-dim);font-style:normal;font-weight:500;margin-left:4px}
.topnav{display:flex;gap:2px;flex:1;flex-wrap:nowrap;margin-left:12px;align-items:center;min-width:0}
.topnav>a,.topnav>details>summary{position:relative;color:var(--fg-dim);padding:8px 12px;border-radius:6px;font-size:.92em;font-weight:500;white-space:nowrap;cursor:pointer;transition:color .12s,background .12s}
.topnav>a:hover,.topnav>details>summary:hover{color:var(--fg-strong);background:var(--bg-elev);text-decoration:none}
/* Active state: stronger — accent underline + bold colour, much easier to track */
.topnav>a.is-active,.topnav>details.has-active>summary{color:var(--fg-strong);background:var(--bg-elev)}
.topnav>a.is-active::after,.topnav>details.has-active>summary::after{content:"";position:absolute;left:10px;right:10px;bottom:2px;height:2px;background:var(--accent);border-radius:2px}
/* Pushes the Browse dropdown to sit closer to the right utilities, leaving primary nav links left-anchored */
.topnav-spacer{flex:1 1 auto;min-width:8px}
.topnav-more{position:relative}
.topnav-more>summary{list-style:none;display:inline-flex;align-items:center;gap:5px;user-select:none}
.topnav-more>summary::-webkit-details-marker{display:none}
.topnav-more>summary::marker{content:""}
.topnav-more .caret{font-size:.78em;color:var(--fg-mute);transition:transform .15s ease}
.topnav-more[open] .caret{transform:rotate(180deg)}
.topnav-more[open]>summary{color:var(--fg-strong);background:var(--bg-elev)}
/* Panel: anchored to summary's right edge, with a notch pointing back at it */
.topnav-more-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:320px;background:var(--bg-card);border:1px solid var(--line-strong);border-radius:10px;padding:10px;box-shadow:0 12px 32px rgba(0,0,0,.22),0 2px 6px rgba(0,0,0,.08);z-index:60;display:flex;flex-direction:column;gap:6px}
.topnav-more-panel::before{content:"";position:absolute;top:-7px;right:18px;width:12px;height:12px;background:var(--bg-card);border-left:1px solid var(--line-strong);border-top:1px solid var(--line-strong);transform:rotate(45deg)}
.topnav-more-title{display:block;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;padding:4px 8px 6px;border-bottom:1px solid var(--line);margin-bottom:2px}
.topnav-more-section{display:flex;flex-direction:column;gap:1px;padding:6px 4px;border-bottom:1px solid var(--line)}
.topnav-more-section:last-child{border-bottom:0}
.topnav-more-h{display:block;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;padding:4px 8px 6px}
.topnav-more-panel a{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:8px 10px;border-radius:6px;color:var(--fg);font-size:.92em;font-weight:500;line-height:1.3}
.topnav-more-panel a:hover{background:var(--bg-elev);color:var(--fg-strong);text-decoration:none}
.topnav-more-panel a.is-active{background:var(--bg-elev);color:var(--fg-strong);box-shadow:inset 2px 0 0 var(--accent)}
.topnav-hint{color:var(--fg-mute);font-size:.78em;font-weight:400;text-align:right}
@media (max-width: 880px){.topnav>a:not([data-nav="home"]):not([data-nav="demo"]):not([data-nav="stages"]):not([data-nav="developers"]){display:none}.topnav-more-panel{right:auto;left:0}.topnav-more-panel::before{right:auto;left:18px}}
@media (max-width: 640px){.brand-text em{display:none}.brand-text{font-size:.92em}.topnav{margin-left:6px;gap:0;justify-content:flex-end}.topnav>a,.topnav>details>summary{padding:6px 10px;font-size:.88em}.topbar-right{padding-left:6px;margin-left:0;gap:6px;border-left:none}.theme-toggle{width:28px;height:28px}.badge-internal{display:none}.topnav>a:not([data-nav="home"]):not([data-nav="stages"]){display:none}.topnav-more{display:none}}
.topbar-right{display:flex;align-items:center;gap:10px;padding-left:14px;margin-left:6px;border-left:1px solid var(--line)}
.badge-internal{background:var(--internal-bg);color:var(--internal-fg);border:1px solid var(--internal-border);padding:3px 8px;border-radius:4px;font-size:.75em;letter-spacing:.06em;text-transform:uppercase}

/* Theme toggle */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--fg-dim);border-radius:6px;cursor:pointer;padding:0}
.theme-toggle:hover{color:var(--fg-strong);border-color:var(--accent)}
.theme-icon{width:16px;height:16px;display:none}
:root[data-theme="light"] .theme-icon-moon{display:block}
:root[data-theme="dark"] .theme-icon-sun{display:block}
.scroll-progress{position:absolute;bottom:-1px;left:0;right:0;height:2px;background:transparent}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .08s linear}

/* Hero */
.hero{padding:64px 24px 32px;text-align:left}
.hero .badge-internal{display:inline-block;margin-bottom:14px}
.hero-title{font-size:2.6rem;font-weight:700;letter-spacing:-.02em;margin:0 0 12px}
.hero-lede{font-size:1.15rem;color:var(--fg-dim);max-width:760px}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;margin:28px 0}
.stat{display:flex;flex-direction:column}
.stat-num{font-size:1.8rem;color:var(--fg-strong);font-weight:600}
.stat-label{color:var(--fg-mute);font-size:.85em;text-transform:uppercase;letter-spacing:.06em}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.btn{display:inline-block;padding:9px 16px;border-radius:8px;border:1px solid var(--line-strong);color:var(--fg);background:var(--bg-elev);font-weight:500}
.btn:hover{text-decoration:none;border-color:var(--accent);color:var(--fg-strong)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:#1f6ad9;border-color:#1f6ad9;color:#fff}

.section-title{margin-top:56px;font-size:1.4rem}
.section-lede{color:var(--fg-dim);margin-top:-2px}
.page-title{margin-top:36px}
.page-lede{color:var(--fg-dim);font-size:1.05rem;max-width:780px}

/* Pills */
.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.72rem;letter-spacing:.03em;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--fg);margin-right:4px}
.pill-status.status-live{background:rgba(62,207,142,.12);color:#79e6b3;border-color:rgba(62,207,142,.4)}
.pill-status.status-beta{background:rgba(240,180,0,.12);color:#ffd560;border-color:rgba(240,180,0,.4)}
.pill-status.status-planned{background:rgba(154,163,178,.12);color:var(--fg-dim);border-color:var(--line-strong)}
.pill-layer{font-weight:600}
.pill-layer[data-layer="disc"]{color:var(--layer-disc-text);border-color:rgba(139,92,246,.5);background:rgba(139,92,246,.1)}
.pill-layer[data-layer="risk"]{color:var(--layer-risk-text);border-color:rgba(242,91,109,.5);background:rgba(242,91,109,.1)}
.pill-layer[data-layer="exec"]{color:var(--layer-exec-text);border-color:rgba(46,125,246,.5);background:rgba(46,125,246,.12)}
.pill-layer[data-layer="strat"]{color:var(--layer-strat-text);border-color:rgba(37,212,194,.5);background:rgba(37,212,194,.1)}
.pill-layer[data-layer="intel"]{color:var(--layer-intel-text);border-color:rgba(240,180,0,.5);background:rgba(240,180,0,.1)}
.pill-layer[data-layer="sec"]{color:var(--layer-sec-text);border-color:rgba(249,115,22,.5);background:rgba(249,115,22,.1)}
.pill-layer[data-layer="gov"]{color:var(--layer-gov-text);border-color:rgba(111,121,145,.4);background:rgba(168,176,196,.12)}
.pill-flagship{background:rgba(46,125,246,.15);color:#bdd5ff;border-color:rgba(46,125,246,.45)}
.pill-reference{background:rgba(37,212,194,.12);color:#9eebe0;border-color:rgba(37,212,194,.4)}
.pill-stub{background:transparent;color:var(--fg-mute);border-color:var(--line)}
.pill-class,.pill-auth,.pill-readiness{color:var(--fg-dim)}
.pill-wired{background:rgba(62,207,142,.14);color:var(--green);border-color:rgba(62,207,142,.45);font-weight:600}
:root[data-theme="light"] .pill-wired{color:#0e8a55}

/* Bot grid */
.bot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin:14px 0 28px}
.bot-card{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);color:var(--fg);transition:border-color .15s,transform .15s}
.bot-card:hover{border-color:var(--line-strong);text-decoration:none;transform:translateY(-1px)}
.bot-card-flagship{border-color:rgba(46,125,246,.45)}
.bot-card-wired{border-color:rgba(62,207,142,.45);box-shadow:inset 3px 0 0 var(--green)}
.bot-card-wired:hover{border-color:rgba(62,207,142,.7)}
.bot-card-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bot-card-id{color:var(--fg-mute);font-size:.78rem}
.bot-card-name{font-weight:600;color:var(--fg-strong);font-size:1.02rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bot-card-purpose{color:var(--fg-dim);font-size:.92rem;line-height:1.45;min-height:2.6em}
.bot-card-foot{display:flex;justify-content:space-between;color:var(--fg-mute);border-top:1px solid var(--line);padding-top:8px;margin-top:auto}

/* Why This Bot Matters — card list + worked-example callout (section 3) */
.matters-list{list-style:none;padding:0;margin:8px 0 4px;display:flex;flex-direction:column;gap:14px}
.matters-card{padding:14px 16px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.matters-card + .matters-card{margin-top:0}
.matters-failure{margin:0 0 6px;font-size:1rem;font-weight:600;color:var(--fg-strong);line-height:1.35}
.matters-consequence{margin:0;color:var(--fg);line-height:1.6}
.matters-hint{margin:10px 0 0}
.worked-example{margin-top:12px;padding:12px 14px;background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:var(--radius-sm)}
.we-head{color:var(--green);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px;font-weight:600}
:root[data-theme="light"] .we-head{color:#0e8a55}
.we-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start;padding:6px 0}
.we-row + .we-row{border-top:1px dashed var(--line)}
.we-row p{margin:0;color:var(--fg);line-height:1.55;font-size:.93rem}
.we-label{color:var(--fg-mute);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;padding-top:2px}
.we-without .we-label{color:var(--warn,#c8742d)}
.we-with .we-label{color:var(--green)}
:root[data-theme="light"] .we-with .we-label{color:#0e8a55}
@media (max-width: 640px){.we-row{grid-template-columns:1fr;gap:2px}.we-row p{padding-top:2px}}

/* Wired bot callout (per-bot page) */
.wired-cta{margin:14px 0 18px;padding:14px 16px;background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:var(--radius)}
.wired-cta-h{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.wired-cta-h .pill{margin:0}
.wired-cta-h .mono{color:var(--fg-dim);font-size:.85rem}
.wired-cta-body{color:var(--fg);line-height:1.55;margin:6px 0 4px}
.wired-cta-meta{color:var(--fg-mute);font-size:.85rem;margin-bottom:10px}
.wired-cta-meta code{color:var(--fg-dim)}
.wired-cta-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:8px}
.wired-cta-actions .btn-primary{padding:7px 14px;font-size:.88rem;font-weight:500;border-radius:var(--radius-sm);background:var(--green);border:1px solid var(--green);color:#06231a}
.wired-cta-actions .btn-primary:hover{filter:brightness(1.05);text-decoration:none}
:root[data-theme="dark"] .wired-cta-actions .btn-primary{color:#04150f}
.wired-cta-actions a:not(.btn-primary){color:var(--accent);font-size:.88rem}

/* Homepage wired bot chip grid */
.wired-grid{list-style:none;padding:0;margin:14px 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.wired-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:var(--radius-sm);font-size:.9rem}
.wired-chip-name{font-weight:600;color:var(--fg-strong);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-decoration:none}
.wired-chip-name:hover{text-decoration:underline}
.wired-chip-spec{color:var(--fg-mute);font-size:.78rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wired-chip-alias{display:inline-block;padding:1px 6px;border:1px dashed var(--warn);border-radius:3px;color:var(--warn);font-size:.7rem;white-space:nowrap}
.wired-chip-id{font-family:var(--mono);font-size:.78rem;color:var(--fg-mute);white-space:nowrap}
.wired-chip-run{color:var(--green);font-weight:500;font-size:.85rem;white-space:nowrap;padding-left:8px;border-left:1px solid var(--line)}
:root[data-theme="light"] .wired-chip-run{color:#0e8a55}

/* Layer block + group block */
.layer-block,.group-block{padding:24px 0;border-top:1px solid var(--line)}
.layer-block:first-of-type,.group-block:first-of-type{border-top:0}
.layer-block-head,.group-block-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.layer-block-head h2,.group-block-head h2{margin:0}
.layer-marker{width:8px;height:24px;border-radius:3px;background:var(--fg-mute)}
.layer-block[data-layer="disc"] .layer-marker{background:var(--layer-disc)}
.layer-block[data-layer="risk"] .layer-marker{background:var(--layer-risk)}
.layer-block[data-layer="exec"] .layer-marker{background:var(--layer-exec)}
.layer-block[data-layer="strat"] .layer-marker{background:var(--layer-strat)}
.layer-block[data-layer="intel"] .layer-marker{background:var(--layer-intel)}
.layer-block[data-layer="sec"] .layer-marker{background:var(--layer-sec)}
.layer-block[data-layer="gov"] .layer-marker{background:var(--layer-gov)}
.layer-block-blurb{color:var(--fg-dim);max-width:780px;margin:0 0 12px}

/* View grid */
.view-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin:18px 0 32px}
.view-card{padding:16px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);color:var(--fg)}
.view-card:hover{border-color:var(--accent);text-decoration:none}
.view-card h3{margin:0 0 6px}
.view-card p{margin:0;color:var(--fg-dim)}

/* Bot page */
.bot-shell{padding:28px 0 80px}
.bot-head{padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:24px}
.bot-crumbs{color:var(--fg-mute);margin-bottom:10px}
.bot-crumbs a{color:var(--fg-dim)}
.bot-title{margin:0;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;font-size:2rem}
.bot-id{color:var(--fg-mute);font-size:1.2rem}
.bot-name{color:var(--fg-strong)}
.bot-pillrow{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 10px}
.bot-lede{color:var(--fg-dim);font-size:1.05rem;margin:6px 0 12px;max-width:720px}
.bot-pagenav{display:flex;justify-content:space-between;color:var(--fg-mute);margin-top:6px}
.bot-pagenav a{color:var(--fg-dim)}

.bot-body{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:32px}
@media (max-width:960px){
  .bot-body{grid-template-columns:1fr}
  .bot-side{display:none}
}
.bot-main .botsec{padding:24px 0;border-top:1px solid var(--line)}
.bot-main .botsec:first-child{border-top:0;padding-top:0}
.bot-main .botsec h2{margin-top:0}

/* Sticky side nav */
.bot-side{position:relative}
.side-sticky{position:sticky;top:80px}
.side-title{color:var(--fg-mute);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.side-nav{list-style:none;padding:0;margin:0;border-left:1px solid var(--line)}
.side-nav li{margin:0}
.side-nav a{display:block;padding:5px 12px;color:var(--fg-dim);font-size:.88rem;border-left:2px solid transparent;margin-left:-1px}
.side-nav a:hover{color:var(--fg-strong);text-decoration:none;background:var(--bg-elev)}
.side-nav a.is-active{color:var(--fg-strong);border-left-color:var(--accent)}

/* Tables */
.tbl-wrap{overflow-x:auto;margin:8px 0 14px;border:1px solid var(--line);border-radius:var(--radius)}
.tbl{width:100%;border-collapse:collapse;font-size:.92rem}
.tbl th,.tbl td{padding:9px 12px;text-align:left;vertical-align:top;border-top:1px solid var(--line)}
.tbl thead th{background:var(--bg-elev);color:var(--fg-dim);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;border-top:0}
.tbl tbody tr:hover{background:var(--hover-bg)}
.identity-tbl th{width:200px;color:var(--fg-dim);font-weight:500}
.legacy-note{color:var(--fg-mute);font-size:.85rem;font-style:italic;margin:4px 0}

/* Code */
pre.code{background:var(--bg-code);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;overflow-x:auto;font-size:.85rem;margin:8px 0 14px;line-height:1.55}
pre.code code{font-family:var(--mono);color:var(--code-text)}
code.mono{background:var(--bg-elev);border:1px solid var(--line);border-radius:4px;padding:1px 6px;color:var(--code-text)}

/* Cross-bot interlinks */
.botref{font-family:var(--mono);font-size:.92em;color:var(--fg);background:var(--bg-elev);border:1px solid var(--line);border-radius:4px;padding:1px 6px;text-decoration:none;border-bottom:1px dotted var(--fg-mute);transition:color .12s ease,border-color .12s ease,background .12s ease}
.botref:hover{color:var(--fg-strong);background:var(--bg-card);border-color:var(--line-strong);text-decoration:none}
.botref[data-layer="disc"]:hover{color:var(--layer-disc-text);border-bottom-color:var(--layer-disc)}
.botref[data-layer="risk"]:hover{color:var(--layer-risk-text);border-bottom-color:var(--layer-risk)}
.botref[data-layer="exec"]:hover{color:var(--layer-exec-text);border-bottom-color:var(--layer-exec)}
.botref[data-layer="strat"]:hover{color:var(--layer-strat-text);border-bottom-color:var(--layer-strat)}
.botref[data-layer="intel"]:hover{color:var(--layer-intel-text);border-bottom-color:var(--layer-intel)}
.botref[data-layer="sec"]:hover{color:var(--layer-sec-text);border-bottom-color:var(--layer-sec)}
.botref[data-layer="gov"]:hover{color:var(--layer-gov-text);border-bottom-color:var(--layer-gov)}
.botref-inline{color:inherit;text-decoration:none;border-bottom:1px dotted var(--fg-mute);transition:color .12s ease,border-color .12s ease}
.botref-inline:hover{color:var(--fg-strong);text-decoration:none}
.botref-inline[data-layer="disc"]:hover{color:var(--layer-disc-text);border-bottom-color:var(--layer-disc);border-bottom-style:solid}
.botref-inline[data-layer="risk"]:hover{color:var(--layer-risk-text);border-bottom-color:var(--layer-risk);border-bottom-style:solid}
.botref-inline[data-layer="exec"]:hover{color:var(--layer-exec-text);border-bottom-color:var(--layer-exec);border-bottom-style:solid}
.botref-inline[data-layer="strat"]:hover{color:var(--layer-strat-text);border-bottom-color:var(--layer-strat);border-bottom-style:solid}
.botref-inline[data-layer="intel"]:hover{color:var(--layer-intel-text);border-bottom-color:var(--layer-intel);border-bottom-style:solid}
.botref-inline[data-layer="sec"]:hover{color:var(--layer-sec-text);border-bottom-color:var(--layer-sec);border-bottom-style:solid}
.botref-inline[data-layer="gov"]:hover{color:var(--layer-gov-text);border-bottom-color:var(--layer-gov);border-bottom-style:solid}

/* Decision grid */
.decision-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:8px 0 14px}
@media (max-width:760px){.decision-grid{grid-template-columns:1fr}}
.decision-card{padding:12px 14px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);border-left:3px solid var(--fg-mute)}
.decision-card h3{margin:0 0 6px;font-size:.95rem}
.decision-card p{margin:0;color:var(--fg-dim)}
.decision-approve{border-left-color:var(--green)}
.decision-reshape_required{border-left-color:var(--amber)}
.decision-reject{border-left-color:var(--red)}
.decision-warning_only{border-left-color:var(--accent)}

/* Param block */
.param-block{padding:18px 0;border-top:1px dashed var(--line)}
.param-block:first-of-type{border-top:0;padding-top:6px}
.param-name{margin:0 0 6px;color:var(--fg-strong);font-size:1.02rem}
.param-block blockquote{margin:6px 0;padding:8px 14px;border-left:2px solid var(--accent);background:var(--bg-elev);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--fg)}
blockquote.quote{padding:14px 18px;border-left:3px solid var(--accent-2);background:var(--bg-elev);border-radius:0 var(--radius) var(--radius) 0;color:var(--fg);font-size:1.02rem}

/* Flow list */
.flow-list{padding-left:1.4em;color:var(--fg)}
.flow-list li{margin:.3em 0}

/* Checklist */
.ready-summary{margin:0 0 10px;color:var(--fg-dim)}
.check{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.78rem}
.check-done{background:rgba(62,207,142,.15);color:#79e6b3;border:1px solid rgba(62,207,142,.35)}
.check-todo{background:rgba(154,163,178,.1);color:var(--fg-mute);border:1px solid var(--line-strong)}

/* Rules list */
.rules{padding-left:1.2em}
.rules li{margin:.4em 0;color:var(--fg)}
.rules code.mono{background:var(--bg-elev)}

/* Schema link */
.schema-link{font-family:var(--mono);font-size:.92em}

/* Howto */
.howto{padding-left:1.4em;color:var(--fg)}
.howto li{margin:.4em 0}

/* Footer */
.sitefoot{margin-top:60px;border-top:1px solid var(--line);padding:18px 0}
.sitefoot .container{display:flex;justify-content:space-between;color:var(--fg-mute)}

/* ─── Class-driven home + class hub + class detail ─────────────────────── */
.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;margin:24px 0 36px}
.class-grid-tight{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin:18px 0 32px}
.class-card{display:flex;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);color:var(--fg);transition:border-color .15s,transform .15s,box-shadow .15s;position:relative}
.class-card:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 18px rgba(46,125,246,.08)}
.class-card-icon{flex:0 0 44px;width:44px;height:44px;border-radius:10px;background:var(--bg-elev);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.class-card-icon svg{width:22px;height:22px;display:block}
.class-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.class-card-name{margin:0;font-size:1.18rem;font-weight:600;color:var(--fg-strong);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.class-card-blurb{margin:0;color:var(--fg-dim);font-size:.94rem;line-height:1.5}
.class-card-examples{display:flex;flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none}
.class-card-examples li{font-size:.9rem;color:var(--fg-dim)}
.class-card-examples li strong{color:var(--fg)}
.class-card-ref{font-family:var(--mono);font-size:.78rem;padding:2px 7px;border-radius:4px;background:var(--bg-elev);border:1px solid var(--line);color:var(--fg-dim)}
.class-card-foot{display:flex;justify-content:space-between;align-items:center;color:var(--fg-mute);font-size:.85rem;margin-top:auto;padding-top:10px;border-top:1px dashed var(--line)}
.class-card-arrow{color:var(--accent);font-weight:600}

/* Class detail head */
.class-detail-head{display:flex;gap:18px;align-items:flex-start;padding:32px 0 18px;border-bottom:1px solid var(--line);margin-bottom:24px}
.class-detail-icon{flex:0 0 56px;width:56px;height:56px;border-radius:12px;background:var(--bg-elev);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.class-detail-icon svg{width:28px;height:28px;display:block}
.class-detail-meta{flex:1;min-width:0}
.class-detail-meta h1{margin:0 0 6px}
.class-detail-meta .lede{color:var(--fg-dim);font-size:1.05rem;max-width:780px;margin:0}
.class-detail-meta .stats{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;color:var(--fg-mute);font-size:.88rem}
.class-detail-meta .stats strong{color:var(--fg-strong);font-weight:600;margin-right:4px}

/* Reference strip + secondary view-card row on home */
.ref-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin:16px 0 28px}

/* ─── System diagram (home page) ──────────────────────────────────────────── */
.sys-diagram{margin:18px 0 36px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;display:flex;flex-direction:column;gap:18px}
.sys-flowhint{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;color:var(--fg-dim);font-size:.86rem}
.sys-flowhint-step{padding:4px 10px;background:var(--bg-elev);border:1px solid var(--line);border-radius:6px}
.sys-flowhint-step strong{color:var(--fg-strong);font-weight:600;margin-right:4px}
.sys-flowhint-arrow{color:var(--fg-mute);font-weight:600}
@media (max-width:760px){.sys-flowhint{flex-direction:column;align-items:flex-start}}
.layer-pipeline{margin:10px 0 22px;overflow-x:auto;padding-bottom:4px}
.layer-pipeline-row{display:flex;align-items:center;gap:0;min-width:780px}
.lp-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 12px;border:1px solid var(--line);border-radius:6px;font-size:.85rem;font-weight:600;color:var(--fg-strong);background:var(--bg-card);min-width:96px;text-align:center;white-space:nowrap}
.lp-sub{font-size:.72rem;font-weight:400;color:var(--fg-mute);margin-top:2px;white-space:nowrap}
.lp-gate{border-width:2px;border-color:var(--fg-dim)}
.lp-arrow{color:var(--fg-mute);font-size:1.1rem;padding:0 4px;flex-shrink:0}
.lp-disc{border-left:3px solid #8b5cf6}
.lp-intel{border-left:3px solid #f0b400}
.lp-strat{border-left:3px solid #25d4c2}
.lp-risk{border-left:3px solid #f25b6d}
.lp-sec{border-left:3px solid #f97316}
.lp-exec{border-left:3px solid #2e7df6}
.lp-gov{border-left:3px solid #a8b0c4}
.layer-pipeline-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--fg-mute);margin-top:8px;min-width:780px;padding:0 2px}
.lp-label-gate{font-family:var(--font-mono);background:var(--bg-elev);border:1px solid var(--line);border-radius:4px;padding:1px 6px}
.layer-pipeline-return{font-size:.78rem;color:var(--fg-mute);margin-top:6px;padding-left:2px}
.hero-stats-caption{color:var(--fg-mute);margin:-12px 0 22px;font-size:.8rem}
.plain-english-block{margin:24px 0 18px;padding:24px 28px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.plain-english-title{font-size:1.05rem;font-weight:700;margin:0 0 18px;color:var(--fg-strong);text-transform:uppercase;letter-spacing:.05em}
.plain-english-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px 28px}
.pe-item h3{font-size:.95rem;font-weight:600;margin:0 0 6px;color:var(--fg-strong)}
.pe-item p{font-size:.9rem;color:var(--fg-dim);margin:0;line-height:1.6}
.pe-item em{color:var(--fg-strong);font-style:italic}
.glossary-callout{margin:22px 0 0;padding:16px 20px;background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--fg-mute);border-radius:var(--radius)}
.glossary-title{margin:0 0 10px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}
.glossary-list{display:grid;grid-template-columns:max-content 1fr;gap:6px 16px;margin:0;font-size:.88rem}
.glossary-list dt{font-family:var(--font-mono);font-weight:600;color:var(--fg-strong);white-space:nowrap}
.glossary-list dd{margin:0;color:var(--fg-dim)}
@media (max-width:600px){.glossary-list{grid-template-columns:1fr}.glossary-list dt{margin-top:8px}}
.order-flow-block{margin:18px 0 18px;padding:22px 24px;background:var(--bg-card);border:1px solid var(--line);border-left:4px solid var(--ok,#1aa260);border-radius:var(--radius)}
.order-flow-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.order-flow-steps{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:8px}
.order-flow-steps li{font-size:.92rem;color:var(--fg-dim);line-height:1.55}
.order-flow-steps li strong{color:var(--fg-strong)}
.start-here-context{font-size:.9rem;color:var(--fg-dim);margin:0 0 10px}

.sys-stack{display:flex;flex-direction:column;gap:10px}
.sys-row{display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:stretch;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;min-height:84px}
@media (max-width:860px){.sys-row{grid-template-columns:1fr}}
.sys-row-label{display:flex;gap:10px;padding:14px 14px 14px 0;align-items:flex-start}
.sys-row-bar{flex:0 0 6px;width:6px;align-self:stretch;background:var(--fg-mute);border-radius:0 3px 3px 0}
.sys-row[data-layer="disc"]  .sys-row-bar{background:var(--layer-disc)}
.sys-row[data-layer="risk"]  .sys-row-bar{background:var(--layer-risk)}
.sys-row[data-layer="exec"]  .sys-row-bar{background:var(--layer-exec)}
.sys-row[data-layer="strat"] .sys-row-bar{background:var(--layer-strat)}
.sys-row[data-layer="intel"] .sys-row-bar{background:var(--layer-intel)}
.sys-row[data-layer="sec"]   .sys-row-bar{background:var(--layer-sec)}
.sys-row[data-layer="gov"]   .sys-row-bar{background:var(--layer-gov)}
.sys-row-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.sys-row-name{color:var(--fg-strong);font-weight:600;font-size:1.02rem}
.sys-row-role{color:var(--fg-dim);line-height:1.45}
.sys-row-counts{color:var(--fg-mute)}
.sys-row-chips{display:flex;flex-wrap:wrap;gap:6px;padding:14px 14px 14px 0;align-content:flex-start}
@media (max-width:860px){.sys-row-chips{padding:0 14px 14px}}

.sys-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:14px;border:1px solid var(--line-strong);background:var(--bg-card);color:var(--fg);font-size:.8rem;font-family:var(--mono);line-height:1.2;white-space:nowrap;transition:transform .12s,border-color .12s,background .12s}
.sys-chip:hover{text-decoration:none;border-color:var(--accent);transform:translateY(-1px)}
.sys-chip[data-readiness="demo-wired"], .sys-chip.is-wired{border-color:rgba(62,207,142,.55);background:rgba(62,207,142,.08);color:var(--fg-strong)}
.sys-chip[data-readiness="docs-complete"]{color:var(--fg);border-style:solid}
.sys-chip.is-ref::before{content:"★";color:var(--accent-2);margin-right:2px;font-size:.8em}
.sys-chip.is-wired::after{content:"●";color:rgba(62,207,142,.85);margin-left:4px;font-size:.7em}

.sys-legend{display:flex;flex-wrap:wrap;gap:14px;padding-top:8px;border-top:1px dashed var(--line);color:var(--fg-mute)}
.sys-legend-item{display:inline-flex;align-items:center;gap:6px}
.sys-dot{width:10px;height:10px;border-radius:50%;display:inline-block;border:1px solid var(--line-strong)}
.sys-dot.is-wired{background:rgba(62,207,142,.55);border-color:rgba(62,207,142,.85)}
.sys-dot.is-docs{background:var(--bg-card);border-color:var(--line-strong)}
.sys-dot.is-ref{background:var(--accent-2);border-color:var(--accent-2)}

/* Implementation-depth additions */
.pill-sev{font-weight:600}
.pill-sev.sev-hard_reject{background:rgba(242,91,109,.15);color:#ffb1b9;border-color:rgba(242,91,109,.5)}
.pill-sev.sev-reshape{background:rgba(46,125,246,.15);color:#bdd5ff;border-color:rgba(46,125,246,.5)}
.pill-sev.sev-warn{background:rgba(240,180,0,.15);color:#ffd560;border-color:rgba(240,180,0,.5)}
.pill-sev.sev-explain{background:rgba(154,163,178,.12);color:var(--fg-dim);border-color:var(--line-strong)}
.pill-sev.sev-info{background:rgba(154,163,178,.10);color:var(--fg-dim);border-color:var(--line)}
.pill-sev.sev-p0{background:rgba(242,91,109,.2);color:#ffb1b9;border-color:rgba(242,91,109,.6)}
.pill-sev.sev-p1{background:rgba(249,115,22,.15);color:#ffc89a;border-color:rgba(249,115,22,.5)}
.pill-bool.yes{background:rgba(62,207,142,.12);color:#79e6b3;border-color:rgba(62,207,142,.4)}
.pill-bool.no{background:rgba(154,163,178,.12);color:var(--fg-dim);border-color:var(--line-strong)}
.pill-api{background:rgba(46,125,246,.10);color:#bdd5ff;border-color:rgba(46,125,246,.35);font-weight:500}
.pill-net{background:rgba(37,212,194,.10);color:#9eebe0;border-color:rgba(37,212,194,.35);font-weight:500}
.chiprow{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 16px}
.code-pseudo{font-size:.86rem;line-height:1.55;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px}
:root[data-theme="light"] .pill-sev.sev-hard_reject{background:rgba(220,38,38,.10);color:#b91c1c;border-color:rgba(220,38,38,.4)}
:root[data-theme="light"] .pill-sev.sev-reshape{background:rgba(37,99,235,.10);color:#1d4ed8;border-color:rgba(37,99,235,.4)}
:root[data-theme="light"] .pill-sev.sev-warn{background:rgba(202,138,4,.10);color:#854d0e;border-color:rgba(202,138,4,.4)}
:root[data-theme="light"] .pill-bool.yes{background:rgba(22,163,74,.10);color:#15803d;border-color:rgba(22,163,74,.4)}
:root[data-theme="light"] .pill-bool.no{background:rgba(100,116,139,.10);color:#475569;border-color:rgba(100,116,139,.35)}
:root[data-theme="light"] .pill-api{background:rgba(37,99,235,.08);color:#1d4ed8;border-color:rgba(37,99,235,.3)}
:root[data-theme="light"] .pill-net{background:rgba(13,148,136,.08);color:#0f766e;border-color:rgba(13,148,136,.3)}

/* Reason-codes table compactness */
.botsec h3{margin:18px 0 8px;font-size:1rem;font-weight:600;color:var(--fg-strong)}

/* Principles sub-pages */
.principles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin:18px 0 28px}
.principles-card{display:block;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-card);text-decoration:none;color:inherit;transition:border-color .15s,transform .15s}
.principles-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.principles-card-title{font-weight:600;color:var(--fg-strong);margin-bottom:4px}
.principles-card-desc{color:var(--fg-dim);font-size:.88rem;line-height:1.45}

/* Reporting page */
.reporting-toc{display:flex;flex-wrap:wrap;gap:6px 10px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);margin:16px 0 28px;font-size:.88rem}
.reporting-toc a{color:var(--fg-dim);padding:2px 8px;border-radius:4px;text-decoration:none}
.reporting-toc a:hover{color:var(--fg-strong);background:var(--bg-elev)}
.reporting-section{padding:24px 0;border-top:1px solid var(--line)}
.reporting-section:first-of-type{border-top:0;padding-top:8px}
.reporting-section h2{margin:0 0 6px;font-size:1.25rem}
.reporting-section h3{margin:18px 0 8px;font-size:1rem;font-weight:600;color:var(--fg-strong)}
.reporting-section > p{color:var(--fg-dim);max-width:78ch;margin:0 0 14px}
.reporting-principles{margin:8px 0 0;padding-left:20px}
.reporting-principles li{margin:8px 0;color:var(--fg-dim);line-height:1.55}
.reporting-principles li strong{color:var(--fg-strong)}
.reporting-list{margin:8px 0 0;padding-left:20px}
.reporting-list li{margin:6px 0;color:var(--fg-dim);line-height:1.55}
.reporting-list li strong{color:var(--fg-strong)}
.reporting-checklist{list-style:none;padding:0;margin:8px 0 0}
.reporting-checklist li{padding:6px 0;color:var(--fg-dim);display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.reporting-checklist input[type="checkbox"]{margin-top:4px}

/* Lifecycle group cards */
.rg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px;margin:14px 0 8px}
.rg-card{padding:16px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px}
.rg-card-head{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px}
.rg-title{margin:0;font-size:1rem;font-weight:600;color:var(--fg-strong);flex:1;min-width:200px}
.rg-subtitle{margin:0;color:var(--fg-dim);font-size:.85rem;flex-basis:100%}
.rg-purpose{margin:0;color:var(--fg);font-size:.92rem;line-height:1.55}
.rg-meta{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px dashed var(--line)}
.rg-meta > div{display:flex;flex-direction:column;gap:4px}
.rg-meta > div > div{font-size:.9rem;color:var(--fg)}
.rg-examples{margin-top:4px}
.rg-examples summary{cursor:pointer;color:var(--fg-dim);padding:4px 0}
.rg-examples summary:hover{color:var(--fg-strong)}
.rg-examples ul{margin:6px 0 0;padding-left:18px;font-size:.88rem;color:var(--fg-dim)}
.rg-examples li{margin:3px 0;line-height:1.5}

/* Bot chips */
.bot-chip-row{display:flex;flex-wrap:wrap;gap:6px}
.bot-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;background:var(--bg-elev);border:1px solid var(--line);border-radius:999px;font-size:.82rem;text-decoration:none;color:var(--fg)}
.bot-chip:hover{border-color:var(--accent);color:var(--fg-strong);text-decoration:none}

/* Report-kind badges */
.rk-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.78rem;font-weight:500;border:1px solid;letter-spacing:.02em;white-space:nowrap}
.rk-obs  {background:rgba(13,148,136,.10);color:#0f766e;border-color:rgba(13,148,136,.4)}
.rk-risk {background:rgba(220,38,38,.10);color:#b91c1c;border-color:rgba(220,38,38,.4)}
.rk-dec  {background:rgba(124,58,237,.10);color:#6d28d9;border-color:rgba(124,58,237,.4)}
.rk-exec {background:rgba(37,99,235,.10);color:#1d4ed8;border-color:rgba(37,99,235,.4)}
.rk-sett {background:rgba(22,163,74,.10);color:#15803d;border-color:rgba(22,163,74,.4)}
.rk-ops  {background:rgba(100,116,139,.10);color:#475569;border-color:rgba(100,116,139,.4)}
:root[data-theme="dark"] .rk-obs  {background:rgba(13,148,136,.18);color:#5eead4;border-color:rgba(13,148,136,.5)}
:root[data-theme="dark"] .rk-risk {background:rgba(220,38,38,.18);color:#fca5a5;border-color:rgba(220,38,38,.5)}
:root[data-theme="dark"] .rk-dec  {background:rgba(124,58,237,.18);color:#c4b5fd;border-color:rgba(124,58,237,.5)}
:root[data-theme="dark"] .rk-exec {background:rgba(37,99,235,.18);color:#93c5fd;border-color:rgba(37,99,235,.5)}
:root[data-theme="dark"] .rk-sett {background:rgba(22,163,74,.18);color:#86efac;border-color:rgba(22,163,74,.5)}
:root[data-theme="dark"] .rk-ops  {background:rgba(148,163,184,.18);color:#cbd5e1;border-color:rgba(148,163,184,.5)}

/* Verdict pills */
.verdict-pill{display:inline-flex;align-items:center;padding:1px 8px;border-radius:999px;font-size:.76rem;font-weight:500;border:1px solid;text-transform:lowercase}
.v-pass    {background:rgba(22,163,74,.12);color:#15803d;border-color:rgba(22,163,74,.4)}
.v-reshape {background:rgba(202,138,4,.12);color:#854d0e;border-color:rgba(202,138,4,.4)}
.v-reject  {background:rgba(220,38,38,.12);color:#b91c1c;border-color:rgba(220,38,38,.4)}
.v-info    {background:rgba(100,116,139,.10);color:#475569;border-color:rgba(100,116,139,.35)}
:root[data-theme="dark"] .v-pass    {color:#86efac;background:rgba(22,163,74,.18)}
:root[data-theme="dark"] .v-reshape {color:#fde68a;background:rgba(202,138,4,.18)}
:root[data-theme="dark"] .v-reject  {color:#fca5a5;background:rgba(220,38,38,.18)}
:root[data-theme="dark"] .v-info    {color:#cbd5e1;background:rgba(148,163,184,.16)}

/* Trace timeline */
.trace-meta{display:flex;flex-wrap:wrap;gap:18px;padding:10px 14px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-sm);margin:0 0 12px}
.trace-meta .dim{margin-right:4px}
.trace-list{list-style:none;padding:0;margin:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-card);overflow:hidden}
.trace-row{display:grid;grid-template-columns:90px 130px 160px auto auto 1fr;gap:12px;align-items:center;padding:8px 14px;border-bottom:1px solid var(--line);font-size:.88rem}
.trace-bot{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trace-row:last-child{border-bottom:0}
.trace-row:hover{background:var(--bg-elev)}
.trace-time{color:var(--fg)}
.trace-stage{white-space:nowrap}
.trace-bot{color:var(--fg-strong)}
.trace-summary{color:var(--fg-dim);line-height:1.5}
@media (max-width: 900px){
  .trace-row{grid-template-columns:1fr 1fr;gap:6px}
  .trace-summary{grid-column:1/-1}
}

/* Payload sketches */
.payload-sketch{margin:10px 0;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-card);overflow:hidden}
.payload-sketch summary{cursor:pointer;padding:10px 14px;color:var(--fg-strong);display:flex;align-items:center;gap:8px}
.payload-sketch summary:hover{background:var(--bg-elev)}
.payload-sketch[open] summary{border-bottom:1px solid var(--line)}
.payload-sketch pre.code{margin:0;border-radius:0;border:0}

/* Dev-pages (Standards / Developers / Pipelines / Ops / Templates) */
.page-hero{padding:42px 0 22px;border-bottom:1px solid var(--line);margin-bottom:28px}
.page-hero h1{margin:0 0 8px;font-size:2.1rem;letter-spacing:-0.01em}
.lede{font-size:1.05rem;color:var(--fg-dim);max-width:62ch;line-height:1.55}
.breadcrumb{color:var(--fg-mute);font-size:.85rem;margin:0 0 10px;text-transform:uppercase;letter-spacing:.06em}
.breadcrumb a{color:var(--fg-dim);text-decoration:none}
.breadcrumb a:hover{color:var(--fg-strong)}
.subsec-h{font-size:.95rem;margin:22px 0 6px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.callout{padding:12px 16px;border-left:3px solid var(--amber, #d6a55a);background:var(--bg-elev);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:16px 0;color:var(--fg-strong)}
.callout strong{color:var(--fg-strong)}
/* Build-tiers page: Tier 1 / Tier 2 / Tier 3 tables and status pills */
.build-tier-table{width:100%;border-collapse:collapse;margin:14px 0 8px;font-size:.92rem}
.build-tier-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--line-strong);color:var(--fg-mute);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.build-tier-table td{padding:10px 10px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.45}
.build-tier-table td:first-child{white-space:nowrap;width:1%}
.build-tier-table td:nth-child(3){white-space:nowrap;width:1%}
.build-tier-table tr:hover{background:var(--bg-elev)}
/* Build-order page: phase × module table with State / Next task / Promotion gate columns */
.build-order-table{width:100%;border-collapse:collapse;margin:14px 0 8px;font-size:.88rem;table-layout:fixed}
.build-order-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--line-strong);color:var(--fg-mute);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;vertical-align:bottom}
.build-order-table td{padding:10px 10px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.45;word-wrap:break-word;overflow-wrap:break-word}
.build-order-table th:nth-child(1),.build-order-table td:nth-child(1){width:48px}
.build-order-table th:nth-child(2),.build-order-table td:nth-child(2){width:200px}
.build-order-table th:nth-child(3),.build-order-table td:nth-child(3){width:200px}
.build-order-table th:nth-child(4),.build-order-table td:nth-child(4){width:170px}
.build-order-table th:nth-child(5),.build-order-table td:nth-child(5){width:120px}
.build-order-table th:nth-child(6),.build-order-table td:nth-child(6){width:auto}
.build-order-table th:nth-child(7),.build-order-table td:nth-child(7){width:auto}
.build-order-table tr:hover{background:var(--bg-elev)}
.build-order-table code.mono{font-size:.82rem;word-break:break-all}
/* Status board: three-track header */
.status-tracks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0 8px}
.status-track{padding:14px 16px;background:var(--bg-card);border:1px solid var(--line-strong);border-radius:var(--radius-sm);position:relative}
.status-track .track-num{display:inline-block;width:22px;height:22px;line-height:22px;text-align:center;border-radius:50%;background:var(--accent);color:#fff;font-size:.74rem;font-weight:700;margin-right:6px}
.status-track h3{margin:6px 0 8px;font-size:1rem;color:var(--fg-strong);font-weight:650;display:inline-block}
.status-track p{margin:0 0 8px;font-size:.86rem;line-height:1.5;color:var(--fg-strong)}
.status-track .track-link{color:var(--accent);text-decoration:none;border-bottom:1px dotted var(--accent)}
.status-track .track-link:hover{border-bottom-style:solid}
@media (max-width: 880px){.status-tracks{grid-template-columns:1fr}}
/* First five developer tasks page */
.first-five-list{display:flex;flex-direction:column;gap:18px;margin:18px 0 8px}
.first-five-task{padding:18px 22px;background:var(--bg-card);border:1px solid var(--line-strong);border-left:4px solid var(--accent);border-radius:var(--radius-sm)}
.first-five-task[data-status="shipped"]{border-left-color:#246e35}
.first-five-task[data-status="in-progress"]{border-left-color:#a05a00}
.first-five-task[data-status="pending"]{border-left-color:#6b6b6b}
.first-five-head{display:flex;align-items:center;gap:14px;margin:0 0 8px;flex-wrap:wrap}
.first-five-head h2{margin:0;font-size:1.08rem;color:var(--fg-strong);font-weight:650;flex:1;min-width:200px}
.first-five-num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#0b0d10;font-weight:700;font-size:.86rem}
.first-five-task[data-status="shipped"] .first-five-num{background:#246e35;color:#fff}
.first-five-task[data-status="in-progress"] .first-five-num{background:#a05a00;color:#fff}
.first-five-task[data-status="pending"] .first-five-num{background:#6b6b6b;color:#fff}
.first-five-why{margin:6px 0 14px;line-height:1.55;color:var(--fg-strong)}
.first-five-meta{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding-top:12px;border-top:1px solid var(--line)}
.first-five-meta h4{margin:0 0 6px;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem}
.first-five-meta p{margin:0;line-height:1.5}
.first-five-files{margin:0;padding-left:18px;line-height:1.7}
@media (max-width: 720px){.first-five-meta{grid-template-columns:1fr}}
.pill-status{display:inline-block;padding:2px 7px;border-radius:3px;border:1px solid var(--line);background:var(--bg-elev);color:var(--fg-strong);font-size:.7rem;letter-spacing:.04em;white-space:nowrap}
.pill-status.pill-docs{border-color:#6b6b6b40;color:#6b6b6b}
.pill-status.pill-demo{border-color:#246e3540;color:#246e35;background:#246e3510}
.pill-status.pill-shadow{border-color:#a05a0040;color:#a05a00;background:#a05a0010}
.pill-status.pill-runtime{border-color:#1c4f9c40;color:#1c4f9c;background:#1c4f9c10}
.pill-status.pill-prod{border-color:#7f1d1d40;color:#7f1d1d;background:#7f1d1d10}
/* Homepage Q3a blocks: Start Here, readiness truth, what's next */
.start-here-block{margin:22px 0 16px;padding:22px 24px;background:var(--bg-card);border:1px solid var(--line-strong);border-left:4px solid var(--accent);border-radius:var(--radius);box-shadow:0 1px 0 rgba(0,0,0,0.04)}
.start-here-head{display:flex;align-items:center;gap:12px;margin:0 0 12px;flex-wrap:wrap}
.start-here-head h2{font-size:1.18rem;color:var(--fg-strong);font-weight:650}
.start-here-steps{counter-reset:tier;list-style:none;padding:0;margin:14px 0 16px}
.start-here-steps li{counter-increment:tier;position:relative;padding:12px 14px 12px 50px;border-left:3px solid var(--accent);background:var(--bg-elev);margin-bottom:8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;line-height:1.5;color:var(--fg-strong)}
.start-here-steps li::before{content:counter(tier);position:absolute;left:14px;top:12px;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#0b0d10;font-weight:700;font-size:.82rem;font-family:var(--font-mono,monospace);display:flex;align-items:center;justify-content:center}
.start-here-steps li a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent}
.start-here-steps li a:hover{border-bottom-color:var(--accent)}
.start-here-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.start-here-cta .btn-primary,.start-here-cta .btn-secondary{display:inline-block;padding:9px 16px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;text-decoration:none;border:1px solid transparent;line-height:1;white-space:nowrap}
.start-here-cta .btn-primary{background:var(--accent);color:#0b0d10;border-color:var(--accent)}
.start-here-cta .btn-primary:hover{filter:brightness(1.08)}
.start-here-cta .btn-secondary{background:transparent;color:var(--fg-strong);border-color:var(--line-strong)}
.start-here-cta .btn-secondary:hover{background:var(--bg-elev);border-color:var(--accent);color:var(--accent)}
.readiness-truth{margin:18px 0 16px;padding:18px 22px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.readiness-truth h3{margin:0 0 10px;font-size:1.02rem;color:var(--fg-strong);font-weight:600;letter-spacing:.01em}
.readiness-table{width:100%;border-collapse:collapse;font-size:.92rem}
.readiness-table th{text-align:left;padding:6px 10px;border-bottom:2px solid var(--line-strong);color:var(--fg-mute);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em}
.readiness-table td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.45;color:var(--fg-strong)}
.readiness-table td:first-child{white-space:nowrap;width:1%}
.readiness-table td:nth-child(2){white-space:nowrap;width:1%;font-family:var(--font-mono,monospace);color:var(--fg-strong)}
.readiness-table tr:last-child td{border-bottom:none}
.whats-next-block{margin:18px 0 22px;padding:20px 22px;background:linear-gradient(180deg,rgba(240,180,0,0.04),transparent 60%),var(--bg-card);border:1px solid var(--line);border-left:4px solid var(--warn,#f0b400);border-radius:var(--radius)}
.whats-next-head{display:flex;align-items:center;gap:12px;margin:0 0 10px;flex-wrap:wrap}
.whats-next-head h3{font-size:1.05rem;color:var(--fg-strong);font-weight:600;margin:0}
.whats-next-list{margin:6px 0 14px;padding-left:22px;color:var(--fg-strong)}
.whats-next-list li{margin:6px 0;line-height:1.55}
.whats-next-list code{background:var(--bg-elev);padding:1px 5px;border-radius:3px;font-size:.86em;border:1px solid var(--line)}
.phase-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:14px 0 22px}
.phase-card{padding:16px 20px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.phase-card h3{margin:0 0 6px;font-size:1.05rem}
.phase-card .phase-meta{color:var(--fg-dim);font-size:.85rem;margin-bottom:8px}
.phase-bots{margin:8px 0 0;padding-left:20px;color:var(--fg-dim);font-size:.92rem}
.phase-bots li{margin:2px 0}
.pipeline{counter-reset:step;list-style:none;padding:0;margin:14px 0 22px}
.pipeline li{counter-increment:step;position:relative;padding:12px 14px 12px 46px;border-left:3px solid var(--accent, #6aa8ff);background:var(--bg-elev);margin-bottom:8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.pipeline li::before{content:counter(step);position:absolute;left:12px;top:12px;width:24px;height:24px;border-radius:50%;background:var(--accent, #6aa8ff);color:#0b0d10;font-weight:700;font-size:.78rem;display:flex;align-items:center;justify-content:center}
.pipeline li strong{display:block;color:var(--fg-strong);margin-bottom:2px}
.playbook{margin:14px 0;padding:16px 20px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.playbook h3{margin:0 0 8px;font-size:1.05rem;color:var(--fg-strong)}
.playbook .playbook-meta{color:var(--fg-dim);font-size:.85rem;margin-bottom:10px}
.playbook ol,.playbook ul{margin:6px 0 6px 20px;color:var(--fg-strong)}
.pill-row{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 14px}
.mode-pill{display:inline-block;padding:3px 9px;border-radius:999px;border:1px solid var(--line);background:var(--bg-elev);font-size:.8rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}
.mode-pill[data-mode="off"]{color:var(--fg-mute, #6b7280)}
.mode-pill[data-mode="shadow"]{color:var(--accent-2, #9aa7ff)}
.mode-pill[data-mode="advisory"]{color:var(--amber, #d6a55a)}
.mode-pill[data-mode="enforced"]{color:var(--green, #4ec99d)}
.mode-pill[data-mode="quarantine"]{color:var(--red, #e26a6a)}
.forbidden-grid{display:grid;grid-template-columns:1fr;gap:10px;margin:14px 0}
.forbidden-card{padding:12px 16px;border-left:3px solid var(--red, #e26a6a);background:var(--bg-elev);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.forbidden-card strong{color:var(--fg-strong);display:block;margin-bottom:3px}
.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin:14px 0 22px}
.template-card{padding:14px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:inherit;transition:border-color .15s}
.template-card:hover{border-color:var(--accent, #6aa8ff)}
.template-card .tcard-title{font-weight:600;color:var(--fg-strong);margin-bottom:4px}
.template-card .tcard-desc{color:var(--fg-dim);font-size:.88rem;line-height:1.45}
@media (max-width: 700px){
  .page-hero{padding:28px 0 16px}
  .page-hero h1{font-size:1.6rem}
  .lede{font-size:.98rem}
}

/* ============================================================ */
/* v3 spine: health bar, three-score, status board, phase cards */
/* ============================================================ */

/* Health bar — under topnav on every page */
.health-bar{background:var(--bg-elev);border-bottom:1px solid var(--line);font-size:.85rem}
.health-bar-inner{max-width:1200px;margin:0 auto;padding:8px 24px;display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.health-label{padding:2px 8px;border-radius:4px;background:var(--accent, #6aa8ff);color:#0b0d10;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem}
.health-phase{color:var(--fg-strong);font-weight:600}
.health-stat{color:var(--fg-dim)}
.health-stat strong{color:var(--fg-strong)}
.health-link{margin-left:auto;color:var(--accent, #6aa8ff);text-decoration:none;border-bottom:1px dotted currentColor;padding-bottom:1px}
.health-link + .health-link{margin-left:0}
.health-link:hover{color:var(--fg-strong)}
@media (max-width:780px){
  .health-bar-inner{padding:6px 16px;gap:10px}
  .health-link{margin-left:0}
}

/* State pills — five-state visual coding */
.state-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;border:1px solid var(--line);background:var(--bg-elev);font-size:.8rem}
.state-dot{font-size:.78rem;line-height:1;display:inline-block}
.state-pill.state-green{color:#1a7a52;background:rgba(78,201,157,.10);border-color:rgba(78,201,157,.35)}
.state-pill.state-amber{color:#a36b18;background:rgba(214,165,90,.12);border-color:rgba(214,165,90,.40)}
.state-pill.state-grey{color:var(--fg-dim);background:var(--bg-elev);border-color:var(--line)}
.state-pill.state-red{color:#a83333;background:rgba(226,106,106,.10);border-color:rgba(226,106,106,.40)}
.state-pill.state-black{color:#222;background:#e6e6e6;border-color:#bdbdbd}
[data-theme="dark"] .state-pill.state-green{color:#7fe0b3}
[data-theme="dark"] .state-pill.state-amber{color:#e8c084}
[data-theme="dark"] .state-pill.state-red{color:#f08e8e}
[data-theme="dark"] .state-pill.state-black{color:#bdbdbd;background:#222;border-color:#333}

/* Capital impact pill */
.pill-cap{font-size:.78rem}
.pill-cap[data-cap="Critical"]{color:#a83333;border-color:rgba(226,106,106,.45);background:rgba(226,106,106,.10)}
.pill-cap[data-cap="Direct"]{color:#a36b18;border-color:rgba(214,165,90,.45);background:rgba(214,165,90,.10)}
.pill-cap[data-cap="Indirect"]{color:var(--fg-dim);background:var(--bg-elev)}
[data-theme="dark"] .pill-cap[data-cap="Critical"]{color:#f08e8e}
[data-theme="dark"] .pill-cap[data-cap="Direct"]{color:#e8c084}

/* Phase badge */
.pill-phase{font-size:.78rem;background:rgba(106,168,255,.10);border-color:rgba(106,168,255,.40);color:var(--accent, #2c6dc7)}
[data-theme="dark"] .pill-phase{color:#9cc0ff}

/* Three-score block on each bot page */
.three-score{margin:14px 0 8px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.three-score .subsec-h{margin:0 0 10px;font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-dim)}
.score-row{display:grid;grid-template-columns:24px 80px 60px 1fr 110px 80px;align-items:center;gap:10px;padding:6px 0;border-top:1px dashed var(--line)}
.score-row:first-of-type{border-top:none}
.score-glyph{font-size:1rem;text-align:center}
.score-num{color:var(--fg-strong)}
.score-bar{height:6px;background:var(--bg-elev);border-radius:3px;overflow:hidden}
.score-bar > span{display:block;height:100%;background:#bdbdbd;border-radius:3px;transition:width .2s}
.score-row.score-green .score-bar > span{background:#4ec99d}
.score-row.score-green .score-glyph{color:#4ec99d}
.score-row.score-amber .score-bar > span{background:#d6a55a}
.score-row.score-amber .score-glyph{color:#d6a55a}
.score-row.score-red .score-bar > span{background:#e26a6a}
.score-row.score-red .score-glyph{color:#e26a6a}
.score-state{color:var(--fg-dim);text-transform:lowercase}
@media (max-width:760px){
  .score-row{grid-template-columns:24px 1fr 60px;gap:8px}
  .score-row .score-bar, .score-row .score-state, .score-row a{display:none}
}

/* v3 plan — phase cards with state */
.phase-card.phase-done{border-left:3px solid #4ec99d}
.phase-card.phase-in_progress{border-left:3px solid #d6a55a}
.phase-card.phase-locked{border-left:3px solid #888;opacity:.65}
.phase-card.phase-pending{border-left:3px solid var(--line)}
.phase-card-h{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px;margin-bottom:8px}
.phase-card-h h2{margin:0;font-size:1.1rem}
.phase-num{padding:2px 8px;border-radius:4px;background:var(--bg-elev);color:var(--fg-dim);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}
.phase-progress{margin:10px 0;display:flex;align-items:center;gap:10px}
.phase-progress-bar{flex:1;height:6px;background:var(--bg-elev);border-radius:3px;overflow:hidden}
.phase-progress-bar.inline{width:120px;flex:none}
.phase-progress-bar > span{display:block;height:100%;background:#4ec99d;border-radius:3px}
.phase-card.phase-pending .phase-progress-bar > span,.phase-card.phase-locked .phase-progress-bar > span{background:#888}
.phase-card.phase-in_progress .phase-progress-bar > span{background:#d6a55a}
.phase-detail{margin-top:8px;padding:8px 0;border-top:1px dashed var(--line)}
.phase-detail summary{cursor:pointer;color:var(--fg-dim);font-size:.85rem;letter-spacing:.04em}
.phase-detail summary:hover{color:var(--fg-strong)}
.phase-detail p{margin:8px 0 4px;color:var(--fg-strong);font-size:.92rem}

/* Status board — tabs and filters */
.board-tabs{display:flex;gap:0;margin:18px 0 0;border-bottom:1px solid var(--line)}
.board-tab{appearance:none;border:none;background:none;padding:10px 18px;cursor:pointer;color:var(--fg-dim);font:inherit;font-size:.92rem;border-bottom:2px solid transparent;margin-bottom:-1px}
.board-tab.active{color:var(--fg-strong);border-bottom-color:var(--accent, #6aa8ff);font-weight:600}
.board-tab:hover{color:var(--fg-strong)}
.board-pane{display:none;padding-top:14px}
.board-pane.active{display:block}
.board-filters{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:8px 0 14px}
.board-filters label{margin-right:6px;color:var(--fg-dim)}
.board-filter{appearance:none;border:1px solid var(--line);background:var(--bg-elev);padding:4px 10px;border-radius:999px;cursor:pointer;color:var(--fg-dim);font:inherit;font-size:.8rem}
.board-filter.active{background:var(--accent, #6aa8ff);color:#0b0d10;border-color:transparent}
.board-filter:hover{color:var(--fg-strong)}
.board-tbl tr[data-state="deprecated"]{opacity:.55}
.state-counts{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 6px}

/* Schema blocks (manifest-driven) */
.schema-block{margin:24px 0;padding:18px 20px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius)}
.schema-block-h{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px;margin-bottom:6px}
.schema-block-h h3{margin:0;font-size:1.05rem;color:var(--fg-strong)}
.schema-detail{margin-top:8px}
.schema-detail summary{cursor:pointer;color:var(--fg-dim);font-size:.85rem;letter-spacing:.04em;padding:4px 0}
.schema-detail summary:hover{color:var(--fg-strong)}
.schema-detail pre{margin-top:8px}

/* Homepage v3 callout */
.v3-callout{margin:22px 0 18px;padding:22px 26px;background:linear-gradient(135deg, rgba(106,168,255,.08), rgba(78,201,157,.06));border:1px solid var(--line);border-radius:var(--radius)}
[data-theme="dark"] .v3-callout{background:linear-gradient(135deg, rgba(106,168,255,.10), rgba(78,201,157,.06))}
.v3-callout-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.v3-callout-head h2{margin:0;font-size:1.4rem;color:var(--fg-strong)}
.v3-callout > p{margin:8px 0 14px;color:var(--fg-strong)}
.v3-callout-stats{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:14px;color:var(--fg-dim)}
.v3-callout-stats strong{color:var(--fg-strong);font-size:1.08rem}
.v3-callout-cta{display:flex;flex-wrap:wrap;gap:8px}
.btn-primary,.btn-secondary{display:inline-block;padding:8px 16px;border-radius:6px;text-decoration:none;font-size:.9rem;font-weight:500;transition:transform .1s, box-shadow .1s}
.btn-primary{background:var(--accent, #6aa8ff);color:#0b0d10}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{background:var(--bg-elev);color:var(--fg-strong);border:1px solid var(--line)}
.btn-secondary:hover{border-color:var(--accent, #6aa8ff)}

/* Tombstone for deprecated bots */
.page-hero.tombstone{background:repeating-linear-gradient(45deg, var(--bg-elev), var(--bg-elev) 12px, var(--bg) 12px, var(--bg) 24px);border-bottom:2px solid #888}
.page-hero.tombstone h1{color:var(--fg-dim);text-decoration:line-through}

/* v3.5 — demo + optimize pages */
.demo-grid{display:grid;grid-template-columns:320px 1fr;gap:24px;align-items:flex-start}
@media (max-width: 1100px){.demo-grid{grid-template-columns:1fr}}
.demo-controls{background:var(--bg-elev);padding:16px;border-radius:8px;border:1px solid var(--border);position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto}
.demo-controls h3{margin:14px 0 8px;font-size:.95rem;color:var(--fg-strong);border-bottom:1px solid var(--border);padding-bottom:4px}
.demo-controls h3:first-child{margin-top:0}
.control-row{display:grid;grid-template-columns:1fr;gap:4px;margin:8px 0}
.control-row label{font-size:.82rem;color:var(--fg-dim);font-family:ui-monospace,monospace}
.control-row select,.control-row input[type=number],.control-row input[type=password],.control-row input[type=text]{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg);font-family:ui-monospace,monospace;font-size:.88rem}
.control-row input[type=range]{width:100%}
.control-row output{font-family:ui-monospace,monospace;font-size:.78rem;color:var(--fg-dim);text-align:right}
/* New richer parameter row used in renderParamSliders. Each row is a small
   card with a labelled header (label left, current value right), the control,
   a min↔max scale for ranges, and a dim one-line help string. */
.param-row{display:flex;flex-direction:column;gap:6px;padding:10px 12px;margin:10px 0;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px}
.param-row + .param-row{margin-top:8px}
.param-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.param-label{font-size:.86rem;color:var(--fg-strong);font-weight:500;font-family:inherit;line-height:1.3}
.param-value{font-family:ui-monospace,monospace;font-size:.82rem;color:var(--fg);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.param-control{width:100%}
.param-row select.param-control,.param-row input[type=text].param-control,.param-row input[type=number].param-control{padding:6px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg);font-family:ui-monospace,monospace;font-size:.88rem}
.param-row input[type=range].param-control{width:100%}
.param-bool{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--fg);cursor:pointer}
.param-bool input[type=checkbox]{margin:0}
.param-scale{display:flex;justify-content:space-between;font-family:ui-monospace,monospace;font-size:.72rem;color:var(--fg-dim);margin-top:-2px}
.param-help{margin:2px 0 0;font-size:.78rem;color:var(--fg-dim);line-height:1.45}
.control-actions{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}
.control-actions button{flex:1 1 auto;padding:8px 12px;border-radius:4px;border:1px solid var(--border);background:var(--bg);color:var(--fg);font-family:inherit;font-size:.85rem;cursor:pointer}
.control-actions .btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.control-actions .btn-primary:hover{filter:brightness(1.1)}
.demo-main{display:flex;flex-direction:column;gap:18px}
.demo-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}
.stat-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;padding:10px 12px;display:flex;flex-direction:column}
.stat-num{font-size:1.4rem;font-weight:600;color:var(--fg-strong);font-variant-numeric:tabular-nums}
.stat-label{font-size:.72rem;color:var(--fg-dim);font-family:ui-monospace,monospace;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.demo-chart-wrap{background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;padding:12px}
.demo-chart-wrap h3{margin:0 0 8px;font-size:.9rem;color:var(--fg-strong)}
.demo-chart-wrap canvas{width:100%;height:auto;display:block;background:var(--bg);border-radius:4px}
.demo-tables{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 800px){.demo-tables{grid-template-columns:1fr}}
.demo-tables>div{background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;padding:12px}
.demo-tables h3{margin:0 0 8px;font-size:.9rem}
.envelope-stream{background:var(--bg);padding:8px;border-radius:4px;color:var(--fg);font-size:.78rem;line-height:1.4;max-height:240px;overflow-y:auto;white-space:pre-wrap}
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border);color:var(--fg-dim);font-weight:500;font-family:ui-monospace,monospace;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.data-table td{padding:6px 8px;border-bottom:1px solid var(--border)}
.data-table tr:last-child td{border-bottom:none}


/* ---------- stage up-link banner used on pipelines/ and ops/ pages ---------- */
.stage-uplink{display:inline-block;margin:16px 0 0;padding:8px 14px;background:rgba(14,126,110,.08);border:1px solid rgba(14,126,110,.25);border-radius:8px;color:var(--fg)}
.stage-uplink a{color:var(--accent);font-weight:600}

/* ---------- /stages/ pages ---------- */
.stages-hub-hero{padding:32px 0 24px;border-bottom:1px solid var(--border);margin-bottom:32px}
.stages-hub-hero h1{font-size:42px;line-height:1.1;letter-spacing:-.02em;margin:14px 0 12px;max-width:880px}
.stages-hub-lede{font-size:17px;line-height:1.55;color:var(--fg);max-width:780px;margin:0 0 14px}
.stages-hub-rule{color:var(--fg-mute);max-width:780px}

.stages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}
.stages-tile{display:flex;flex-direction:column;gap:8px;padding:22px 22px 18px;background:var(--card);border:1px solid var(--border);border-radius:14px;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.stages-tile:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.08);border-color:var(--accent);text-decoration:none}
.stages-tile-num{color:var(--fg-mute);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}
.stages-tile-title{font-size:18px;line-height:1.3;margin:0;font-weight:700}
.stages-tile-tagline{font-size:14px;line-height:1.5;color:var(--fg-mute);margin:4px 0 6px;flex:1}
.stages-tile-meta{color:var(--fg-mute);display:flex;gap:6px;flex-wrap:wrap;font-size:11px}

.stages-tile-registry{border-left:3px solid #4c6ef5}
.stages-tile-ingestion{border-left:3px solid #15aabf}
.stages-tile-canonical{border-left:3px solid #20c997}
.stages-tile-signals{border-left:3px solid #51cf66}
.stages-tile-fairvalue{border-left:3px solid #9775fa}
.stages-tile-execution{border-left:3px solid #ffd43b}
.stages-tile-decision{border-left:3px solid #ff8787}
.stages-tile-oms{border-left:3px solid #ff922b}
.stages-tile-inventory{border-left:3px solid #38d9a9}
.stages-tile-replay{border-left:3px solid #748ffc}
.stages-tile-monitoring{border-left:3px solid #f06595}
.stages-tile-recap{border-left:3px solid var(--accent);background:linear-gradient(135deg,rgba(14,126,110,.04),transparent)}

/* ---------- single stage page ---------- */
.stage-page{max-width:1080px}
.stage-crumbs{margin:18px 0 6px}
.stage-hero{padding:18px 0 28px;border-bottom:1px solid var(--border);margin-bottom:28px}
.stage-hero-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.stage-num{color:var(--fg-mute);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:700;padding:3px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg-sub)}
.stage-title{font-size:36px;line-height:1.15;letter-spacing:-.02em;margin:0;font-weight:700}
.stage-tagline{font-size:17px;line-height:1.55;color:var(--fg);margin:10px 0 0;max-width:840px}

.stage-twocol{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:18px 0}
@media (max-width:760px){.stage-twocol{grid-template-columns:1fr}}

.stage-card{padding:20px 22px;background:var(--card);border:1px solid var(--border);border-radius:12px}
.stage-card-h{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-mute);margin:0 0 10px;font-weight:700}
.stage-card-challenge{border-left:3px solid #ff8787}
.stage-card-what{border-left:3px solid #20c997}
.stage-card-why{border-left:3px solid #ffa94d}
.stage-card-backend{border-left:3px solid #4c6ef5}
.stage-card-maths{border-left:3px solid #9775fa}
.stage-card p{margin:0;font-size:15px;line-height:1.6}

.stage-section{margin:28px 0 8px}
.stage-section-h{font-size:18px;font-weight:700;margin:0 0 6px}
.stage-section-lede{color:var(--fg-mute);font-size:14px;line-height:1.55;margin:0 0 14px;max-width:820px}

/* ---------- diagram ---------- */
.stage-diagram{display:flex;align-items:stretch;gap:6px;flex-wrap:wrap;padding:18px;background:var(--bg-sub);border:1px dashed var(--border);border-radius:12px;margin:8px 0}
.stage-diagram-wide{padding:14px;gap:4px}
.stage-node{display:flex;flex-direction:column;justify-content:center;gap:4px;padding:12px 14px;min-width:120px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit}
.stage-node:hover{border-color:var(--accent);text-decoration:none}
.stage-node-label{font-weight:600;font-size:13px;line-height:1.3}
.stage-node-sub{color:var(--fg-mute);font-size:11px;line-height:1.4}
.stage-arrow{display:flex;align-items:center;justify-content:center;color:var(--fg-mute);font-size:18px;padding:0 4px}

.stage-node-registry{border-top:3px solid #4c6ef5}
.stage-node-ingestion{border-top:3px solid #15aabf}
.stage-node-canonical{border-top:3px solid #20c997}
.stage-node-signals{border-top:3px solid #51cf66}
.stage-node-fairvalue{border-top:3px solid #9775fa}
.stage-node-execution{border-top:3px solid #ffd43b}
.stage-node-decision{border-top:3px solid #ff8787}
.stage-node-oms{border-top:3px solid #ff922b}
.stage-node-inventory{border-top:3px solid #38d9a9}
.stage-node-replay{border-top:3px solid #748ffc}
.stage-node-monitoring{border-top:3px solid #f06595}
.stage-node-recap{border-top:3px solid var(--accent);background:linear-gradient(180deg,rgba(14,126,110,.06),var(--card))}

/* ---------- bullets / maths / code / mock links ---------- */
.stage-bullets{list-style:disc;padding-left:20px;margin:0;font-size:14px;line-height:1.7}
.stage-bullets li{margin:2px 0}

.stage-math-list{display:flex;flex-direction:column;gap:6px}
.stage-math{font-size:15px;padding:6px 0;overflow-x:auto}

/* ---------- rich math card (stage pages) ---------- */
.math-card{border-left:3px solid #9775fa;padding:24px 26px}
.math-list{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.math-item{padding:18px 20px 16px;background:var(--bg-sub,var(--bg-elev));border:1px solid var(--border,var(--line));border-radius:10px}
.math-item-h{display:flex;align-items:baseline;gap:10px;margin:0 0 6px}
.math-item-num{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:11px;background:rgba(151,117,250,.15);color:#7c5ce6;font-weight:700;font-size:11px}
:root[data-theme="dark"] .math-item-num{background:rgba(151,117,250,.22);color:#c4b1ff}
.math-item-h h3{font-size:15px;font-weight:700;line-height:1.3;margin:0;color:var(--fg-strong,var(--fg))}
.math-formula{font-size:16px;padding:8px 0 6px;overflow-x:auto}
.math-vars{width:100%;border-collapse:collapse;font-size:13px;margin:6px 0 8px;table-layout:fixed}
.math-vars th{text-align:left;color:var(--fg-mute);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:11px;padding:6px 8px;border-bottom:1px solid var(--line)}
.math-vars td{padding:6px 8px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.45}
.math-vars td.mi-sym{width:140px;font-size:14px}
.math-vars td.mi-mean{color:var(--fg)}
.math-vars td.mi-units{width:34%;color:var(--fg-mute)}
.math-vars tr:last-child td{border-bottom:0}
@media (max-width:640px){.math-vars{display:block;overflow-x:auto}.math-vars td.mi-sym{width:auto}.math-vars td.mi-units{width:auto}}
.math-example{margin:6px 0 4px;padding:10px 12px;border-left:3px solid #25d4c2;background:rgba(37,212,194,.06);border-radius:6px;overflow-x:auto}
.math-example-h{display:block;color:#0e8a7e;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
:root[data-theme="dark"] .math-example-h{color:#7eebdf}
.math-note{margin:8px 0 0;color:var(--fg-mute);line-height:1.55}

.stage-code-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.stage-code-list li{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:var(--bg-sub);border:1px solid var(--border);border-radius:10px}
.stage-code-list code{font-size:13px;font-weight:600;color:var(--accent)}
.stage-code-blurb{font-size:13px;line-height:1.5;color:var(--fg)}

.stage-mock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.stage-mock-link{display:flex;flex-direction:column;gap:2px;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit;transition:border-color .15s,transform .15s}
.stage-mock-link:hover{border-color:var(--accent);transform:translateY(-1px);text-decoration:none}
.stage-mock-arrow{font-size:14px;color:var(--accent);font-weight:700}
.stage-mock-label{font-weight:600;font-size:14px;line-height:1.3}
.stage-mock-path{color:var(--fg-mute);font-size:11px}

.stage-rc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.stage-rc-list li{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-sub);border:1px solid var(--border);border-radius:8px}
.stage-rc-list code{font-size:13px;font-weight:700;color:var(--accent)}
.stage-rc-label{font-size:13px;color:var(--fg)}

.stage-prevnext{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:36px;padding-top:24px;border-top:1px solid var(--border)}
.stage-prevnext a{display:flex;flex-direction:column;gap:4px;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:inherit;transition:border-color .15s,transform .15s}
.stage-prevnext a:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.stage-prev{text-align:left}
.stage-next{text-align:right}
.stage-nav-title{font-weight:600;font-size:14px;line-height:1.3}
.stage-prevnext .mono.small{color:var(--fg-mute)}
@media (max-width:600px){.stage-prevnext{grid-template-columns:1fr}}
