/* ============ Trifecta Dashboard IDE — styles ============
   Report-pane component styles mirror the hand-authored report.html so the
   dossier looks identical; the IDE layout + chat sidebar wrap around it. */
:root{
  --bg:#0b0d10; --bg-2:#0f1217; --panel:#13171d; --panel-2:#181d25;
  --line:#262d38; --line-soft:#1d232c; --ink:#eae6dd; --ink-dim:#9aa3b0;
  --ink-faint:#646d7a; --signal:#ff5c28; --signal-soft:#ff7d52; --paper:#f4efe6;
  --high:#5ad19a; --medium:#f0b95a; --none:#6b7280;
  --serif:"Fraunces",Georgia,serif;
  --sans:"IBM Plex Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow:hidden}
::selection{background:var(--signal);color:#0b0d10}
a{color:inherit}

/* ---------- IDE layout ----------
   Claude.ai-style shell: BOTH sidebars run the FULL viewport height —
   the TOC in column 1 and the "Ask Trey" chat in the last column (grid-row 1/-1).
   The app bar sits in row 1 of the MIDDLE column only (over the report, between
   the two sidebars, never under them); the report lives in row 2 of that column. */
.app{display:grid;grid-template-columns:1fr minmax(360px,420px);grid-template-rows:auto 1fr;height:100vh;
  --chat-w:420px}
.report-pane{position:relative;overflow-y:auto;overflow-x:hidden;grid-row:2}

/* ---------- top app bar (over the content only; controls + current page title) ---------- */
.appbar{grid-column:1/-1;grid-row:1;display:flex;align-items:center;gap:12px;height:52px;padding:0 14px;
  background:var(--panel);border-bottom:1px solid var(--line);position:relative;z-index:40}
.ab-brand{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--paper);line-height:1;
  display:flex;align-items:baseline;gap:8px;flex:none}
.ab-brand small{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500}
.ab-sep{color:var(--ink-faint);font-family:var(--serif);font-size:17px;flex:none}
/* the app-bar brand (D.A.) + separator + expand toggle only appear when the sidebar
   is collapsed to a rail — when the sidebar is open the brand lives in the sidebar.
   (These hide rules come AFTER the styling above so `display:none` wins by order.) */
.ab-expand{display:none}
.ab-brand{display:none}
.ab-sep{display:none}
.ab-title{font-family:var(--sans);font-size:14px;color:var(--ink-dim);font-weight:600;flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ab-btn{display:inline-flex;align-items:center;gap:7px;background:var(--panel-2);color:var(--ink);
  border:1px solid var(--line);border-radius:8px;font-family:var(--mono);font-size:12.5px;font-weight:600;
  padding:8px 11px;cursor:pointer;line-height:1;transition:.18s;flex:none}
.ab-btn:hover{border-color:var(--signal);color:var(--paper)}
.ab-btn svg{display:block}
.ab-ask{color:#0b0d10;background:var(--signal);border-color:var(--signal)}
.ab-ask:hover{background:var(--signal-soft);color:#0b0d10;border-color:var(--signal-soft)}
/* the app bar replaces the old floating FABs + docked toggles */
.toc-fab,.chat-fab,.dock-toggle{display:none !important}
@media(max-width:560px){.ab-brand small{display:none}.ab-ask-label{display:none}}
.report-pane::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),
    linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 40% 0%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 60% at 40% 0%,#000,transparent 75%);opacity:.5}
.wrap{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:0 32px 80px}

/* ---------- masthead ---------- */
.terminal{font-family:var(--mono);font-size:12.5px;color:var(--ink-dim);
  border:1px solid var(--line);border-radius:9px;background:rgba(15,18,23,.7);
  padding:10px 14px;display:flex;align-items:center;gap:9px;max-width:560px;margin-top:34px}
.terminal .dot{width:9px;height:9px;border-radius:50%;flex:none}
.terminal .dot:nth-child(1){background:#ff5f57}.terminal .dot:nth-child(2){background:#febc2e}
.terminal .dot:nth-child(3){background:#28c840}
.terminal .cmd{margin-left:6px;color:var(--paper)}.terminal .cmd .flag{color:var(--signal-soft)}
.cursor{display:inline-block;width:7px;height:14px;background:var(--signal);margin-left:2px;
  transform:translateY(2px);animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--signal);margin:30px 0 14px;font-weight:600}
h1.title{font-family:var(--serif);font-weight:600;font-size:clamp(40px,6.5vw,82px);line-height:.94;
  letter-spacing:-.02em;margin:0;color:var(--paper)}
h1.title .db{font-style:italic;font-weight:500;color:var(--signal)}
.subhead{font-family:var(--serif);font-size:clamp(17px,2vw,22px);font-weight:400;font-style:italic;
  color:var(--ink-dim);margin:20px 0 0;max-width:680px;line-height:1.4}
.meta-row{display:flex;flex-wrap:wrap;gap:9px 24px;margin:26px 0 0;font-family:var(--mono);
  font-size:12px;color:var(--ink-faint)}
.meta-row b{color:var(--ink-dim);font-weight:500}

.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:44px 0 14px}
.statband .cell{background:var(--panel);padding:22px 20px;min-width:0}
@media(max-width:640px){.statband{grid-template-columns:repeat(2,1fr)}}
.statband .num{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4vw,46px);line-height:1;
  color:var(--paper);letter-spacing:-.02em}
.statband .num.em,.statband .cell:first-child .num{color:var(--signal)}
.statband .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:10px}

/* ---------- sections ---------- */
section{position:relative;z-index:1;padding:54px 0}
.sec-head{display:flex;align-items:baseline;gap:16px;margin-bottom:8px}
.sec-kicker{font-family:var(--mono);font-size:11.5px;color:var(--signal);letter-spacing:.2em;
  text-transform:uppercase;font-weight:600}
.sec-num{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint)}
h2.sec{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,42px);letter-spacing:-.018em;
  margin:6px 0 0;color:var(--paper);line-height:1.05}
.sec-lede{font-size:16px;color:var(--ink-dim);max-width:640px;margin:18px 0 0}

.verdict{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;margin-top:38px}
/* grid children must be allowed to shrink below content, or long monospace
   strings blow the track out and the report-pane clips them (no x-scroll) */
.verdict>*{min-width:0}
@media(max-width:1400px){.verdict{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px}
.card h3{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);margin:0 0 18px;font-weight:600}
.platform{display:flex;align-items:center;gap:15px}
.platform .wp{width:46px;height:46px;border-radius:12px;flex:none;
  background:linear-gradient(135deg,#2b3440,#1a2029);border:1px solid var(--line);display:grid;
  place-items:center;font-family:var(--serif);font-weight:700;font-size:20px;color:var(--paper)}
.platform .name{font-family:var(--serif);font-size:27px;font-weight:600;color:var(--paper);line-height:1.05}
.platform .name small{display:block;font-family:var(--sans);font-size:12.5px;font-weight:400;
  color:var(--ink-faint);margin-top:5px}
.ev-note{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);line-height:1.55;
  border-left:2px solid var(--line);padding-left:12px;margin-top:16px}
.purposes{display:flex;flex-direction:column;gap:10px}
.purpose{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:10px;
  background:var(--panel-2);border:1px solid var(--line-soft);transition:transform .25s,border-color .25s}
.purpose:hover{transform:translateX(4px);border-color:var(--clr)}
.purpose .ico{width:8px;height:32px;border-radius:4px;background:var(--clr);flex:none;
  box-shadow:0 0 16px -2px var(--clr)}
.purpose .body{flex:1;min-width:0}
.purpose .pname{font-weight:600;font-size:14.5px;color:var(--paper)}
.purpose .pev{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:3px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.badge{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 9px;border-radius:999px;flex:none;border:1px solid}
.badge.high{color:var(--high);border-color:color-mix(in srgb,var(--high) 40%,transparent);
  background:color-mix(in srgb,var(--high) 11%,transparent)}
.badge.medium{color:var(--medium);border-color:color-mix(in srgb,var(--medium) 40%,transparent);
  background:color-mix(in srgb,var(--medium) 11%,transparent)}
.badge.low,.badge.none{color:var(--none);border-color:color-mix(in srgb,var(--none) 45%,transparent);
  background:color-mix(in srgb,var(--none) 11%,transparent)}
.profile-grid{display:flex;flex-wrap:wrap;gap:10px}
.pchip{font-family:var(--mono);font-size:12px;padding:9px 13px;border-radius:9px;background:var(--panel-2);
  border:1px solid var(--line-soft)}
.pchip b{color:var(--ink-faint);font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  font-size:10px;display:block;margin-bottom:3px}
.pchip span{color:var(--paper);font-size:13.5px}
.gap{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--ink-dim);padding:10px 0;
  border-top:1px solid var(--line-soft)}
.gap .x{color:var(--signal);font-family:var(--mono);font-weight:700;flex:none}

.hubrow{display:grid;grid-template-columns:200px 1fr 80px;align-items:center;gap:14px;padding:8px 0;
  border-bottom:1px solid var(--line-soft)}
.hubrow .tname{font-family:var(--mono);font-size:12px;color:var(--ink-dim);overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.hubrow .bartrack{height:11px}
.hubrow .bar{height:11px;border-radius:3px;background:linear-gradient(90deg,var(--signal),var(--signal-soft));
  transition:width 1s cubic-bezier(.2,.7,.2,1)}
.hubrow .rc{font-family:var(--mono);font-size:12px;color:var(--paper);text-align:right;font-weight:600}

/* ---------- role tabs ---------- */
/* single-line, horizontally-scrollable role tabs (no wrapping — saves vertical
   space on mobile). Scrollbar hidden; tabs never shrink. */
.tabnav{position:sticky;top:0;z-index:5;display:flex;gap:6px;flex-wrap:nowrap;padding:14px 0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  background:linear-gradient(var(--bg) 72%,transparent)}
.tabnav::-webkit-scrollbar{display:none}
.tab{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink-dim);background:var(--panel);
  border:1px solid var(--line);border-radius:999px;padding:9px 15px;cursor:pointer;display:flex;flex:none;
  align-items:center;gap:8px;transition:.22s;white-space:nowrap}
.tab .swatch{width:9px;height:9px;border-radius:50%;background:var(--clr);flex:none;transition:.22s}
.tab:hover{color:var(--paper);border-color:var(--clr)}
.tab.active{color:#0b0d10;background:var(--clr);border-color:var(--clr);font-weight:600}
.tab.active .swatch{background:#0b0d10}
.panel{display:none}.panel.active{display:block;animation:fadein .45s cubic-bezier(.2,.7,.2,1)}
@keyframes fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.role-hero{border-left:3px solid var(--clr);padding:4px 0 4px 24px;margin:28px 0 6px}
.role-tag{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--clr);font-weight:600}
.role-name{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,40px);color:var(--paper);
  line-height:1.04;margin:9px 0 0;letter-spacing:-.015em}
.role-obj{font-size:16px;color:var(--ink-dim);max-width:680px;margin:14px 0 0}
.owns{font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin-top:16px}
.owns b{color:var(--clr)}
.rstats{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin:30px 0 6px}
.rstats>*{min-width:0}
@media(max-width:760px){.rstats{grid-template-columns:repeat(2,1fr)}}
.rstat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;
  position:relative;overflow:hidden}
.rstat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--clr);opacity:.7}
.rstat .v{font-family:var(--serif);font-weight:600;font-size:clamp(24px,3vw,34px);color:var(--paper);
  line-height:1;letter-spacing:-.02em}
.rstat .v em{font-style:normal;color:var(--clr)}
.rstat .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:9px;line-height:1.4}
.rstat .v,.rstat .k,.rstat .t{overflow-wrap:anywhere;word-break:break-word}
/* prose findings: no fake big-number — show the claim as readable wrapped text */
.rstat-text{display:flex;align-items:center}
.rstat-text .t{font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.32;
  color:var(--paper);letter-spacing:-.01em}
.blk-head{display:flex;align-items:center;gap:12px;margin:46px 0 20px}
.blk-head .ln{height:1px;background:var(--line);flex:1}
.blk-head h4{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--clr);margin:0;font-weight:600}
.evidence{display:grid;gap:12px}
.ev{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  transition:border-color .25s,transform .25s}
.ev:hover{border-color:var(--clr);transform:translateY(-2px)}
.ev .top{display:flex;gap:14px;padding:16px 19px 13px;align-items:flex-start}
.ev .idx{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--clr);line-height:1;
  flex:none;width:28px}
.ev .claim{font-weight:600;font-size:15px;color:var(--paper);line-height:1.4}
.ev .qrow{font-family:var(--mono);font-size:11.5px;background:var(--bg-2);border-top:1px solid var(--line-soft);
  padding:11px 19px;color:var(--ink-dim);display:flex;gap:9px;align-items:flex-start;overflow-x:auto}
.ev .qrow .prompt{color:var(--clr);flex:none;font-weight:600}
.ev .qrow code{white-space:pre;color:#cdd5e0}
.ev .resimp{display:grid;grid-template-columns:3fr 2fr;border-top:1px solid var(--line-soft)}
@media(max-width:620px){.ev .resimp{grid-template-columns:1fr}}
.ev .res{padding:13px 19px;background:color-mix(in srgb,var(--clr) 7%,transparent);
  border-right:1px solid var(--line-soft);min-width:160px}
.ev .res .rlbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.ev .res .rval{font-family:var(--mono);font-size:13px;color:var(--paper);font-weight:600;margin-top:5px;line-height:1.45}
.ev .imp{padding:13px 19px;font-size:13px;color:var(--ink-dim);line-height:1.5}
.ev .imp .ilbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--clr);display:block;margin-bottom:5px}
.recs{display:grid;gap:10px;counter-reset:rec}
.rec{display:flex;gap:15px;background:var(--panel);border:1px solid var(--line);border-radius:11px;
  padding:15px 18px;align-items:flex-start;transition:.25s}
.rec:hover{border-color:var(--clr);background:var(--panel-2)}
.rec::before{counter-increment:rec;content:counter(rec,decimal-leading-zero);font-family:var(--mono);
  font-size:12px;font-weight:700;color:var(--clr);flex:none;padding-top:2px;min-width:24px}
.rec p{margin:0;font-size:14px;color:var(--ink);line-height:1.55}
.rec p b{color:var(--paper);font-weight:600}
.oq{margin-top:28px;background:var(--panel);border:1px dashed var(--line);border-radius:12px;padding:20px 22px}
.oq h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);margin:0 0 13px;font-weight:600}
.oq ul{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.oq li{display:flex;gap:11px;font-size:13.5px;color:var(--ink-dim);line-height:1.5}
.oq li .q{color:var(--clr);font-family:var(--serif);font-weight:700;flex:none}

/* answered-from-the-data callout */
.qa{margin:28px 0 4px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--clr);
  border-radius:12px;padding:20px 22px}
.qa .qtag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--clr);font-weight:600;display:flex;align-items:center;gap:8px}
.qa .qtag::before{content:"◆";font-size:9px}
.qa .qq{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--paper);line-height:1.3;margin:11px 0 13px}
.qa .qbody{font-size:14px;color:var(--ink-dim);line-height:1.6}
.qa ul.qlist{list-style:none;margin:14px 0 4px;padding:0;display:grid;gap:10px}
.qa ul.qlist li{display:grid;grid-template-columns:24px 1fr;gap:11px;font-size:13.5px;color:var(--ink-dim);line-height:1.5}
.qa .qcite{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:14px;
  border-top:1px solid var(--line-soft);padding-top:12px;line-height:1.55}

/* honesty */
.honesty{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);
  border-radius:16px;padding:36px 34px;margin-top:28px}
.honesty .lede{font-family:var(--serif);font-size:19px;font-style:italic;color:var(--ink-dim);
  max-width:560px;line-height:1.45;margin:0 0 24px}
.conf-ladder{display:flex;gap:0;flex-wrap:wrap;margin:0 0 18px;border:1px solid var(--line);
  border-radius:11px;overflow:hidden;background:rgba(0,0,0,.18)}
.conf-ladder .rung{flex:1;min-width:90px;padding:12px 14px;border-right:1px solid var(--line-soft)}
.conf-ladder .rung:last-child{border-right:none}
.conf-ladder .rung.is-none{background:color-mix(in srgb,var(--signal) 9%,transparent)}
.conf-ladder .lvl{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.conf-ladder .rung.high .lvl{color:var(--high)}.conf-ladder .rung.medium .lvl{color:var(--medium)}
.conf-ladder .rung.low .lvl{color:#7f8896}.conf-ladder .rung.is-none .lvl{color:var(--signal)}
.conf-ladder .desc{font-size:11.5px;color:var(--ink-faint);margin-top:7px;line-height:1.4}
.conf-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);margin:0 0 12px}
.notconc{display:flex;flex-wrap:wrap;gap:10px}
.nc{font-family:var(--mono);font-size:12.5px;color:var(--ink-dim);padding:10px 15px;border:1px solid var(--line);
  border-radius:9px;background:rgba(0,0,0,.2);display:flex;gap:10px;align-items:center}
.nc .strike{color:var(--signal);font-weight:700}

/* custom sections */
.custom-sec{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px 28px;margin-top:18px}
.custom-sec h3{font-family:var(--serif);font-size:24px;color:var(--paper);margin:0 0 14px;font-weight:600}
.custom-sec .body{font-size:15px;color:var(--ink-dim);line-height:1.65}

/* change-flash highlight (the chef's-kiss live-edit moment) */
@keyframes flash{0%{box-shadow:0 0 0 0 var(--signal);background:color-mix(in srgb,var(--signal) 14%,transparent)}
  100%{box-shadow:0 0 0 8px transparent;background:transparent}}
.flash{animation:flash 1.8s cubic-bezier(.2,.7,.2,1)}

/* askable affordance */
.askable{position:relative}
.ask-btn{position:absolute;top:8px;right:8px;z-index:6;font-family:var(--mono);font-size:10.5px;
  color:#0b0d10;background:var(--signal);border:none;border-radius:999px;padding:4px 9px;cursor:pointer;
  opacity:0;transform:translateY(-3px);transition:.18s;font-weight:700;letter-spacing:.04em}
.askable:hover>.ask-btn{opacity:1;transform:none}
.ask-btn:hover{background:var(--signal-soft)}

/* ============ CHAT SIDEBAR ============ */
.chat{position:relative;display:flex;flex-direction:column;height:100%;border-left:1px solid var(--line);
  background:var(--bg-2);min-width:0;min-height:0;overflow:hidden}
/* draggable left-edge resize handle (desktop only; see @media(min-width:901px)).
   Hidden/inert by default — the desktop rule below shows it. */
.chat-resize{display:none;position:absolute;top:0;left:0;width:8px;height:100%;z-index:42;
  cursor:col-resize;transform:translateX(-4px);touch-action:none;
  background:transparent;transition:background .15s}
.chat-resize::before{content:"";position:absolute;top:0;left:4px;width:1px;height:100%;background:transparent}
.chat-resize:hover::before,.chat-resize.dragging::before{background:var(--signal)}
.chat-resize.dragging{background:color-mix(in srgb,var(--signal) 12%,transparent)}
.chat-toolbar{display:flex;align-items:center;gap:8px;height:52px;padding:0 14px;border-bottom:1px solid var(--line);
  background:var(--panel);flex:none}
.chat-toolbar .brand{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--signal);font-weight:600;white-space:nowrap;flex:none}
.chat-toolbar button{font-family:var(--mono);font-size:11.5px;background:var(--panel-2);color:var(--ink);
  border:1px solid var(--line);border-radius:8px;height:30px;padding:0 10px;box-sizing:border-box;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;cursor:pointer;transition:.18s}
.chat-toolbar button:hover{border-color:var(--signal);color:var(--paper)}
/* filterable session history — slides in over the chat body (no overflow) */
/* right-justify the control cluster (history · ＋New · ✕); brand stays left */
.session-picker{display:flex;flex:none;margin-left:auto}
#sessionBtn[aria-expanded="true"]{border-color:var(--signal);color:var(--paper)}
/* full-width overlay panel inside .chat, below the toolbar, covering the message body */
.session-panel{position:absolute;left:0;right:0;top:var(--chat-toolbar-h,49px);bottom:0;z-index:40;
  background:var(--bg-2);border-top:1px solid var(--line);
  display:flex;flex-direction:column;min-height:0;
  transform:translateY(-10px);opacity:0;pointer-events:none;
  transition:transform .22s cubic-bezier(.2,.7,.2,1),opacity .22s ease}
.session-panel[hidden]{display:none}
.session-panel.open{transform:translateY(0);opacity:1;pointer-events:auto}
.session-panel-head{display:flex;align-items:center;gap:8px;flex:none;
  padding:10px 12px;border-bottom:1px solid var(--line);background:var(--panel)}
.session-panel-title{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--signal);font-weight:600;flex:1;text-align:center}
.session-back,.session-close{font-family:var(--mono);font-size:13px;line-height:1;background:var(--panel-2);
  color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:6px 9px;cursor:pointer;
  transition:.18s;flex:none}
.session-back:hover,.session-close:hover{border-color:var(--signal);color:var(--paper)}
.session-filter{font-family:var(--mono);font-size:12px;background:var(--bg-2);color:var(--ink);
  border:0;border-bottom:1px solid var(--line);padding:10px 12px;outline:none;flex:none}
.session-filter::placeholder{color:var(--ink-faint)}
.session-list{list-style:none;margin:0;padding:6px;flex:1 1 auto;min-height:0;
  overflow-y:auto;overscroll-behavior:contain}
.session-item{display:flex;flex-direction:column;gap:2px;padding:7px 9px;border-radius:7px;cursor:pointer;outline:none}
.session-item:hover,.session-item:focus{background:rgba(255,255,255,.05)}
.session-item.active{background:color-mix(in srgb,var(--signal) 15%,transparent)}
.session-item.active .s-title{color:var(--paper)}
.session-item .s-title{font-size:12.5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.session-item .s-meta{font-family:var(--mono);font-size:10px;color:var(--ink-faint)}
.session-empty{padding:12px;text-align:center;color:var(--ink-faint);font-family:var(--mono);font-size:11.5px;list-style:none}
.chat-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;
  padding:18px 16px;display:flex;flex-direction:column;gap:14px}
.msg{display:flex;flex-direction:column;gap:6px;max-width:100%}
.msg .who{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.msg .bubble{font-size:14px;line-height:1.55;border-radius:12px;padding:11px 14px;white-space:pre-wrap;word-wrap:break-word}
.msg.user .who{color:var(--signal)}
.msg.user .bubble{background:var(--panel);border:1px solid var(--line)}
.msg.assistant .bubble{background:var(--panel-2);border:1px solid var(--line-soft);color:var(--ink);white-space:normal;margin-top:2px}
.msg .bubble b{color:var(--paper)}
/* rendered Markdown inside an assistant bubble */
.msg.assistant .bubble>:first-child{margin-top:0}
.msg.assistant .bubble>:last-child{margin-bottom:0}
.msg.assistant .bubble p{margin:0 0 8px}
.msg.assistant .bubble strong{color:var(--paper)}
.msg.assistant .bubble em{font-style:italic}
.msg.assistant .bubble h1,.msg.assistant .bubble h2,.msg.assistant .bubble h3,
.msg.assistant .bubble h4,.msg.assistant .bubble h5,.msg.assistant .bubble h6{
  font-family:var(--serif);color:var(--paper);font-weight:600;line-height:1.25;margin:14px 0 6px}
.msg.assistant .bubble h1{font-size:18px}.msg.assistant .bubble h2{font-size:16px}
.msg.assistant .bubble h3{font-size:15px}.msg.assistant .bubble h4,
.msg.assistant .bubble h5,.msg.assistant .bubble h6{font-size:14px}
.msg.assistant .bubble ul,.msg.assistant .bubble ol{margin:6px 0 8px;padding-left:20px}
.msg.assistant .bubble li{margin:2px 0}
.msg.assistant .bubble a{color:var(--signal-soft);text-decoration:underline;text-underline-offset:2px}
.msg.assistant .bubble code{font-family:var(--mono);font-size:12.5px;background:rgba(255,255,255,.06);
  border:1px solid var(--line-soft);border-radius:4px;padding:1px 5px}
.msg.assistant .bubble pre{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  padding:10px 12px;margin:8px 0;overflow-x:auto}
.msg.assistant .bubble pre code{background:none;border:0;padding:0;font-size:12.5px;white-space:pre;color:var(--ink)}
.msg.assistant .bubble blockquote{margin:8px 0;padding:2px 0 2px 12px;border-left:3px solid var(--line);
  color:var(--ink-dim)}
.msg.assistant .bubble hr{border:0;border-top:1px solid var(--line);margin:12px 0}
.msg.assistant .bubble .md-err{font-family:var(--mono);font-size:12px;color:var(--signal-soft);margin-top:6px}
.msg.assistant .bubble table{border-collapse:collapse;width:100%;margin:8px 0;font-size:12.5px;display:block;overflow-x:auto}
.msg.assistant .bubble th,.msg.assistant .bubble td{border:1px solid var(--line);padding:5px 9px;text-align:left;vertical-align:top}
.msg.assistant .bubble th{background:var(--bg-2);color:var(--paper);font-weight:600;font-family:var(--mono);
  font-size:11px;letter-spacing:.04em}
.msg.assistant .bubble tbody tr:nth-child(even){background:rgba(255,255,255,.025)}
.toolchips{display:flex;flex-wrap:wrap;gap:6px}
.toolchips:empty{display:none}   /* no chips (e.g. user turns) → no flex gap above the bubble */
.toolchip{font-family:var(--mono);font-size:10.5px;color:var(--ink-dim);background:rgba(255,92,40,.08);
  border:1px solid color-mix(in srgb,var(--signal) 30%,transparent);border-radius:999px;padding:3px 9px}
.toolchip .spin{display:inline-block;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* live activity log under a turn — see each tool call's args + result as it streams */
.toollog{margin-top:1px}   /* working trail sits above the final response now; flex gap handles separation */
.toollog>summary{cursor:pointer;list-style:none;font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-faint)}
.toollog>summary::-webkit-details-marker{display:none}
.toollog>summary::before{content:"▸ "}
.toollog[open]>summary::before{content:"▾ "}
.tl-body{margin-top:7px;display:grid;gap:8px;max-height:300px;overflow:auto;
  border-left:2px solid var(--line);padding-left:11px;font-family:var(--mono);font-size:11px}
.tl-row{display:grid;gap:3px}
.tl-call{color:var(--ink-dim);line-height:1.45;overflow-wrap:anywhere}
.tl-call b{color:var(--paper);font-weight:600}
.tl-call .tl-args{color:var(--ink-faint)}
.tl-call .spin{display:inline-block;animation:spin 1s linear infinite}
.tl-res{color:var(--ink-dim);white-space:pre-wrap;overflow-wrap:anywhere;line-height:1.5;
  background:var(--bg-2);border-radius:6px;padding:6px 9px;max-height:160px;overflow:auto}
.tl-res:empty{display:none}
.chat-empty{color:var(--ink-dim);font-size:13px;line-height:1.55;padding:18px 16px;font-family:var(--sans)}
.chat-empty b{color:var(--paper);display:block;margin-bottom:8px;font-family:var(--mono);font-size:12px;
  letter-spacing:.12em;text-transform:uppercase}
.chat-empty p{margin:0 0 14px}
.chat-empty strong{color:var(--paper);font-weight:600}
.chat-empty-hint{color:var(--ink-faint);font-size:12px;margin:14px 0 0}
.suggest-list{display:flex;flex-direction:column;gap:7px}
.suggest{display:block;width:100%;text-align:left;font-family:var(--sans);font-size:12.5px;color:var(--ink);
  background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;cursor:pointer;
  transition:.15s;line-height:1.4}
.suggest:hover{border-color:var(--signal);color:var(--paper);background:var(--panel)}
.ctx-chip{margin:0 16px 8px;font-family:var(--mono);font-size:11px;color:var(--ink-dim);background:var(--panel);
  border:1px solid var(--line);border-radius:8px;padding:8px 11px;display:flex;gap:8px;align-items:center}
.ctx-chip .clr{margin-left:auto;cursor:pointer;color:var(--ink-faint)}
.ctx-chip .clr:hover{color:var(--signal)}
.composer{border-top:1px solid var(--line);padding:12px 14px;background:var(--panel);display:flex;gap:9px;align-items:flex-end}
.composer textarea{flex:1;resize:none;font-family:var(--sans);font-size:14px;background:var(--panel-2);
  color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:10px 12px;max-height:150px;line-height:1.5}
.composer textarea:focus{outline:none;border-color:var(--signal)}
.composer button{font-family:var(--mono);font-size:12px;font-weight:600;background:var(--signal);color:#0b0d10;
  border:none;border-radius:10px;padding:11px 15px;cursor:pointer;transition:.18s}
.composer button:hover{background:var(--signal-soft)}
.composer button:disabled{opacity:.45;cursor:default}

/* ---- desktop docked panel toggles (collapse/expand TOC + chat) ---- */
/* hidden by default (and on mobile); only the relevant one shows on desktop
   when its panel is collapsed, so it stays reachable to reopen the panel. */
.dock-toggle{position:absolute;top:14px;z-index:8;display:none;align-items:center;justify-content:center;
  width:36px;height:36px;color:var(--ink-dim);background:rgba(15,18,23,.82);border:1px solid var(--line);
  border-radius:9px;cursor:pointer;backdrop-filter:blur(4px);transition:.18s}
.dock-toggle:hover{color:var(--paper);border-color:var(--signal)}
.dock-toc{left:14px}
.dock-chat{right:14px}

/* mobile drawer: FAB to open, close button + backdrop to dismiss */
.chat-fab{position:fixed;right:16px;bottom:16px;z-index:60;display:none;align-items:center;gap:7px;
  font-family:var(--mono);font-size:13px;font-weight:700;color:#0b0d10;background:var(--signal);
  border:none;border-radius:999px;padding:13px 18px;box-shadow:0 8px 30px rgba(0,0,0,.55);cursor:pointer}
.chat-fab:active{transform:scale(.96)}
.toc-fab{position:fixed;left:16px;bottom:16px;z-index:60;display:none;align-items:center;gap:7px;
  font-family:var(--mono);font-size:13px;font-weight:700;color:#0b0d10;background:var(--signal);
  border:none;border-radius:999px;padding:13px 16px;box-shadow:0 8px 30px rgba(0,0,0,.55);cursor:pointer}
.toc-fab:active{transform:scale(.96)}
/* inherits height/padding/flex from `.chat-toolbar button`; only the glyph size differs */
.chat-close{background:var(--panel-2);color:var(--ink);
  border:1px solid var(--line);border-radius:8px;font-family:var(--mono);font-size:13px;cursor:pointer}
.chat-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:45;opacity:0;pointer-events:none;
  transition:opacity .28s}

@media(max-width:900px){
  .app{grid-template-columns:1fr;height:100dvh}
  .report-pane{width:100vw}
  .chat{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(92vw,420px);z-index:50;
    transform:translateX(101%);transition:transform .3s cubic-bezier(.2,.7,.2,1);
    box-shadow:-24px 0 60px rgba(0,0,0,.6)}
  .app.chat-open .chat{transform:translateX(0)}
  .app.chat-open .chat-backdrop{opacity:1;pointer-events:auto}
  .chat-fab{display:flex}
  .app.chat-open .chat-fab{display:none}
  .chat-close{display:inline-flex;align-items:center}
  /* TOC becomes a left slide-in drawer (page list is otherwise unreachable on mobile).
     Use `.app .toc` specificity to beat the later base `.toc{display:none}` rule.
     The icon rail is desktop-only — mobile always shows the full inner (brand + tree),
     even if the desktop `toc-collapsed` state happens to be persisted. */
  .app .toc{display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;height:100dvh;
    width:min(86vw,330px);z-index:50;
    transform:translateX(-101%);transition:transform .3s cubic-bezier(.2,.7,.2,1);
    box-shadow:24px 0 60px rgba(0,0,0,.6)}
  .app .toc-inner{display:flex}
  .app .toc-rail{display:none}
  /* mobile drawer: no in-drawer collapse toggle (use the backdrop/Pages button) */
  .app .toc-collapse{display:none}
  /* the app-bar button opens the drawer on mobile (the "Pages" affordance) — always
     visible since it's the only way to reach the TOC drawer */
  .appbar .ab-expand{display:inline-flex}
  /* Ask Trey opens the chat drawer; hide it only while that drawer is already open */
  .ab-ask{display:inline-flex}
  .app.chat-open .ab-ask{display:none}
  .app.toc-open .toc{transform:translateX(0)}
  .app.toc-open .chat-backdrop{opacity:1;pointer-events:auto}
  .toc-fab{display:flex}
  .app.toc-open .toc-fab,.app.chat-open .toc-fab{display:none}
  .dock-toggle{display:none !important}  /* desktop-only docked toggles */
}

/* ============ charts on findings (inline, no lib) ============ */
.chart{border-top:1px solid var(--line-soft);padding:14px 19px 16px;background:var(--bg-2)}
.chart-title{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:11px}
.cbars{display:grid;gap:7px}
.cbar-row{display:grid;grid-template-columns:minmax(64px,32%) 1fr auto;align-items:center;gap:10px}
.cbar-lbl{font-family:var(--mono);font-size:11px;color:var(--ink-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cbar-track{height:10px;background:var(--panel-2);border-radius:3px;overflow:hidden}
.cbar-fill{display:block;height:100%;border-radius:3px;min-width:2px}
.cbar-val{font-family:var(--mono);font-size:11.5px;color:var(--paper);font-weight:600;text-align:right}
.cdonut{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.clegend{display:grid;gap:6px;font-family:var(--mono);font-size:11.5px;color:var(--ink-dim)}
.cleg{display:flex;align-items:center;gap:8px}
.cdot{width:10px;height:10px;border-radius:3px;flex:none}
.cleg b{color:var(--paper);font-weight:600}.cpct{color:var(--ink-faint)}
.cline svg{display:block}
.cline-x{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--ink-faint);margin-top:5px}

/* collapsed SQL behind a details/summary (non-technical readers see graph + meaning) */
.qdetails{border-top:1px solid var(--line-soft)}
.qdetails>summary{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);padding:9px 19px;cursor:pointer;list-style:none;user-select:none}
.qdetails>summary::-webkit-details-marker{display:none}
.qdetails>summary::before{content:"▸";color:var(--clr);margin-right:7px;display:inline-block;transition:transform .15s}
.qdetails[open]>summary::before{transform:rotate(90deg)}
.qdetails>summary:hover{color:var(--ink-dim)}
.qdetails .qrow{border-top:1px solid var(--line-soft)}

/* ============ left table-of-contents sidebar ============
   Full-height column (grid-row 1/-1) to the LEFT of the app bar. */
.toc{display:none;position:relative;z-index:41;grid-column:1;grid-row:1/-1;
  border-right:1px solid var(--line);background:var(--bg-2);overflow-y:auto;
  display:flex;flex-direction:column}
.toc-inner{display:flex;flex-direction:column;min-height:100%;padding:0 18px 22px}
.toc h6{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);margin:0 0 14px;font-weight:600}

/* ---- sidebar brand header (replaces the old "Contents" head) ---- */
.toc-brandhead{display:flex;align-items:center;gap:10px;height:52px;flex:none;
  margin:0 -18px 14px;padding:0 16px 0 18px;border-bottom:1px solid var(--line-soft)}
.toc-brand{display:flex;align-items:baseline;gap:8px;flex:1;min-width:0;
  font-family:var(--serif);font-weight:700;font-size:18px;color:var(--paper);line-height:1}
.toc-brand small{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500}
.toc-collapse{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;flex:none;
  color:var(--ink-faint);background:none;border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:.18s}
.toc-collapse:hover{color:var(--paper);border-color:var(--signal)}
.toc-collapse svg{display:block}

/* ---- collapsed icon rail (desktop) ---- */
.toc-rail{display:none;flex-direction:column;align-items:center;gap:8px;padding:11px 0;height:100%}
.toc-rail .rail-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;
  color:var(--ink-dim);background:none;border:1px solid transparent;border-radius:9px;cursor:pointer;transition:.18s}
.toc-rail .rail-btn:hover{color:var(--paper);border-color:var(--signal);background:var(--panel)}
.toc-rail .rail-btn.active{color:var(--signal)}
.toc-rail .rail-spacer{flex:1}
.toc-rail svg{display:block}
.toc .toc-sec{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--sans);
  font-size:13.5px;color:var(--ink-dim);padding:8px 10px;border-radius:8px;border-left:2px solid transparent;transition:.18s}
.toc .toc-sec:hover{color:var(--paper);background:var(--panel)}
.toc .toc-sec .n{font-family:var(--mono);font-size:10px;color:var(--ink-faint);margin-right:8px}
.toc .toc-roles{margin:3px 0 8px}
.toc .toc-role{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--mono);font-size:12px;color:var(--ink-faint);padding:6px 10px 6px 16px;border-radius:7px;
  border-left:2px solid transparent;transition:.18s}
.toc .toc-role:hover{color:var(--paper);background:var(--panel)}
.toc .toc-role .dot{width:8px;height:8px;border-radius:50%;background:var(--clr);flex:none}
.toc .toc-role.active{color:var(--paper);background:var(--panel);border-left-color:var(--clr)}
.toc-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft)}
.toc-foot-meta{margin-top:12px;font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);line-height:1.6}
.toc-history{display:inline-flex;align-items:center;gap:8px;width:100%;background:var(--panel-2);color:var(--ink-dim);
  border:1px solid var(--line);border-radius:8px;padding:7px 11px;cursor:pointer;
  font-family:var(--mono);font-size:11.5px;font-weight:600;letter-spacing:.02em;
  transition:border-color .15s,color .15s}
.toc-history:hover{border-color:var(--signal);color:var(--paper)}
.toc-history svg{display:block;flex:none}
/* signed-in account, pinned in the sidebar footer: identity row + ⋮ submenu */
.toc-acct{position:relative;margin-top:14px;padding-top:12px;border-top:1px solid var(--line-soft)}
.toc-acct-id{display:flex;align-items:center;gap:9px;padding:0 2px}
.toc-avatar{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  background:var(--signal);color:#0b0d10;font:700 12px var(--mono);flex:none}
.toc-acct-name{flex:1;min-width:0;display:flex;flex-direction:column;color:var(--ink);font-size:13px;font-weight:600;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.toc-acct-name small{font:500 9.5px var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:2px}
.toc-acct-kebab{flex:none;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;
  border-radius:7px;background:none;border:1px solid transparent;color:var(--ink-dim);cursor:pointer}
.toc-acct-kebab:hover,.toc-acct-kebab[aria-expanded="true"]{border-color:var(--line);color:var(--paper)}
.toc-acct-kebab svg{display:block}
/* the submenu drops UP (the account sits at the sidebar's bottom edge) */
.toc-acct-menu{position:absolute;right:2px;bottom:calc(100% - 4px);min-width:184px;z-index:70;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:0 16px 40px rgba(0,0,0,.5);
  padding:6px;display:flex;flex-direction:column;gap:2px}
.toc-acct-menu[hidden]{display:none}
.acct-menu-head{display:flex;flex-direction:column;gap:2px;padding:6px 10px 8px;margin-bottom:4px;
  border-bottom:1px solid var(--line-soft)}
.acct-menu-head b{color:var(--ink);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-menu-head span{color:var(--ink-faint);font:10.5px var(--mono);letter-spacing:.03em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-mi{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;
  color:var(--ink);font:13px var(--sans);padding:8px 10px;border-radius:6px;cursor:pointer}
.acct-mi:hover{background:var(--panel-2)}
.acct-mi svg{display:block;flex:none;color:var(--ink-dim)}
.acct-mi-danger{color:var(--signal-soft)}
.acct-mi-danger svg{color:var(--signal-soft)}

/* ---- Overview tree: collapsible root whose children are the report sections ---- */
.toc-node{display:flex;align-items:stretch;gap:2px}
.toc-node .toc-caret{flex:none;width:22px;display:inline-flex;align-items:center;justify-content:center;
  background:none;border:0;color:var(--ink-faint);font-size:11px;cursor:pointer;border-radius:7px;
  transition:transform .15s,color .15s;align-self:center;height:30px}
.toc-node .toc-caret:hover{color:var(--paper)}
.toc-node .toc-caret.open{transform:rotate(90deg)}
.toc-node .toc-caret[disabled]{opacity:0;cursor:default;pointer-events:none}
.toc-node .toc-root{flex:1;min-width:0}
/* the section subtree (children of Overview): hidden unless .open, indented a level */
.toc-subtree{display:none;margin:2px 0 4px 22px;padding-left:8px;border-left:1px solid var(--line-soft)}
.toc-subtree.open{display:block}
/* roles sit a further level in, under Stakeholders */
.toc-subtree .toc-roles{margin:2px 0 6px 6px}
.toc-subtree .toc-role{padding-left:14px}

/* ---- desktop layout + collapse states (≥901px; separate from the mobile drawer) ----
   On desktop the sidebar is a real grid column (full height in col 1). When the
   sidebar is collapsed it shrinks to a thin icon RAIL (it is never fully hidden);
   the app-bar then shows the D.A. brand + an expand toggle. */
@media(min-width:901px){
  :root{--rail-w:54px}
  /* sidebar full-height in column 1; app bar over the content columns only */
  .app{grid-template-columns:240px 1fr var(--chat-w);grid-template-rows:52px 1fr}
  .toc{display:flex}
  /* the left-edge resize handle is a desktop affordance only */
  .chat-resize{display:block}
  /* app bar covers ONLY the report column — between the TOC (col 1) and the
     full-height chat (col 3); both sidebars are level with it, never under it */
  .appbar{grid-column:2/3;grid-row:1}
  .report-pane{grid-column:2;grid-row:2}
  /* chat is a full-height right sidebar mirroring the TOC (top→bottom of viewport) */
  .chat{grid-column:3;grid-row:1/-1}

  /* sidebar collapsed → thin icon rail (show rail markup, hide the full inner) */
  .app.toc-collapsed{grid-template-columns:var(--rail-w) 1fr var(--chat-w)}
  .app.toc-collapsed .toc-inner{display:none}
  .app.toc-collapsed .toc-rail{display:flex}
  /* app-bar brand + separator appear only when the sidebar is collapsed to a rail.
     The TOC toggle (.ab-expand) is NEVER shown in the app bar on desktop: when the
     sidebar is open its brand-header carries the collapse toggle, and when collapsed
     the rail's own top toggle reopens it — so the app-bar one is always redundant. */
  .app.toc-collapsed .ab-brand{display:flex}
  .app.toc-collapsed .ab-sep{display:inline}
  .ab-expand{display:none}

  /* chat can be collapsed at any desktop width; drop its column */
  .app.chat-collapsed{grid-template-columns:240px 1fr}
  .app.chat-collapsed .chat{display:none}
  .app.chat-collapsed.toc-collapsed{grid-template-columns:var(--rail-w) 1fr}

  /* Ask Trey app-bar button is a RE-OPEN affordance only: shown when the chat is
     collapsed, hidden when the docked chat is open (it has its own ✕ / Esc). */
  .ab-ask{display:none}
  .app.chat-collapsed .ab-ask{display:inline-flex}
}

/* slightly narrower sidebar + chat in the 901–1200 range to keep the report roomy */
@media(min-width:901px) and (max-width:1200px){
  .app{grid-template-columns:212px 1fr var(--chat-w)}
  .app.chat-collapsed{grid-template-columns:212px 1fr}
}

/* ============ WIKI PAGES (additive companion docs) ============ */
/* TOC: the page switcher (Overview home + generated pages) */
.toc-pages{display:flex;flex-direction:column;gap:2px;margin:2px 0 6px}
.toc-page{display:flex;align-items:center;gap:9px;width:100%;text-align:left;
  background:none;border:0;color:var(--ink-dim);font:inherit;font-size:13px;
  padding:7px 10px;border-radius:8px;cursor:pointer;border-left:2px solid transparent}
.toc-page:hover{background:var(--panel-2);color:var(--ink)}
.toc-page.active{background:var(--panel-2);color:var(--ink);border-left-color:var(--signal)}
.toc-page .pg-ico{font-size:12px;color:var(--ink-faint);width:14px;text-align:center}
.toc-page.active .pg-ico{color:var(--signal)}
.toc-page .pg-del{margin-left:auto;opacity:0;color:var(--ink-faint);font-size:12px;
  padding:0 4px;border-radius:4px}
.toc-page:hover .pg-del{opacity:.7}
.toc-page .pg-del:hover{opacity:1;color:var(--signal)}

/* page header in the report pane */
.page-head{margin:8px 0 30px}
.page-head .page-kicker{font-family:var(--mono);font-size:11.5px;color:var(--signal);
  letter-spacing:.2em;text-transform:uppercase}
.page-head h1{font-family:var(--serif,Fraunces,serif);font-size:clamp(30px,5vw,46px);
  line-height:1.04;margin:14px 0 0;font-weight:600}
.page-head .page-summary{color:var(--ink-dim);max-width:680px;margin:16px 0 0;line-height:1.5}
/* the back link is rendered as a sibling BEFORE .page-head, so scope it directly
   (not as a .page-head descendant) or it falls back to the default browser button */
.page-back{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px;
  font-family:var(--mono);font-size:12px;color:var(--ink-faint);background:none;border:0;
  cursor:pointer;padding:0}
.page-back:hover{color:var(--signal)}
/* "Refresh all" + last-refreshed stamp (shown only when the page has re-runnable data) */
.page-refresh{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:20px 0 0}
.page-refresh-all{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;
  letter-spacing:.04em;color:var(--ink-dim);background:var(--panel-2);border:1px solid var(--line);
  border-radius:8px;padding:7px 12px;cursor:pointer;transition:.18s}
.page-refresh-all:hover{color:var(--paper);border-color:var(--signal)}
.page-refresh-all.busy{opacity:.7;pointer-events:none}
.page-refresh-all .ref-ico{display:inline-block;line-height:1}
.page-refresh-all.busy .ref-ico{animation:spin .8s linear infinite}
.page-refresh-ts{font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--ink-faint)}

.page-blocks{display:flex;flex-direction:column;gap:20px}
.pblock{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 24px;position:relative}
/* loading state while a data block re-runs its query (can take seconds for GraphQL) */
.pblock.refreshing{pointer-events:none}
.pblock.refreshing::after{content:"";position:absolute;inset:0;border-radius:inherit;z-index:5;
  background:color-mix(in srgb,var(--panel) 60%,transparent)}
.pblock.refreshing::before{content:"";position:absolute;top:calc(50% - 12px);left:calc(50% - 12px);
  width:24px;height:24px;z-index:6;border-radius:50%;
  border:2px solid var(--line);border-top-color:var(--signal);animation:spin .8s linear infinite}
.pblock.prose{background:none;border:0;padding:4px 0}
.pblock h3.pb-title{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-faint);margin:0 0 14px;font-weight:600;
  display:flex;align-items:center;gap:10px}
.pblock .pb-prose{color:var(--ink);line-height:1.6}
.pblock .pb-prose p{margin:0 0 12px}
.pblock .pb-prose a{color:var(--signal);text-decoration:none;border-bottom:1px solid rgba(255,92,40,.4)}
.pblock .pb-prose a:hover{border-bottom-color:var(--signal)}

/* finding block (evidence-card flavor) */
.pblock.finding .pb-claim{font-size:16px;line-height:1.45;color:var(--ink);margin:0 0 12px}
.pblock .pb-resimp{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:6px}
@media(max-width:560px){.pblock .pb-resimp{grid-template-columns:1fr}}
.pblock .pb-resimp .rlbl,.pblock .pb-resimp .ilbl{font-family:var(--mono);font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:5px}
.pblock .pb-resimp .rval{color:var(--ink);font-size:14px}
.pblock .pb-resimp .imp{color:var(--ink-dim);font-size:14px;line-height:1.5}

/* data table */
.pb-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:10px}
table.pb-table{width:100%;border-collapse:collapse;font-size:13px}
table.pb-table th,table.pb-table td{padding:9px 14px;text-align:left;border-bottom:1px solid var(--line-soft);
  white-space:nowrap}
table.pb-table thead th{font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-faint);cursor:pointer;user-select:none;position:sticky;top:0;
  background:var(--panel-2)}
table.pb-table thead th:hover{color:var(--ink)}
table.pb-table thead th .sort-ind{color:var(--signal);margin-left:6px;font-size:10px}
table.pb-table tbody tr:hover{background:var(--panel-2)}
table.pb-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.pb-empty{color:var(--ink-faint);font-size:13px;padding:14px;font-style:italic}

/* source-reference affordance + refresh */
.pb-tools{margin-left:auto;display:flex;align-items:center;gap:8px}
.pb-src,.pb-refresh{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;
  background:var(--panel-2);border:1px solid var(--line);color:var(--ink-faint);
  border-radius:7px;padding:4px 9px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.pb-src:hover,.pb-refresh:hover{color:var(--ink);border-color:var(--ink-faint)}
.pb-refresh.busy{opacity:.7;pointer-events:none}
.pb-refresh .ref-ico{display:inline-block;line-height:1}
.pb-refresh.busy .ref-ico{animation:spin .8s linear infinite}
.pb-src.no-src{cursor:default;opacity:.5}
.pb-source{margin-top:14px;border-top:1px dashed var(--line);padding-top:12px;display:none}
.pblock.show-src .pb-source{display:block}
.pb-source .qrow{font-family:var(--mono);font-size:12px;color:var(--ink-dim);
  background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;padding:10px 12px;
  white-space:pre-wrap;word-break:break-word}
.pb-source .ev-ref{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:8px;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pb-source .refreshed{font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);margin-top:8px}

/* ---- table pagination ("showing N of M") ---- */
.pb-pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-top:10px;font-family:var(--mono);font-size:11px;color:var(--ink-faint)}
.pb-pager .pb-count{letter-spacing:.04em}
.pb-pgbtns{display:flex;align-items:center;gap:4px}
.pb-pgnum{padding:0 6px;color:var(--ink-dim)}
.pb-pg{font-family:var(--mono);font-size:12px;background:var(--panel-2);border:1px solid var(--line);
  color:var(--ink-dim);border-radius:6px;min-width:24px;padding:3px 7px;cursor:pointer;line-height:1}
.pb-pg:hover:not([disabled]){color:var(--ink);border-color:var(--ink-faint)}
.pb-pg[disabled]{opacity:.35;cursor:default}

/* ---- in-UI block controls (reorder + inline prose edit) ---- */
.pb-edit,.pb-move{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;
  background:var(--panel-2);border:1px solid var(--line);color:var(--ink-faint);
  border-radius:7px;padding:4px 8px;cursor:pointer;line-height:1}
.pb-edit:hover:not([disabled]),.pb-move:hover:not([disabled]){color:var(--ink);border-color:var(--ink-faint)}
.pb-move{padding:4px 7px}
.pb-move[disabled]{opacity:.3;cursor:default}
.pb-evidence{font-family:var(--mono);font-size:10px;background:var(--panel-2);border:1px solid var(--line);
  color:var(--ink-faint);border-radius:6px;padding:2px 7px;cursor:pointer}
.pb-evidence:hover{color:var(--signal);border-color:var(--signal)}
.pb-evidence.busy{opacity:.6;pointer-events:none}
.pb-evidence-out:empty{display:none}
.ev-card{margin-top:10px;border:1px solid var(--line-soft);border-radius:8px;padding:10px 12px;background:var(--bg-2)}
.ev-card .ev-meta{font-family:var(--mono);font-size:10px;color:var(--ink-faint);letter-spacing:.06em;margin-bottom:6px}
.ev-card .ev-rc{font-family:var(--mono);font-size:10.5px;color:var(--ink-dim);margin-top:6px}
.ev-card .ev-sample{font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin:8px 0 0;
  max-height:220px;overflow:auto;white-space:pre-wrap;word-break:break-word}
.ev-miss{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:8px}

/* prose block head (title + inline-edit/reorder tools) */
.pb-prose-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pb-prose-title{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:600}
.pblock.prose .pb-tools{margin-left:auto;opacity:0;transition:opacity .12s}
.pblock.prose:hover .pb-tools{opacity:1}
.pb-prose-edit{margin-top:6px}
.pb-prose-ta{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font:inherit;font-size:14px;line-height:1.55;padding:10px 12px;resize:vertical}
.pb-prose-actions{display:flex;gap:8px;margin-top:8px}
.pb-prose-save,.pb-prose-cancel{font-family:var(--mono);font-size:11px;border-radius:7px;padding:5px 12px;cursor:pointer}
.pb-prose-save{background:var(--signal);border:1px solid var(--signal);color:#1a0f08;font-weight:600}
.pb-prose-cancel{background:var(--panel-2);border:1px solid var(--line);color:var(--ink-dim)}
.pb-prose-cancel:hover{color:var(--ink)}

/* ---- "what links here" (backlinks footer) ---- */
.pb-backlinks{margin-top:26px;border-top:1px dashed var(--line);padding-top:16px}
.pb-backlinks .bl-head{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:10px}
.pb-backlinks .bl-list{display:flex;flex-wrap:wrap;gap:8px}
.pb-backlinks .bl-link{font-size:13px;color:var(--signal);text-decoration:none;background:var(--panel);
  border:1px solid var(--line);border-radius:999px;padding:5px 13px}
.pb-backlinks .bl-link:hover{border-color:var(--signal)}

/* ---- TOC page reorder buttons ---- */
.toc-page .pg-reorder{display:none;margin-left:auto;gap:2px}
.toc-page:hover .pg-reorder{display:inline-flex}
.toc-page .pg-up,.toc-page .pg-down{color:var(--ink-faint);font-size:11px;padding:0 3px;border-radius:4px;cursor:pointer}
.toc-page .pg-up:hover,.toc-page .pg-down:hover{color:var(--signal)}
.toc-page .pg-up.off,.toc-page .pg-down.off{opacity:.25;cursor:default}
.toc-page:hover .pg-del{margin-left:4px}

/* ============ version history (TOC-footer trigger + modal) ============ */
.hist-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:24px}
.hist-modal[hidden]{display:none}
.hist-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.hist-panel{position:relative;z-index:1;width:min(780px,94vw);max-height:84vh;display:flex;flex-direction:column;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.hist-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.hist-head h3{font-family:var(--serif);font-size:20px;color:var(--paper);margin:0;font-weight:600}
.hist-x{background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:6px 10px;
  cursor:pointer;font-family:var(--mono);font-size:13px}
.hist-x:hover{border-color:var(--signal);color:var(--paper)}
.hist-note{padding:12px 20px;font-size:12.5px;color:var(--ink-faint);border-bottom:1px solid var(--line-soft);line-height:1.5}
.hist-list{overflow-y:auto;padding:4px 0}
.hist-item{border-bottom:1px solid var(--line-soft)}
.hist-row{display:flex;align-items:center;gap:12px;padding:11px 20px;cursor:pointer}
.hist-row:hover{background:var(--panel-2)}
.hist-auth{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;flex:none;border:1px solid;min-width:44px;text-align:center}
.auth-trey{color:var(--signal);border-color:color-mix(in srgb,var(--signal) 40%,transparent);background:color-mix(in srgb,var(--signal) 12%,transparent)}
.auth-you{color:#6fd3b6;border-color:color-mix(in srgb,#6fd3b6 40%,transparent);background:color-mix(in srgb,#6fd3b6 12%,transparent)}
.auth-system{color:var(--ink-faint);border-color:var(--line);background:var(--panel-2)}
.hist-subj{flex:1;min-width:0;font-size:13.5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hist-time{font-family:var(--mono);font-size:11px;color:var(--ink-faint);flex:none}
.hist-restore{font-family:var(--mono);font-size:11px;font-weight:600;background:var(--panel-2);color:var(--ink-dim);
  border:1px solid var(--line);border-radius:7px;padding:5px 9px;cursor:pointer;flex:none}
.hist-restore:hover{border-color:var(--signal);color:var(--signal)}
.hist-diff{margin:0;padding:12px 20px;background:var(--bg-2);border-top:1px solid var(--line-soft);
  font-family:var(--mono);font-size:11px;color:#cdd5e0;white-space:pre;overflow:auto;max-height:340px}
.hist-empty{padding:26px 20px;color:var(--ink-faint);font-family:var(--mono);font-size:13px;text-align:center}

/* ---------- toasts (transient error/success/info notices) ---------- */
#toasts{position:fixed;right:16px;bottom:16px;z-index:9000;display:flex;flex-direction:column;gap:10px;
  max-width:min(380px,calc(100vw - 32px));pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:12px 12px 12px 14px;
  background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-left:3px solid var(--ink-faint);
  border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.45);font-size:13.5px;line-height:1.45;
  opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}
.toast.in{opacity:1;transform:translateY(0)}
.toast.leaving{opacity:0;transform:translateY(10px)}
.toast-msg{flex:1;min-width:0;word-break:break-word}
.toast-x{flex:none;background:none;border:none;color:var(--ink-faint);cursor:pointer;font-size:13px;
  line-height:1;padding:2px 2px 0;margin-left:2px}
.toast-x:hover{color:var(--ink)}
.toast-error{border-left-color:var(--signal)}
.toast-error .toast-msg{color:var(--ink)}
.toast-success{border-left-color:var(--high)}
.toast-info{border-left-color:var(--medium)}
@media(max-width:560px){#toasts{left:16px;right:16px;max-width:none}}

/* ============ MCP servers panel ============ */
#tocMcpBtn{margin-top:8px}
.mcp-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:24px}
.mcp-modal[hidden]{display:none}
.mcp-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.mcp-panel{position:relative;z-index:1;width:min(640px,94vw);max-height:88vh;display:flex;flex-direction:column;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.mcp-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.mcp-head h3{font-family:var(--serif);font-size:20px;color:var(--paper);margin:0;font-weight:600}
.mcp-x{background:none;border:none;color:var(--ink-faint);font-size:18px;cursor:pointer;line-height:1}
.mcp-x:hover{color:var(--paper)}
.mcp-note{padding:12px 20px;font-size:12.5px;color:var(--ink-faint);border-bottom:1px solid var(--line-soft);line-height:1.5}
.mcp-note b{color:var(--ink-dim)}
.mcp-list{overflow-y:auto;padding:8px 16px;display:flex;flex-direction:column;gap:8px}
.mcp-empty{padding:20px;text-align:center;color:var(--ink-faint);font-size:13px}
.mcp-item{border:1px solid var(--line-soft);border-radius:10px;padding:10px 12px;background:var(--bg-2)}
.mcp-item.locked{border-style:dashed;opacity:.92}
.mcp-row{display:flex;align-items:center;gap:8px}
.mcp-name{font-weight:600;color:var(--ink);font-size:13.5px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mcp-builtin{font-family:var(--mono);font-size:9.5px;color:var(--signal);border:1px solid var(--signal);border-radius:5px;padding:1px 5px;font-weight:600}
.mcp-type{font-family:var(--mono);font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em}
.mcp-badge{font-family:var(--mono);font-size:9.5px;border-radius:5px;padding:1px 6px;font-weight:600}
.mcp-badge.on{color:#0b0d10;background:var(--signal)}
.mcp-badge.off{color:var(--ink-faint);border:1px solid var(--line)}
.mcp-where{font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin-top:5px;word-break:break-all}
.mcp-actions{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.mcp-actions button{background:var(--panel-2);color:var(--ink-dim);border:1px solid var(--line);border-radius:7px;
  font-family:var(--mono);font-size:11.5px;font-weight:600;padding:4px 10px;cursor:pointer}
.mcp-actions button:hover{border-color:var(--signal);color:var(--paper)}
.mcp-del:hover{border-color:#e0533a !important;color:#ff8c72 !important}
.mcp-toggle{display:inline-flex;align-items:center;cursor:pointer}
.mcp-toggle input{accent-color:var(--signal);cursor:pointer}
.mcp-status{margin-top:8px;font-family:var(--mono);font-size:11px;line-height:1.5;color:var(--ink-faint);
  border-top:1px dashed var(--line-soft);padding-top:7px;word-break:break-word}
.mcp-status.ok{color:#7fd49a}.mcp-status.err{color:#ff8c72}
.mcp-add-btn{margin:6px 16px 14px;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);
  border-radius:8px;font-family:var(--mono);font-size:12.5px;font-weight:600;padding:9px;cursor:pointer}
.mcp-add-btn:hover{border-color:var(--signal);color:var(--paper)}
.mcp-form{border-top:1px solid var(--line);padding:14px 20px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:11px}
.mcp-form[hidden]{display:none}
.mcp-form-head{font-family:var(--serif);font-size:15px;color:var(--paper);font-weight:600}
.mcp-field{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em}
.mcp-field input,.mcp-field select,.mcp-kv-row input,.mcp-arg-row input{
  font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--bg-2);border:1px solid var(--line);
  border-radius:7px;padding:8px 10px;text-transform:none;letter-spacing:0}
.mcp-field input:focus,.mcp-field select:focus,.mcp-kv-row input:focus,.mcp-arg-row input:focus{outline:none;border-color:var(--signal)}
.mcp-kv-head{font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.mcp-kv,.mcp-args{display:flex;flex-direction:column;gap:6px}
.mcp-kv-row,.mcp-arg-row{display:flex;gap:6px;align-items:center}
.mcp-kv-row .mcp-kv-k{flex:0 0 34%}.mcp-kv-row .mcp-kv-v{flex:1}.mcp-arg-row .mcp-arg-v{flex:1}
.mcp-kv-del{flex:none;background:none;border:1px solid var(--line);color:var(--ink-faint);border-radius:6px;
  width:30px;height:30px;cursor:pointer;font-size:13px}
.mcp-kv-del:hover{border-color:#e0533a;color:#ff8c72}
.mcp-kv-add{align-self:flex-start;background:none;border:1px dashed var(--line);color:var(--ink-dim);
  border-radius:7px;font-family:var(--mono);font-size:11px;padding:5px 10px;cursor:pointer}
.mcp-kv-add:hover{border-color:var(--signal);color:var(--paper)}
.mcp-net[hidden],.mcp-stdio[hidden]{display:none}
.mcp-net,.mcp-stdio{display:flex;flex-direction:column;gap:9px}
.mcp-enable{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-dim);cursor:pointer}
.mcp-enable input{accent-color:var(--signal)}
.mcp-form-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:4px}
.mcp-cancel,.mcp-save{font-family:var(--mono);font-size:12.5px;font-weight:600;border-radius:8px;padding:8px 16px;cursor:pointer}
.mcp-cancel{background:var(--panel-2);color:var(--ink-dim);border:1px solid var(--line)}
.mcp-cancel:hover{border-color:var(--signal);color:var(--paper)}
.mcp-save{background:var(--signal);color:#0b0d10;border:1px solid var(--signal)}
.mcp-save:hover{background:var(--signal-soft);border-color:var(--signal-soft)}
.mcp-form-err{color:#ff8c72;font-size:12.5px;font-family:var(--mono);background:rgba(224,83,58,.08);
  border:1px solid rgba(224,83,58,.4);border-radius:7px;padding:8px 10px}
.mcp-form-err[hidden]{display:none}
.mcp-lock{font-size:10px}

.toolchip.thinking{color:var(--ink-faint);font-style:italic}

/* ============ Auth: gate overlay, user menu, users admin ============ */
/* Full-screen sign-in / first-run bootstrap. Sits above everything until the
   user is authenticated; the rest of the app boots only behind it. */
.auth-gate{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:24px;background:radial-gradient(120% 120% at 50% 0,var(--bg-2),var(--bg));}
.auth-card{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:28px 26px;box-shadow:0 24px 60px rgba(0,0,0,.45);}
.auth-brand{font-family:var(--serif);font-weight:700;font-size:22px;color:var(--paper);margin-bottom:18px}
.auth-brand small{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);margin-left:8px}
.auth-title{font-family:var(--serif);font-size:21px;color:var(--ink);margin:0 0 4px}
.auth-sub{font-size:13px;color:var(--ink-dim);margin:0 0 18px}
/* the `hidden` attribute must win over these display rules (same guard the other
   modals use) — without it the gate shows before JS wires the form (so a click
   does a native GET reload) and can't be dismissed after a successful login. */
.auth-gate[hidden],.users-modal[hidden],.auth-field[hidden]{display:none}
.auth-field{display:block;margin-bottom:13px}
.auth-field>span{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:5px}
.auth-field input{width:100%;box-sizing:border-box;background:var(--bg-2);border:1px solid var(--line);
  border-radius:8px;color:var(--ink);font:14px/1.3 var(--sans);padding:10px 11px}
.auth-field input:focus{outline:none;border-color:var(--signal)}
.auth-err{font-size:12.5px;color:#ff8c6b;background:rgba(255,92,40,.08);border:1px solid rgba(255,92,40,.3);
  border-radius:7px;padding:8px 10px;margin-bottom:12px}
.auth-submit{width:100%;background:var(--signal);color:#0b0d10;border:none;border-radius:8px;
  font:600 14px var(--sans);padding:11px;cursor:pointer}
.auth-submit:hover{background:var(--signal-soft)}
.auth-submit:disabled{opacity:.6;cursor:default}

/* User menu in the app bar */
.ab-user{margin-left:auto;position:relative}
.ab-userbtn{padding:5px 9px 5px 5px}
.ab-avatar{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;
  background:var(--signal);color:#0b0d10;font:700 11px var(--mono)}
.ab-username{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:560px){.ab-username{display:none}}
.user-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:210px;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;box-shadow:0 16px 40px rgba(0,0,0,.5);padding:6px;z-index:60}
.user-id{padding:8px 10px 10px;border-bottom:1px solid var(--line-soft);margin-bottom:6px;display:flex;
  flex-direction:column;gap:2px}
.user-id b{color:var(--ink);font-size:13.5px}
.user-id span{color:var(--ink-dim);font-size:12px}
.user-role{align-self:flex-start;margin-top:4px;font:600 9.5px var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--signal);border:1px solid rgba(255,92,40,.4);border-radius:5px;padding:1px 6px}
.user-mi{display:block;width:100%;text-align:left;background:none;border:none;color:var(--ink);
  font:13px var(--sans);padding:8px 10px;border-radius:6px;cursor:pointer}
.user-mi:hover{background:var(--panel-2)}
.user-mi-danger{color:var(--signal-soft)}

/* Users admin modal — mirrors the MCP modal pattern */
.users-modal{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:24px}
.users-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.users-panel{position:relative;width:100%;max-width:560px;max-height:82vh;overflow:auto;background:var(--panel);
  border:1px solid var(--line);border-radius:14px;padding:22px 24px;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.users-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.users-head h3{font-family:var(--serif);font-size:19px;color:var(--ink);margin:0}
.users-x{background:none;border:none;color:var(--ink-dim);font-size:17px;cursor:pointer}
.users-note{font-size:12.5px;color:var(--ink-dim);line-height:1.5;margin-bottom:16px}
.user-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px 12px;padding:10px 0;border-top:1px solid var(--line-soft)}
.user-row-id{flex:1 1 100%;min-width:0;display:flex;flex-direction:column}
.user-row-id b{color:var(--ink);font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-row-id span{color:var(--ink-faint);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role-sel,.users-field select{background:var(--bg-2);border:1px solid var(--line);border-radius:7px;
  color:var(--ink);font:13px var(--sans);padding:6px 8px}
.user-active{display:inline-flex;align-items:center;gap:5px;color:var(--ink-dim);font-size:12.5px}
.user-reset{background:var(--panel-2);border:1px solid var(--line);border-radius:7px;color:var(--ink);
  font:12px var(--sans);padding:6px 9px;cursor:pointer}
.user-reset:hover{border-color:var(--signal)}
.users-add-btn{margin-top:14px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font:13px var(--sans);padding:9px 12px;cursor:pointer}
.users-add-btn:hover{border-color:var(--signal)}
.users-form{margin-top:14px;border-top:1px solid var(--line-soft);padding-top:14px}
.users-form-head{font:600 13px var(--sans);color:var(--ink);margin-bottom:10px}
.users-field{display:block;margin-bottom:11px}
.users-field>span{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:5px}
.users-field input{width:100%;box-sizing:border-box;background:var(--bg-2);border:1px solid var(--line);
  border-radius:8px;color:var(--ink);font:14px var(--sans);padding:9px 11px}
.users-field input:focus,.users-field select:focus{outline:none;border-color:var(--signal)}
.users-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.users-cancel{background:none;border:1px solid var(--line);border-radius:8px;color:var(--ink-dim);
  font:13px var(--sans);padding:8px 14px;cursor:pointer}
.users-save{background:var(--signal);border:none;border-radius:8px;color:#0b0d10;font:600 13px var(--sans);
  padding:8px 16px;cursor:pointer}
.users-form-err{margin-top:10px;font-size:12.5px;color:#ff8c6b}

/* My-profile editor (reuses the users-modal chrome) */
.profile-text{width:100%;box-sizing:border-box;background:var(--bg-2);border:1px solid var(--line);
  border-radius:9px;color:var(--ink);font:13.5px/1.55 var(--mono);padding:12px 13px;resize:vertical;min-height:200px}
.profile-text:focus{outline:none;border-color:var(--signal)}
.profile-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:12px}
.profile-count{font:11px var(--mono);color:var(--ink-faint)}
.profile-actions{display:flex;gap:8px}

/* What Trey remembers — memory panel (reuses the users-modal chrome) */
.mem-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.mem-row{display:flex;align-items:center;gap:10px;padding:9px 11px;background:var(--bg-2);
  border:1px solid var(--line);border-radius:8px}
.mem-text{flex:1;min-width:0;color:var(--ink);font:13px/1.45 var(--sans)}
.mem-forget{flex:none;background:none;border:none;color:var(--ink-faint);font-size:14px;cursor:pointer;
  width:24px;height:24px;border-radius:6px}
.mem-forget:hover{color:var(--signal-soft);background:var(--panel-2)}
.mem-add{display:flex;gap:8px}
.mem-add input{flex:1;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;color:var(--ink);
  font:13.5px var(--sans);padding:9px 11px}
.mem-add input:focus{outline:none;border-color:var(--signal)}
