:root{
  --bg:#0f141b; --panel:#171f2a; --panel2:#1e2733; --line:#2a3645;
  --txt:#e6edf3; --muted:#8b98a8; --accent:#3b82f6; --ok:#22c55e; --err:#ef4444; --warn:#f59e0b;
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--txt)}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)} .small{font-size:12px}

.topbar{display:flex;align-items:center;gap:24px;padding:12px 20px;background:var(--panel);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{font-weight:700}
.topbar nav{display:flex;gap:16px;flex:1}
.topbar .user{display:flex;align-items:center;gap:12px;color:var(--muted)}
.topbar .user em{font-style:normal;color:var(--accent)}

.container{max-width:1100px;margin:24px auto;padding:0 20px}
h1{font-size:22px;margin:0 0 16px} h2{font-size:17px;margin:28px 0 12px}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin:18px 0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;position:relative}
.card h3{margin:0 0 8px}

.alert{padding:10px 14px;border-radius:8px;margin:0 0 16px}
.alert.ok{background:rgba(34,197,94,.12);border:1px solid var(--ok);color:#86efac}
.alert.err{background:rgba(239,68,68,.12);border:1px solid var(--err);color:#fca5a5}

.login-card{max-width:380px;margin:8vh auto;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:28px}
.login-card h1{text-align:center;font-size:18px;margin-bottom:20px}

label{display:block;margin:0 0 12px;color:var(--muted)}
input,select{width:100%;margin-top:4px;padding:9px 11px;background:var(--panel2);color:var(--txt);
  border:1px solid var(--line);border-radius:8px;font:inherit}
.form-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.form-row input,.form-row select{width:auto;margin:0;flex:1;min-width:140px}
.form-col{max-width:380px}
button,.btn{cursor:pointer;background:var(--accent);color:#fff;border:0;border-radius:8px;
  padding:9px 16px;font:inherit;font-weight:600}
button:hover,.btn:hover{filter:brightness(1.1)}
.btn.small{padding:5px 10px;font-size:12px}
button.link{background:none;color:var(--muted);padding:0;font-weight:400;text-decoration:underline}
form.inline{display:inline-flex;gap:6px;align-items:center;margin:0}

table.grid{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;overflow:hidden}
.grid th,.grid td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}
.grid th{background:var(--panel2);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.grid tr:last-child td{border-bottom:0}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.actions input{width:130px;margin:0}

.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;background:var(--panel2);
  border:1px solid var(--line);color:var(--muted)}
.badge.ok{color:#86efac;border-color:var(--ok)}
.badge.off{color:#fca5a5;border-color:var(--err)}
.badge.soon{position:absolute;top:14px;right:14px;color:var(--warn);border-color:var(--warn)}

/* v2 — stats & peers */
.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;
  display:flex;flex-direction:column;gap:4px;min-width:120px}
.stat .num{font-size:24px;font-weight:700}
.stat .lbl{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.stat.ok .num{color:#86efac} .stat.err .num{color:#fca5a5}
.card .big{font-size:30px;font-weight:700;margin:6px 0}
.btn.danger{background:var(--err)}
.badge.soon2{color:var(--muted);border-style:dashed}
