:root{
  --bg:#0f1115; --card:#181b22; --line:#262b36; --txt:#e6e9ef; --mut:#8a93a6;
  --acc:#4f8cff; --ok:#2ecc71; --warn:#f1c40f; --err:#e74c3c; --pw:#11141a;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font:14px/1.45 system-ui,Segoe UI,Roboto,sans-serif;padding:0 16px 40px}
h1,h2{margin:0 0 12px}
a{color:var(--acc);text-decoration:none}
code{background:#000;padding:1px 4px;border-radius:4px;font-size:12px}
.muted{color:var(--mut);font-weight:400}.small{font-size:12px}

.topbar{display:flex;align-items:center;gap:16px;padding:14px 0;
  border-bottom:1px solid var(--line);margin-bottom:16px;position:sticky;top:0;
  background:var(--bg);z-index:5}
.topbar .stats{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.logout{margin-left:auto}
.chip{background:var(--card);border:1px solid var(--line);padding:3px 9px;
  border-radius:20px;font-size:12px}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-bottom:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.span2{grid-column:span 2}
@media(max-width:700px){.span2{grid-column:auto}}

input,textarea,select,button{font:inherit;color:var(--txt);background:#0d0f14;
  border:1px solid var(--line);border-radius:8px;padding:8px 10px;width:100%}
textarea{resize:vertical;font-family:ui-monospace,monospace}
button{background:var(--acc);border:0;cursor:pointer;font-weight:600;width:auto;padding:9px 16px}
button:hover{filter:brightness(1.1)}
button.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
button.danger{background:var(--err)} button.danger.ghost{background:transparent;color:var(--err);border-color:var(--err)}
.btn{display:inline-block;padding:9px 16px;border-radius:8px}
form>*{margin-bottom:8px}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.col{display:flex;flex-direction:column;gap:6px}
.col label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--mut)}
.chk{display:flex;align-items:center;gap:6px;width:auto}
.chk input{width:auto}
hr{border:0;border-top:1px solid var(--line);margin:12px 0}

.alert{padding:10px 14px;border-radius:8px;margin:10px 0}
.alert.ok{background:#10301c;border:1px solid #1e6b3c}
.alert.err{background:#3a1414;border:1px solid #7a2424}
.alert.warn{background:#322a0c;border:1px solid #6b5a1e}
.alert ul{margin:8px 0 0;padding-left:18px}

.progress{margin-top:10px;color:var(--mut);font-size:13px}
.domains{display:flex;flex-wrap:wrap;gap:6px;max-height:160px;overflow:auto}
.dpill{background:#0d0f14;border:1px solid var(--line);border-radius:8px;padding:4px 9px;font-size:12px}
.dpill b{color:var(--ok)}

.filters select,.filters input{width:auto;min-width:130px}
.tablewrap{overflow:auto;max-height:560px;border:1px solid var(--line);border-radius:8px}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{padding:7px 10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
th{position:sticky;top:0;background:#0d0f14}
td.pw{font-family:ui-monospace,monospace;color:var(--mut)}
.badge{font-size:11px;padding:2px 7px;border-radius:12px;border:1px solid var(--line)}
.s-valid .badge,.badge.s-valid{color:var(--ok);border-color:var(--ok)}
.badge.s-invalid_auth{color:var(--err);border-color:var(--err)}
.badge.s-timeout,.badge.s-proxy_error{color:var(--warn);border-color:var(--warn)}
.badge.s-not_checked{color:var(--mut)}

.login-body{display:grid;place-items:center;min-height:100vh}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:28px;width:320px;display:flex;flex-direction:column;gap:12px}
.login-card label{display:flex;flex-direction:column;gap:5px;font-size:13px}

/* --- тосты --- */
#toasts{position:fixed;top:14px;right:14px;z-index:50;display:flex;flex-direction:column;gap:8px;max-width:380px}
.toast{padding:11px 15px;border-radius:9px;font-size:13px;box-shadow:0 6px 20px rgba(0,0,0,.4);
  border:1px solid var(--line);animation:slidein .2s ease}
.toast.ok{background:#10301c;border-color:#1e6b3c}
.toast.warn{background:#322a0c;border-color:#6b5a1e}
.toast.err{background:#3a1414;border-color:#7a2424}
.toast.hide{opacity:0;transition:opacity .5s}
@keyframes slidein{from{transform:translateX(30px);opacity:0}to{transform:none;opacity:1}}

/* статусы прокси */
.badge.s-invalid{color:var(--err);border-color:var(--err)}
.badge.s-valid{color:var(--ok);border-color:var(--ok)}

/* --- дашборд по доменам --- */
.dashboard{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:12px 16px;margin-bottom:14px}
.metric{display:flex;flex-direction:column;min-width:120px;padding:6px 14px;
  border:1px solid var(--line);border-radius:10px;background:#0d0f14}
.metric-num{font-size:22px;font-weight:700;line-height:1.1}
.metric-lbl{font-size:12px;color:var(--mut)}
.metric.ok .metric-num{color:var(--ok)}
.metric.err .metric-num{color:var(--err)}

/* активная "булавка" */
button.ghost.active{border-color:var(--acc);color:var(--acc)}
td.num{text-align:right;font-variant-numeric:tabular-nums}

/* статусы логов (доп. типы ошибок) */
.badge.s-banner_error,.badge.s-conn_refused,.badge.s-dns_error,.badge.s-ssh_error{
  color:var(--warn);border-color:var(--warn)}

/* --- индикатор шифрования в шапке --- */
.lock-badge{font-size:12px;color:var(--ok);border:1px solid var(--ok);
  border-radius:6px;padding:2px 8px;white-space:nowrap}
.topbar form{margin:0}
button.small{font-size:12px;padding:4px 10px}

/* страница разблокировки использует .login-card — доп. стили для подсказки */
.login-card .muted{color:var(--mut)}
.login-card .alert{margin-bottom:10px}

/* --- счётчик валидных по домену в строке --- */
td.dom-ok{color:var(--ok);font-variant-numeric:tabular-nums;font-weight:600}
td.dom-dead{color:var(--err);font-variant-numeric:tabular-nums;font-weight:600}

/* --- теги наличия кода в инжекторе --- */
.tag-ok{color:var(--ok);border:1px solid var(--ok);border-radius:6px;padding:1px 8px;font-size:12px}
.tag-dead{color:var(--err);border:1px solid var(--err);border-radius:6px;padding:1px 8px;font-size:12px}

/* плитки-кнопки статистики инжекта */
button.metric{cursor:pointer;font:inherit;text-align:left;background:#0d0f14}
button.metric:hover{border-color:var(--acc)}
