/* ============================================================
   Albion Financial Group — Agentic Operations Cockpit
   Visual system. Light / ivory · racing green + gold · grotesk + mono
   ============================================================ */

:root{
  /* surfaces */
  --paper:        #EEEAE0;   /* page / parchment */
  --paper-2:      #E7E2D5;   /* map field */
  --panel:        #FAF7F0;   /* panels */
  --panel-2:      #FFFFFF;   /* raised cards / nodes */
  --panel-sunk:   #F2EEE4;

  /* ink */
  --ink:          #1B1A15;
  --ink-2:        #57534A;
  --ink-3:        #8B8678;
  --ink-4:        #B4AE9D;

  /* hairlines */
  --line:         #DAD3C2;
  --line-2:       #C8C0AC;
  --line-soft:    #E6E0D1;

  /* brand */
  --green:        #123F2E;   /* racing green */
  --green-2:      #0C2C20;
  --green-tint:   #DCE6DC;
  --gold:         #9C7B26;
  --gold-2:       #BE9C49;
  --gold-soft:    #E6D5A8;

  /* status */
  --idle:         #8B8678;
  --active:       #B07A14;   /* amber — working */
  --active-2:     #D89A22;
  --active-glow:  rgba(184,128,30,.30);
  --done:         #2C6B47;   /* signed off */
  --done-glow:    rgba(44,107,71,.22);
  --esc:          #A63427;   /* escalation oxblood */
  --esc-2:        #C04535;
  --esc-glow:     rgba(166,52,39,.32);

  --r:            10px;
  --r-sm:         7px;
  --shadow:       0 1px 2px rgba(30,26,16,.05), 0 8px 24px rgba(30,26,16,.06);
  --shadow-lg:    0 2px 6px rgba(30,26,16,.08), 0 24px 64px rgba(30,26,16,.18);

  --sans: 'Archivo', system-ui, sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, monospace;
  --serif:'Source Serif 4', Georgia, serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
body{
  background:#0b0a08;
  font-family:var(--sans);
  color:var(--ink);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---- scale-to-fit stage ---- */
.stage{ position:fixed; inset:0; display:flex; align-items:center; justify-content:center; background:#0b0a08; overflow:hidden; }
.scaler{ width:1920px; height:1080px; transform-origin:center center; flex:0 0 auto; }

/* ---- cockpit shell ---- */
.cockpit{
  width:1920px; height:1080px; position:relative;
  background:
    radial-gradient(120% 80% at 50% -10%, #F4F1E8 0%, var(--paper) 55%, #E8E3D6 100%);
  display:flex; flex-direction:column;
  font-feature-settings:"ss01","cv05";
}

/* ============================== TOP BAR ============================== */
.topbar{ height:104px; display:flex; flex-direction:column; flex:0 0 auto; border-bottom:1px solid var(--line-2); background:linear-gradient(180deg,#FBF8F2,#F4F0E6); }
.topbar-main{ flex:1; display:flex; align-items:center; padding:0 30px; gap:28px; }

/* brand */
.brand{ display:flex; align-items:center; gap:15px; min-width:330px; }
.crest{ width:46px; height:46px; flex:0 0 auto; position:relative; }
.brand-tx{ display:flex; flex-direction:column; gap:3px; }
.brand-name{ font-size:18px; font-weight:700; letter-spacing:.14em; color:var(--green); line-height:1; }
.brand-sub{ font-family:var(--mono); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-3); }

/* transport cluster */
.transport{ display:flex; align-items:center; gap:18px; }
.play-btn{
  width:54px; height:54px; border-radius:50%; border:1.5px solid var(--green);
  background:var(--green); color:#F4F1E8; display:flex; align-items:center; justify-content:center;
  cursor:pointer; flex:0 0 auto; transition:transform .15s ease, background .2s; box-shadow:0 4px 14px rgba(18,63,46,.28);
}
.play-btn:hover{ transform:scale(1.05); }
.play-btn:active{ transform:scale(.96); }
.play-btn svg{ width:22px; height:22px; }

.speed{ display:flex; align-items:center; background:var(--panel-sunk); border:1px solid var(--line-2); border-radius:8px; overflow:hidden; }
.speed b{ font-family:var(--mono); font-size:9px; letter-spacing:.16em; color:var(--ink-3); padding:0 10px; border-right:1px solid var(--line); align-self:stretch; display:flex; align-items:center; }
.speed button{
  font-family:var(--mono); font-size:13px; font-weight:500; color:var(--ink-2);
  background:none; border:none; padding:9px 13px; cursor:pointer; transition:.15s; border-right:1px solid var(--line-soft);
}
.speed button:last-child{ border-right:none; }
.speed button:hover{ background:#fff; color:var(--ink); }
.speed button.on{ background:var(--green); color:#F4F1E8; }

/* clock */
.clock{ display:flex; align-items:baseline; gap:14px; margin-left:6px; white-space:nowrap; }
.clock-q{ font-size:30px; font-weight:700; color:var(--green); letter-spacing:.01em; white-space:nowrap; }
.clock-date{ font-family:var(--mono); font-size:18px; font-weight:500; color:var(--ink); letter-spacing:.02em; white-space:nowrap; }
.clock-meta{ display:flex; flex-direction:column; gap:3px; padding-left:14px; border-left:1px solid var(--line-2); }
.clock-day{ font-family:var(--mono); font-size:11px; color:var(--ink-3); letter-spacing:.05em; white-space:nowrap; }
.clock-acc{ font-family:var(--mono); font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); white-space:nowrap; }

.tb-spacer{ flex:1; }

/* status + inject */
.tb-right{ display:flex; align-items:center; gap:16px; }
.livepill{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; padding:7px 13px; border-radius:20px; border:1px solid var(--line-2); color:var(--ink-2); background:var(--panel-sunk); }
.livepill .dot{ width:8px; height:8px; border-radius:50%; background:var(--idle); }
.livepill.live{ color:var(--done); border-color:rgba(44,107,71,.4); background:rgba(44,107,71,.07); }
.livepill.live .dot{ background:var(--done); animation:livedot 1.6s ease-in-out infinite; }
@keyframes livedot{ 0%,100%{ box-shadow:0 0 0 0 var(--done-glow);} 50%{ box-shadow:0 0 0 6px transparent; } }

.inject-btn{
  display:flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:600; font-size:13px;
  color:var(--ink); background:var(--panel-2); border:1px solid var(--line-2); border-radius:9px;
  padding:9px 15px 9px 12px; cursor:pointer; transition:.16s; box-shadow:var(--shadow);
}
.inject-btn:hover{ border-color:var(--gold); color:var(--green); }
.inject-btn .bolt{ width:16px; height:16px; color:var(--gold); }

/* year timeline track */
.timeline{ height:34px; flex:0 0 auto; display:flex; align-items:center; padding:0 30px; gap:14px; background:#F1ECE0; border-top:1px solid var(--line-soft); }
.tl-label{ font-family:var(--mono); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); white-space:nowrap; }
.tl-track{ position:relative; flex:1; height:16px; cursor:pointer; }
.tl-rail{ position:absolute; top:50%; left:0; right:0; height:3px; transform:translateY(-50%); background:var(--line-2); border-radius:2px; }
.tl-fill{ position:absolute; top:50%; left:0; height:3px; transform:translateY(-50%); background:var(--green); border-radius:2px; }
.tl-q{ position:absolute; top:50%; transform:translate(-50%,-50%); font-family:var(--mono); font-size:9px; color:var(--ink-4); letter-spacing:.1em; }
.tl-qtick{ position:absolute; top:50%; width:1px; height:9px; transform:translate(-50%,-50%); background:var(--line-2); }
.tl-ev{ position:absolute; top:50%; width:6px; height:6px; border-radius:50%; transform:translate(-50%,-50%); background:var(--ink-4); border:1px solid var(--paper); }
.tl-ev.hero{ background:var(--gold); width:7px; height:7px; }
.tl-ev.esc{ background:var(--esc); }
.tl-ev.fired{ box-shadow:0 0 0 3px rgba(156,123,38,.15); }
.tl-head{ position:absolute; top:50%; width:13px; height:13px; border-radius:50%; transform:translate(-50%,-50%); background:#fff; border:2.5px solid var(--green); box-shadow:0 1px 4px rgba(18,63,46,.35); z-index:3; pointer-events:none; }

/* ============================== BODY GRID ============================== */
.body{ flex:1; display:flex; gap:22px; padding:20px 24px 24px; min-height:0; }
.main-col{ flex:1; position:relative; min-width:0; }
.feed-col{ width:472px; flex:0 0 auto; }

/* panel chrome */
.panel{ background:var(--panel); border:1px solid var(--line-2); border-radius:var(--r); box-shadow:var(--shadow); display:flex; flex-direction:column; height:100%; overflow:hidden; }
.panel-head{ display:flex; align-items:center; gap:12px; padding:13px 18px; border-bottom:1px solid var(--line); flex:0 0 auto; background:linear-gradient(180deg,#FCFAF4,#F7F3EA); }
.panel-idx{ font-family:var(--mono); font-size:10px; color:var(--gold); letter-spacing:.1em; }
.panel-title{ font-size:12px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--ink); }
.panel-spacer{ flex:1; }

/* legend */
.legend{ display:flex; gap:15px; }
.legend span{ display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.legend i{ width:9px; height:9px; border-radius:50%; display:inline-block; }
.lg-idle{ background:var(--idle); } .lg-active{ background:var(--active); } .lg-done{ background:var(--done); } .lg-esc{ background:var(--esc); }

/* ============================== ORG MAP ============================== */
.map-wrap{ flex:1; position:relative; overflow:hidden; background:
  radial-gradient(130% 100% at 50% 35%, #FAF7EF 0%, var(--paper-2) 100%); }
.map-grid{ position:absolute; inset:0; opacity:.5;
  background-image:radial-gradient(var(--line-soft) 1px, transparent 1px);
  background-size:30px 30px; }
.map-wrap{ cursor:grab; user-select:none; }
.map-wrap.grabbing{ cursor:grabbing; }
.map-canvas{ position:absolute; top:0; left:0; transform-origin:0 0; will-change:transform; }
.map-controls{ position:absolute; right:14px; bottom:14px; z-index:9; display:flex; gap:6px; }
.map-controls button{ font-family:var(--mono); font-size:11px; min-width:30px; height:28px; padding:0 9px; border:1px solid var(--line-2); background:var(--panel-2); color:var(--ink-2); border-radius:7px; cursor:pointer; transition:.14s; }
.map-controls button:hover{ background:#fff; color:var(--ink); border-color:var(--gold-soft); }
.map-svg{ position:absolute; inset:0; width:100%; height:100%; overflow:visible; }

/* connectors */
.conn{ fill:none; stroke:var(--line-2); }
.conn.spine{ stroke:var(--gold-soft); stroke-width:2; }
.conn.structure{ stroke:var(--line-2); stroke-width:1.4; stroke-dasharray:2 7; stroke-linecap:round; }
.conn.flow{ stroke:#CDBE9A; stroke-width:2.4; }
.conn.escalation{ stroke:var(--esc); stroke-width:2; stroke-dasharray:6 6; opacity:0; transition:opacity .25s; }
.conn.escalation.armed{ opacity:.85; animation:escdash .6s linear infinite; }
@keyframes escdash{ to{ stroke-dashoffset:-12; } }
.conn.lit{ stroke:var(--gold); stroke-width:3; filter:drop-shadow(0 0 5px rgba(156,123,38,.4)); transition:stroke .2s; }

/* traveling token */
.token{ position:absolute; left:0; top:0; transform:translate(-50%,-50%); display:flex; align-items:center; gap:6px; z-index:5; pointer-events:none; will-change:transform; }
.token-dot{ width:13px; height:13px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px rgba(156,123,38,.18), 0 0 14px rgba(156,123,38,.6); }
.token-tag{ font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:.04em; color:var(--green); background:var(--panel-2); border:1px solid var(--gold-soft); border-radius:5px; padding:2px 7px; white-space:nowrap; box-shadow:var(--shadow); }
.token.escalation .token-dot{ background:var(--esc); box-shadow:0 0 0 4px var(--esc-glow), 0 0 16px rgba(166,52,39,.7); }
.token.escalation .token-tag{ color:#fff; background:var(--esc); border-color:var(--esc-2); }
.token.sign .token-dot{ background:var(--done); box-shadow:0 0 0 4px var(--done-glow), 0 0 14px rgba(44,107,71,.55); }
.token.sign .token-tag{ color:var(--done); border-color:rgba(44,107,71,.4); }

/* agent node */
.node{ position:absolute; transform:translate(-50%,-50%); width:206px; cursor:pointer; z-index:4; transition:transform .28s cubic-bezier(.2,.7,.3,1); }
.node-card{
  position:relative; background:var(--panel-2); border:1.5px solid var(--line-2); border-radius:11px;
  padding:13px 15px; box-shadow:var(--shadow); transition:border-color .25s, box-shadow .25s, background .25s; overflow:hidden;
}
.node-card::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--idle); transition:background .25s; }
.node-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.node-role{ font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }
.node-stat{ font-family:var(--mono); font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--idle); display:flex; align-items:center; gap:5px; }
.node-stat .sd{ width:7px; height:7px; border-radius:50%; background:var(--idle); }
.node-name{ font-size:16.5px; font-weight:700; color:var(--ink); line-height:1.12; letter-spacing:-.01em; }
.node-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:9px; }
.node-code{ font-family:var(--mono); font-size:9px; color:var(--ink-4); letter-spacing:.04em; }
.node-doc{ font-family:var(--mono); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); display:none; align-items:center; gap:4px; }
.node-doc.has{ display:flex; }
.node-doc svg{ width:10px; height:10px; }

/* node states */
.node.s-active .node-card{ border-color:var(--active); background:#FFFBF1; box-shadow:0 2px 6px rgba(176,122,20,.14), 0 0 0 4px var(--active-glow); }
.node.s-active .node-card::before{ background:var(--active); }
.node.s-active .node-stat{ color:var(--active); } .node.s-active .node-stat .sd{ background:var(--active); animation:nodepulse 1.3s ease-in-out infinite; }
.node.s-active{ transform:translate(-50%,-50%) scale(1.035); }
.node.s-active .node-card::after{ content:''; position:absolute; inset:-1.5px; border-radius:11px; border:1.5px solid var(--active); opacity:0; animation:nodering 1.8s ease-out infinite; pointer-events:none; }

.node.s-done .node-card{ border-color:rgba(44,107,71,.55); background:#F6FAF6; }
.node.s-done .node-card::before{ background:var(--done); }
.node.s-done .node-stat{ color:var(--done); } .node.s-done .node-stat .sd{ background:var(--done); }

.node.s-escalate .node-card{ border-color:var(--esc); background:#FDF4F2; box-shadow:0 2px 6px rgba(166,52,39,.16), 0 0 0 4px var(--esc-glow); animation:escshake .5s ease 1; }
.node.s-escalate .node-card::before{ background:var(--esc); }
.node.s-escalate .node-stat{ color:var(--esc); } .node.s-escalate .node-stat .sd{ background:var(--esc); animation:nodepulse .8s ease-in-out infinite; }

.node.pulse .node-card{ animation:ambientpulse 2.4s ease-out 1; }

.node.sel .node-card{ outline:2px solid var(--green); outline-offset:2px; }
.node:hover .node-card{ border-color:var(--gold); }

@keyframes nodepulse{ 0%,100%{ transform:scale(1);opacity:1;} 50%{ transform:scale(1.25);opacity:.6;} }
@keyframes nodering{ 0%{ transform:scale(1);opacity:.7;} 100%{ transform:scale(1.18);opacity:0;} }
@keyframes ambientpulse{ 0%{ box-shadow:0 0 0 0 var(--active-glow);} 100%{ box-shadow:0 0 0 14px transparent;} }
@keyframes escshake{ 0%,100%{transform:translateX(0);} 20%{transform:translateX(-4px);} 60%{transform:translateX(4px);} }

/* tier label chips on map */
.tier-tag{ position:absolute; font-family:var(--mono); font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-4); transform:translate(-50%,-50%); }

/* ============================== FEED ============================== */
.feed-list{ flex:1; overflow-y:auto; padding:6px 0; }
.feed-list::-webkit-scrollbar{ width:8px; } .feed-list::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:4px; border:2px solid var(--panel); }
.feed-empty{ padding:34px 22px; text-align:center; color:var(--ink-3); font-size:13px; line-height:1.6; }
.feed-row{ position:relative; display:flex; gap:13px; padding:13px 18px 14px; border-bottom:1px solid var(--line-soft); cursor:default; transition:background .15s; animation:feedin .45s cubic-bezier(.2,.7,.3,1); }
.feed-row.clickable{ cursor:pointer; } .feed-row.clickable:hover{ background:#fff; }
@keyframes feedin{ from{ opacity:0; transform:translateY(-8px);} to{ opacity:1; transform:none;} }
.feed-rail{ flex:0 0 auto; display:flex; flex-direction:column; align-items:center; padding-top:3px; }
.feed-bullet{ width:11px; height:11px; border-radius:50%; border:2px solid var(--ink-4); background:var(--panel); flex:0 0 auto; }
.feed-line{ width:2px; flex:1; background:var(--line); margin-top:4px; }
.feed-body{ flex:1; min-width:0; }
.feed-meta{ display:flex; align-items:center; gap:8px; margin-bottom:5px; flex-wrap:wrap; }
.feed-time{ font-family:var(--mono); font-size:10.5px; color:var(--ink-3); letter-spacing:.02em; }
.feed-route{ font-family:var(--mono); font-size:10px; letter-spacing:.03em; color:var(--green); display:flex; align-items:center; gap:5px; white-space:nowrap; }
.feed-route .arr{ color:var(--gold); }
.feed-title{ font-size:14px; font-weight:600; line-height:1.32; color:var(--ink); letter-spacing:-.005em; }
.feed-detail{ font-size:12px; color:var(--ink-2); line-height:1.45; margin-top:4px; }
.feed-tag{ font-family:var(--mono); font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; padding:2px 7px; border-radius:4px; border:1px solid var(--line-2); color:var(--ink-3); }
.feed-doc{ display:inline-flex; align-items:center; gap:5px; margin-top:8px; font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--gold); }
.feed-doc svg{ width:11px; height:11px; }

/* feed type accents */
.feed-row.t-mandate .feed-bullet{ border-color:var(--gold); background:var(--gold-soft); }
.feed-row.t-handoff .feed-bullet{ border-color:var(--green); }
.feed-row.t-produce .feed-bullet{ border-color:var(--green); background:var(--green); }
.feed-row.t-resolve .feed-bullet{ border-color:var(--done); background:var(--done); }
.feed-row.t-escalation{ background:linear-gradient(90deg, rgba(166,52,39,.07), transparent 60%); }
.feed-row.t-escalation .feed-bullet{ border-color:var(--esc); background:var(--esc); animation:escbullet 1s ease-in-out infinite; }
.feed-row.t-escalation .feed-title{ color:var(--esc); }
.feed-row.t-escalation .feed-route{ color:var(--esc); } .feed-row.t-escalation .feed-route .arr{ color:var(--esc); }
.feed-row.t-inject{ background:linear-gradient(90deg, rgba(156,123,38,.08), transparent 60%); }
.feed-row.t-inject .feed-bullet{ border-color:var(--gold); background:var(--gold); }
.feed-row.t-inject .feed-route{ color:var(--gold); }
.feed-row.t-ambient{ opacity:.82; } .feed-row.t-ambient .feed-title{ font-weight:500; font-size:13px; color:var(--ink-2); }
@keyframes escbullet{ 0%,100%{ box-shadow:0 0 0 0 var(--esc-glow);} 50%{ box-shadow:0 0 0 5px transparent;} }

/* ============================== ARTIFACT DRAWER ============================== */
.scrim{ position:absolute; inset:0; background:rgba(20,18,12,.18); backdrop-filter:blur(1.5px); opacity:0; pointer-events:none; transition:opacity .3s; z-index:8; border-radius:var(--r); }
.scrim.show{ opacity:1; pointer-events:auto; }

.drawer{ position:absolute; left:0; right:0; bottom:0; height:138px; background:var(--panel-2); border-top:1px solid var(--line-2);
  border-radius:0 0 var(--r) var(--r); box-shadow:0 -8px 40px rgba(30,26,16,.14); z-index:9;
  transition:height .42s cubic-bezier(.2,.75,.25,1); display:flex; flex-direction:column; overflow:hidden; }
.drawer.open{ height:640px; }

/* collapsed rail */
.rail{ display:flex; align-items:center; gap:16px; padding:0 22px; height:138px; flex:0 0 138px; }
.rail-hint{ display:flex; flex-direction:column; gap:5px; padding-right:20px; border-right:1px solid var(--line); }
.rail-hint b{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.rail-hint span{ font-size:13px; color:var(--ink-2); max-width:210px; line-height:1.4; }
.rail-cards{ display:flex; gap:14px; flex:1; overflow-x:auto; padding:4px 0; }
.rail-cards::-webkit-scrollbar{ height:6px; } .rail-cards::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:3px; }
.doc-card{ flex:0 0 auto; width:230px; background:var(--panel); border:1px solid var(--line-2); border-radius:8px; padding:13px 15px; cursor:pointer; transition:.16s; position:relative; overflow:hidden; }
.doc-card::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--green); }
.doc-card:hover{ border-color:var(--gold); transform:translateY(-2px); box-shadow:var(--shadow); }
.doc-card .dc-type{ font-family:var(--mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.doc-card .dc-title{ font-size:13.5px; font-weight:700; color:var(--ink); line-height:1.25; margin-bottom:8px; }
.doc-card .dc-ref{ font-family:var(--mono); font-size:9.5px; color:var(--ink-3); }
.rail-empty{ flex:1; display:flex; align-items:center; font-size:13px; color:var(--ink-4); font-style:italic; }

/* open document */
.drawer-bar{ display:flex; align-items:center; gap:14px; padding:0 20px; height:54px; flex:0 0 54px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.drawer-tabs{ display:flex; gap:8px; }
.dtab{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:7px 13px; border-radius:7px; border:1px solid var(--line-2); background:var(--panel); color:var(--ink-2); cursor:pointer; transition:.15s; }
.dtab:hover{ border-color:var(--gold); } .dtab.on{ background:var(--green); color:#F4F1E8; border-color:var(--green); }
.drawer-close{ margin-left:auto; width:34px; height:34px; border-radius:7px; border:1px solid var(--line-2); background:var(--panel); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--ink-2); transition:.15s; }
.drawer-close:hover{ border-color:var(--esc); color:var(--esc); }
.drawer-close svg{ width:15px; height:15px; }
.drawer-scroll{ flex:1; overflow-y:auto; background:#F6F3EC; padding:30px; display:flex; justify-content:center; align-items:flex-start; }
.drawer-scroll::-webkit-scrollbar{ width:10px; } .drawer-scroll::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:5px; border:2px solid #F6F3EC; }

/* ---- the document sheet ---- */
.sheet{ width:780px; background:#FCFBF7; border:1px solid var(--line); box-shadow:0 2px 8px rgba(30,26,16,.07), 0 30px 60px rgba(30,26,16,.1); padding:46px 56px 40px; position:relative; }
.sheet::before{ content:''; position:absolute; left:0; right:0; top:0; height:4px; background:linear-gradient(90deg,var(--green) 0 60%, var(--gold) 60%); }
.doc-letterhead{ display:flex; align-items:flex-start; gap:14px; padding-bottom:18px; border-bottom:2px solid var(--green); margin-bottom:5px; }
.doc-crest{ width:42px; height:42px; flex:0 0 auto; }
.lh-tx{ flex:1; }
.lh-name{ font-size:16px; font-weight:700; letter-spacing:.16em; color:var(--green); }
.lh-office{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-top:4px; }
.lh-class{ font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--esc); border:1px solid rgba(166,52,39,.4); padding:5px 9px; border-radius:5px; align-self:flex-start; white-space:nowrap; }
.lh-class.priv{ color:var(--green); border-color:rgba(18,63,46,.35); }

.doc-meta{ display:flex; flex-wrap:wrap; gap:0 36px; padding:14px 0 4px; }
.dm{ display:flex; flex-direction:column; gap:3px; padding:8px 0; }
.dm b{ font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.dm span{ font-family:var(--mono); font-size:12px; color:var(--ink); }
.doc-type{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-top:18px; }
.doc-h1{ font-family:var(--serif); font-size:27px; font-weight:600; color:var(--ink); line-height:1.2; margin:6px 0 4px; letter-spacing:-.01em; }
.doc-hr{ height:1px; background:var(--line); margin:22px 0; }

/* document body (serif) */
.doc-body{ font-family:var(--serif); }
.doc-body h3{ font-family:var(--sans); font-size:14px; font-weight:700; letter-spacing:.02em; color:var(--green); margin:26px 0 10px; text-transform:none; }
.doc-body p{ font-size:15px; line-height:1.62; color:#2a2720; margin-bottom:12px; }
.doc-body p strong{ font-weight:700; color:var(--ink); }
.doc-body ul, .doc-body ol{ margin:4px 0 14px 4px; padding-left:22px; }
.doc-body li{ font-size:14.5px; line-height:1.55; color:#2a2720; margin-bottom:8px; }

.doc-kpis{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:8px; overflow:hidden; margin:8px 0 18px; }
.kpi{ background:#fff; padding:15px 16px; }
.kpi-v{ font-family:var(--sans); font-size:24px; font-weight:700; color:var(--green); line-height:1; letter-spacing:-.01em; }
.kpi-l{ font-family:var(--sans); font-size:11px; font-weight:600; color:var(--ink); margin-top:8px; }
.kpi-s{ font-family:var(--mono); font-size:9.5px; color:var(--ink-3); margin-top:3px; letter-spacing:.02em; }

.doc-table{ width:100%; border-collapse:collapse; margin:10px 0 8px; font-family:var(--sans); }
.doc-table th{ font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); text-align:left; padding:9px 12px; border-bottom:1.5px solid var(--green); }
.doc-table td{ font-size:13.5px; color:var(--ink); padding:10px 12px; border-bottom:1px solid var(--line-soft); }
.doc-table tr:last-child td{ border-bottom:none; }
.doc-table .num{ text-align:right; font-family:var(--mono); font-size:12.5px; }
.doc-table th.num{ text-align:right; }
.doc-note{ font-family:var(--sans); font-size:11.5px; color:var(--ink-3); font-style:italic; line-height:1.5; margin:4px 0 16px; }

.doc-callout{ display:flex; gap:13px; padding:15px 18px; border-radius:8px; margin:8px 0 16px; font-family:var(--sans); }
.doc-callout .ic{ flex:0 0 auto; width:20px; height:20px; margin-top:1px; }
.doc-callout p{ font-family:var(--sans); font-size:13px; line-height:1.55; margin:0; }
.doc-callout.warn{ background:rgba(166,52,39,.06); border:1px solid rgba(166,52,39,.25); color:#7c281e; } .doc-callout.warn .ic{ color:var(--esc); }
.doc-callout.warn p strong{ color:#7c281e; }
.doc-callout.info{ background:rgba(44,107,71,.06); border:1px solid rgba(44,107,71,.25); color:#1f4d33; } .doc-callout.info .ic{ color:var(--done); }
.doc-callout.privilege{ background:rgba(156,123,38,.07); border:1px solid var(--gold-soft); color:#6b531a; } .doc-callout.privilege .ic{ color:var(--gold); }

.doc-resolved{ margin:8px 0 16px; padding:18px 20px; background:rgba(18,63,46,.04); border:1px solid rgba(18,63,46,.18); border-radius:8px; }
.doc-resolved .rsv-h{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--green); margin-bottom:12px; }
.doc-resolved ol{ margin:0; padding-left:26px; }
.doc-resolved li{ font-family:var(--serif); font-size:14.5px; line-height:1.5; margin-bottom:10px; }

.doc-sign{ display:flex; gap:50px; margin-top:30px; padding-top:22px; border-top:1px solid var(--line); }
.sign-col{ flex:1; }
.sign-role{ font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:18px; }
.sign-rule{ height:1px; background:var(--ink-3); margin-bottom:7px; }
.sign-name{ font-family:var(--sans); font-size:13px; font-weight:600; color:var(--ink); }
.sign-date{ font-family:var(--mono); font-size:10px; color:var(--ink-3); margin-top:3px; }

.doc-foot{ display:flex; justify-content:space-between; align-items:center; margin-top:34px; padding-top:14px; border-top:1px solid var(--line); font-family:var(--mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-4); }

/* ============================== INJECT MENU ============================== */
.inject-pop{ position:absolute; top:108px; right:24px; width:340px; background:var(--panel-2); border:1px solid var(--line-2); border-radius:12px; box-shadow:var(--shadow-lg); z-index:40; overflow:hidden; transform-origin:top right; animation:popin .18s cubic-bezier(.2,.8,.3,1); }
@keyframes popin{ from{ opacity:0; transform:scale(.96) translateY(-6px);} to{ opacity:1; transform:none;} }
.ip-head{ padding:14px 18px; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:9px; }
.ip-head .bolt{ width:15px; height:15px; color:var(--gold); }
.ip-head b{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); }
.ip-head span{ font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-left:auto; }
.ip-item{ display:flex; align-items:center; gap:13px; padding:14px 18px; border-bottom:1px solid var(--line-soft); cursor:pointer; transition:.14s; }
.ip-item:last-child{ border-bottom:none; }
.ip-item:hover{ background:var(--panel-sunk); }
.ip-mk{ width:9px; height:9px; border-radius:50%; flex:0 0 auto; background:var(--gold); }
.ip-mk.esc{ background:var(--esc); }
.ip-tx b{ display:block; font-size:13.5px; font-weight:600; color:var(--ink); }
.ip-tx span{ font-family:var(--mono); font-size:10px; color:var(--ink-3); letter-spacing:.02em; }

/* keyboard hint */
.kbd-hint{ position:absolute; left:24px; bottom:8px; font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; color:var(--ink-4); display:flex; gap:14px; z-index:6; }
.kbd-hint kbd{ font-family:var(--mono); background:var(--panel-2); border:1px solid var(--line-2); border-bottom-width:2px; border-radius:4px; padding:1px 6px; color:var(--ink-2); font-size:9.5px; }

/* Agent profile (drawer) */
.sheet.profile .doc-h1{ margin-bottom:2px; }
.profile-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px 26px; margin:14px 0 18px; }
.profile-grid .pf{ display:flex; flex-direction:column; gap:2px; }
.profile-grid .pf b{ font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.profile-grid .pf span{ font-size:13px; color:var(--ink); }
.profile-scores{ display:flex; flex-wrap:wrap; gap:8px; margin:0 0 20px; }
.profile-scores .ps{ display:flex; align-items:center; gap:7px; padding:5px 11px; border:1px solid var(--line-2); border-radius:8px; background:var(--panel-sunk); }
.profile-scores .ps span{ font-family:var(--mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.profile-scores .ps b{ font-family:var(--mono); font-size:13px; color:var(--ink); }
.profile-h{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--green); margin:20px 0 8px; }
.profile-prompt{ font-family:var(--serif); font-size:13.5px; line-height:1.6; color:var(--ink); white-space:pre-wrap; background:var(--panel-sunk); border:1px solid var(--line); border-left:3px solid var(--gold-soft); border-radius:6px; padding:16px 18px; margin:0 0 4px; }

/* Chief of Agents — per-node score badge */
.node-score{ position:absolute; top:-9px; right:-9px; z-index:3; min-width:22px; height:22px; padding:0 5px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:11px; font-weight:700; color:#fff; border:2px solid var(--panel); box-shadow:0 1px 4px rgba(30,26,16,.25); }
.node-score.hi{ background:#1A6B49; }
.node-score.mid{ background:#B68A2C; }
.node-score.lo{ background:#A63427; }

/* Chief of Agents — scoreboard */
/* demo menu bar — sits under the timeline, full width */
.cockpit-menu{ flex:0 0 auto; display:flex; align-items:center; gap:8px; padding:8px 30px; background:#EFEADD; border-bottom:1px solid var(--line-2); }
.cm-label{ font-family:var(--mono); font-size:9.5px; letter-spacing:.18em; color:var(--ink-3); margin-right:8px; }
.cm-item{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:7px 14px; border-radius:7px; border:1px solid var(--line-2); background:var(--panel); color:var(--ink-2); cursor:pointer; transition:.13s; }
.cm-item:hover{ background:#fff; border-color:var(--gold); color:var(--ink); }
.cm-spacer{ flex:1; }
.cm-llm{ font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--green); padding:6px 10px; border:1px solid var(--line-2); border-radius:7px; background:var(--panel); margin-right:8px; }
.cm-live{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; padding:6px 12px; border-radius:7px; border:1px solid var(--line-2); background:var(--panel); color:var(--ink-2); cursor:pointer; transition:.13s; }
.cm-live:not(:disabled):hover{ background:#fff; }
.cm-live:disabled{ cursor:default; }
.cm-live-dot{ width:8px; height:8px; border-radius:50%; background:var(--ink-3); }
.cm-live.on{ border-color:var(--green); color:var(--green); }
.cm-live.on .cm-live-dot{ background:var(--green); box-shadow:0 0 0 3px rgba(18,63,46,.14); }
.cm-live.off{ border-color:var(--gold-soft); color:var(--gold); }
.cm-live.off .cm-live-dot{ background:var(--gold); }
.cm-live.none{ color:var(--ink-3); }

/* Disruption Ledger — always-on bottom strip */
.ledger{ flex:0 0 auto; display:flex; align-items:center; gap:22px; height:44px; padding:0 24px; border-top:1px solid var(--line-2); background:linear-gradient(180deg,#FCFAF4,#F3EFE5); font-family:var(--mono); }
.ld-tag{ display:flex; flex-direction:column; line-height:1.15; }
.ld-tag b{ font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--green); }
.ld-tag span{ font-size:8px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.ld-grp{ display:flex; align-items:center; gap:12px; padding:5px 14px; border-radius:9px; }
.ld-grp.human{ background:rgba(18,63,46,.06); }
.ld-grp.agent{ background:rgba(158,123,38,.09); }
.ld-k{ font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.ld-v{ font-size:14px; font-weight:600; color:var(--ink); }
.ld-v i{ font-style:normal; font-size:9px; color:var(--ink-3); letter-spacing:.05em; }
.ld-arrow{ font-size:18px; color:var(--ink-4); }
.ld-head{ font-size:13px; color:var(--ink-2); }
.ld-head b{ font-size:16px; color:var(--green); font-weight:700; }
.ld-docs{ margin-left:auto; font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }

/* Race the Bank */
.race-scrim{ position:absolute; inset:0; z-index:42; background:rgba(20,18,12,.40); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.race{ width:1280px; max-width:94%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); overflow:hidden; }
.race-head{ display:flex; align-items:center; gap:14px; padding:18px 24px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F4F0E6); }
.race-title{ display:flex; flex-direction:column; }
.race-title b{ font-size:15px; color:var(--ink); }
.race-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.race-play{ margin-left:auto; font-family:var(--mono); font-size:12px; letter-spacing:.08em; padding:9px 18px; border-radius:9px; border:1px solid var(--gold-soft); background:var(--gold); color:#fff; cursor:pointer; }
.race-play:hover{ filter:brightness(1.08); }
.race-lanes{ padding:36px 34px 14px; display:flex; flex-direction:column; gap:34px; }
.rl-head{ display:flex; align-items:center; gap:12px; margin-bottom:13px; }
.rl-name{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); }
.race-lane.albion .rl-name{ color:var(--green); }
.rl-flag{ font-family:var(--mono); font-size:9px; letter-spacing:.14em; padding:2px 9px; border-radius:5px; background:var(--green); color:#fff; }
.race-lane.trad .rl-flag{ background:var(--ink-3); }
.rl-track{ position:relative; height:14px; border-radius:9px; background:var(--panel-sunk); border:1px solid var(--line); margin-bottom:28px; }
.rl-fill{ position:absolute; left:0; top:0; bottom:0; border-radius:9px; }
.race-lane.albion .rl-fill{ background:linear-gradient(90deg,#1A6B49,#2A9468); }
.race-lane.trad .rl-fill{ background:linear-gradient(90deg,#C2BBA8,#8B8678); }
.rl-dot{ position:absolute; top:50%; transform:translate(-50%,-50%); width:13px; height:13px; border-radius:50%; background:var(--panel-2); border:2px solid var(--line-2); transition:.2s; }
.rl-dot.lit{ background:var(--green); border-color:#fff; box-shadow:0 0 0 3px rgba(18,63,46,.18); }
.race-lane.trad .rl-dot.lit{ background:var(--gold); box-shadow:0 0 0 3px rgba(158,123,38,.18); }
.rl-dot-l{ position:absolute; top:15px; left:50%; transform:translateX(-50%); white-space:nowrap; font-family:var(--mono); font-size:8.5px; letter-spacing:.02em; color:var(--ink-3); }
.race-foot{ min-height:54px; padding:4px 30px 26px; display:flex; align-items:center; justify-content:center; text-align:center; }
.race-call{ font-size:14px; color:var(--ink-2); }
.race-call b{ color:var(--ink); }
.race-reveal{ font-family:var(--serif); font-size:25px; color:var(--ink); }
.race-reveal b{ color:var(--green); }

/* State of the Bank board */
.bb-scrim{ position:absolute; inset:0; z-index:42; background:rgba(20,18,12,.40); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.bankboard{ width:1240px; max-width:95%; max-height:88%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.bb-head{ display:flex; align-items:center; gap:14px; padding:18px 24px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F4F0E6); }
.bb-title{ display:flex; flex-direction:column; }
.bb-title b{ font-size:15px; color:var(--ink); }
.bb-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.05em; color:var(--ink-3); margin-top:2px; }
.bb-move{ padding:10px 24px; background:var(--panel-sunk); border-bottom:1px solid var(--line-soft); font-size:12.5px; color:var(--ink-2); }
.bb-move b{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-right:6px; }
.bb-grid{ overflow-y:auto; padding:18px 22px 24px; display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.bb-tile{ position:relative; padding:14px 15px; border:1px solid var(--line-2); border-radius:11px; background:var(--panel-2); }
.bb-k{ font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.bb-v{ font-size:23px; font-weight:700; color:var(--ink); margin-top:5px; letter-spacing:-.01em; }
.bb-d{ font-family:var(--mono); font-size:11px; margin-top:3px; color:var(--ink-3); }
.bb-d.up{ color:#1A6B49; }
.bb-d.down{ color:var(--esc); }
.bb-spark{ width:100%; height:30px; margin-top:8px; display:block; }
.bb-spark path{ fill:none; stroke:var(--gold); stroke-width:1.6; }
.bb-spark .bb-base{ stroke:var(--line-2); stroke-width:1; stroke-dasharray:2 3; }
.sb-scrim{ position:absolute; inset:0; z-index:40; background:rgba(20,18,12,.34); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.scoreboard{ width:1180px; max-width:94%; max-height:86%; background:var(--panel); border:1px solid var(--line-2); border-radius:14px; box-shadow:0 30px 80px rgba(30,26,16,.28); display:flex; flex-direction:column; overflow:hidden; }
.sb-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.sb-title{ display:flex; flex-direction:column; }
.sb-title b{ font-size:14px; color:var(--ink); }
.sb-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.sb-legend{ margin-left:auto; display:flex; gap:14px; font-family:var(--mono); font-size:10px; color:var(--ink-2); }
.sb-legend span{ display:flex; align-items:center; gap:6px; } .sb-legend i{ width:11px; height:11px; border-radius:3px; }
.sb-colhead{ display:flex; align-items:center; gap:16px; padding:8px 22px; font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); border-bottom:1px solid var(--line-soft); }
.sb-body{ overflow-y:auto; padding:6px 0; }
.sb-row{ display:flex; align-items:center; gap:16px; padding:9px 22px; border-bottom:1px solid var(--line-soft); }
.sb-row:hover{ background:var(--panel-sunk); }
.sb-agent{ width:160px; flex:0 0 160px; font-family:var(--mono); font-size:12px; color:var(--ink); }
.sb-cells{ display:flex; gap:5px; flex:0 0 auto; }
.sb-ch{ width:38px; text-align:center; }
.sb-ch.fy{ width:46px; font-weight:700; color:var(--ink-2); }
.sb-cell{ width:38px; height:30px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:12px; font-weight:600; color:#fff; }
.sb-cell.fy{ width:46px; box-shadow:0 0 0 1px var(--gold-soft) inset; }
.sb-rec{ flex:1; min-width:0; display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:11.5px; color:var(--ink-2); }
.sb-pri{ font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; padding:2px 7px; border-radius:5px; border:1px solid var(--line-2); }
.sb-pri.high{ color:var(--esc); border-color:var(--esc); } .sb-pri.medium{ color:var(--gold); border-color:var(--gold-soft); } .sb-pri.low{ color:var(--ink-3); }
.sb-rl{ display:block; flex-basis:100%; } .sb-rl b{ color:var(--ink); font-weight:600; }

/* ---------------- Ask the Bank Anything ---------------- */
.ask-scrim{ position:absolute; inset:0; z-index:43; background:rgba(20,18,12,.40); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.askbank{ width:860px; max-width:94%; max-height:88%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.ab-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.ab-title{ display:flex; flex-direction:column; }
.ab-title b{ font-size:14px; color:var(--ink); }
.ab-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.ab-ask{ display:flex; gap:10px; padding:18px 22px 10px; }
.ab-input{ flex:1; font-family:var(--serif); font-size:15px; color:var(--ink); padding:11px 14px; border:1px solid var(--line-2); border-radius:9px; background:var(--panel-sunk); outline:none; transition:.15s; }
.ab-input:focus{ border-color:var(--gold); background:#fff; }
.ab-go{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:0 20px; border-radius:9px; border:1px solid var(--green); background:var(--green); color:#fff; cursor:pointer; transition:.15s; }
.ab-go:hover:not(:disabled){ filter:brightness(1.12); }
.ab-go:disabled{ opacity:.45; cursor:default; }
.ab-chips{ display:flex; flex-wrap:wrap; gap:7px; padding:2px 22px 16px; border-bottom:1px solid var(--line-soft); }
.ab-chip{ font-family:var(--mono); font-size:10.5px; color:var(--ink-2); padding:6px 11px; border-radius:20px; border:1px solid var(--line-2); background:var(--panel); cursor:pointer; transition:.15s; }
.ab-chip:hover:not(:disabled){ border-color:var(--gold); color:var(--ink); background:#fff; }
.ab-chip:disabled{ opacity:.5; cursor:default; }
.ab-stage{ overflow-y:auto; padding:20px 22px 24px; min-height:120px; }
.ab-empty, .ab-thinking{ font-family:var(--mono); font-size:12px; color:var(--ink-3); display:flex; align-items:center; gap:8px; }
.ab-dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); animation:abpulse 1.1s infinite ease-in-out; }
.ab-dot:nth-child(2){ animation-delay:.18s; } .ab-dot:nth-child(3){ animation-delay:.36s; }
@keyframes abpulse{ 0%,80%,100%{ opacity:.25; } 40%{ opacity:1; } }
.ab-badge{ display:inline-flex; align-items:baseline; gap:9px; margin-bottom:12px; padding:7px 13px; border-radius:9px; border:1px solid var(--line-2); background:var(--panel-sunk); }
.ab-badge b{ font-size:13px; color:var(--ink); }
.ab-badge span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.ab-badge .ab-live{ font-family:var(--mono); font-size:9px; letter-spacing:.08em; color:var(--green); font-style:normal; }
.ab-badge .ab-mock{ font-family:var(--mono); font-size:9px; letter-spacing:.08em; color:var(--gold); font-style:normal; }
.ab-text{ font-family:var(--serif); font-size:15px; line-height:1.66; color:var(--ink); white-space:pre-wrap; }
.ab-cites{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-top:16px; padding-top:14px; border-top:1px solid var(--line-soft); }
.ab-cites-l{ font-family:var(--mono); font-size:9px; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); }
.ab-cite{ font-family:var(--mono); font-size:10.5px; color:var(--ink-2); padding:5px 10px; border-radius:6px; border:1px solid var(--line-2); background:var(--panel); }
.ab-cite.on{ cursor:pointer; color:var(--green); border-color:var(--green-soft, var(--line-2)); }
.ab-cite.on:hover{ background:#fff; border-color:var(--green); }
.ab-note{ font-family:var(--mono); font-size:11px; line-height:1.5; color:var(--ink-3); margin-top:14px; padding:10px 13px; border-radius:8px; border:1px dashed var(--line-2); background:var(--panel-sunk); }

/* ---------------- Red-Team Console ---------------- */
.rt-scrim{ position:absolute; inset:0; z-index:44; background:rgba(20,18,12,.44); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.redteam{ width:1080px; max-width:95%; max-height:88%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.rt-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.rt-title{ display:flex; flex-direction:column; }
.rt-title b{ font-size:14px; color:var(--ink); }
.rt-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.rt-tally{ margin-left:auto; display:flex; gap:8px; font-family:var(--mono); font-size:10px; }
.rt-t{ padding:4px 9px; border-radius:6px; border:1px solid var(--line-2); color:var(--ink-2); }
.rt-t.held{ color:var(--green); border-color:var(--green); }
.rt-t.escalated{ color:var(--gold); border-color:var(--gold-soft); }
.rt-t.breached{ color:var(--esc); border-color:var(--esc); }
.rt-body{ display:flex; min-height:0; flex:1; }
.rt-list{ width:300px; flex:0 0 300px; border-right:1px solid var(--line); overflow-y:auto; padding:8px; background:var(--panel-sunk); }
.rt-item{ padding:11px 12px; border-radius:9px; border:1px solid transparent; cursor:pointer; transition:.13s; margin-bottom:4px; }
.rt-item:hover{ background:var(--panel); }
.rt-item.on{ background:var(--panel); border-color:var(--line-2); }
.rt-vec{ font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--esc); }
.rt-name{ font-size:12.5px; color:var(--ink); margin:3px 0 6px; line-height:1.35; }
.rt-foot{ display:flex; align-items:center; gap:8px; }
.rt-target{ font-family:var(--mono); font-size:10px; color:var(--ink-3); }
.rt-chip{ margin-left:auto; font-family:var(--mono); font-size:8.5px; letter-spacing:.08em; padding:2px 6px; border-radius:4px; color:#fff; }
.rt-chip.held{ background:var(--green); } .rt-chip.escalated{ background:var(--gold); } .rt-chip.breached, .rt-chip.error{ background:var(--esc); }
.rt-detail{ flex:1; min-width:0; overflow-y:auto; padding:20px 24px; }
.rt-empty{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.rt-target-line{ font-size:12px; color:var(--ink-2); margin-bottom:12px; } .rt-target-line b{ color:var(--ink); font-family:var(--mono); }
.rt-naive{ margin-left:10px; font-family:var(--mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; color:var(--esc); border:1px solid var(--esc); border-radius:5px; padding:2px 7px; }
.rt-xmit{ border:1px solid var(--line-2); border-radius:10px; overflow:hidden; margin-bottom:14px; }
.rt-xmit-h{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--esc); padding:8px 13px; background:rgba(166,52,39,.07); border-bottom:1px solid var(--line-soft); }
.rt-xmit-b{ font-family:var(--mono); font-size:12px; line-height:1.6; color:var(--ink); padding:12px 14px; white-space:pre-wrap; }
.rt-launch{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:10px 18px; border-radius:9px; border:1px solid var(--esc); background:var(--esc); color:#fff; cursor:pointer; transition:.15s; }
.rt-launch:hover:not(:disabled){ filter:brightness(1.1); } .rt-launch:disabled{ opacity:.5; cursor:default; }
.rt-thinking{ margin-top:16px; font-family:var(--mono); font-size:12px; color:var(--ink-3); display:flex; align-items:center; gap:8px; }
.rt-result{ margin-top:18px; }
.rt-verdict{ display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:15px; font-weight:700; letter-spacing:.08em; padding:9px 16px; border-radius:10px; color:#fff; }
.rt-verdict .rt-vmark{ width:9px; height:9px; border-radius:50%; background:#fff; }
.rt-verdict.held{ background:var(--green); } .rt-verdict.escalated{ background:var(--gold); } .rt-verdict.breached, .rt-verdict.error{ background:var(--esc); }
.rt-verdict .ab-live{ font-size:9px; font-weight:400; font-style:normal; opacity:.9; } .rt-verdict .ab-mock{ font-size:9px; font-weight:400; font-style:normal; opacity:.85; }
.rt-response{ font-family:var(--serif); font-size:15px; line-height:1.66; color:var(--ink); white-space:pre-wrap; margin-top:14px; padding:14px 16px; border-radius:10px; border:1px solid var(--line-2); background:var(--panel-sunk); }
.rt-control{ font-size:12px; color:var(--ink-2); margin-top:12px; } .rt-control b{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--green); }
.rt-signals{ display:flex; flex-wrap:wrap; align-items:center; gap:7px; margin-top:12px; }
.rt-sig-l{ font-family:var(--mono); font-size:9px; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); }
.rt-sig{ font-family:var(--mono); font-size:10px; color:var(--ink-2); padding:3px 8px; border-radius:5px; border:1px solid var(--line-2); background:var(--panel); }

/* ---------------- Glass Box (decision provenance) ---------------- */
.gb-toggle{ display:inline-flex; gap:0; border:1px solid var(--line-2); border-radius:7px; overflow:hidden; }
.gb-tab{ font-family:var(--mono); font-size:10px; letter-spacing:.05em; padding:5px 11px; border:none; background:var(--panel); color:var(--ink-3); cursor:pointer; transition:.13s; }
.gb-tab.on{ background:var(--ink); color:#fff; }
.gb-tab:not(.on):hover{ background:var(--panel-sunk); color:var(--ink); }
.sheet.gb{ font-family:var(--sans, inherit); }
.gb-empty{ font-family:var(--mono); font-size:12px; color:var(--ink-3); padding:20px 0; }
.gb-h{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--green); margin-bottom:14px; }
.gb-producer{ padding:14px 16px; border:1px solid var(--line-2); border-radius:11px; background:var(--panel-sunk); }
.gb-pname{ font-family:var(--serif); font-size:17px; color:var(--ink); }
.gb-pmeta{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.gb-pmeta span{ font-family:var(--mono); font-size:10px; padding:3px 8px; border-radius:5px; border:1px solid var(--line-2); color:var(--ink-2); }
.gb-pmeta .gb-model{ color:var(--green); border-color:var(--green); }
.gb-pmeta .gb-fp{ color:var(--ink-3); }
.gb-fingerprint{ font-family:var(--mono); font-size:11px; color:var(--ink-3); margin:12px 2px 18px; }
.gb-fingerprint b{ color:var(--ink-2); } .gb-fingerprint i{ color:var(--ink-3); }
.gb-chain{ position:relative; padding-left:8px; }
.gb-step{ position:relative; display:flex; gap:13px; padding:0 0 16px 14px; border-left:2px solid var(--line-2); }
.gb-step:last-child{ border-left-color:transparent; }
.gb-mark{ position:absolute; left:-7px; top:2px; width:12px; height:12px; border-radius:50%; background:var(--ink-3); box-shadow:0 0 0 3px var(--panel); }
.gb-step.produced .gb-mark{ background:var(--ink-2); }
.gb-step.approved .gb-mark{ background:var(--green); }
.gb-step.rejected .gb-mark{ background:var(--esc); }
.gb-step.escalated .gb-mark{ background:var(--gold); }
.gb-step.deferred .gb-mark{ background:var(--ink-3); }
.gb-step-b{ flex:1; min-width:0; }
.gb-step-h{ display:flex; flex-wrap:wrap; align-items:baseline; gap:9px; }
.gb-kind{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:2px 7px; border-radius:5px; border:1px solid var(--line-2); color:var(--ink-2); }
.gb-step.approved .gb-kind{ color:var(--green); border-color:var(--green); }
.gb-step.rejected .gb-kind{ color:var(--esc); border-color:var(--esc); }
.gb-step.escalated .gb-kind{ color:var(--gold); border-color:var(--gold-soft); }
.gb-actor{ font-family:var(--mono); font-size:11.5px; color:var(--ink); }
.gb-seq{ margin-left:auto; font-family:var(--mono); font-size:10px; color:var(--ink-3); }
.gb-note{ font-size:12.5px; color:var(--ink-2); margin-top:5px; line-height:1.5; }
.gb-inputs{ margin-top:18px; padding-top:14px; border-top:1px solid var(--line-soft); }
.gb-inputs-l{ font-family:var(--mono); font-size:9px; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.gb-input{ display:inline-block; font-family:var(--mono); font-size:11px; color:var(--green); padding:6px 11px; margin:0 7px 7px 0; border-radius:7px; border:1px solid var(--line-2); background:var(--panel); cursor:pointer; transition:.13s; }
.gb-input:hover{ background:#fff; border-color:var(--green); }
.gb-input span{ color:var(--ink-3); }

/* ---------------- The Constitution ---------------- */
.con-scrim{ position:absolute; inset:0; z-index:44; background:rgba(20,18,12,.44); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.constitution{ width:1100px; max-width:95%; max-height:90%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.con-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.con-title{ display:flex; flex-direction:column; }
.con-title b{ font-size:14px; color:var(--ink); }
.con-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.con-banner{ padding:11px 22px; background:rgba(166,52,39,.07); border-bottom:1px solid var(--line-soft); }
.con-banner-t{ font-family:var(--mono); font-size:11px; color:var(--esc); letter-spacing:.04em; } .con-banner-t b{ color:var(--esc); }
.con-roster{ display:flex; flex-wrap:wrap; gap:4px; margin-top:8px; }
.con-dot{ width:8px; height:8px; border-radius:2px; background:var(--esc); opacity:.25; animation:condot .7s ease forwards; }
@keyframes condot{ from{ opacity:.12; transform:scale(.7); } to{ opacity:.85; transform:scale(1); } }
.con-body{ display:flex; min-height:0; flex:1; }
.con-articles{ width:520px; flex:0 0 520px; border-right:1px solid var(--line); overflow-y:auto; padding:14px 18px; }
.con-article{ display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--line-soft); }
.con-article:last-child{ border-bottom:none; }
.con-anum{ flex:0 0 22px; width:22px; height:22px; border-radius:50%; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:11px; color:var(--ink-3); }
.con-article.amended .con-anum{ border-color:var(--esc); color:var(--esc); }
.con-abody{ flex:1; min-width:0; }
.con-atitle{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--green); }
.con-article.amended .con-atitle{ color:var(--esc); }
.con-atext{ font-family:var(--serif); font-size:14px; line-height:1.55; color:var(--ink); margin:5px 0 8px; }
.con-article.amended .con-atext{ color:var(--esc); font-style:italic; }
.con-toggle{ display:inline-flex; border:1px solid var(--line-2); border-radius:7px; overflow:hidden; }
.con-tab{ font-family:var(--mono); font-size:9.5px; letter-spacing:.04em; padding:5px 10px; border:none; background:var(--panel); color:var(--ink-3); cursor:pointer; transition:.13s; }
.con-tab.on{ background:var(--ink); color:#fff; }
.con-tab.amend.on{ background:var(--esc); }
.con-tab:not(.on):hover{ background:var(--panel-sunk); color:var(--ink); }
.con-preview{ flex:1; min-width:0; overflow-y:auto; padding:18px 22px; }
.con-hint{ font-family:var(--mono); font-size:12px; line-height:1.6; color:var(--ink-3); }
.con-demo{ font-size:13px; line-height:1.5; color:var(--ink-2); margin-bottom:12px; } .con-demo b{ font-family:var(--mono); color:var(--ink); }
.con-run{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:10px 18px; border-radius:9px; border:1px solid var(--esc); background:var(--esc); color:#fff; cursor:pointer; transition:.15s; }
.con-run:hover:not(:disabled){ filter:brightness(1.1); } .con-run:disabled{ opacity:.5; cursor:default; }
.con-thinking{ margin-top:14px; font-family:var(--mono); font-size:12px; color:var(--ink-3); display:flex; align-items:center; gap:8px; }
.con-ba{ display:flex; gap:12px; margin-top:16px; }
.con-col{ flex:1; min-width:0; border:1px solid var(--line-2); border-radius:11px; overflow:hidden; }
.con-col.after{ border-color:var(--esc); }
.con-col-h{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; padding:8px 12px; border-bottom:1px solid var(--line-soft); color:var(--ink-3); background:var(--panel-sunk); }
.con-col.after .con-col-h{ color:var(--esc); background:rgba(166,52,39,.06); }
.con-col-h .ab-live{ font-size:9px; font-style:normal; color:var(--green); } .con-col-h .ab-mock{ font-size:9px; font-style:normal; color:var(--gold); }
.con-col-b{ font-family:var(--serif); font-size:13.5px; line-height:1.6; color:var(--ink); padding:12px 14px; white-space:pre-wrap; }
.con-foot{ padding:12px 22px; border-top:1px solid var(--line); font-family:var(--mono); font-size:10.5px; line-height:1.5; color:var(--ink-3); background:var(--panel-sunk); }

/* ---------------- Fork the Bank ---------------- */
.fk-scrim{ position:absolute; inset:0; z-index:44; background:rgba(20,18,12,.44); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.fork{ width:1120px; max-width:96%; max-height:90%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.fk-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.fk-title{ display:flex; flex-direction:column; }
.fk-title b{ font-size:14px; color:var(--ink); }
.fk-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.fk-body{ display:flex; min-height:0; flex:1; }
.fk-list{ width:300px; flex:0 0 300px; border-right:1px solid var(--line); overflow-y:auto; padding:8px; background:var(--panel-sunk); }
.fk-item{ padding:11px 12px; border-radius:9px; border:1px solid transparent; cursor:pointer; transition:.13s; margin-bottom:4px; }
.fk-item:hover{ background:var(--panel); }
.fk-item.on{ background:var(--panel); border-color:var(--line-2); }
.fk-label{ font-size:13px; color:var(--ink); font-weight:600; }
.fk-sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--green); margin:2px 0 5px; }
.fk-narr{ font-size:11px; line-height:1.45; color:var(--ink-3); }
.fk-detail{ flex:1; min-width:0; overflow-y:auto; padding:18px 22px; }
.fk-empty{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.fk-run{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:10px 18px; border-radius:9px; border:1px solid var(--green); background:var(--green); color:#fff; cursor:pointer; transition:.15s; }
.fk-run:hover:not(:disabled){ filter:brightness(1.12); } .fk-run:disabled{ opacity:.5; cursor:default; }
.fk-thinking{ margin-top:14px; font-family:var(--mono); font-size:12px; color:var(--ink-3); display:flex; align-items:center; gap:8px; }
.fk-legend{ display:flex; align-items:center; gap:14px; margin:16px 0 6px; font-family:var(--mono); font-size:10px; color:var(--ink-3); }
.fk-lg.base{ color:var(--ink-2); } .fk-lg.shock{ color:var(--esc); }
.fk-at{ margin-left:auto; color:var(--ink-3); }
.fk-charts{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fk-metric{ border:1px solid var(--line-2); border-radius:11px; padding:12px 14px; background:var(--panel-sunk); }
.fk-mk{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); margin-bottom:6px; }
.fk-spark{ width:100%; height:46px; display:block; }
.fk-spark .fk-mark{ stroke:var(--line-2); stroke-width:1; stroke-dasharray:2 3; }
.fk-spark .fk-base{ fill:none; stroke:var(--ink-2); stroke-width:1.6; }
.fk-spark .fk-shock{ fill:none; stroke:var(--esc); stroke-width:1.6; stroke-dasharray:4 3; }
.fk-vals{ display:flex; align-items:baseline; gap:8px; margin-top:8px; font-family:var(--mono); font-size:12px; }
.fk-bv{ color:var(--ink-3); } .fk-arr{ color:var(--ink-3); } .fk-sv{ color:var(--ink); font-weight:600; }
.fk-dv{ margin-left:auto; font-size:11px; } .fk-dv.up{ color:var(--green); } .fk-dv.down{ color:var(--esc); }
.fk-response{ margin-top:18px; padding:14px 16px; border:1px solid var(--line-2); border-radius:11px; }
.fk-resp-h{ display:flex; align-items:baseline; gap:9px; margin-bottom:8px; }
.fk-resp-h b{ font-size:13px; color:var(--ink); }
.fk-resp-h span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.fk-resp-h .ab-live{ font-family:var(--mono); font-size:9px; font-style:normal; color:var(--green); }
.fk-resp-h .ab-mock{ font-family:var(--mono); font-size:9px; font-style:normal; color:var(--gold); }
.fk-resp-b{ font-family:var(--serif); font-size:14.5px; line-height:1.62; color:var(--ink); white-space:pre-wrap; }

/* markdown-rendered documents (agent output) */
.doc-body.md{ font-family:var(--serif); color:var(--ink); font-size:14px; line-height:1.62; }
.doc-body.md h1{ font-family:var(--serif); font-size:21px; font-weight:700; color:var(--ink); margin:22px 0 8px; letter-spacing:-.01em; }
.doc-body.md h2{ font-family:var(--serif); font-size:16px; font-weight:700; color:var(--ink); margin:22px 0 7px; }
.doc-body.md h3{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--green); margin:18px 0 6px; }
.doc-body.md p{ margin:0 0 11px; }
.doc-body.md ul, .doc-body.md ol{ margin:0 0 12px; padding-left:22px; }
.doc-body.md li{ margin:0 0 5px; }
.doc-body.md strong{ font-weight:700; color:var(--ink); }
.doc-body.md em{ font-style:italic; }
.doc-body.md code{ font-family:var(--mono); font-size:12px; background:var(--panel-sunk); padding:1px 5px; border-radius:4px; }
.doc-body.md table{ width:100%; border-collapse:collapse; margin:8px 0 16px; font-family:var(--mono); font-size:11.5px; }
.doc-body.md thead th{ text-align:left; font-weight:600; color:var(--ink-2); border-bottom:1.5px solid var(--line-2); padding:7px 10px; letter-spacing:.04em; }
.doc-body.md tbody td{ border-bottom:1px solid var(--line-soft); padding:7px 10px; color:var(--ink); }
.doc-body.md blockquote{ border-left:3px solid var(--gold-soft); margin:0 0 12px; padding:4px 14px; color:var(--ink-2); }

/* ---------------- Guide (overview / manual) ---------------- */
.cm-guide{ border-color:var(--gold-soft); color:var(--ink); }
.gd-scrim{ position:absolute; inset:0; z-index:45; background:rgba(20,18,12,.46); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; }
.guide{ width:920px; max-width:94%; max-height:90%; background:var(--panel); border:1px solid var(--line-2); border-radius:16px; box-shadow:0 30px 80px rgba(30,26,16,.3); display:flex; flex-direction:column; overflow:hidden; }
.gd-head{ display:flex; align-items:center; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#FCFAF4,#F6F2E9); }
.gd-title{ display:flex; flex-direction:column; }
.gd-title b{ font-size:14px; color:var(--ink); }
.gd-title span{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; color:var(--ink-3); margin-top:2px; }
.gd-scroll{ overflow-y:auto; padding:26px 40px 34px; }
.gd-empty{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.gd-doc{ max-width:720px; margin:0 auto; }
.gd-doc h1{ font-size:26px; margin:0 0 14px; }
.gd-doc hr{ border:none; border-top:1px solid var(--line-soft); margin:22px 0; }
.gd-doc pre{ background:var(--panel-sunk); border:1px solid var(--line-soft); border-radius:8px; padding:12px 14px; overflow-x:auto; font-family:var(--mono); font-size:12px; line-height:1.55; margin:0 0 14px; }
.gd-doc pre code{ background:none; padding:0; }
