:root{
  --bg:#0b1220; --panel:#111b2e; --panel2:#0e1626; --line:#1e2c44;
  --text:#e6edf7; --muted:#8aa0bf; --accent:#3b82f6; --accent2:#1d4ed8;
  --ok:#16a34a; --warn:#e08a00; --err:#ef4444; --user:#1e3a8a;
  --radius:12px; --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:-apple-system,"Segoe UI",Roboto,Inter,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px}
#root{height:100vh;display:flex}
a{color:var(--accent)}
button{font-family:inherit}

/* ---- login ---- */
.login{margin:auto;width:340px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.login h1{font-size:19px;margin:0 0 4px}
.login .sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.fld{display:block;margin-bottom:12px}
.fld span{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.fld input,.fld textarea,.fld select{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:9px;padding:9px 11px;font-size:14px;outline:none}
.fld input:focus,.fld textarea:focus{border-color:var(--accent)}
.btn{background:var(--accent);color:#fff;border:1px solid transparent;border-radius:9px;padding:9px 14px;
  font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s}
.btn:hover{filter:brightness(1.08)}
.btn.block{width:100%}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn.sm{padding:6px 10px;font-size:13px}
.btn[disabled]{opacity:.5;cursor:default}
.err{color:var(--err);font-size:13px;margin-top:8px;min-height:18px}

/* ---- shell ---- */
.shell{display:flex;width:100%}
.nav{width:208px;flex:none;background:var(--panel2);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:14px 10px}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 16px;font-weight:800;font-size:15px}
.brand svg{color:var(--accent)}
.navbtn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:none;color:var(--muted);
  border-radius:9px;padding:10px 11px;font-size:14px;cursor:pointer}
.navbtn:hover{background:var(--panel);color:var(--text)}
.navbtn.active{background:var(--panel);color:var(--text)}
.navbtn svg{flex:none}
.nav .spacer{flex:1}
.nav .who{font-size:12px;color:var(--muted);padding:8px;border-top:1px solid var(--line)}
.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ---- chat ---- */
.chat{display:flex;flex-direction:column;height:100%}
.chat-top{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line)}
.chat-top .title{font-weight:700}
.chat-top .status{font-size:12px;color:var(--muted)}
.chat-top .spacer{flex:1}
.msgs{flex:1;overflow:auto;padding:18px 16px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:760px;width:fit-content;padding:11px 14px;border-radius:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.msg.user{align-self:flex-end;background:var(--user)}
.msg.ai{align-self:flex-start;background:var(--panel)}
.msg.sys{align-self:center;background:transparent;color:var(--muted);font-size:12.5px;padding:4px}
.tool{align-self:flex-start;max-width:760px;font-family:var(--mono);font-size:12px;background:var(--panel2);
  border:1px solid var(--line);border-radius:9px;padding:8px 11px;color:var(--muted)}
.tool b{color:var(--accent)}
.tool .res{margin-top:6px;color:var(--text);max-height:200px;overflow:auto;white-space:pre-wrap}
.cursor::after{content:"▍";color:var(--accent);animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.inputbar{border-top:1px solid var(--line);padding:12px 16px;display:flex;gap:10px;align-items:flex-end}
.inputbar textarea{flex:1;resize:none;max-height:160px;background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:12px;padding:11px 13px;font-size:14px;outline:none;font-family:inherit}
.inputbar textarea:focus{border-color:var(--accent)}

/* ---- content pages ---- */
.page{padding:24px;overflow:auto}
.page h2{margin:0 0 4px;font-size:20px}
.page .sub{color:var(--muted);margin-bottom:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px;max-width:680px}
.card h3{margin:0 0 12px;font-size:15px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px}
.pill.ok{background:rgba(22,163,74,.16);color:#4ade80}
.pill.off{background:rgba(239,68,68,.16);color:#fca5a5}
.muted{color:var(--muted)}
.kv{display:grid;grid-template-columns:160px 1fr;gap:8px 14px;font-size:13px;margin:8px 0}
.kv .k{color:var(--muted)}
table.leads{width:100%;border-collapse:collapse;font-size:13px}
table.leads th,table.leads td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
table.leads th{color:var(--muted);font-weight:600}
code{font-family:var(--mono);font-size:12px;background:var(--panel2);padding:1px 5px;border-radius:5px}
