/* Brain Console — theme ported from design/wireframe.html.
   Dark theme, system fonts only (no external URLs / no web fonts).
   Shared by every screen. Screen agents reuse these classes and may add
   app/static/screens/<name>.css for screen-specific tweaks. */

:root{
  --bg:#0E1420; --panel:#151D2C; --panel2:#1B2537; --line:#26314B; --line-soft:#1E2940;
  --text:#E9EEF8; --muted:#8B98B2; --dim:#5C6A87;
  --amber:#F0B429; --amber-soft:rgba(240,180,41,.14);
  --ok:#3FBF7F; --ok-soft:rgba(63,191,127,.14);
  --off:#5C6A87; --off-soft:rgba(92,106,135,.16);
  --red:#E5534B; --red-soft:rgba(229,83,75,.13);
  --blue:#5B9DD9; --blue-soft:rgba(91,157,217,.14);
  --violet:#D9A0E8; --violet-soft:rgba(217,160,232,.12);
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.55}
::selection{background:var(--amber-soft)}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px;border-radius:4px}
mark{background:var(--amber-soft);color:var(--amber);padding:0 2px;border-radius:3px}

/* ---------- topbar ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}
.brand{font-family:var(--mono);font-size:15px;letter-spacing:.14em;font-weight:700;color:var(--text)}
.brand .dot{color:var(--amber)}
.sync{margin-left:auto;display:flex;gap:16px;align-items:center;font-family:var(--mono);font-size:12px;color:var(--muted);flex-wrap:wrap}
.sync .git{color:var(--ok);display:inline-flex;align-items:center;gap:6px}
.sync .git.warn{color:var(--amber)}
.sync .git::before{content:"●"}
.sync .git.warn::before{content:"⚠"}
.sync form{display:inline}
.sync .syncbtn{padding:4px 12px;border:1px solid var(--line);border-radius:7px;color:var(--muted);font-family:var(--mono);font-size:11px}
.sync .syncbtn:hover{border-color:var(--amber);color:var(--text)}
.sync .logout{color:var(--dim)}
.sync .logout:hover{color:var(--red)}
#sync-msg{font-family:var(--mono);font-size:11px}
#sync-msg.ok{color:var(--ok)}
#sync-msg.err{color:var(--red)}

/* ---------- shell + nav ---------- */
.shell{display:flex;min-height:calc(100vh - 58px)}
nav.side{width:198px;flex:none;border-right:1px solid var(--line-soft);padding:18px 10px;display:flex;flex-direction:column;gap:4px}
.navbtn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 12px;border-radius:8px;color:var(--muted);font-size:14px}
.navbtn:hover{background:var(--panel);color:var(--text);text-decoration:none}
.navbtn.on{background:var(--panel2);color:var(--text);box-shadow:inset 3px 0 0 var(--amber)}
.navbtn .k{font-family:var(--mono);font-size:11px;color:var(--dim);margin-left:auto}
nav.side .sep{margin:12px 12px 6px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--dim);text-transform:uppercase}

main{flex:1;padding:24px 26px 60px;min-width:0}

/* ---------- flash ---------- */
.flash{padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:13.5px}
.flash.ok{background:var(--ok-soft);color:var(--ok);border:1px solid rgba(63,191,127,.3)}
.flash.err{background:var(--red-soft);color:var(--red);border:1px solid rgba(229,83,75,.3)}
.flash.info{background:var(--panel2);color:var(--muted);border:1px solid var(--line)}

/* ---------- headings ---------- */
h1{font-size:19px;margin:0 0 4px;font-weight:650}
.sub{color:var(--muted);font-size:13.5px;margin:0 0 22px}
h2{font-size:12px;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:26px 0 12px}

/* ---------- stat cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.stat{background:var(--panel);border:1px solid var(--line-soft);border-radius:10px;padding:14px 16px}
.stat .n{font-family:var(--mono);font-size:26px;font-weight:700;font-variant-numeric:tabular-nums}
.stat .n small{font-size:14px;color:var(--muted);font-weight:400}
.stat .l{font-size:12px;color:var(--muted);margin-top:2px}
.stat.hot .n{color:var(--amber)}
.stat .cav{font-size:10.5px;line-height:1.35;color:var(--muted);opacity:.8;margin-top:6px;font-style:italic}

.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;align-items:start}
@media(max-width:980px){.grid2{grid-template-columns:1fr}}

/* ---------- panel ---------- */
.panel{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:16px 18px}
.panel h3{margin:0 0 12px;font-size:14px;font-weight:650}
.panel h3 .when{font-family:var(--mono);font-size:11px;color:var(--dim);font-weight:400;margin-left:8px}

.digest{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.digest li{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;background:var(--panel2);border-radius:8px;font-size:13.5px}
.digest .src{font-family:var(--mono);font-size:11px;color:var(--dim);flex:none;padding-top:2px;width:64px}

/* ---------- chip / pill ---------- */
.chip{display:inline-block;padding:2px 8px;border-radius:999px;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.chip.dept{color:var(--blue);border-color:rgba(91,157,217,.4);background:var(--blue-soft)}
.chip.wf{color:var(--amber);border-color:rgba(240,180,41,.4);background:var(--amber-soft)}
.chip.log{color:var(--dim)}
.chip.fin{color:var(--violet);border-color:rgba(217,160,232,.4);background:var(--violet-soft)}
.chip.private{color:var(--amber);border-color:rgba(240,180,41,.4)}
.chip.rotate{color:var(--red);border-color:rgba(229,83,75,.5);background:var(--red-soft)}

.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.06em}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.pill.act{color:var(--ok);background:var(--ok-soft)}
.pill.slp{color:var(--off);background:var(--off-soft)}
.pill.wrn{color:var(--amber);background:var(--amber-soft)}

/* ---------- rings ---------- */
.rings{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.ringviz{width:190px;height:190px;flex:none;position:relative}
.ringviz div{position:absolute;border-radius:50%;border:1.5px solid}
.r1{inset:0;border-color:rgba(91,157,217,.55);background:rgba(91,157,217,.05)}
.r2{inset:32px;border-color:rgba(217,160,232,.6);background:rgba(217,160,232,.05)}
.r3{inset:64px;border-color:var(--amber);background:var(--amber-soft)}
.ringviz span{position:absolute;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;color:var(--muted)}
.ringviz .t1{top:7px}.ringviz .t2{top:39px;color:var(--violet)}.ringviz .t3{top:50%;transform:translate(-50%,-50%);color:var(--amber);text-align:center;line-height:1.5}
.ringleg{flex:1;min-width:230px;font-size:13px;color:var(--muted)}
.ringleg b{color:var(--text);font-weight:600}
.ringleg p{margin:0 0 10px}

.bars{display:flex;flex-direction:column;gap:10px}
.bar{display:grid;grid-template-columns:88px 1fr 74px;gap:10px;align-items:center;font-family:var(--mono);font-size:12px}
.bar .tr{height:8px;background:var(--panel2);border-radius:4px;overflow:hidden}
.bar .fl{height:100%;border-radius:4px;background:var(--amber)}
.bar .v{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}

.note{border:1.5px dashed rgba(240,180,41,.45);border-radius:10px;padding:10px 14px;font-size:12.5px;color:var(--muted);margin-top:14px}
.note b{color:var(--amber);font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase}
.empty{border:1.5px dashed var(--line);border-radius:12px;padding:26px 22px;color:var(--muted);font-size:13.5px;text-align:center}
.empty h3{color:var(--text);font-size:15px;margin:0 0 8px}

/* ---------- fleet ---------- */
.fleet{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px}
.agent{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}
.agent.off{opacity:.62}
.agent .head{display:flex;align-items:center;gap:10px}
.agent .name{font-family:var(--mono);font-weight:700;font-size:15px}
.agent .plat{font-size:11.5px;color:var(--dim);font-family:var(--mono)}
.agent .head .pill{margin-left:auto}
.agent .role{font-size:13px;color:var(--muted);min-height:38px}
.agent .meta{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:11.5px;color:var(--dim)}
.agent .meta b{color:var(--muted);font-weight:500}
.agent .foot{display:flex;gap:8px;margin-top:2px;flex-wrap:wrap;align-items:center}
.ghostbtn{display:inline-block;padding:5px 12px;border:1px solid var(--line);border-radius:7px;font-size:12px;color:var(--muted)}
.ghostbtn:hover{border-color:var(--amber);color:var(--text);text-decoration:none}

/* ---------- brain browser ---------- */
.browser{display:grid;grid-template-columns:290px 1fr;gap:16px;align-items:start}
@media(max-width:900px){.browser{grid-template-columns:1fr}}
.tree{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:12px;font-family:var(--mono);font-size:12.5px}
.tree .search{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:7px;padding:7px 10px;color:var(--text);font:inherit;margin-bottom:10px}
.tree .search::placeholder{color:var(--dim)}
.tree details{margin:1px 0}
.tree summary{cursor:pointer;padding:4px 6px;border-radius:6px;color:var(--muted);list-style:none}
.tree summary::before{content:"▸ ";color:var(--dim)}
.tree details[open]>summary::before{content:"▾ "}
.tree summary:hover{background:var(--panel2)}
.tree .leaf{display:block;width:100%;text-align:left;padding:3px 6px 3px 22px;border-radius:6px;color:var(--dim);font-family:var(--mono);font-size:12.5px}
.tree .leaf:hover{background:var(--panel2);color:var(--text);text-decoration:none}
.tree .leaf.on{background:var(--amber-soft);color:var(--amber)}
.tree .sub{padding-left:14px}
.preview{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;min-width:0}
.preview .path{font-family:var(--mono);font-size:12px;color:var(--dim);padding:12px 18px;border-bottom:1px solid var(--line-soft);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.preview .path .chip{margin-left:auto}
.doc{padding:20px 24px;max-width:74ch}
.doc h1,.doc h2,.doc h3,.doc h4{color:var(--text)}
.doc h1{font-size:20px;margin:0 0 8px}
.doc h2{font-family:var(--sans);text-transform:none;letter-spacing:normal;font-size:16px;color:var(--text);margin:20px 0 8px}
.doc h3{font-size:14px;margin:16px 0 6px}
.doc .meta-line{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-bottom:14px}
.doc p{margin:0 0 12px;color:var(--muted);font-size:13.5px}
.doc ul,.doc ol{margin:0 0 12px;padding-left:20px;color:var(--muted);font-size:13.5px}
.doc li{margin:3px 0}
.doc code{font-family:var(--mono);font-size:12px;background:var(--panel2);padding:1px 6px;border-radius:4px}
.doc pre{background:var(--panel2);padding:12px 14px;border-radius:8px;overflow-x:auto}
.doc pre code{background:none;padding:0}
.doc blockquote{border-left:3px solid var(--line);margin:0 0 12px;padding:2px 14px;color:var(--dim)}
.doc table{border-collapse:collapse;font-size:12.5px;margin:0 0 12px;display:block;overflow-x:auto}
.doc th,.doc td{border:1px solid var(--line-soft);padding:6px 10px;text-align:left}
.doc a{color:var(--blue)}

/* ---------- dreams ---------- */
.night{margin-bottom:26px}
.nighthead{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--amber);text-transform:uppercase;margin-bottom:12px}
.nighthead::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.dream{display:grid;grid-template-columns:56px 1fr;gap:14px;margin-bottom:10px}
.dream .t{font-family:var(--mono);font-size:11.5px;color:var(--dim);padding-top:14px;text-align:right;font-variant-numeric:tabular-nums}
.dream .body{background:var(--panel);border:1px solid var(--line-soft);border-radius:10px;padding:12px 16px}
.dream .who{font-family:var(--mono);font-size:12.5px;font-weight:700;margin-bottom:4px}
.dream .what{font-size:13.5px;color:var(--muted);margin-bottom:8px;white-space:pre-wrap}
.dream .verdicts{display:flex;gap:6px;flex-wrap:wrap}
.dream.lib .body{border-color:rgba(240,180,41,.35);background:linear-gradient(0deg,var(--amber-soft),var(--amber-soft)),var(--panel)}

/* ---------- kanban ---------- */
.board{display:grid;grid-template-columns:repeat(4,minmax(215px,1fr));gap:12px;overflow-x:auto;padding-bottom:6px}
@media(max-width:1050px){.board{grid-template-columns:repeat(4,240px)}}
.col{background:var(--panel);border:1px solid var(--line-soft);border-radius:12px;padding:12px;min-width:0}
.col h4{margin:0 0 10px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;justify-content:space-between}
.col h4 .cnt{color:var(--dim)}
.col.drop{outline:1.5px dashed var(--amber);outline-offset:-4px}
.card{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;margin-bottom:9px;font-size:13px;cursor:grab}
.card:hover{border-color:var(--amber)}
.card.dragging{opacity:.5}
.card .cm{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;align-items:center}
.card .who{font-family:var(--mono);font-size:10.5px;color:var(--dim);margin-left:auto}
.card.done{opacity:.55}
.card.done .ttl{text-decoration:line-through}

/* ---------- access matrix ---------- */
.mtx{width:100%;border-collapse:collapse;font-size:13px;min-width:640px}
.mtx th,.mtx td{padding:9px 12px;border-bottom:1px solid var(--line-soft);text-align:center}
.mtx th{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
.mtx td:first-child,.mtx th:first-child{text-align:left}
.mtx td:first-child{font-family:var(--mono);font-weight:600}
.mtx .y{color:var(--ok);font-weight:700}
.mtx .n{color:var(--dim)}
.mtx .p{color:var(--violet);font-weight:700}
.mtx tr:hover td{background:var(--panel2)}
.scrollx{overflow-x:auto;border:1px solid var(--line-soft);border-radius:12px;background:var(--panel)}

/* ---------- auth screens ---------- */
.authwrap{max-width:380px;margin:8vh auto;padding:0 20px}
.authcard{background:var(--panel);border:1px solid var(--line-soft);border-radius:14px;padding:26px 24px}
.authcard h1{font-size:17px;margin-bottom:14px}
.authcard label{display:block;font-size:12px;color:var(--muted);margin:12px 0 4px;font-family:var(--mono);letter-spacing:.04em}
.authcard input{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;color:var(--text);font:inherit}
.authcard input:focus{border-color:var(--amber);outline:none}
.authcard .primary{width:100%;margin-top:18px;padding:10px;background:var(--amber);color:#1a1300;border-radius:8px;font-weight:600;font-family:var(--mono);letter-spacing:.04em}
.authcard .primary:hover{filter:brightness(1.06)}
.authcard .hint{font-size:12px;color:var(--dim);margin-top:14px;line-height:1.5}
.authbrand{font-family:var(--mono);letter-spacing:.14em;font-weight:700;text-align:center;margin-bottom:20px}
.authbrand .dot{color:var(--amber)}

footer{padding:26px 22px;color:var(--dim);font-size:12px;font-family:var(--mono);text-align:center;border-top:1px solid var(--line-soft)}

@media(max-width:760px){
  .shell{flex-direction:column}
  nav.side{width:100%;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--line-soft);padding:10px}
  nav.side .sep{display:none}
  .navbtn{width:auto}
  .navbtn .k{display:none}
  .dream{grid-template-columns:1fr}
  .dream .t{text-align:left;padding-top:0}
}
