/* docs-v5.css — v5 visual system for the mnemur component-docs pages.
   Shared by docs.html + docs-core/gateway/evals/loops/telemetry/mq/voice.

   This is the v5 chrome (dual-theme tokens, nav, header, footer, wordmark)
   shared with index-v5.html / docs-system.html, PLUS the docs two-column
   layout, sidebar/TOC, and content typography — rebuilt against the v5 tokens
   so the reference pages match docs-system on both light and dark themes.

   The FOUC pre-paint theme script + the dark/light toggle live inline on each
   page (as on index-v5 / docs-system). The doc CONTENT and the docs-search.js
   DOM hooks (.docs-menu, #docs-search, #docs-results, #docs-nav, a.sub, .sel,
   .active) are unchanged — this file only restyles them. */

/* ── DUAL-THEME TOKENS (shared verbatim with index-v5 / docs-system) ── */
:root,
html[data-theme="light"]{
  --paper:#fbfaf7; --paper-2:#f2f0ea; --card:#ffffff;
  --ink:#1b1d20; --ink-soft:#3a3d40; --muted:#64686b; --faint:#696d70;
  --line:#e6e3db; --line-2:#d6d2c7;
  --accent:#b14a26; --accent-soft:#f4e6df; --ok:#2f6f4f;
}
html[data-theme="dark"]{
  --paper:#14171a; --paper-2:#1b1f23; --card:#1f2429;
  --ink:#ecefec; --ink-soft:#c4cac6; --muted:#8b938e; --faint:#868f89;
  --line:#2a3036; --line-2:#363d44;
  --accent:#dd7a4f; --accent-soft:rgba(221,122,79,.12); --ok:#6fc295;
}
:root{
  --serif:Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  --mono:'SF Mono',ui-monospace,'JetBrains Mono',Menlo,Consolas,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s}
.sans{font-family:var(--sans)}
.wrap{max-width:940px;margin:0 auto;padding:0 30px}

/* ── NAV / HEADER (verbatim from index-v5 / docs-system) ── */
header.nav{position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--paper) 85%,transparent);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid var(--line)}
header.nav .wrap{display:flex;justify-content:space-between;align-items:center;padding:15px 30px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand img{height:26px;width:auto;display:block}
html[data-theme="dark"] .brand img{filter:invert(1) hue-rotate(180deg) brightness(1.4)}
.brand .wm{font-family:var(--mono);font-size:16px;letter-spacing:.18em;font-weight:500;color:var(--accent)}
nav.links{display:flex;align-items:center}
nav.links a{font-family:var(--sans);font-size:13.5px;color:var(--muted);text-decoration:none;margin-left:22px;letter-spacing:.01em}
nav.links a:hover{color:var(--ink)}
nav.links a[aria-current="page"]{color:var(--ink)}
.toggle{margin-left:22px;background:none;border:1px solid var(--line-2);color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:6px 11px;border-radius:3px;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.toggle:hover{border-color:var(--accent);color:var(--ink)}
.toggle .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);display:inline-block}
@media(max-width:820px){nav.links a:not(.btn){display:none}.brand .wm{display:none}.toggle{margin-left:14px}}

/* ── PAGE TITLE (top of the content column, beside the sidebar) ── */
.docs-title{margin:0 0 38px}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.docs-title .hero-t{font-size:clamp(30px,4.5vw,44px);line-height:1.08;font-weight:500;letter-spacing:-.02em}
.meta{font-family:var(--sans);font-size:13px;color:var(--faint);margin-top:8px}

/* ── TWO-COLUMN LAYOUT: sticky sidebar + content ── */
.docs-layout{display:grid;grid-template-columns:232px minmax(0,1fr);gap:54px;max-width:1180px;margin:0 auto;padding:48px 30px 90px;align-items:start}

/* ── SIDEBAR ── */
.docs-side{position:sticky;top:76px;max-height:calc(100vh - 96px);overflow-y:auto;font-family:var(--sans);scrollbar-width:thin}
.docs-menu>summary{display:none}
.side-head{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:6px 0 12px}
.side-search{position:relative;margin-bottom:16px}
.side-search input{width:100%;font-family:var(--sans);font-size:13.5px;padding:8px 10px;border:1px solid var(--line-2);border-radius:4px;background:var(--card);color:var(--ink)}
.side-search input::placeholder{color:var(--faint)}
.side-search input:focus{outline:none;border-color:var(--accent)}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:-40px;z-index:30;background:var(--card);border:1px solid var(--line-2);border-radius:6px;box-shadow:0 12px 36px rgba(0,0,0,.18);max-height:340px;overflow-y:auto}
html[data-theme="dark"] .search-results{box-shadow:0 12px 36px rgba(0,0,0,.55)}
.search-results a{display:block;padding:9px 12px;text-decoration:none;border-bottom:1px solid var(--line)}
.search-results a:last-child{border-bottom:none}
.search-results a .t{display:block;font-size:13px;color:var(--ink);font-weight:600;line-height:1.35}
.search-results a .w{display:block;font-size:10.5px;color:var(--accent);font-family:var(--mono);letter-spacing:.04em;margin-top:2px}
.search-results a .s{display:block;font-size:12px;color:var(--muted);line-height:1.45;margin-top:3px}
.search-results a:hover,.search-results a.sel{background:var(--paper-2)}
.search-results .none{display:block;padding:10px 12px;font-size:12.5px;color:var(--muted)}
.side-nav a{display:block;font-size:13.5px;color:var(--muted);text-decoration:none;padding:5px 10px;border-left:2px solid transparent;border-radius:0 4px 4px 0;line-height:1.45}
.side-nav a:hover{color:var(--ink)}
.side-nav a.top{font-weight:600;color:var(--ink-soft);margin-top:10px}
.side-nav a.top:first-child{margin-top:0}
.side-nav a.sub{padding-left:24px;font-size:13px}
.side-nav a.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-soft)}

/* ── CONTENT COLUMN — typography ── */
.doc{min-width:0;max-width:790px}
.doc h2{font-family:var(--serif);font-size:26px;font-weight:400;margin:54px 0 12px;letter-spacing:-.01em;padding-top:34px;border-top:1px solid var(--line);color:var(--ink)}
.doc h2.nb{border-top:none;padding-top:0;margin-top:8px}
.doc h3{font-family:var(--sans);font-size:15px;font-weight:600;margin:34px 0 8px;letter-spacing:.02em;color:var(--ink)}
.doc h4{font-family:var(--sans);font-size:13.5px;font-weight:600;margin:24px 0 6px;color:var(--ink)}
.doc h2,.doc h3,.doc h4{scroll-margin-top:88px}
.doc p{font-size:16.5px;color:var(--ink-soft);margin-top:14px;line-height:1.7}
.doc .first{font-size:19.5px;color:var(--ink)}
.doc strong{color:var(--ink);font-weight:600}
.doc ul,.doc ol{margin:12px 0 0 20px;color:var(--ink-soft);font-size:15.5px;line-height:1.7}
.doc li{margin-top:7px}
.doc code{font-family:var(--mono);font-size:.9em;background:var(--accent-soft);border-radius:4px;padding:1px 5px;color:var(--accent)}
.doc pre{font-family:var(--mono);font-size:13px;line-height:1.75;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:16px 20px;margin-top:14px;overflow-x:auto}
.doc pre code{background:none;padding:0;font-size:inherit;color:var(--ink-soft)}
.doc table{width:100%;border-collapse:collapse;margin-top:14px;font-size:14px}
.doc th{font-family:var(--sans);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);text-align:left;font-weight:600;padding:8px 12px 8px 0;border-bottom:1px solid var(--line-2)}
.doc td{padding:9px 12px 9px 0;border-bottom:1px solid var(--line);color:var(--ink-soft);vertical-align:top;line-height:1.55}
.doc td code,.doc th code{white-space:nowrap}
.doc a{color:var(--accent);text-decoration:none}
.doc a:hover{text-decoration:underline}
.sig{font-family:var(--mono);font-size:13.5px;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:0 8px 8px 0;padding:10px 16px;margin-top:18px;overflow-x:auto;white-space:pre}
.pill{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.05em;border:1px solid var(--line-2);border-radius:4px;padding:1px 8px;color:var(--muted);vertical-align:middle;margin-left:8px;background:none}
.pipeline{font-family:var(--mono);font-size:13.5px;line-height:1.9;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:18px 22px;margin-top:18px;overflow-x:auto;white-space:pre;color:var(--ink-soft)}
.lic{border-left:2px solid var(--accent);padding-left:20px;margin:26px 0;font-size:16px;color:var(--ink-soft)}
.statusline{font-family:var(--sans);font-size:13px;color:var(--faint);margin-top:10px}
.statusline a{color:var(--accent);text-decoration:none}
.statusline a:hover{text-decoration:underline}

/* ── LAYERED ARCHITECTURE STACK (docs.html overview) ── */
.arch{margin-top:20px;font-family:var(--sans)}
.arch-layer{border:1px solid var(--line-2);border-radius:8px;background:var(--card);padding:15px 20px}
.arch-layer.hl{border-left:2px solid var(--accent)}
.arch-layer.base{background:var(--paper-2);border-style:dashed}
.arch-layer .lab{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.arch-layer .who{font-size:15px;font-weight:600;color:var(--ink);margin-top:4px}
.arch-layer .who a{color:var(--ink)}
.arch-layer .who a:hover{color:var(--accent);text-decoration:none}
.arch-layer .what{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.55}
.arch-flow{text-align:center;font-family:var(--mono);font-size:12px;color:var(--faint);padding:7px 0}
.arch-libs{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:10px}
.arch-libs a{display:block;border:1px solid var(--line);border-radius:6px;padding:10px 12px;text-decoration:none;background:var(--paper-2)}
.arch-libs a:hover{border-color:var(--accent);text-decoration:none}
.arch-libs strong{display:block;font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--accent)}
.arch-libs span{display:block;font-size:12px;color:var(--muted);line-height:1.45;margin-top:3px}

/* ── FOOTER (v5; matches docs-system footer voice) ── */
footer.foot{border-top:1px solid var(--line);background:var(--paper-2)}
footer.foot .wrap{padding:30px 30px 40px;max-width:1180px}
footer.foot p{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.02em;line-height:1.7;max-width:900px}
footer.foot a{color:var(--muted)}
footer.foot a:hover{color:var(--accent)}

/* ── MOBILE: sidebar collapses to a details/summary block above the content ── */
@media(max-width:680px){
  .docs-layout{display:block;padding:20px 22px 70px}
  .docs-title{margin-bottom:30px}
  .docs-side{position:static;max-height:none;overflow:visible;margin-bottom:28px}
  .docs-menu{border:1px solid var(--line-2);border-radius:6px;background:var(--card)}
  .docs-menu>summary{display:block;cursor:pointer;font-family:var(--sans);font-size:14px;font-weight:600;color:var(--ink);padding:12px 14px;list-style:none}
  .docs-menu>summary::-webkit-details-marker{display:none}
  .docs-menu>summary::after{content:"\25BE";float:right;color:var(--muted)}
  .docs-menu[open]>summary::after{content:"\25B4"}
  .docs-menu .side-inner{padding:2px 14px 14px}
  .search-results{right:0}
}
