:root{
  --bg:#0b1020; --bg2:#0f1629; --panel:#121a30; --panel2:#0e1526;
  --line:#1e293b; --line2:#243049;
  --txt:#e2e8f0; --muted:#94a3b8; --muted2:#64748b;
  --accent:#6366f1; --accent2:#818cf8;
  --radius:14px; --shadow:0 8px 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%,#15203f 0,var(--bg) 55%);color:var(--txt);
  font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2{margin:0 0 .3em;letter-spacing:-.4px}
h1{font-size:26px}h2{font-size:17px}
.muted{color:var(--muted)}.xs{font-size:12px}.nowrap{white-space:nowrap}
.container{width:100%;max-width:1080px;margin:0 auto;padding:24px 20px;flex:1}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--line);background:rgba(11,16,32,.8);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}
.brand{font-size:18px;font-weight:600;color:var(--txt);display:flex;gap:8px;align-items:center}
.brand b{color:var(--accent2);font-weight:700}.brand span{font-weight:500}
.topnav{display:flex;align-items:center;gap:16px}
.topnav .who{color:var(--muted);font-size:13px}
.inline{display:inline}

/* buttons */
.btn{border:1px solid var(--line2);background:var(--panel);color:var(--txt);padding:10px 16px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;transition:.15s}
.btn:hover{border-color:var(--accent);transform:translateY(-1px)}
.btn.primary{background:linear-gradient(180deg,var(--accent2),var(--accent));border-color:transparent;color:#fff}
.btn.ghost{background:transparent}
.btn.danger{color:#fca5a5;border-color:#3f1d1d}
.btn.danger:hover{border-color:#ef4444}
.btn.sm{padding:7px 12px;font-size:13px}
.btn.block{width:100%}

/* auth */
.authwrap{display:flex;align-items:center;justify-content:center;padding:24px 0 12px}
.authcard{width:380px;max-width:100%;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);text-align:center}
.authlogo{font-size:40px}
.authcard h1{font-size:24px;margin:.2em 0}
.tabs{display:flex;gap:6px;background:var(--panel2);border-radius:10px;padding:4px;margin:18px 0}
.tabs a{flex:1;padding:9px;border-radius:8px;color:var(--muted);font-weight:600;font-size:14px}
.tabs a.active{background:var(--accent);color:#fff}
.tabs a:hover{text-decoration:none}
.authform{display:flex;flex-direction:column;gap:14px;text-align:left;margin-top:8px}
.authform label{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
input,textarea{background:var(--bg2);border:1px solid var(--line2);color:var(--txt);border-radius:10px;padding:11px 13px;font:inherit;width:100%}
input:focus,textarea:focus{outline:none;border-color:var(--accent)}
.alert{border-radius:10px;padding:11px 14px;font-size:13px;margin-bottom:6px}
.alert.error{background:#2a1416;border:1px solid #4c1d1d;color:#fca5a5}

/* hero / scan form */
.hero{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:26px;box-shadow:var(--shadow)}
.scanform{display:flex;gap:12px;align-items:flex-start;margin-top:14px}
.scanform textarea{flex:1;resize:vertical;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:14px}
.scanform .btn{white-space:nowrap;height:fit-content}
.scanform.dragover textarea{border-color:var(--accent);border-style:dashed;background:color-mix(in srgb,var(--accent) 10%,var(--bg2))}
.uploadrow{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:12px}
.uploadrow label.btn{margin:0}
#csvInfo{font-weight:600}
.progress-area{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.prog{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:11px 14px}
.prog .ph{display:flex;justify-content:space-between;font-size:13px;margin-bottom:7px}
.prog .ph .host{font-weight:600}

/* bars */
.bar{height:7px;background:var(--panel2);border-radius:6px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .4s}
.bar.big{height:12px;margin:18px 0}

/* sites grid */
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:block;color:var(--txt);transition:.15s}
.card:hover{border-color:var(--accent);transform:translateY(-2px);text-decoration:none;box-shadow:var(--shadow)}
.card.site.scanning,.card.site.queued{opacity:.85}
.site-top{display:flex;gap:14px;align-items:center}
.site-host{font-weight:700;font-size:15px;word-break:break-all}
.site-status{color:var(--muted);font-size:13px;margin:10px 0 8px}
.site-meta{display:flex;flex-direction:column;gap:5px}
.sevrow{display:flex;gap:6px;margin-top:14px}
.chip{display:inline-flex;min-width:30px;justify-content:center;padding:3px 8px;border-radius:7px;font-size:12px;font-weight:700;color:var(--p);background:color-mix(in srgb,var(--p) 14%,transparent);border:1px solid color-mix(in srgb,var(--p) 35%,transparent)}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:50px;border:1px dashed var(--line2);border-radius:var(--radius)}

/* pills */
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;color:var(--p);background:color-mix(in srgb,var(--p) 16%,transparent);border:1px solid color-mix(in srgb,var(--p) 40%,transparent);width:fit-content}
.pill.sev{min-width:74px;text-align:center}

/* score ring (conic) */
.ring{--val:0;--c:#6366f1;width:84px;height:84px;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(var(--c) calc(var(--val)*1%),var(--line) 0)}
.ring::after{content:"";position:absolute;width:64px;height:64px;border-radius:50%;background:var(--panel)}
.ring span{position:relative;font-size:22px;font-weight:800}
.ring span small{font-size:11px;color:var(--muted);font-weight:600}
.ring.sm{width:56px;height:56px}.ring.sm::after{width:42px;height:42px}.ring.sm span{font-size:16px}

/* report */
.back{display:inline-block;color:var(--muted);font-size:13px;margin-bottom:14px}
.report-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;margin-bottom:20px}
.report-head .url{word-break:break-all;font-size:13px}
.verdict-banner{--p:#22c55e;border:1px solid color-mix(in srgb,var(--p) 45%,transparent);background:color-mix(in srgb,var(--p) 12%,transparent);border-radius:12px;padding:12px 18px;text-align:right;min-width:200px}
.verdict-banner .vlabel{font-size:22px;font-weight:800;color:var(--p)}
.verdict-banner .vnote{font-size:12px;color:var(--muted)}

.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:22px}
.kpi{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:130px}
.kpi .ring{position:relative}
.kpi-num{font-size:34px;font-weight:800}
.kpi-cap{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* donut */
.donut{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;position:relative}
.donut-hole{width:50px;height:50px;border-radius:50%;background:var(--panel);display:grid;place-items:center;text-align:center;line-height:1}
.donut-hole b{font-size:17px}.donut-hole span{font-size:9px;color:var(--muted)}

/* trend */
.spark{width:100%;height:46px}
.trend-delta{font-size:12px;font-weight:700;margin-top:2px}

/* columns */
.cols{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}

/* category bars */
.catbar{display:grid;grid-template-columns:1fr 90px 30px;align-items:center;gap:10px;padding:6px 0}
.catbar-label{font-size:13px}
.catbar-track{background:var(--panel2);height:9px;border-radius:6px;overflow:hidden}
.catbar-track i{display:block;height:100%;border-radius:6px}
.catbar-val{font-weight:800;text-align:right;font-size:14px}

/* filters */
.filters{display:flex;gap:6px;flex-wrap:wrap}
.fbtn{border:1px solid var(--line2);background:transparent;color:var(--muted);border-radius:8px;padding:5px 9px;font-size:11px;font-weight:700;cursor:pointer}
.fbtn.on{color:var(--p);border-color:color-mix(in srgb,var(--p) 50%,transparent);background:color-mix(in srgb,var(--p) 12%,transparent)}
.fbtn b{opacity:.8}

/* findings table */
table.findings{width:100%;border-collapse:collapse;font-size:13px}
.findings th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;border-bottom:1px solid var(--line)}
.findings td{padding:10px;border-bottom:1px solid var(--line);vertical-align:top}
.owasp{font-family:ui-monospace,monospace;font-size:12px;color:var(--muted);background:var(--panel2);padding:2px 7px;border-radius:6px}
.fixbtn{display:block;margin-top:6px;background:transparent;border:none;color:var(--accent2);font-size:12px;cursor:pointer;padding:0;font-weight:600}
.fix{margin-top:8px;background:var(--panel2);border:1px solid var(--line2);border-left:3px solid var(--accent);border-radius:8px;padding:10px 12px;font-size:13px;color:#cbd5e1}

.actions{display:flex;gap:10px;margin:22px 0;align-items:center;flex-wrap:wrap}
.scanning{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px;text-align:center}
.foot{text-align:center;color:var(--muted2);font-size:12px;padding:24px}

/* ---- About / what it does ---- */
.about{margin-top:30px;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.about-head{text-align:center;max-width:680px;margin:0 auto 20px}
.about-head h2{font-size:20px}
.about-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:14px}
.about-card{display:flex;gap:12px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:15px;transition:.15s}
.about-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.ac-ic{font-size:22px;line-height:1.2;flex:0 0 auto}
.ac-t{font-weight:700;font-size:14px;margin-bottom:3px}
.ac-d{color:var(--muted);font-size:12.5px;line-height:1.45}

/* ---- Footer (distinct dark design) ---- */
.sitefooter{margin-top:46px;background:linear-gradient(180deg,#0c1226,#080d1b);border-top:1px solid var(--line);position:relative}
.sitefooter::before{content:"";position:absolute;top:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent)}
.sf-inner{max-width:1080px;margin:0 auto;padding:34px 20px 22px;display:grid;grid-template-columns:2.2fr 1fr 1.2fr;gap:34px}
.sf-logo{font-size:19px;font-weight:600;margin-bottom:10px}
.sf-logo b{color:var(--accent2);font-weight:800}
.sf-tag{color:var(--muted);font-size:13px;line-height:1.6;max-width:420px;margin:0 0 10px}
.sf-note{color:#fcd34d;font-size:12px;margin:0}
.sf-h{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted2);margin-bottom:12px}
.sf-author{font-weight:800;font-size:15px;letter-spacing:.3px}
.sf-muted{color:var(--muted);font-size:13px;margin-top:3px}
.sf-chip{display:flex;align-items:center;gap:7px;color:var(--txt);background:rgba(99,102,241,.08);border:1px solid var(--line2);border-radius:9px;padding:8px 12px;margin-bottom:9px;font-size:13px;width:fit-content;transition:.15s}
.sf-chip:hover{border-color:var(--accent);text-decoration:none;transform:translateX(2px)}
.sf-soc{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:5px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;font-style:normal}
.sf-bar{border-top:1px solid var(--line);text-align:center;color:var(--muted2);font-size:12px;padding:14px 20px;display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}
.sf-dot{opacity:.5}
@media(max-width:760px){ .sf-inner{grid-template-columns:1fr;gap:24px} }

/* nav alert badge */
.alertlink{position:relative}
.badge{display:inline-block;min-width:17px;height:17px;line-height:17px;text-align:center;background:#ef4444;color:#fff;border-radius:9px;font-size:10px;font-weight:800;padding:0 4px;margin-left:4px;vertical-align:top}

/* schedule + settings rows */
.sched{margin-bottom:16px}
.schedrow{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:6px}
.schedrow select{background:var(--bg2);border:1px solid var(--line2);color:var(--txt);border-radius:8px;padding:8px 10px;font:inherit}

/* alerts */
.alertlist{display:flex;flex-direction:column;gap:12px}
.alertcard{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--p);border-radius:12px;padding:14px 16px}
.alertcard-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.alertreasons{margin:8px 0 6px;padding-left:18px;color:#cbd5e1;font-size:13px}
.alertreasons li{margin:2px 0}

.kpis.fleet .kpi{min-height:120px}

@media(max-width:860px){
  .kpis{grid-template-columns:repeat(3,1fr)}
  .cols{grid-template-columns:1fr}
  .scanform{flex-direction:column}.scanform .btn{width:100%}
}
