:root{
  --bg:#0d1117; --panel:#161b22; --panel2:#1c232d; --line:#2a323d;
  --txt:#e6edf3; --muted:#8b949e; --accent:#2f81f7; --accent2:#1f6feb;
  --ok:#3fb950; --warn:#d29922; --crit:#f85149; --chip:#21262d;
  --radius:12px; --shadow:0 6px 24px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--txt);font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.hidden{display:none!important}
.muted{color:var(--muted)}
a{color:var(--accent);text-decoration:none;cursor:pointer}
button{font:inherit;cursor:pointer;border:none;border-radius:8px;padding:8px 14px;background:var(--accent);color:#fff}
button:hover{background:var(--accent2)}
button.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
button.ghost:hover{background:var(--panel2)}
button.danger{background:var(--crit)}
button.small{padding:5px 10px;font-size:12px}
input,select,textarea{font:inherit;background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:8px;padding:9px 11px;width:100%}
textarea{min-height:90px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}

/* login */
.login{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% -10%,#12243f,transparent),var(--bg)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:34px 30px;width:340px;box-shadow:var(--shadow);text-align:center}
.login-card input{margin-top:10px}
.login-card button{margin-top:16px;width:100%}
.login-card h1{margin:14px 0 2px;font-size:22px}
.logo{width:56px;height:56px;margin:0 auto;border-radius:14px;background:linear-gradient(135deg,#2f81f7,#a371f7)}
.err{color:var(--crit);margin-top:10px;min-height:18px;font-size:13px}

/* shell */
#app{display:grid;grid-template-columns:230px 1fr;height:100vh}
.side{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px}
.brand{font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px;padding:6px 8px 16px}
.dot{width:10px;height:10px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px var(--ok)}
.side nav{display:flex;flex-direction:column;gap:2px;flex:1}
.side nav a{padding:9px 12px;border-radius:8px;color:var(--muted)}
.side nav a:hover{background:var(--panel2);color:var(--txt)}
.side nav a.active{background:var(--accent);color:#fff}
.side-foot{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--line)}
main{overflow:auto;padding:26px 30px}

h2{margin:0 0 4px;font-size:20px}
.sub{color:var(--muted);margin:0 0 20px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.grid{display:grid;gap:14px}
.cards{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card h3{margin:0 0 6px;font-size:13px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat{font-size:30px;font-weight:700}
.section{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.section h3{margin:0 0 12px}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
tr:hover td{background:var(--panel2)}

.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:20px;font-size:12px;background:var(--chip);border:1px solid var(--line)}
.badge.ok{color:var(--ok)} .badge.warn{color:var(--warn)} .badge.crit{color:var(--crit)} .badge.off{color:var(--muted)}
.badge .b-dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.pill{padding:2px 8px;border-radius:6px;background:var(--chip);font-size:12px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar .spacer{flex:1}
.kv{display:grid;grid-template-columns:180px 1fr;gap:6px 14px;font-size:13px}
.kv div:nth-child(odd){color:var(--muted)}
pre.logs{background:#0a0e14;border:1px solid var(--line);border-radius:8px;padding:12px;max-height:420px;overflow:auto;font-size:12px;white-space:pre-wrap}
code.mono{font-family:ui-monospace,Menlo,Consolas,monospace;background:var(--chip);padding:2px 6px;border-radius:6px;font-size:12px}

/* toast + modal */
.toast{position:fixed;bottom:22px;right:22px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);max-width:360px;z-index:50}
.toast.ok{border-left-color:var(--ok)} .toast.err{border-left-color:var(--crit)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;z-index:60;padding:20px}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;width:min(640px,96vw);max-height:90vh;overflow:auto;box-shadow:var(--shadow)}
.modal-card h3{margin:0 0 14px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:820px){#app{grid-template-columns:1fr}.side{flex-direction:row;overflow:auto}.split{grid-template-columns:1fr}}
.hint{background:var(--panel2);border:1px dashed var(--line);border-radius:10px;padding:12px 14px;font-size:13px;color:var(--muted);margin:10px 0}
.steps{counter-reset:s;padding-left:0;list-style:none}
.steps li{counter-increment:s;padding:8px 0 8px 34px;position:relative;border-bottom:1px solid var(--line)}
.steps li::before{content:counter(s);position:absolute;left:0;top:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:12px}
