:root{
  --bg:#0d1117; --panel:#161b22; --panel2:#1c2330; --line:#2a3140;
  --text:#e6edf3; --muted:#8b949e; --accent:#3b82f6; --accent2:#2563eb;
  --green:#3fb950; --red:#f85149; --yellow:#d29922; --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font:15px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:24px;margin:0}
h2{font-size:18px;margin:0}
h3{font-size:15px;margin:0 0 10px}
.muted{color:var(--muted)}
.small{font-size:13px}
.row{display:flex;align-items:center}
.row.gap{gap:10px}
.row.spread{justify-content:space-between;align-items:center}
.row.wrap{flex-wrap:wrap}
.gap{gap:10px}

.topbar{display:flex;justify-content:space-between;align-items:center;
  padding:12px 22px;background:var(--panel);border-bottom:1px solid var(--line)}
.topbar .brand{font-weight:700;font-size:17px;color:var(--text)}
.topbar nav{display:flex;align-items:center;gap:18px}
.topbar .who{color:var(--muted);font-size:13px}
.topbar .logout{color:var(--muted)}
main{max-width:1100px;margin:0 auto;padding:24px 22px}
.page{display:flex;flex-direction:column;gap:18px}
.back{display:inline-block;color:var(--muted);font-size:13px;margin-bottom:4px}

button{font:inherit;cursor:pointer;border:1px solid var(--line);background:var(--panel2);
  color:var(--text);padding:8px 14px;border-radius:7px}
button:hover{border-color:var(--accent)}
button.primary,.login-card button{background:var(--accent2);border-color:var(--accent2);color:#fff}
button.primary:hover,.login-card button:hover{background:var(--accent)}
button.ghost{background:transparent}
button.danger{color:var(--red);border-color:#5b2526}
button.danger:hover{background:#2a1718}
button.x{border:none;background:none;color:var(--muted);font-size:16px;padding:2px 8px}
input,select{font:inherit;background:var(--panel);border:1px solid var(--line);color:var(--text);
  padding:8px 10px;border-radius:7px}
input:focus{outline:none;border-color:var(--accent)}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:32px;width:340px;display:flex;flex-direction:column;gap:14px}
.login-card h1{text-align:center}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.error{background:#2a1718;color:var(--red);padding:8px 12px;border-radius:7px;font-size:13px}

/* stats + grid */
.stats{display:flex;gap:14px;flex-wrap:wrap}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 18px;min-width:120px}
.stat .n{font-size:22px;font-weight:700}
.stat .l{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.agent-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;display:block}
.agent-card:hover{border-color:var(--accent);text-decoration:none}
.agent-card .name{font-weight:600;font-size:16px;color:var(--text)}
.agent-card .host{color:var(--muted);font-size:13px;font-family:var(--mono)}
.bars{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.bar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.bar .track{flex:1;height:6px;background:var(--panel2);border-radius:4px;overflow:hidden}
.bar .fill{height:100%;background:var(--accent)}
.bar .fill.warn{background:var(--yellow)}.bar .fill.hot{background:var(--red)}

.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dot.on{background:var(--green);box-shadow:0 0 6px var(--green)}
.dot.off{background:var(--muted)}
.pill{font-size:12px;padding:4px 10px;border-radius:20px;border:1px solid var(--line)}
.pill.on{color:var(--green);border-color:#1c3a23}
.pill.off{color:var(--muted)}

/* metrics strip */
.metrics-strip{display:flex;gap:14px;flex-wrap:wrap}
.metric{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 16px;min-width:110px}
.metric .v{font-size:18px;font-weight:600}
.metric .k{color:var(--muted);font-size:12px}

/* tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line)}
.tab{background:none;border:none;border-bottom:2px solid transparent;border-radius:0;color:var(--muted);padding:10px 14px}
.tab.active{color:var(--text);border-bottom-color:var(--accent)}
.tab:hover{border-color:transparent;border-bottom-color:var(--line);color:var(--text)}
.tabpane{display:none;padding-top:16px}
.tabpane.active{display:block}

.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:14px}

/* terminal */
#terminalContainer{height:60vh;border-radius:10px;overflow:hidden;border:1px solid var(--line)}

.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--muted);font-weight:500;padding:6px 8px;border-bottom:1px solid var(--line)}
.tbl td{padding:8px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl code{font-family:var(--mono);font-size:12px}

.vnc-screen{margin-top:14px;background:#000;border:1px solid var(--line);border-radius:10px;min-height:200px}
.vnc-screen canvas{display:block;margin:0 auto}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:grid;place-items:center;z-index:50}
.modal[hidden]{display:none}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px;width:min(640px,92vw)}
.cmd{background:#0a0e14;border:1px solid var(--line);border-radius:8px;padding:12px;
  font-family:var(--mono);font-size:12px;white-space:pre-wrap;word-break:break-all}
hr{border:none;border-top:1px solid var(--line);margin:16px 0}
code{font-family:var(--mono);background:var(--panel2);padding:2px 6px;border-radius:5px;font-size:12px}
.ghost.small{padding:4px 8px;font-size:12px}
