:root{
  --bg:#0b0d12; --bg2:#0f121a; --panel:#161922; --panel2:#1c2030; --line:#272c3b;
  --txt:#e8ebf2; --mut:#8b93a7; --mut2:#666e84;
  --acc:#7589d5; --acc2:#9fb0ff; --acc-d:#5566b0;
  --ok:#3fae6b; --flag:#e7c84a; --kick:#e8694a; --ban:#d24d6a; --info:#5aa6e8;
  --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1200px 600px at 80% -10%, rgba(117,137,213,.10), transparent 60%), var(--bg);
  color:var(--txt); font:14px/1.55 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  min-height:100vh;
}
a{color:var(--acc2);text-decoration:none}
a:hover{text-decoration:underline}
[data-lucide]{width:18px;height:18px;vertical-align:-3px;stroke-width:2}

/* ---------- AUTH ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{
  width:100%;max-width:400px;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow)
}
.auth-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:700;margin-bottom:6px}
.auth-logo .badge{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--acc),var(--acc-d));box-shadow:0 6px 18px rgba(117,137,213,.45)}
.auth-logo .badge [data-lucide]{width:20px;height:20px;color:#fff}
.auth-sub{color:var(--mut);margin:0 0 22px;font-size:13px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--mut);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.input{
  width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:11px 13px;border-radius:10px;font-size:14px;outline:none;transition:border-color .15s
}
.input:focus{border-color:var(--acc)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  background:linear-gradient(135deg,var(--acc),var(--acc-d));color:#fff;border:none;
  padding:11px 16px;border-radius:10px;font-size:14px;font-weight:600;width:100%;transition:filter .15s
}
.btn:hover{filter:brightness(1.08)}
.btn.sm{width:auto;padding:7px 12px;font-size:13px}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.btn.danger{background:linear-gradient(135deg,#d24d6a,#a73a52)}
.btn.warn{background:linear-gradient(135deg,#e0913a,#b9702a)}
.btn.okk{background:linear-gradient(135deg,#3fae6b,#2c8a52)}
.auth-foot{margin-top:18px;text-align:center;color:var(--mut);font-size:13px}

/* ---------- APP SHELL ---------- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:linear-gradient(180deg,var(--bg2),var(--bg));border-right:1px solid var(--line);padding:20px 14px;position:sticky;top:0;height:100vh}
.side .brand{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;padding:6px 8px 18px}
.side .brand .badge{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--acc),var(--acc-d))}
.side .brand .badge [data-lucide]{width:18px;height:18px;color:#fff}
.nav a{display:flex;align-items:center;gap:11px;color:var(--mut);padding:10px 12px;border-radius:10px;margin-bottom:3px;font-weight:500}
.nav a:hover{background:var(--panel);color:var(--txt);text-decoration:none}
.nav a.active{background:linear-gradient(135deg,rgba(117,137,213,.22),rgba(117,137,213,.08));color:#fff;border:1px solid rgba(117,137,213,.35)}
.nav .sep{font-size:11px;color:var(--mut2);text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px}
.side .me{position:absolute;bottom:16px;left:14px;right:14px;border-top:1px solid var(--line);padding-top:14px;font-size:13px;color:var(--mut)}
.side .me b{color:var(--txt)}
.side .me .role{display:inline-block;font-size:10px;padding:1px 7px;border-radius:10px;margin-left:6px;background:rgba(117,137,213,.18);color:var(--acc2)}

.main{padding:26px 30px;max-width:1180px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:21px;margin:0;display:flex;align-items:center;gap:10px}
.period a{color:var(--mut);padding:6px 12px;border:1px solid var(--line);border-radius:9px;margin-left:6px}
.period a.on{background:var(--acc);color:#fff;border-color:var(--acc)}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:8px}
.card{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden}
.card .ic{position:absolute;right:14px;top:14px;opacity:.25}
.card .ic [data-lucide]{width:30px;height:30px}
.card .n{font-size:30px;font-weight:700;line-height:1}
.card .l{color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.05em;margin-top:6px}
.card.flag .n{color:var(--flag)} .card.kick .n{color:var(--kick)} .card.ban .n{color:var(--ban)} .card.ok .n{color:var(--ok)}

h2.sec{font-size:13px;color:var(--mut);text-transform:uppercase;letter-spacing:.06em;margin:28px 0 12px;display:flex;align-items:center;gap:8px}

/* tables */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
table{width:100%;border-collapse:collapse}
th,td{padding:10px 13px;text-align:left;border-bottom:1px solid var(--line);font-size:13px}
th{color:var(--mut);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.05em;background:var(--panel2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.015)}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;color:var(--acc2)}
.muted{color:var(--mut)}
.empty{padding:22px;text-align:center;color:var(--mut)}
.score{font-weight:700}

.badge2{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;display:inline-block}
.b-flag{background:rgba(231,200,74,.16);color:var(--flag)}
.b-kick{background:rgba(232,105,74,.16);color:var(--kick)}
.b-ban{background:rgba(210,77,106,.16);color:var(--ban)}
.b-allow,.b-active{background:rgba(63,174,107,.16);color:var(--ok)}
.b-pending{background:rgba(231,200,74,.16);color:var(--flag)}
.b-disabled{background:rgba(150,150,150,.14);color:var(--mut)}
.b-admin{background:rgba(117,137,213,.2);color:var(--acc2)}
.b-staff{background:rgba(90,166,232,.16);color:var(--info)}

/* histogram */
.hist{display:flex;flex-direction:column;gap:9px}
.hist .row{display:grid;grid-template-columns:130px 1fr 50px;align-items:center;gap:12px}
.hist .bar{height:20px;border-radius:6px;background:var(--acc);min-width:3px;transition:width .3s}
.hist .row.flag .bar{background:var(--flag)} .hist .row.kick .bar{background:var(--kick)} .hist .row.ban .bar{background:var(--ban)}

/* forms inline */
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:end;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.inline-form .field{margin:0}
.inline-form select.input,.inline-form input.input{min-width:150px;width:auto}

/* flash */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:16px;display:flex;align-items:center;gap:10px;font-size:14px}
.flash.ok{background:rgba(63,174,107,.12);border:1px solid rgba(63,174,107,.4);color:#bdf0d2}
.flash.err{background:rgba(210,77,106,.12);border:1px solid rgba(210,77,106,.45);color:#ffd0da}

/* settings grid */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.set-item{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.set-item label{display:block;font-size:13px;color:var(--txt);margin-bottom:8px}
.switch{position:relative;display:inline-block;width:46px;height:26px}
.switch input{display:none}
.switch .sl{position:absolute;inset:0;background:var(--line);border-radius:20px;transition:.2s;cursor:pointer}
.switch .sl:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .sl{background:var(--acc)}
.switch input:checked + .sl:before{transform:translateX(20px)}
.foot{margin-top:30px;color:var(--mut2);font-size:12px;text-align:center}
@media(max-width:820px){.shell{grid-template-columns:1fr}.side{position:static;height:auto}.side .me{position:static;margin-top:14px}}
