:root{--bg:#0f1419;--panel:#1a2129;--line:#2a3441;--txt:#e6edf3;--muted:#8b98a5;--accent:#3b82f6;--ok:#22c55e;--bad:#ef4444}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--txt);font-size:15px}
nav{display:flex;align-items:center;gap:18px;background:var(--panel);padding:0 22px;height:56px;border-bottom:1px solid var(--line)}
nav .brand{font-weight:700;margin-right:10px}
nav a{color:var(--muted);text-decoration:none;font-weight:500}
nav a:hover{color:var(--txt)}
nav .spacer{flex:1}
nav .who{color:var(--muted);font-size:13px}
nav .logout{color:var(--bad)}
main{max-width:980px;margin:0 auto;padding:28px 22px}
h1{font-size:24px;margin:0 0 20px}
h2{font-size:17px;margin:30px 0 12px;color:var(--muted);font-weight:600}
.cards{display:flex;gap:16px;flex-wrap:wrap}
.card{flex:1;min-width:150px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px}
.card .num{font-size:34px;font-weight:700}
.card .lbl{color:var(--muted);font-size:13px;margin-top:4px}
table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}
th,td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);font-size:14px}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tr:last-child td{border-bottom:none}
tr.dim{opacity:.5}
.ok{color:var(--ok);font-weight:600}
.bad{color:var(--bad);font-weight:600}
.muted{color:var(--muted)}
.badge{display:inline-block;background:#243044;color:#9db4d4;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600}
.badge.online{background:#0f2e1a;color:var(--ok)}
.btn{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;padding:7px 13px;border-radius:7px;border:none;cursor:pointer;font-size:13px;font-weight:600}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.danger{background:var(--bad)}
.btn:hover{opacity:.9}
.actions{display:flex;gap:6px;align-items:center}
.inline-form{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.inline-form input{flex:1;min-width:160px;background:var(--bg);border:1px solid var(--line);color:var(--txt);padding:9px 12px;border-radius:8px}
.inline-form button{background:var(--accent);color:#fff;border:none;padding:9px 18px;border-radius:8px;cursor:pointer;font-weight:600}
.alert{padding:11px 15px;border-radius:9px;margin-bottom:16px;font-size:14px}
.alert.ok{background:#0f2e1a;color:#86efac;border:1px solid #1d5235}
.alert.err{background:#2e0f0f;color:#fca5a5;border:1px solid #5c2222}
/* login */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-box{background:var(--panel);border:1px solid var(--line);padding:34px;border-radius:14px;width:320px;display:flex;flex-direction:column;gap:14px}
.login-box h1{text-align:center;margin:0 0 8px;font-size:20px}
.login-box label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.login-box input{background:var(--bg);border:1px solid var(--line);color:var(--txt);padding:10px 12px;border-radius:8px;font-size:15px}
.login-box button{background:var(--accent);color:#fff;border:none;padding:11px;border-radius:8px;cursor:pointer;font-weight:600;font-size:15px;margin-top:6px}
footer{text-align:center;color:var(--muted);font-size:12px;padding:30px}
.card-form{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:22px;max-width:380px;display:flex;flex-direction:column;gap:14px}
.card-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.card-form input{background:var(--bg);border:1px solid var(--line);color:var(--txt);padding:9px 12px;border-radius:8px;font-size:15px}
.card-form button{background:var(--accent);color:#fff;border:none;padding:10px;border-radius:8px;cursor:pointer;font-weight:600;margin-top:4px}
