/* Fisher Investments · Redaction Console — design language lifted verbatim from the
   fisher-voice prototype (Newsreader + Public Sans, the green/paper/oxblood palette). */

@font-face{font-family:"Newsreader";src:url("/fonts/news-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Newsreader";src:url("/fonts/news-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Newsreader";src:url("/fonts/news-400i.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Public Sans";src:url("/fonts/ps-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Public Sans";src:url("/fonts/ps-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Public Sans";src:url("/fonts/ps-600.woff2") format("woff2");font-weight:600;font-display:swap}

:root{
  --ink:#1a1f1c;--ink2:#3b433d;--muted:#5b645d;--faint:#727a72;
  --paper:#f6f4ee;--green:#14402e;--green2:#1b5e40;--green3:#2c6e49;
  --rule:#e4ded1;--rule2:#d7d0c0;--ox:#8c2f22;--gold:#7e6420;
  --ws:#eceee9;--ws-card:#f4f5f1;--ws-ink:#7c837b;--ws-rule:#dde0da;--ws-faint:#9aa097;
  --serif:"Newsreader",Georgia,serif;--sans:"Public Sans",-apple-system,BlinkMacSystemFont,sans-serif;--r:5px;
}
*{box-sizing:border-box}
html,body{height:100%}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;background:var(--ws);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5;
  display:grid;grid-template-rows:52px 44px 1fr;height:100vh;overflow:hidden}
.tnum{font-variant-numeric:tabular-nums}
b,strong{font-weight:600}
button{font-family:inherit}
a{color:var(--green3)}

/* appbar */
.appbar{display:flex;align-items:center;justify-content:space-between;background:var(--green);color:#eef0e9;padding:0 24px;height:52px;border-bottom:3px solid #0e3122}
.appbar .brand{display:flex;align-items:baseline;gap:13px}
.appbar .mark{font-family:var(--serif);font-weight:600;font-size:18px;color:#fff}
.appbar .vr{width:1px;height:18px;background:rgba(255,255,255,.28);align-self:center}
.appbar .prod{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#b8ccc0}
.appbar .right{display:flex;align-items:center;gap:16px;font-size:13px;color:#cfe0d6}
.appbar .live{display:flex;align-items:center;gap:7px}
.appbar .dot{width:7px;height:7px;border-radius:50%;background:#7fdca6}

/* sub-nav tabs */
.nav{display:flex;align-items:stretch;gap:2px;background:#e4e7e1;border-bottom:1px solid var(--ws-rule);padding:0 18px}
.nav button{background:none;border:0;border-bottom:2px solid transparent;color:var(--ws-faint);font-size:13px;font-weight:500;padding:0 14px;cursor:pointer;letter-spacing:.01em}
.nav button:hover{color:#5f665e}
.nav button[aria-selected="true"]{color:var(--green);border-bottom-color:var(--green2)}

/* main */
.main{overflow:hidden}
.screen{display:none;height:100%;overflow:auto}
.screen.on{display:block}
.split{display:grid;grid-template-columns:1fr 1fr;height:100%}
.lab{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;display:flex;align-items:center;gap:9px;margin:0 0 14px;color:var(--green2)}
.lab::before{content:"";width:16px;height:2px;background:var(--green2)}
.h-serif{font-family:var(--serif);font-weight:600}
.muted{color:var(--muted)}.faint{color:var(--faint)}

/* source (de-emphasized) side */
.source{background:var(--ws);color:var(--ws-ink);padding:24px 28px;overflow:auto;border-right:1px solid var(--ws-rule)}
.source .lab{color:var(--ws-faint)}.source .lab::before{background:var(--ws-faint)}
.source h2{font-family:var(--serif);font-weight:400;font-size:20px;color:#6c736a;margin:0 0 2px}
.source .meta{font-size:12px;color:var(--ws-faint);margin:0 0 16px}
.doc{white-space:pre-wrap;background:var(--ws-card);border:1px solid var(--ws-rule);border-radius:6px;padding:16px 18px;font-size:13.5px;line-height:1.6;color:#7c837b}

/* product (paper) side */
.product{background:var(--paper);padding:24px 28px;overflow:auto}
.btn{font-size:13.5px;font-weight:600;color:#fff;background:var(--green2);border:0;border-radius:var(--r);padding:11px 16px;min-height:44px;cursor:pointer}
.btn:hover{background:var(--green)}.btn:disabled{opacity:.5;cursor:default}
.lk{background:none;border:0;color:var(--muted);font-size:13px;cursor:pointer;padding:8px 6px;border-bottom:1px solid transparent}
.lk:hover{border-bottom-color:var(--muted)}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.status{font-size:13px;color:var(--muted);margin-top:10px;min-height:18px}

/* record rail */
.rail{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.rail .grp{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ws-faint);margin:14px 0 4px}
.rec-btn{text-align:left;background:var(--ws-card);border:1px solid var(--ws-rule);border-radius:5px;padding:9px 11px;cursor:pointer;color:#6c736a;font-size:13px}
.rec-btn:hover{border-color:var(--ws-faint)}
.rec-btn[aria-current="true"]{border-color:var(--green2);box-shadow:0 0 0 2px rgba(27,94,64,.12)}
.rec-btn .t{display:block;color:#5f665e;font-weight:600}
.rec-btn .hh{font-size:11px;color:var(--ws-faint)}

/* tier marks (color by SENSITIVITY TIER) */
mark{border-radius:3px;padding:0 1px;border-bottom:2px solid transparent;cursor:pointer;color:inherit}
mark.tier-direct{background:color-mix(in srgb, var(--ox) 14%, transparent);border-bottom-color:var(--ox)}
mark.tier-quasi{background:color-mix(in srgb, var(--gold) 16%, transparent);border-bottom-color:var(--gold)}
mark.tier-relationship{background:color-mix(in srgb, var(--green2) 14%, transparent);border-bottom-color:var(--green2)}
mark.sel{box-shadow:0 0 0 2px rgba(27,94,64,.25)}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:4px 0 14px}
.legend .sw{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:6px;vertical-align:-1px}
.sw.direct{background:var(--ox)}.sw.quasi{background:var(--gold)}.sw.relationship{background:var(--green2)}
.render{background:#fff;border:1px solid var(--rule2);border-radius:6px;padding:16px 18px;white-space:pre-wrap;line-height:1.7;font-size:14px}
.sidebyside{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sidebyside .cap{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:0 0 6px}

/* inspector + tables */
.tbl{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.tbl th{text-align:left;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:7px 10px;border-bottom:1px solid var(--rule2)}
.tbl td{padding:8px 10px;border-bottom:1px solid var(--rule);vertical-align:top}
.pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}
.pill.direct{color:var(--ox);background:color-mix(in srgb,var(--ox) 12%,transparent)}
.pill.quasi{color:var(--gold);background:color-mix(in srgb,var(--gold) 14%,transparent)}
.pill.relationship{color:var(--green2);background:color-mix(in srgb,var(--green2) 12%,transparent)}
.conf-hi{color:var(--green2);font-weight:600}.conf-mid{color:var(--gold);font-weight:600}.conf-lo{color:var(--ox);font-weight:600}
code,.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px}

/* cards / KPIs */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:6px 0 18px}
.card{background:#fff;border:1px solid var(--rule2);border-radius:6px;padding:14px 16px}
.card .k{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.card .v{font-family:var(--serif);font-size:26px;color:var(--ink)}
.gate{border-radius:6px;padding:18px 20px;margin:6px 0 18px;border:1px solid var(--rule2)}
.gate .metric{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.gate .verdict{font-family:var(--serif);font-size:30px;margin-top:4px}
.gate.pass{background:color-mix(in srgb,var(--green2) 8%,#fff)}
.gate.pass .verdict{color:var(--green2)}
.gate.fail{background:color-mix(in srgb,var(--ox) 8%,#fff)}
.gate.fail .verdict{color:var(--ox)}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.badge{font-size:11.5px;color:var(--green);background:color-mix(in srgb,var(--green2) 9%,#fff);border:1px solid color-mix(in srgb,var(--green2) 22%,transparent);border-radius:20px;padding:4px 11px}
.note{font-size:13px;color:var(--ink2);line-height:1.55;margin:10px 0}

/* gold callout (verbatim from prototype) */
.gold-note{border-left:2px solid var(--gold);padding:3px 0 3px 12px;margin:16px 0;font-size:12.5px;color:var(--ink2)}
.gold-note b{color:var(--gold)}

/* vault */
.proof{background:#fff;border:1px solid var(--rule2);border-left:3px solid var(--green2);border-radius:6px;padding:14px 16px;margin:14px 0;font-size:13.5px;color:var(--ink2)}
.f label{display:block;font-size:11px;font-weight:600;color:var(--ink2);margin-bottom:5px}
.f input{font-family:inherit;font-size:14px;background:#fff;border:1px solid var(--rule2);border-radius:var(--r);padding:9px 11px;color:var(--ink);min-width:240px}
.f input:focus{outline:none;border-color:var(--green2);box-shadow:0 0 0 3px rgba(27,94,64,.13)}

/* audit timeline */
.tl{list-style:none;margin:8px 0;padding:0}
.tl li{display:grid;grid-template-columns:64px 130px 1fr;gap:12px;padding:9px 0;border-top:1px solid var(--rule);font-size:13px}
.tl li:first-child{border-top:0}
.tl .seq{color:var(--faint);font-variant-numeric:tabular-nums}
.tl .ev{font-weight:600;color:var(--green2)}
.intact{display:inline-block;font-size:12px;font-weight:600;color:var(--green2)}
.broken{display:inline-block;font-size:12px;font-weight:600;color:var(--ox)}

/* config */
.toggle{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--rule);font-size:13.5px}
.toggle input{accent-color:var(--green2);width:16px;height:16px}

.empty{color:var(--faint);font-size:13.5px;padding:30px 0}
:focus-visible{outline:2px solid var(--green2);outline-offset:2px;border-radius:3px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
@media(max-width:900px){
  .split,.sidebyside{grid-template-columns:1fr}
  .source{border-right:0;border-bottom:1px solid var(--ws-rule)}
}
