:root{
  --bg:#0f172a; --panel:#1e293b; --panel2:#172033; --line:#334155;
  --text:#e2e8f0; --muted:#94a3b8; --accent:#3b82f6; --green:#22c55e;
  --red:#ef4444; --amber:#f59e0b;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px}
a{color:var(--accent);text-decoration:none}

/* ---- login ---- */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--panel);padding:2rem;border-radius:14px;width:320px;
  box-shadow:0 10px 40px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:.75rem}
.login-card h1{margin:0;font-size:1.6rem;text-align:center}
.login-card .sub{margin:0 0 .5rem;text-align:center;color:var(--muted);font-size:.85rem}
.login-card label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--muted)}
.login-card input{padding:.6rem;border-radius:8px;border:1px solid var(--line);
  background:var(--panel2);color:var(--text);font-size:.95rem}
.login-card button{margin-top:.5rem;padding:.7rem;border:0;border-radius:8px;
  background:var(--accent);color:#fff;font-weight:600;cursor:pointer}
.alert{background:var(--panel2);border:1px solid var(--line);padding:.6rem .8rem;
  border-radius:8px;margin-bottom:1rem}
.alert.err{border-color:var(--red);color:#fecaca}

/* ---- layout ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:.8rem 1.2rem;background:var(--panel);border-bottom:1px solid var(--line)}
.brand{font-weight:700;font-size:1.1rem}
.brand span{color:var(--muted);font-weight:400;font-size:.8rem}
.topbar nav{display:flex;gap:.4rem;align-items:center}
.topbar nav a{padding:.4rem .8rem;border-radius:8px;color:var(--muted)}
.topbar nav a.active{background:var(--panel2);color:var(--text)}
.topbar nav a.logout{color:#fca5a5}
.badge{background:var(--red);color:#fff;border-radius:10px;padding:0 .4rem;font-size:.7rem}
main{padding:1.2rem;max-width:1400px;margin:0 auto}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.2rem}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem;text-align:center}
.stat .n{font-size:1.8rem;font-weight:700}
.stat .l{color:var(--muted);font-size:.75rem;margin-top:.2rem}
.stat.bad .n{color:var(--red)} .stat.warn .n{color:var(--amber)}

/* ---- filters ---- */
.filters{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}
.filters input[type=text]{padding:.5rem .7rem;border-radius:8px;border:1px solid var(--line);
  background:var(--panel);color:var(--text)}
.filters .chk{display:flex;align-items:center;gap:.3rem;color:var(--muted)}
.filters button{padding:.5rem 1rem;border:0;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer}
.filters .reset{padding:.5rem .8rem;color:var(--muted)}

/* ---- table ---- */
.table-wrap{overflow-x:auto;background:var(--panel);border:1px solid var(--line);border-radius:12px}
table{width:100%;border-collapse:collapse}
th,td{padding:.55rem .7rem;text-align:left;border-bottom:1px solid var(--line);font-size:.82rem}
th{color:var(--muted);font-weight:600;position:sticky;top:0;background:var(--panel2)}
tr:hover td{background:rgba(255,255,255,.02)}
.nowrap{white-space:nowrap}
.ip{font-family:ui-monospace,Menlo,monospace}
.reasons{color:var(--amber);font-size:.75rem;max-width:200px}
.ua{color:var(--muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.traffic{font-size:.72rem;line-height:1.3}
.traffic .src{color:#7dd3fc;font-weight:600}
.traffic .camp{display:block;color:var(--muted)}
.traffic .ref{color:#c4b5fd}
.traffic .direct{color:var(--muted)}
.row-bot td{background:rgba(239,68,68,.06)}
.row-banned td{background:rgba(239,68,68,.14)}
.empty{text-align:center;color:var(--muted);padding:2rem}
.risk{display:inline-block;min-width:28px;text-align:center;padding:.1rem .4rem;border-radius:6px;font-weight:700}
.risk.rhi{background:rgba(239,68,68,.2);color:#fca5a5}
.risk.rlo{background:rgba(34,197,94,.15);color:#86efac}
.tag{font-size:.65rem;padding:.05rem .35rem;border-radius:5px;margin-left:.3rem;vertical-align:middle}
.tag.ban{background:var(--red);color:#fff}
.tag.auto{background:var(--amber);color:#000}
.tag.manual{background:var(--line);color:var(--text)}
.act form{margin:0}
.btn{padding:.35rem .7rem;border:0;border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:600}
.btn.ban{background:var(--red);color:#fff}
.btn.unban{background:var(--green);color:#04210f}

/* ---- pager ---- */
.pager{display:flex;gap:1rem;align-items:center;justify-content:center;margin-top:1rem;color:var(--muted)}

/* ---- stats page ---- */
h2{font-size:1rem;margin:1.6rem 0 .6rem;color:var(--text);font-weight:600}
h2 small{color:var(--muted);font-weight:400}
.stat-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem}
.period{display:flex;gap:.3rem;background:var(--panel);padding:.25rem;border-radius:10px;border:1px solid var(--line)}
.period a{padding:.4rem .8rem;border-radius:7px;color:var(--muted);font-size:.85rem}
.period a.active{background:var(--accent);color:#fff}
.site-pick select{padding:.5rem .7rem;border-radius:8px;border:1px solid var(--line);
  background:var(--panel);color:var(--text)}
.stat-controls .ctx{color:var(--muted);font-size:.85rem;margin-left:auto}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:900px){.cols2{grid-template-columns:1fr}}

/* chart */
.chart{display:flex;align-items:flex-end;gap:3px;height:160px;background:var(--panel);
  border:1px solid var(--line);border-radius:12px;padding:1rem .8rem 0;overflow-x:auto}
.chart .bar{flex:1;min-width:18px;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}
.chart .col{width:60%;min-width:8px;background:var(--green);border-radius:3px 3px 0 0;
  display:flex;align-items:flex-start;position:relative}
.chart .col .bot{width:100%;background:var(--red);border-radius:3px 3px 0 0}
.chart .lbl{font-size:.62rem;color:var(--muted);margin-top:.25rem;white-space:nowrap}
.legend{display:flex;gap:1rem;align-items:center;color:var(--muted);font-size:.78rem;margin-top:.5rem}
.legend .sw{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:.3rem;vertical-align:middle}
.legend .human{background:var(--green)} .legend .botc{background:var(--red)}
.btn.view{background:var(--panel2);color:var(--accent);text-decoration:none}
.note{margin-top:1.5rem;padding:.8rem 1rem;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;color:var(--muted);font-size:.85rem}

/* ---- settings / connect ---- */
main.narrow{max-width:760px}
h3{font-size:.9rem;margin:1.2rem 0 .5rem;color:var(--muted);font-weight:600}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.2rem;margin-bottom:1rem}
.hint{color:var(--muted);font-size:.85rem;line-height:1.5;margin:.3rem 0 .8rem}
.hint code,.note code{background:var(--panel2);padding:.1rem .35rem;border-radius:5px;font-family:ui-monospace,monospace;color:#7dd3fc}
.switch{display:flex;align-items:center;gap:.6rem;font-size:1rem;cursor:pointer}
.switch input{width:18px;height:18px;accent-color:var(--green)}
.crit-list{display:flex;flex-direction:column;gap:.6rem;margin:.5rem 0 1rem}
.chk{display:flex;align-items:center;gap:.5rem;color:var(--text);font-size:.9rem;cursor:pointer;flex-wrap:wrap}
.chk input[type=checkbox]{width:17px;height:17px;accent-color:var(--accent)}
.chk .num{width:64px;padding:.3rem .4rem;border-radius:6px;border:1px solid var(--line);
  background:var(--panel2);color:var(--text)}
.chk span:last-child{color:var(--muted);font-size:.8rem}
.actions{margin-top:1rem}
.btn.save{background:var(--accent);color:#fff;padding:.6rem 1.2rem;font-size:.9rem}
.btn[disabled]{opacity:.45;cursor:not-allowed}
.warn-line{color:var(--amber);font-size:.85rem}

.snippet{position:relative;margin:.5rem 0 1rem}
.snippet pre{background:#0b1220;border:1px solid var(--line);border-radius:10px;
  padding:1rem;overflow-x:auto;color:#d1e9ff;font-family:ui-monospace,Menlo,monospace;
  font-size:.82rem;margin:0;white-space:pre-wrap;word-break:break-all}
.snippet .copy{position:absolute;top:.5rem;right:.5rem;background:var(--accent);color:#fff;
  border:0;border-radius:7px;padding:.35rem .7rem;font-size:.75rem;cursor:pointer}
.snippet .copy:hover{filter:brightness(1.1)}
main.narrow table th{text-align:left;white-space:nowrap;width:230px;vertical-align:top}

/* steps / download */
.step{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.2rem;margin-bottom:1.2rem}
.step-h{display:flex;align-items:center;gap:.6rem;font-size:1.05rem;font-weight:600;margin-bottom:.6rem}
.step-n{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;
  border-radius:50%;background:var(--accent);color:#fff;font-size:.9rem;flex:none}
.howto{margin:.5rem 0;padding-left:1.4rem;line-height:1.8}
.howto li{margin-bottom:.6rem}
.btn.dl{display:inline-block;background:var(--green);color:#04210f;padding:.55rem 1rem;
  border-radius:8px;text-decoration:none;font-weight:600;font-size:.9rem;margin:.3rem 0}
.btn.dl:hover{filter:brightness(1.08)}
.btn.dl.sm{padding:.4rem .8rem;font-size:.8rem}
.exports{display:flex;gap:.6rem;flex-wrap:wrap;margin:.5rem 0 1rem}

/* clickable stat cards */
a.stat{text-decoration:none;color:inherit;transition:border-color .15s,transform .1s;display:block}
a.stat.link:hover{border-color:var(--accent);transform:translateY(-1px)}
a.stat .l{color:var(--accent)}

/* whitelist tag + button */
.tag.wl{background:#0ea5e9;color:#04210f}
.btn.wl-btn{background:#0ea5e9;color:#04210f}

/* ip detail */
.backlink{color:var(--muted);display:inline-block;margin-bottom:1rem}
.ip-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.ip-title{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.ip-title .mono{font-family:ui-monospace,Menlo,monospace;font-size:1.4rem;font-weight:700}
.ip-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.ip-actions form{margin:0}
.ip-actions .btn{padding:.5rem 1rem;font-size:.85rem}
.btn{background:var(--line);color:var(--text)}

/* webvisor */
.wv-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.wv-stats{display:flex;gap:1rem;flex-wrap:wrap;color:var(--text);font-size:.9rem}
.wv-stats span{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:.4rem .7rem}
.wv-controls{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.8rem}
.wv-controls .btn{padding:.45rem .8rem}
.wv-controls .sp{padding:.3rem .6rem;font-size:.8rem}
.wv-controls .sp.on{background:var(--accent);color:#fff}
.wv-controls #seek{flex:1;min-width:160px;accent-color:var(--accent)}
.wv-controls .clock{font-family:ui-monospace,monospace;color:var(--muted);min-width:54px;text-align:right}
/* компактный плеер со снимком страницы */
.wv-box{position:relative;background:#fff;border:1px solid var(--line);border-radius:10px;
  overflow:hidden;margin:0 auto}
.wv-scaler{position:absolute;left:0;top:0;transform-origin:top left}
.wv-frame{position:relative;overflow:hidden;background:#fff}
.wv-frame iframe{background:#fff}
.play-link{color:var(--accent);text-decoration:none;white-space:nowrap}
.dur{white-space:nowrap;color:var(--text)}
.dur small{color:var(--muted)}
