/* DAR WebAV — стиль (қараңғы, ықшам). */
:root{
  --bg:#0f1420; --card:#171e2e; --card2:#1e2740; --txt:#e6ebf5; --muted:#8b97b0;
  --line:#2a3350; --pri:#3d7bff; --pri2:#2f63d9;
  --crit:#ff4d5e; --high:#ff8a3d; --med:#ffd13d; --low:#5bc0de; --ok:#3ddc84;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font:15px/1.5 -apple-system,Segoe UI,Roboto,Arial,sans-serif}
.wrap{max-width:1000px;margin:0 auto;padding:16px}
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:10px 0 18px;border-bottom:1px solid var(--line);margin-bottom:18px}
.brand{font-size:20px;font-weight:700}
.brand span{color:var(--pri)} .brand small{color:var(--muted);font-weight:400;font-size:12px}
h1{font-size:22px;margin:0 0 8px} h2{font-size:18px;margin:0 0 12px}
.muted{color:var(--muted)} .danger{color:var(--crit)}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:20px;margin-bottom:18px}
.card.narrow{max-width:420px;margin:40px auto}
.flash{background:#3a1d24;border:1px solid var(--crit);color:#ffd7dc;
  padding:10px 14px;border-radius:8px;margin-bottom:14px}
label{display:block;margin:12px 0}
input[type=password]{width:100%;padding:10px;margin-top:4px;border-radius:8px;
  border:1px solid var(--line);background:var(--card2);color:var(--txt);font-size:15px}
.btn{cursor:pointer;border:0;border-radius:8px;padding:10px 16px;font-size:14px;
  font-weight:600;color:#fff}
.btn-primary{background:var(--pri)} .btn-primary:hover{background:var(--pri2)}
.btn-primary:disabled{background:#33405e;cursor:not-allowed;opacity:.6}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.btn-ghost:hover{background:var(--card2)}
.logout-form{margin:0}
.hint{font-size:12px;color:var(--muted);margin-top:14px}
code{background:#0c1120;padding:1px 5px;border-radius:4px;font-size:12px}
.foot{color:var(--muted);font-size:12px;text-align:center;padding:20px 0}

/* Түбірлер */
.roots-list{margin:10px 0}
.root-block{background:var(--card2);border:1px solid var(--line);border-radius:8px;
  padding:10px 12px;margin-bottom:8px}
.root-path{font-size:12px;color:var(--muted);margin-bottom:6px;word-break:break-all}
.children{display:flex;flex-wrap:wrap;gap:6px 18px}
.child{display:flex;align-items:center;gap:6px;margin:2px 0;font-size:14px}
.tag{font-size:10px;padding:1px 6px;border-radius:10px;background:#33405e;color:#cdd8f0}
.tag.wp{background:#1f6feb;color:#fff} .tag.ro{background:#5a2530;color:#ffb9c2}
.actions{display:flex;align-items:center;gap:12px;margin-top:14px}

/* Прогресс */
.hidden{display:none}
.progress-box{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.progress-bar{height:10px;background:var(--card2);border-radius:6px;overflow:hidden}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--pri),#5b9bff);
  transition:width .2s}
.progress-stats{display:flex;flex-wrap:wrap;gap:18px;margin-top:10px;font-size:14px}
.badge{padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}
.badge.run{background:#1f3a5f;color:#9cc4ff} .badge.ok{background:#123a26;color:var(--ok)}
.badge.err{background:#3a1d24;color:var(--crit)}
.sev-row{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.pill{font-size:12px;padding:3px 10px;border-radius:12px;background:var(--card2)}
.pill.crit b{color:var(--crit)} .pill.high b{color:var(--high)}
.pill.med b{color:var(--med)} .pill.low b{color:var(--low)}

/* Нәтиже */
.clean{color:var(--ok);font-size:16px;padding:12px}
.site-group{margin-bottom:16px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.site-head{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card2)}
.site-name{font-weight:600} .site-count{font-size:12px}
.site-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;color:#111}
.sev-critical{background:var(--crit);color:#fff} .sev-high{background:var(--high);color:#111}
.sev-medium{background:var(--med);color:#111} .sev-low{background:var(--low);color:#111}
.site-files{padding:6px 10px}
.file-row{padding:10px;border-left:3px solid var(--line);margin:8px 0;background:#131a2b;border-radius:0 8px 8px 0}
.sev-border-critical{border-left-color:var(--crit)} .sev-border-high{border-left-color:var(--high)}
.sev-border-medium{border-left-color:var(--med)} .sev-border-low{border-left-color:var(--low)}
.file-head{display:flex;align-items:center;gap:8px}
.file-path{font-size:13px;word-break:break-all;background:transparent}
.sev-dot{width:9px;height:9px;border-radius:50%;flex:none}
.sev-dot.sev-critical{background:var(--crit)} .sev-dot.sev-high{background:var(--high)}
.sev-dot.sev-medium{background:var(--med)} .sev-dot.sev-low{background:var(--low)}
.file-meta{font-size:11px;margin:4px 0 6px}
.hit{font-size:12px;padding:5px 8px;margin:4px 0;background:#0c1120;border-radius:6px}
.hit-sev{font-weight:700;font-size:10px;padding:1px 6px;border-radius:4px;background:#33405e}
.hit.sev-critical .hit-sev{background:var(--crit);color:#fff}
.hit.sev-high .hit-sev{background:var(--high);color:#111}
.hit.sev-medium .hit-sev{background:var(--med);color:#111}
.hit.sev-low .hit-sev{background:var(--low);color:#111}
.hit-id{color:var(--muted);font-family:monospace;font-size:11px}
.hit-loc{margin-top:4px;color:var(--muted)}
.hit-loc code{color:#d0d8ea;word-break:break-all}
.err{color:var(--crit)}

/* Карантин / батырмалар */
.btn-danger{background:#c0293a} .btn-danger:hover{background:#a3202f}
.btn-danger:disabled{background:#4a2a30;opacity:.6;cursor:not-allowed}
.btn.sm{padding:5px 10px;font-size:12px}
.res-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:10px 12px;margin-bottom:12px;background:var(--card2);border-radius:8px}
.chk-all{display:flex;align-items:center;gap:6px;margin:0;font-size:14px}
.file-head{gap:8px}
.file-cb{flex:none;width:16px;height:16px;cursor:pointer}
.file-quar{margin-left:auto}
.file-row.quarantined{opacity:.5;border-left-color:var(--ok)!important}
.file-row.quarantined .file-path{text-decoration:line-through}
.quar-row{padding:10px;border-left:3px solid var(--line);margin:8px 0;
  background:#131a2b;border-radius:0 8px 8px 0}
.quar-row.status-restored{opacity:.55;border-left-color:var(--med)}
.quar-row.status-backup_only{border-left-color:var(--high)}
.quar-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.quar-actions{display:flex;gap:8px;margin-top:8px}
@media(max-width:600px){.wrap{padding:10px}.card{padding:14px}
  .file-quar{margin-left:0}.file-head{flex-wrap:wrap}}
