:root{
  --ink:#16303D; --deep:#1C3E4E; --indigo:#285C70; --steel:#517380;
  --dust:#F2EDEA; --paper:#F7F6F2; --line:#DAD5D0; --card:#ffffff;
  --in:#2F7A52; --out:#B0413E; --amber:#B7791F;
  --green-bg:#E3F0E8; --amber-bg:#F6E9D6; --red-bg:#F4DEDD;
  --shadow:0 1px 2px rgba(22,48,61,.05),0 6px 22px rgba(22,48,61,.07);
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,Roboto,Arial,sans-serif;
  --serif:'Iowan Old Style','Palatino Linotype',Georgia,serif;
  --mono:'SFMono-Regular',ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:14.5px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
a{color:var(--indigo)}
.hidden{display:none!important}
.muted{color:var(--steel)}
.mono{font-variant-numeric:tabular-nums}
.pos{color:var(--in)} .neg{color:var(--out)}

/* ---------- login ---------- */
#login{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--ink),var(--indigo))}
.login-card{background:#fff;border-radius:16px;padding:34px 34px 28px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-card .brand{font-family:var(--serif);font-size:30px;font-weight:600}
.login-card .tag{color:var(--steel);font-size:12.5px;margin:2px 0 22px}
.login-card label{display:block;font-size:12px;color:var(--steel);margin:12px 0 4px;text-transform:uppercase;letter-spacing:.05em}
.login-card input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:15px}
.login-card button{width:100%;margin-top:20px;background:var(--ink);color:#fff;border:none;border-radius:9px;padding:12px;font-size:15px;font-weight:600}
.login-err{color:var(--out);font-size:13px;margin-top:12px;min-height:18px}

/* ---------- app shell ---------- */
#app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
nav.side{background:var(--ink);color:var(--dust);padding:22px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
nav .brand{font-family:var(--serif);font-size:22px;color:#fff}
nav .brand .dot{color:var(--steel)}
nav .who{font-size:11.5px;color:#88a6b1;margin:2px 0 22px}
nav a.nav{display:flex;align-items:center;gap:9px;color:#C9D6DC;font-size:14px;padding:9px 11px;border-radius:9px;margin:2px 0;text-decoration:none;cursor:pointer}
nav a.nav:hover{background:rgba(255,255,255,.06);color:#fff}
nav a.nav.active{background:var(--indigo);color:#fff}
nav a.nav .ic{width:18px;text-align:center}
nav .logout{margin-top:18px;color:#88a6b1;font-size:13px;padding:9px 11px;cursor:pointer;border-radius:9px}
nav .logout:hover{background:rgba(255,255,255,.06);color:#fff}
main{padding:26px 30px 70px;min-width:0;max-width:1180px}
h1.view-title{font-family:var(--serif);font-size:26px;margin:0 0 4px;font-weight:600}
.view-sub{color:var(--steel);font-size:13px;margin:0 0 20px}

/* ---------- shared ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow)}
.kpi .lab{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--steel)}
.kpi .val{font-family:var(--serif);font-size:21px;margin-top:5px}
.kpi.inq .val{color:var(--in)} .kpi.outq .val{color:var(--out)}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.tab{background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 14px;font-size:13px;color:var(--deep)}
.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{text-align:right;padding:8px 11px;border-bottom:1px solid var(--line);white-space:nowrap;font-variant-numeric:tabular-nums}
th:first-child,td:first-child{text-align:left}
th{background:var(--ink);color:#fff;font-size:10.5px;letter-spacing:.04em;text-transform:uppercase}
tbody tr:nth-child(even){background:#fbfaf8}
.bar{height:8px;border-radius:4px;display:inline-block;vertical-align:middle;margin-left:6px}
.btn{background:var(--ink);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:600}
.btn.sec{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.ok{background:var(--in)} .btn.no{background:var(--out)} .btn:disabled{opacity:.5}
.banner{padding:14px 18px;border-radius:12px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.banner.HEALTHY{background:var(--green-bg);color:var(--in)}
.banner.CAUTION{background:var(--amber-bg);color:var(--amber)}
.banner.CRITICAL{background:var(--red-bg);color:var(--out)}
.pill{display:inline-block;font-size:11px;padding:2px 9px;border-radius:999px;background:var(--dust);color:var(--deep)}
.pill.green{background:var(--green-bg);color:var(--in)} .pill.amber{background:var(--amber-bg);color:var(--amber)} .pill.red{background:var(--red-bg);color:var(--out)}
.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;min-width:180px;flex:1}
.field label{font-size:11px;color:var(--steel);text-transform:uppercase;letter-spacing:.04em}
.field input,.field select,.field textarea{padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}
.formgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 16px}
.msg{font-size:13px;margin-top:10px;min-height:18px}
.msg.ok{color:var(--in)} .msg.err{color:var(--out)}
svg{display:block;max-width:100%;height:auto}

/* ---------- chat (Tally) ---------- */
.chatwrap{display:flex;flex-direction:column;height:calc(100vh - 150px);max-width:760px}
.chatlog{flex:1;overflow-y:auto;padding:6px 2px;display:flex;flex-direction:column;gap:12px}
.bubble{max-width:78%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.45}
.bubble.me{align-self:flex-end;background:var(--ink);color:#fff;border-bottom-right-radius:4px}
.bubble.tally{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px;box-shadow:var(--shadow)}
.bubble .nm{font-size:11px;color:var(--steel);margin-bottom:3px}
.bubble.tally .nm{color:var(--indigo);font-weight:600}
.confirmbar{margin-top:8px;display:flex;gap:8px}
.chatbar{display:flex;gap:8px;margin-top:12px}
.chatbar input{flex:1;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:15px}
@media(max-width:840px){
  #app{grid-template-columns:1fr}
  nav.side{position:static;height:auto;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
  nav .brand,nav .who{width:100%}
  nav a.nav{padding:7px 10px}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .formgrid{grid-template-columns:1fr}
  main{padding:18px}
}
