/* Frothy docs — "Field Manual" design system (brutalist retro-computing).
   Ported from the Claude Design project: warm manila paper, near-black ink,
   clay + phosphor-green signals, hard 2px ink rules, blunt offset block shadows,
   the mascot critter, and a layered type system (Baste B / Schibsted / Jakarta /
   JetBrains Mono). Light "paper" default + dark "terminal" theme.
   Engines kept: search.js, reference-layout.js, froth-highlight.js (tk-* classes). */

/* ============================ TOKENS ============================ */
:root{
  /* warm neutrals */
  --ink:#1b1812; --ink-pure:#000; --soot:#1e1a13; --char:#2a251c;
  --slate:#5c5544; --ash:#8a8068; --stone:#b3a989;
  --paper:#f1ead9; --paper-2:#e8dfca; --paper-3:#d3c8a9; --white:#fbf8ef;
  /* signals */
  --green:#4fa82e; --green-deep:#3b7e20; --green-soft:#dce9c9;
  --clay:#e0795c; --clay-deep:#c25c3e; --clay-soft:#f6e0d6;
  --ember:#da4321; --ember-deep:#b22d0f; --ember-soft:#f8ddd0;
  --cyan:#1f9fbc; --cyan-deep:#15788e; --cyan-soft:#cfe8ee;
  --amber:#e9a626; --amber-soft:#f6e6c2;

  /* semantic (light / paper) */
  --bg:var(--paper); --surface:var(--white); --surface-sunk:var(--paper-2);
  --text:var(--ink); --text-muted:var(--slate); --text-faint:var(--ash);
  --border:var(--ink); --border-soft:var(--paper-3);
  --accent:var(--clay); --accent-soft:var(--clay-soft); --accent-ink:var(--clay-deep);
  --link:var(--cyan-deep);

  /* aliases used by docs + homepage rules */
  --page:var(--bg); --page-2:var(--paper-2); --card:var(--surface);
  --bg-2:var(--paper-2); --bg-3:var(--paper-3);
  --rule:var(--paper-3); --rule-strong:var(--ink);
  --ink-2:var(--slate); --ink-3:var(--ash); --ink-4:var(--stone);

  /* fonts */
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --font-display:"Baste B","Schibsted Grotesk",system-ui,sans-serif;
  --font-heading:"Schibsted Grotesk","Plus Jakarta Sans",system-ui,sans-serif;
  --font-body:"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,sans-serif;
  --font-serif:"Instrument Serif",ui-serif,Georgia,serif;

  /* radii / borders / shadows / motion */
  --radius-sm:4px; --r-sm:5px; --r:7px; --radius-lg:10px;
  --border-hair:1px; --border-rule:1.5px; --border-bold:2px;
  --shadow-block:3px 3px 0 0 var(--ink);
  --shadow-pop:5px 5px 0 0 var(--ink);
  --ease-snap:cubic-bezier(0.2,0.9,0.3,1);

  /* layout */
  --wrap:1240px; --maxw:1240px; --pad:clamp(22px,4.4vw,64px); --pad-x:var(--pad);

  /* code highlight (light surface default) */
  --tk-w:#3a342a; --tk-kw:var(--clay-deep); --tk-def:var(--green-deep);
  --tk-n:var(--cyan-deep); --tk-s:var(--cyan-deep); --tk-c:var(--ash);
}
html[data-theme="dark"]{
  --paper:#1b1812; --paper-2:#221d15; --paper-3:#322b20; --white:#1e1a13;
  --ink:#e9e0cb; --slate:#a79e8b; --ash:#6f685a; --stone:#544d40;
  --bg:#1b1812; --surface:#1e1a13; --surface-sunk:#110e09;
  --text:#e9e0cb; --text-muted:#a79e8b; --text-faint:#6f685a;
  --border:#e9e0cb; --border-soft:#322b20;
  --accent:var(--clay); --accent-soft:#3a1a10; --accent-ink:#e89a82;
  --link:#4fc3dc;
  --rule:#322b20; --rule-strong:#e9e0cb;
  --tk-w:#d7cfbb; --tk-kw:#e89a82; --tk-def:#7fd15c; --tk-n:#5cc3dc; --tk-s:#5cc3dc; --tk-c:#857c64;
}

/* Baste B — the brand display face. Drop the .otf files in static/fonts/ to enable;
   falls back to Schibsted Grotesk until then. */
@font-face{font-family:"Baste B";src:url("/fonts/BasteB-Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Baste B";src:url("/fonts/BasteB-Medium.otf") format("opentype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Baste B";src:url("/fonts/BasteB-Black.otf") format("opentype");font-weight:800;font-style:normal;font-display:swap}

/* ============================ BASE ============================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;min-height:100vh;display:flex;flex-direction:column;
  background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"liga" 1,"calt" 1}
h1,h2,h3,h4{margin:0;font-family:var(--font-heading);font-weight:800;letter-spacing:-.02em;line-height:1.1;color:var(--text)}
p{margin:0;text-wrap:pretty}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0}
code,pre,kbd{font-family:var(--font-mono)}
::selection{background:var(--green);color:var(--ink)}
:focus-visible{outline:2px solid var(--green);outline-offset:2px}
img{max-width:100%}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.mono{font-family:var(--font-mono);font-feature-settings:"calt" 0,"liga" 0}
.serif{font-family:var(--font-serif);font-style:italic}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.page{flex:1;width:100%}

/* mascot critter glyph */
.mc{display:inline-block;vertical-align:middle;fill:currentColor;flex:none}
/* serif flourish word */
.flo{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--clay);letter-spacing:.005em;text-transform:none}
/* technical eyebrow */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-weight:700;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate)}
.eyebrow .mc{width:15px;height:15px;color:var(--clay-deep)}
.eyebrow .ic{color:var(--clay-deep)}
/* graph-paper grid */
.grid-bg{background-image:
  linear-gradient(to right,color-mix(in srgb,var(--ink) 7%,transparent) 1px,transparent 1px),
  linear-gradient(to bottom,color-mix(in srgb,var(--ink) 7%,transparent) 1px,transparent 1px);
  background-size:32px 32px}

/* buttons */
.fmbtn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
  font-family:var(--font-mono);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  border:2px solid var(--ink);border-radius:5px;height:50px;padding:0 24px;background:var(--card);color:var(--text);
  box-shadow:3px 3px 0 0 var(--ink);transition:transform .14s var(--ease-snap),box-shadow .14s var(--ease-snap)}
.fmbtn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 0 var(--ink)}
.fmbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 0 var(--ink)}
.fmbtn--clay{background:var(--clay);color:#3a1c11;border-color:var(--ink)}
.fmbtn--green{background:var(--green);color:var(--ink)}
.fmbtn .ic{width:17px;height:17px}

/* ============================ NAV (shared) ============================ */
.site-top{position:sticky;top:0;z-index:100}
.fm-nav{background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:2px solid var(--ink)}
.fm-nav-in{max-width:var(--wrap);margin:0 auto;padding:0 var(--pad);height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.fm-brand{display:flex;align-items:center;gap:11px}
.fm-brand .mc{width:28px;height:28px;color:var(--ink)}
.fm-brand .word{font-family:var(--font-display);font-weight:800;font-size:24px;letter-spacing:.01em;text-transform:uppercase;line-height:.9}
.fm-nav-links{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.fm-nav-links a{padding:8px 13px;border:2px solid transparent;border-radius:5px;transition:border-color .14s,background .14s;color:var(--text-muted)}
.fm-nav-links a:hover{border-color:var(--ink);color:var(--text)}
.fm-nav-links a.cur,.fm-nav-links a.active{background:var(--green);border-color:var(--ink);color:var(--ink)}
.fm-nav-right{display:flex;align-items:center;gap:11px;flex:1;justify-content:flex-end;max-width:420px}
.fm-status{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep);border:1.5px solid var(--green-deep);
  background:var(--green-soft);padding:6px 10px;border-radius:4px}
.fm-status i{width:7px;height:7px;border-radius:50%;background:var(--green);display:block;animation:fmpulse 1.8s ease-out infinite}
@keyframes fmpulse{0%{box-shadow:0 0 0 0 rgba(79,168,46,.55)}100%{box-shadow:0 0 0 7px rgba(79,168,46,0)}}
.fm-search{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;font-weight:600;
  color:var(--text-muted);border:2px solid var(--ink);background:var(--card);border-radius:5px;padding:9px 10px 9px 13px;
  box-shadow:2px 2px 0 0 var(--ink);cursor:pointer;transition:transform .14s,box-shadow .14s;flex:1;min-width:0}
.fm-search .sb-label{flex:1;text-align:left}
.fm-search:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 0 var(--ink)}
.fm-search .ic{width:14px;height:14px}
.fm-search kbd{font-family:var(--font-mono);font-size:10px;border:1.5px solid var(--ink);border-radius:3px;padding:2px 5px;background:var(--bg-2)}
.fm-iconbtn{width:42px;height:42px;display:grid;place-items:center;border:2px solid var(--ink);border-radius:5px;
  background:var(--card);color:var(--text);box-shadow:2px 2px 0 0 var(--ink);cursor:pointer;transition:transform .14s,box-shadow .14s}
.fm-iconbtn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 0 var(--ink)}
.fm-iconbtn .ic{width:18px;height:18px}
@media (max-width:880px){.fm-nav-links{display:none}.fm-status{display:none}.fm-search .sb-label,.fm-search kbd{display:none}}

/* pre-alpha banner — repeating ticker (clipped, not animated) */
.prealpha-banner{overflow:hidden;white-space:nowrap;padding:7px 0;color:var(--ink);background:var(--amber);border-bottom:2px solid var(--ink)}
.prealpha-banner .ticker{display:block;white-space:nowrap}
.prealpha-banner span{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.prealpha-banner .t-sep{margin:0 14px;opacity:.55}

/* ============================ FOOTER (shared) ============================ */
.fm-foot{background:var(--ink);color:var(--paper);border-top:2px solid var(--ink);position:relative;overflow:hidden;margin-top:auto}
html[data-theme="dark"] .fm-foot{background:#0d0b07}
.fm-foot-band{position:absolute;inset:0;display:flex;flex-wrap:wrap;gap:20px;padding:20px;opacity:.05;pointer-events:none}
.fm-foot-band .mc{width:46px;height:46px;color:var(--paper)}
.fm-foot-in{position:relative;max-width:var(--wrap);margin:0 auto;padding:56px var(--pad) 0;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.fm-foot-brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;font-size:24px;text-transform:uppercase;color:var(--paper)}
.fm-foot-brand .mc{width:26px;height:26px;color:var(--green)}
.fm-foot-tag{font-size:14px;line-height:1.6;color:#b3a989;margin-top:16px;max-width:34ch}
.fm-foot-credit{font-family:var(--font-mono);font-size:11.5px;color:#857c64;margin-top:16px;letter-spacing:.03em}
.fm-foot-h{font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#857c64;margin-bottom:14px}
.fm-foot-col a{display:block;font-size:14px;color:#d7cfbb;padding:5px 0}
.fm-foot-col a:hover{color:var(--green)}
.fm-foot-base{position:relative;max-width:var(--wrap);margin:48px auto 0;padding:18px var(--pad);border-top:1px solid #2a251c;
  display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:11.5px;color:#857c64;letter-spacing:.02em}
.fm-foot-status{display:inline-flex;align-items:center;gap:8px;color:var(--green)}
.fm-foot-status .ic{width:14px;height:14px}
@media (max-width:920px){.fm-foot-in{grid-template-columns:1fr 1fr;gap:30px}.fm-foot-base{flex-direction:column;gap:10px;text-align:center}}

/* ============================ SEARCH MODAL (search.js DOM) ============================ */
.search-shell{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:13vh 20px 20px;overflow-y:auto}
.search-shell[hidden]{display:none}
.search-backdrop{position:absolute;inset:0;background:color-mix(in srgb,var(--ink) 42%,transparent);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.search-dialog{position:relative;width:min(600px,100%);max-height:calc(100vh - 20vh);background:var(--card);
  border:2px solid var(--ink);border-radius:9px;box-shadow:6px 6px 0 0 var(--ink);display:flex;flex-direction:column;overflow:hidden}
.search-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 18px 0}
.search-label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-weight:700;margin-bottom:2px}
.search-help{font-size:12.5px;color:var(--ink-3)}
.search-close{font-family:var(--font-mono);font-size:11px;color:var(--ink-2);border:1.5px solid var(--ink);border-radius:4px;padding:4px 8px;cursor:pointer}
.search-input-wrap{display:block;padding:12px 18px;border-bottom:2px solid var(--rule)}
.search-input{width:100%;border:0;background:transparent;outline:0;font-family:var(--font-body);font-size:17px;color:var(--text)}
.search-input::placeholder{color:var(--ink-4)}
.search-status{padding:10px 18px;font-family:var(--font-mono);font-size:12px;color:var(--ink-3)}
.search-results{list-style:none;margin:0;padding:8px;overflow-y:auto;flex:1;min-height:0}
.search-result-item+.search-result-item{margin-top:4px}
.search-result-link{display:block;padding:11px 13px;border-radius:6px;border:2px solid transparent;color:var(--text)}
.search-result-link:hover{background:var(--green-soft);border-color:var(--ink)}
.search-result-meta{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);margin-bottom:2px;text-transform:uppercase;letter-spacing:.06em}
.search-result-title{font-weight:700;font-size:14.5px;margin:0 0 3px}
.search-result-detail{font-family:var(--font-mono);font-size:12px;color:var(--ink-3);margin:0 0 4px}
.search-result-snippet{font-size:13px;line-height:1.5;color:var(--ink-2)}
mark{background:var(--clay-soft);color:var(--clay-deep);border-radius:2px;padding:0 1px}
body.search-open{overflow:hidden}

/* ============================ CODE HIGHLIGHT (tk-*) ============================ */
.tk-kw{color:var(--tk-kw);font-weight:600}.tk-def{color:var(--tk-def);font-weight:600}
.tk-n{color:var(--tk-n)}.tk-s{color:var(--tk-s)}.tk-c{color:var(--tk-c);font-style:italic}
.tk-call{color:#7a5cd0}.tk-ref{color:var(--clay-deep);font-weight:600}.tk-p{color:var(--stone)}.tk-w{color:var(--tk-w)}

/* ============================ HERO + EDITOR (homepage) ============================ */
.fm-hero{border-bottom:2px solid var(--ink)}
.fm-hero-in{padding-top:64px;padding-bottom:66px}
.fm-hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center}
.fm-hero-grid>*{min-width:0}
.fm-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:700;font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink);border:2px solid var(--ink);background:var(--card);
  padding:7px 12px;border-radius:4px;box-shadow:3px 3px 0 0 var(--ink)}
.fm-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--clay);display:block}
.fm-h1{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:clamp(40px,5.4vw,64px);line-height:.96;letter-spacing:-.01em;margin-top:24px}
/* In the heavy Baste B hero, the serif-italic flourish clashes (different height/weight,
   oversized trailing period). Keep the word in the display face, just colored clay. */
.fm-h1 .flo{font-family:inherit;font-style:normal;font-weight:inherit;letter-spacing:inherit;text-transform:inherit;color:var(--clay-deep)}
.fm-lede{font-size:17.5px;line-height:1.62;color:var(--slate);max-width:40ch;margin-top:22px}
.fm-lede b{color:var(--green-deep)}
.fm-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.fm-meta{display:flex;gap:22px;margin-top:30px;font-family:var(--font-mono);font-size:12px;color:var(--slate);flex-wrap:wrap}
.fm-meta span{display:inline-flex;align-items:center;gap:8px}
.fm-meta .mc{width:14px;height:14px;color:var(--clay-deep)}
@media (max-width:920px){.fm-hero-grid{grid-template-columns:1fr;gap:40px}}

.froth-ed{width:100%;--tk-w:#3a342a;--tk-kw:var(--clay-deep);--tk-def:var(--green-deep);--tk-n:var(--cyan-deep);--tk-s:var(--cyan-deep);--tk-c:var(--ash)}
.ed-frame{border:2px solid var(--ink);border-radius:7px;overflow:hidden;background:var(--card);box-shadow:5px 5px 0 0 var(--ink);display:flex;flex-direction:column;height:432px}
.ed-bar{display:flex;align-items:center;gap:12px;height:44px;padding:0 14px;background:var(--ink);color:var(--paper)}
.ed-traffic{display:inline-flex;gap:6px}
.ed-traffic i{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--paper);display:block}
.ed-tab{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--paper)}
.ed-tab-dot{width:7px;height:7px;border-radius:50%;background:var(--clay)}
.ed-spacer{flex:1}
.ed-run{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink);background:var(--green);border:1.5px solid var(--paper);border-radius:4px;padding:6px 12px;cursor:pointer}
.ed-run.busy{background:var(--amber)}
.ed-run-tri{width:0;height:0;border-left:7px solid currentColor;border-top:5px solid transparent;border-bottom:5px solid transparent}
.ed-spin{width:11px;height:11px;border:2px solid color-mix(in srgb,var(--ink) 40%,transparent);border-top-color:var(--ink);border-radius:50%;animation:edspin .7s linear infinite}
@keyframes edspin{to{transform:rotate(360deg)}}
.ed-body{flex:1;display:flex;min-height:0}
.ed-main{flex:1;min-width:0;padding:15px 4px 16px 0;overflow:auto;background:var(--card)}
.ed-line{display:flex;align-items:flex-start;font-size:13.5px;line-height:1.78;min-height:1.78em}
.ed-ln{flex:none;width:46px;text-align:right;padding-right:15px;color:var(--stone);font-size:12px;user-select:none;font-family:var(--font-mono)}
.ed-src{white-space:pre;padding-right:18px;color:var(--tk-w);font-family:var(--font-mono)}
.ed-caret{color:var(--clay);margin-left:1px;opacity:0}.ed-caret.on{opacity:1}
.ed-console{flex:none;width:236px;display:flex;flex-direction:column;border-left:2px solid var(--ink);background:var(--paper-2)}
.ed-console-h{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);padding:11px 14px 9px;border-bottom:1.5px solid var(--paper-3)}
.ed-console-dot{width:7px;height:7px;border-radius:50%;background:var(--stone)}
.ed-log{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:4px;padding:12px 14px;font-family:var(--font-mono);font-size:11.5px;line-height:1.5}
.ed-crow{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ed-dim{color:var(--ash)}.ed-tick{color:var(--slate)}.ed-ok{color:var(--green-deep);font-weight:700;white-space:normal}
.ed-board{display:flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:11px;color:var(--slate);background:var(--card);border-top:1.5px solid var(--paper-3);padding:10px 14px}
.ed-led{width:10px;height:10px;border-radius:50%;background:#e0d4c0;border:1px solid var(--stone);transition:all .05s}
.ed-led.on{background:var(--clay);border-color:var(--clay);box-shadow:0 0 10px var(--clay)}

/* ============================ HOMEPAGE SECTIONS ============================ */
.sec{padding-top:74px;padding-bottom:74px}
.sec-head{display:flex;flex-direction:column;gap:14px;margin-bottom:40px;max-width:62ch}
.sec-title{font-family:var(--font-heading);font-weight:800;font-size:clamp(28px,3.6vw,40px);letter-spacing:-.025em;line-height:1.05}
.sec-title .flo{font-size:1.02em}

.fm-why{border-bottom:2px solid var(--ink);background:var(--bg)}
.fm-why-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.fm-why p{font-size:16px;line-height:1.68;color:var(--slate);margin-top:16px;max-width:54ch}
.fm-why p:first-of-type{margin-top:24px}
.fm-why code{font-family:var(--font-mono);font-size:.9em;background:var(--bg-2);border:1px solid var(--paper-3);border-radius:4px;padding:1px 6px;color:var(--clay-deep)}
.fm-why strong{color:var(--ink)}
.fm-callout{display:flex;gap:14px;align-items:center;margin-top:26px;padding:18px 20px;background:var(--card);border:2px solid var(--ink);border-radius:7px;box-shadow:3px 3px 0 0 var(--clay)}
.fm-callout .mc{width:26px;height:26px;color:var(--clay-deep);flex:none}
/* specificity must beat .fm-why p:first-of-type (0,2,1), which otherwise adds a 24px top margin */
.fm-why .fm-callout p{margin:0;font-size:15.5px;line-height:1.55;color:var(--ink)}
.fm-scene{border:2px solid var(--ink);border-radius:8px;overflow:hidden;background:var(--card);box-shadow:5px 5px 0 0 var(--ink)}
.fm-scene-bar{display:flex;align-items:center;gap:8px;padding:9px 14px;background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-weight:700;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase}
.fm-scene-bar .dots{display:inline-flex;gap:5px;margin-left:auto}
.fm-scene-bar .dots i{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--paper);display:block}
.fm-scene img{display:block;width:100%;height:auto}
@media (max-width:920px){.fm-why-grid{grid-template-columns:1fr;gap:36px}}

.fm-ideas{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.icard{background:var(--card);border:2px solid var(--ink);border-radius:7px;padding:22px;box-shadow:3px 3px 0 0 var(--ink);display:flex;flex-direction:column;gap:13px;transition:transform .15s var(--ease-snap),box-shadow .15s var(--ease-snap)}
.icard:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--ink)}
.icard-top{display:flex;align-items:center;justify-content:space-between}
.icard-ic{width:46px;height:46px;border:2px solid var(--ink);border-radius:6px;display:grid;place-items:center}
.icard-ic .ic{width:24px;height:24px}
.icard-kw{font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:4px 9px;border-radius:3px;border:1.5px solid var(--ink)}
.icard-h{font-family:var(--font-heading);font-weight:800;font-size:21px;letter-spacing:-.01em;line-height:1.1}
.icard-b{font-size:13.5px;line-height:1.58;color:var(--slate);flex:1}
.icard-b code{font-family:var(--font-mono);font-size:.9em;color:var(--clay-deep)}
.icard-code{font-family:var(--font-mono);font-size:11.5px;line-height:1.66;white-space:pre;overflow:auto;background:var(--ink);border-radius:5px;padding:13px 14px;margin:0;
  --tk-w:#d7cfbb;--tk-kw:#e89a82;--tk-def:#7fd15c;--tk-n:#5cc3dc;--tk-s:#5cc3dc;--tk-c:#857c64;--tk-ref:#e89a82}
.icard-code .tk-p{color:#9a8f78}.icard-code .tk-call{color:#b79be0}
.icard-note{font-size:12px;color:var(--ash);line-height:1.5}
.icard-note code{color:var(--clay-deep);font-family:var(--font-mono)}
.icard.live .icard-ic,.icard.live .icard-kw{background:var(--green-soft);color:var(--green-deep);border-color:var(--green-deep)}
.icard.trans .icard-ic,.icard.trans .icard-kw{background:var(--cyan-soft);color:var(--cyan-deep);border-color:var(--cyan-deep)}
.icard.read .icard-ic,.icard.read .icard-kw{background:var(--clay-soft);color:var(--clay-deep);border-color:var(--clay-deep)}
@media (max-width:920px){.fm-ideas{grid-template-columns:1fr}}

.fm-show{background:var(--bg);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.fm-show-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:40px;align-items:start}
.fm-term{border:2px solid var(--ink);border-radius:8px;overflow:hidden;background:#15120d;box-shadow:5px 5px 0 0 var(--ink);
  --tk-w:#e9e0cb;--tk-kw:#e89a82;--tk-def:#7fd15c;--tk-n:#5cc3dc;--tk-s:#5cc3dc;--tk-c:#857c64;--tk-ref:#e89a82}
.fm-term-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#0d0b07;color:var(--paper);font-family:var(--font-mono);font-weight:700;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid #2a251c}
.fm-term-bar .dots{display:inline-flex;gap:5px}
.fm-term-bar .dots i{width:9px;height:9px;border-radius:50%;border:1.5px solid #6f685a;display:block}
.fm-term-bar .ti{margin-left:6px;color:#a79e8b}
.fm-term-body{margin:0;padding:18px;font-family:var(--font-mono);font-size:13px;line-height:1.85;color:#e9e0cb;white-space:pre-wrap}
.fm-term-body .tk-p{color:#8a8068}.fm-term-body .tk-call{color:#c3a9ec}
.fm-term-body .ok{color:#7fd15c;font-weight:700}
.fm-show-points{display:flex;flex-direction:column;gap:8px}
.scpoint{display:flex;gap:14px;padding:18px;border:2px solid var(--ink);border-radius:7px;background:var(--card);box-shadow:3px 3px 0 0 var(--ink)}
.scpoint-ic{width:42px;height:42px;flex:none;border:2px solid var(--ink);border-radius:6px;display:grid;place-items:center;background:var(--cyan-soft);color:var(--cyan-deep)}
.scpoint-w{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--clay-deep);margin-bottom:3px}
.scpoint-t{font-family:var(--font-heading);font-weight:800;font-size:15.5px;margin-bottom:3px}
.scpoint-d{font-size:13px;line-height:1.5;color:var(--slate)}
@media (max-width:920px){.fm-show-grid{grid-template-columns:1fr;gap:26px}}

.fm-play-card{border:2px solid var(--ink);border-radius:9px;overflow:hidden;background:var(--card);box-shadow:5px 5px 0 0 var(--ink)}
.fm-play-tabs{display:flex;flex-wrap:wrap;background:var(--ink)}
.fm-play-tab{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:700;font-size:12px;letter-spacing:.04em;color:#a79e8b;background:transparent;border:0;border-right:1px solid #2a251c;padding:13px 18px;cursor:pointer;text-transform:lowercase}
.fm-play-tab .ic{width:15px;height:15px}
.fm-play-tab:hover{color:var(--paper)}
.fm-play-tab.cur{background:var(--card);color:var(--ink)}
.fm-play-body{display:grid;grid-template-columns:1.1fr .9fr}
.fm-play-pane{min-width:0}
.fm-play-pane--code{border-right:2px solid var(--ink)}
.fm-play-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;color:var(--slate);border-bottom:1.5px solid var(--paper-3);background:var(--bg)}
.fm-play-hd .run{display:inline-flex;align-items:center;gap:6px;color:var(--green-deep);font-weight:700}
.fm-play-hd .run .ic{width:13px;height:13px}
.fm-play-hd .copy{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--paper-3);border-radius:4px;padding:4px 8px;background:var(--card);color:var(--slate);cursor:pointer}
.fm-play-pre{margin:0;padding:18px;font-family:var(--font-mono);font-size:13px;line-height:1.8;white-space:pre;overflow:auto;min-height:230px;color:#3a342a;
  --tk-w:#3a342a;--tk-kw:var(--clay-deep);--tk-def:var(--green-deep);--tk-n:var(--cyan-deep);--tk-s:var(--cyan-deep);--tk-c:var(--ash)}
.fm-play-pre[hidden]{display:none}
.fm-play-pane--out .fm-play-pre{background:#15120d;color:#9fe07f;min-height:230px}
.fm-play-pane--out .fm-play-hd{background:#0d0b07;color:#a79e8b;border-bottom-color:#2a251c}
@media (max-width:760px){.fm-play-body,.fm-play-body--annot{grid-template-columns:1fr}.fm-play-pane--code{border-right:0;border-bottom:2px solid var(--ink)}}
/* annotated examples: code | commentary */
.fm-play-body--annot{grid-template-columns:1fr 1fr}
@media (max-width:760px){.fm-play-body--annot{grid-template-columns:1fr}}
.fm-play-pane--note{display:flex;flex-direction:column;background:var(--card)}
.fm-play-note{padding:20px 22px}
.fm-play-note p{font-size:14px;line-height:1.62;color:var(--ink-2);margin:0 0 14px;max-width:46ch}
.fm-play-note p:last-child{margin-bottom:0}
.fm-play-note code{font-family:var(--font-mono);font-size:.86em;color:var(--clay-deep);background:var(--bg-2);border:1px solid var(--paper-3);border-radius:4px;padding:1px 5px}
.fm-play-note em{font-style:italic}
/* inline code inside the showcase points */
.scpoint-d code{font-family:var(--font-mono);font-size:.86em;color:var(--clay-deep)}

.fm-mach-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:22px;align-items:start}
.fm-mach-card{border:2px solid var(--ink);border-radius:8px;overflow:hidden;background:var(--card);box-shadow:4px 4px 0 0 var(--ink)}
.fm-mach-card>img{display:block;width:100%;height:280px;object-fit:cover;background:var(--bg-3);border-bottom:2px solid var(--ink)}
.fm-mach-body{padding:24px}
.fm-mach-h{font-family:var(--font-heading);font-weight:800;font-size:23px;letter-spacing:-.015em;margin-bottom:10px}
.fm-mach-d{font-size:14.5px;line-height:1.62;color:var(--slate);max-width:52ch}
.fm-specs{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.fm-specs span{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--ink);border:1.5px solid var(--ink);border-radius:4px;padding:6px 10px;background:var(--bg)}
.fm-specs .ic{width:14px;height:14px;color:var(--clay-deep)}
.fm-work-card{border:2px solid var(--ink);border-radius:8px;background:var(--ink);color:var(--paper);padding:24px;box-shadow:4px 4px 0 0 var(--clay-deep);height:100%}
.fm-work-ic{width:46px;height:46px;border:2px solid var(--paper);border-radius:6px;display:grid;place-items:center;color:var(--green);margin-bottom:14px}
.fm-work-card .fm-mach-h{color:var(--paper)}
.fm-work-card .fm-mach-d{color:#b3a989}
.fm-missions{display:flex;flex-direction:column;gap:9px;margin-top:18px;font-family:var(--font-mono);font-size:12.5px;list-style:none}
.fm-missions li{display:flex;align-items:center;gap:11px;color:var(--paper)}
.fm-missions .mc{width:15px;height:15px;color:var(--green)}
.fm-missions .n{color:#857c64;font-weight:700}
@media (max-width:920px){.fm-mach-grid{grid-template-columns:1fr}}

.fm-install{background:var(--bg);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.fm-install-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.fm-install p{font-size:16px;line-height:1.62;color:var(--slate);margin-top:16px;max-width:46ch}
.fm-install code{font-family:var(--font-mono);font-size:.9em;background:var(--bg-2);border:1px solid var(--paper-3);border-radius:4px;padding:1px 6px;color:var(--clay-deep)}
.fm-checks{display:flex;flex-direction:column;gap:12px;margin-top:24px;list-style:none}
.fm-checks li{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--ink)}
.fm-checks .ck{width:24px;height:24px;flex:none;border:2px solid var(--green-deep);border-radius:5px;background:var(--green-soft);color:var(--green-deep);display:grid;place-items:center}
.fm-checks .ck .ic{width:14px;height:14px}
.fm-install-card{border:2px solid var(--ink);border-radius:8px;overflow:hidden;background:#15120d;box-shadow:5px 5px 0 0 var(--ink)}
.fm-install-tabs{display:flex;background:#0d0b07;border-bottom:1px solid #2a251c}
.fm-install-tab{font-family:var(--font-mono);font-size:12px;font-weight:600;color:#a79e8b;background:transparent;border:0;border-right:1px solid #2a251c;padding:12px 16px;cursor:pointer}
.fm-install-tab.cur{background:#15120d;color:var(--paper)}
.fm-install-code{margin:0;padding:22px 20px;font-family:var(--font-mono);font-size:14px;line-height:1.7;color:var(--paper);white-space:pre-wrap}
.fm-install-code[hidden]{display:none}
.fm-install-code .d{color:var(--green);font-weight:700}
.fm-install-code .cmt{color:#857c64}
.fm-work-card code{font-family:var(--font-mono);font-size:.88em;color:var(--green);background:rgba(255,255,255,.07);border-radius:3px;padding:0 4px}
.fm-install-foot{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid #2a251c;font-family:var(--font-mono);font-size:11px;color:#a79e8b}
@media (max-width:920px){.fm-install-grid{grid-template-columns:1fr;gap:34px}}

.fm-docs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fm-doc-card{display:flex;flex-direction:column;gap:14px;padding:22px;border:2px solid var(--ink);border-radius:7px;background:var(--card);box-shadow:3px 3px 0 0 var(--ink);transition:transform .15s,box-shadow .15s}
.fm-doc-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--ink)}
.fm-doc-top{display:flex;align-items:center;justify-content:space-between}
.fm-doc-n{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--stone)}
.fm-doc-k{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--clay-deep);background:var(--clay-soft);border:1.5px solid var(--clay-deep);border-radius:3px;padding:3px 7px}
.fm-doc-t{font-family:var(--font-heading);font-weight:800;font-size:18px;letter-spacing:-.01em;line-height:1.15}
.fm-doc-d{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;color:var(--ash);margin-top:auto}
.fm-doc-d .ic{width:14px;height:14px}
.fm-doc-d .go{margin-left:auto;color:var(--clay-deep)}
@media (max-width:920px){.fm-docs-grid{grid-template-columns:1fr}}

/* ============================ DOCS SHELL ============================ */
.docs{max-width:1340px;margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:248px minmax(0,1fr) 212px;gap:48px;align-items:start;flex:1;width:100%}
@media (max-width:1160px){.docs{grid-template-columns:228px minmax(0,1fr);gap:40px}.docs-toc{display:none}}
@media (max-width:860px){.docs{grid-template-columns:1fr}.docs-side{display:none}}
.docs-side{position:sticky;top:72px;align-self:start;max-height:calc(100vh - 72px);overflow-y:auto;padding:32px 0 60px}
.side-group{margin-bottom:26px}
.side-h{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);padding:0 12px;margin-bottom:9px}
.side-link{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;color:var(--ink-2);border-left:2px solid transparent;transition:background .14s,color .14s}
.side-link .ic{color:var(--ink-3);width:16px;height:16px}
.side-link:hover{background:var(--bg-2);color:var(--ink)}
.side-link.active{background:var(--green-soft);color:var(--green-deep);font-weight:700;border-left:3px solid var(--green)}
.side-link.active .ic{color:var(--green-deep)}
.docs-main{padding:40px 0 100px;min-width:0;max-width:760px}
.crumb{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:var(--ink-3);margin-bottom:20px}
.crumb .ic{color:var(--ink-4);width:14px;height:14px}
.crumb b{color:var(--ink-2);font-weight:700}
.doc-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink)}
.doc-kicker .ic{width:15px;height:15px}
.doc-h1{font-family:var(--font-display);font-size:clamp(34px,5vw,52px);line-height:1.02;letter-spacing:-.03em;font-weight:800;text-transform:uppercase;margin:14px 0 0}
.doc-lede{font-size:18.5px;line-height:1.6;color:var(--ink-2);margin:18px 0 0;max-width:60ch}
.doc-rule{height:2px;background:var(--ink);border:0;margin:34px 0;opacity:.85}
.docs-toc{position:sticky;top:72px;align-self:start;padding:44px 0 60px;max-height:calc(100vh - 72px);overflow-y:auto}
.toc-h{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:13px}
.docs-toc nav ul{list-style:none;margin:0;padding:0}.docs-toc nav ul ul{padding-left:12px}
.docs-toc nav a{display:block;font-size:13px;line-height:1.4;color:var(--ink-3);padding:6px 0 6px 14px;border-left:2px solid var(--rule)}
.docs-toc nav a:hover{color:var(--ink-2);border-left-color:var(--rule-strong)}

/* reference index cards */
.ref-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:8px}
@media (max-width:620px){.ref-grid{grid-template-columns:1fr}}
.ref-card{position:relative;display:flex;flex-direction:column;gap:12px;padding:22px;background:var(--card);border:2px solid var(--ink);border-radius:7px;box-shadow:3px 3px 0 0 var(--ink);transition:transform .14s,box-shadow .14s}
.ref-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--ink)}
.ref-card-top{display:flex;align-items:center;justify-content:space-between}
.ref-card-ic{width:42px;height:42px;border:2px solid var(--ink);border-radius:6px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-ink)}
.ref-card-n{font-family:var(--font-mono);font-size:12px;color:var(--ink-4);font-weight:700}
.ref-card-title{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:-.01em;text-transform:uppercase;margin:0}
.ref-card-desc{font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0;flex:1}
.ref-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.ref-tag{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-2);background:var(--bg-2);border:1.5px solid var(--ink);border-radius:4px;padding:3px 7px}

/* word browser (reference-layout.js) */
.ref-table-wrap{margin:0 0 24px;overflow-x:auto;border:2px solid var(--ink);border-radius:6px}
.ref-table-wrap table{margin:0}.ref-table-wrap th,.ref-table-wrap td{min-width:140px}
.ref-entry{position:relative;border-top:2px solid var(--rule);padding:18px 0 4px;margin:18px 0;scroll-margin-top:88px}
.ref-entry>:first-child{margin-top:0}
.ref-entry-signature{position:relative;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 12px;padding-right:96px;margin-bottom:12px;line-height:1.45}
.ref-entry-signature strong code{font-family:var(--font-mono);font-size:1.05rem;font-weight:800;color:var(--ink);background:var(--bg-2);border:1.5px solid var(--ink);border-radius:5px;padding:3px 8px}
.ref-entry-signature>code:last-child{color:var(--ink-3);background:none;border:0;padding:0;font-size:.9rem}
.ref-entry-badge{position:absolute;top:0;right:0;margin:0;padding:3px 9px;border-radius:3px;font-style:normal;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--clay-deep);background:var(--clay-soft);border:1.5px solid var(--clay-deep)}
.words-detail-content>h2{margin-top:36px;scroll-margin-top:88px}
.words-browser{margin:24px 0 44px;padding:20px;border:2px solid var(--ink);border-radius:7px;background:var(--card);box-shadow:3px 3px 0 0 var(--ink)}
.words-browser-toolbar{display:flex;flex-direction:column;gap:14px}
.words-browser-filter-label{display:block;margin-bottom:8px;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.words-browser-filter input{width:100%;padding:11px 14px;border:2px solid var(--ink);border-radius:5px;font:inherit;color:var(--ink);background:var(--bg)}
.words-browser-filter input:focus{outline:none;box-shadow:2px 2px 0 0 var(--ink)}
.words-browser-toolbar-meta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px}
.words-browser-status{margin:0;font-family:var(--font-mono);font-size:12px;color:var(--ink-3)}
.words-browser-clear{border:2px solid var(--ink);border-radius:5px;padding:6px 12px;font-family:var(--font-mono);font-size:12px;color:var(--ink);background:var(--bg);cursor:pointer}
.words-browser-clear:disabled{opacity:.5;cursor:default}
.words-browser-jumps{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.words-browser-jump{display:inline-flex;align-items:center;gap:9px;padding:7px 12px;border:1.5px solid var(--ink);border-radius:5px;color:var(--ink);background:var(--bg)}
.words-browser-jump:hover{background:var(--green-soft)}
.words-browser-jump-label{font-weight:700;font-size:13px}
.words-browser-jump-count{color:var(--ink-3);font-size:11px;font-family:var(--font-mono)}
.words-browser-catalog{margin-top:18px}
.words-browser-section+.words-browser-section{margin-top:18px;padding-top:18px;border-top:2px solid var(--rule)}
.words-browser-section-head,.words-browser-group-head{display:flex;justify-content:space-between;gap:12px}
.words-browser-section-head{align-items:start;margin-bottom:10px}
.words-browser-section-title{margin:0;font-size:16px;font-family:var(--font-display);text-transform:uppercase}
.words-browser-section-title a{color:var(--ink)}
.words-browser-section-count,.words-browser-group-count{white-space:nowrap;font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.words-browser-group+.words-browser-group{margin-top:12px;padding-top:12px;border-top:1px solid var(--rule)}
.words-browser-group-head{align-items:baseline;margin-bottom:6px}
.words-browser-group-title{margin:0;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.words-browser-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:baseline}
.words-browser-item-wrap{display:inline-flex;align-items:baseline}
.words-browser-item-wrap:not(:last-child)::after{content:"/";margin:0 9px;color:var(--ink-4)}
.words-browser-item{display:inline-flex;align-items:baseline;padding:2px 0;color:var(--ink)}
.words-browser-item:hover{color:var(--clay-deep);text-decoration:underline;text-underline-offset:3px}
.words-browser-word-name{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--ink);white-space:nowrap}
.words-browser-empty{margin-top:18px;padding:16px 18px;border:2px dashed var(--ink);border-radius:7px;background:var(--bg-2)}
.words-browser-empty h3{margin:0 0 6px;font-size:1rem;font-family:var(--font-display)}
.words-browser-empty p{margin:0;color:var(--ink-3)}
.is-hidden{display:none !important}

/* ============================ GUIDE: arc + callout + pager ============================ */
.guide-arc{list-style:none;margin:8px 0 0;padding:0;position:relative}
.guide-arc li{position:relative;z-index:1}
.arc-item{display:flex;align-items:center;gap:18px;width:100%;text-align:left;padding:15px 16px;border-radius:7px;border:2px solid transparent;transition:background .14s,box-shadow .14s,border-color .14s}
.arc-item:hover{background:var(--card);border-color:var(--ink);box-shadow:3px 3px 0 0 var(--ink)}
.arc-n{flex:none;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--ink-3);background:var(--card);border:2px solid var(--ink)}
.arc-item:hover .arc-n{background:var(--green);color:var(--ink)}
.arc-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.arc-title{font-family:var(--font-display);font-size:17px;font-weight:800;letter-spacing:-.01em;text-transform:uppercase}
.arc-desc{font-size:13.5px;line-height:1.5;color:var(--ink-2);max-width:64ch}
.arc-meta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.arc-time{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11.5px;color:var(--ink-3)}
.arc-time .ic{color:var(--ink-4);width:14px;height:14px}
.arc-go{color:var(--ink-4);width:16px;height:16px;transition:color .15s,transform .15s}
.arc-item:hover .arc-go{color:var(--clay-deep);transform:translateX(2px)}
@media (max-width:560px){.arc-desc{display:none}}
.guide-adv-h{font-family:var(--font-display);font-size:14px;font-weight:800;letter-spacing:.02em;color:var(--ink-3);text-transform:uppercase;margin:38px 0 4px;padding-left:12px}

.g-callout{display:flex;gap:14px;align-items:flex-start;margin:22px 0;padding:16px 18px;border-radius:7px;border:2px solid var(--ink);background:var(--card)}
.g-callout-ic{flex:none;width:32px;height:32px;border-radius:6px;display:grid;place-items:center;background:var(--bg-2);border:1.5px solid var(--ink)}
.g-callout-ic .ic{width:18px;height:18px}
.g-callout-body{font-size:14.5px;line-height:1.6;color:var(--ink-2);min-width:0}
.g-callout-body>:first-child{margin-top:0}.g-callout-body>:last-child{margin-bottom:0}
.g-callout-title{font-family:var(--font-display);font-size:15px;font-weight:800;text-transform:uppercase;margin-bottom:3px;color:var(--ink)}
.g-callout-note{box-shadow:3px 3px 0 0 var(--clay)}.g-callout-note .g-callout-ic{background:var(--clay-soft);color:var(--clay-deep)}
.g-callout-tip{box-shadow:3px 3px 0 0 var(--green)}.g-callout-tip .g-callout-ic{background:var(--green-soft);color:var(--green-deep)}
.g-callout-warn{box-shadow:3px 3px 0 0 var(--amber)}.g-callout-warn .g-callout-ic{background:var(--amber-soft);color:#b06a00}
.g-pager{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:48px;padding-top:30px;border-top:2px solid var(--rule)}
.g-pager-btn{display:flex;flex-direction:column;gap:4px;padding:16px 18px;border-radius:7px;border:2px solid var(--ink);background:var(--card);box-shadow:3px 3px 0 0 var(--ink);transition:transform .14s,box-shadow .14s}
.g-pager-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 0 var(--ink)}
.g-pager-btn.next{text-align:right;align-items:flex-end}
.g-pager-lab{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.g-pager-title{font-family:var(--font-display);font-size:15.5px;font-weight:800;text-transform:uppercase;color:var(--ink)}
@media (max-width:560px){.g-pager{grid-template-columns:1fr}}

/* ============================ MARKDOWN PROSE ============================ */
.content{font-size:16px;line-height:1.72;color:var(--ink-2)}
.content>:first-child{margin-top:0}
.content h1{font-family:var(--font-display);font-size:clamp(28px,3.2vw,38px);text-transform:uppercase;letter-spacing:-.02em;color:var(--ink);margin:48px 0 16px}
.content h2{font-family:var(--font-heading);font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:42px 0 14px;scroll-margin-top:88px}
.content h3{font-family:var(--font-heading);font-size:20px;font-weight:800;letter-spacing:-.01em;color:var(--ink);margin:32px 0 10px;scroll-margin-top:88px}
.content h4{font-family:var(--font-mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin:26px 0 8px}
.content p{margin:0 0 18px;max-width:68ch}
.content a{color:var(--link);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.content a:hover{text-decoration-thickness:2px}
.content ul,.content ol{margin:0 0 18px 22px;max-width:66ch}
.content li{margin-bottom:6px}.content li::marker{color:var(--clay-deep)}
.content hr{border:0;border-top:2px solid var(--rule);margin:34px 0}
.content blockquote{border-left:3px solid var(--clay);background:var(--bg-2);padding:12px 18px;color:var(--ink-2);margin:0 0 18px}
.content blockquote p:last-child{margin-bottom:0}
.content strong{font-weight:700;color:var(--ink)}
.content em{font-style:italic}
.content :not(pre)>code{font-family:var(--font-mono);font-size:.86em;background:var(--bg-2);border:1.5px solid var(--ink);padding:1px 6px;border-radius:4px;color:var(--clay-deep)}
.content pre{margin:0 0 20px;padding:16px 18px;border-radius:6px;font-size:13.5px;line-height:1.7;overflow:auto;font-family:var(--font-mono);
  background:var(--card);border:1.5px solid var(--ink);color:var(--tk-w);box-shadow:2px 2px 0 0 var(--ink)}
html[data-theme="dark"] .content pre{background:#15120d;color:#e9e0cb}
.content pre code{background:none;border:0;padding:0;font-size:inherit;color:inherit}
.content table{width:100%;border-collapse:collapse;margin:0 0 24px;font-size:14px}
.content thead th{text-align:left;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:700;padding:10px 12px;border-bottom:2px solid var(--ink)}
.content tbody td{padding:10px 12px;border-bottom:1px solid var(--rule);vertical-align:top}
.content tbody tr:nth-child(even) td{background:var(--bg-2)}

/* ============================ CONTACT (bare standalone page) ============================ */
.contact-page{flex:1;width:100%;max-width:640px;margin:0 auto;padding:72px var(--pad) 120px}
.contact-content{font-size:17px;margin-top:18px}
.contact-content p{max-width:60ch}

/* ============================ RESPONSIVE ============================ */
@media (max-width:640px){
  .sec{padding-top:48px;padding-bottom:48px}
  .fm-hero-in{padding-top:40px;padding-bottom:48px}
  .docs-main{padding:24px 0 64px}
  .ref-grid{grid-template-columns:1fr}
}
