:root{
  --bg:#0b1020;
  --panel:#0f1629;
  --card:#121a33;
  --stroke:#1f2a4a;
  --text:#e7ecf6;
  --muted:#9aa6c5;

  --primary:#3b82f6;
  --primary2:#22d3ee;

  --ok:#22c55e;
  --warn:#f59e0b;
  --bad:#ef4444;

  --shadow: 0 20px 40px rgba(0,0,0,.45);
  --shadow-soft: 0 10px 24px rgba(0,0,0,.35);
  --r:16px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 15% -10%, rgba(59,130,246,.20), transparent 60%),
    radial-gradient(900px 500px at 85% 0%, rgba(34,211,238,.18), transparent 60%),
    var(--bg);
}

.wrap{max-width:1100px; margin:0 auto; padding:0 18px;}

.top{
  position:sticky; top:0; z-index:10;
  background: rgba(11,16,32,.75);
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--stroke);
}
.top__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}

.brand{
  display:flex; gap:12px; align-items:center;
  text-decoration:none; color:inherit;
}
.brand__mark{
  width:38px; height:38px; border-radius:12px;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  box-shadow: var(--shadow-soft);
}
.brand__text{display:flex; flex-direction:column}
.brand__name{font-weight:900; letter-spacing:.3px}
.brand__accent{color:var(--primary2)}
.brand__tag{font-size:12px; color:var(--muted); margin-top:3px}

.link{
  color:var(--muted);
  text-decoration:none;
  font-weight:700;
}
.link:hover{color:var(--text)}

.h1{
  font-size:40px;
  line-height:1.05;
  margin:0;
}
.h2{font-size:24px; margin:6px 0 0}
.sub{
  color:var(--muted);
  margin:14px 0 0;
  font-size:15px;
  line-height:1.6;
}
.kicker{
  font-size:12px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.title{font-weight:900}
.small{font-size:12px}
.muted{color:var(--muted)}

.hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:20px;
  padding:28px 0 18px;
}
@media (max-width:980px){
  .hero{grid-template-columns:1fr}
  .h1{font-size:34px}
}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)) , var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--r);
  box-shadow: var(--shadow);
  padding:18px;
}
.card--soft{
  background: var(--panel);
  box-shadow:none;
}
.card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:14px;
}

.pill{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  border:1px solid var(--stroke);
  background: rgba(59,130,246,.12);
  color:var(--primary2);
}
.pill--ok{background:rgba(34,197,94,.15);color:var(--ok)}
.pill--warn{background:rgba(245,158,11,.15);color:var(--warn)}
.pill--bad{background:rgba(239,68,68,.15);color:var(--bad)}

.form{margin-top:6px}
.field{
  display:flex;
  gap:10px;
}
@media (max-width:680px){
  .field{flex-direction:column}
}

.input{
  flex:1;
  background:#0a0f1f;
  border:1px solid var(--stroke);
  border-radius:14px;
  padding:12px 14px;
  font-size:15px;
  color:var(--text);
  outline:none;
}
.input::placeholder{color:#7f8bb0}
.input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(59,130,246,.18);
}

.btn{
  border:1px solid var(--stroke);
  background:#0a0f1f;
  color:var(--text);
  border-radius:14px;
  padding:12px 14px;
  font-weight:900;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn:hover{filter:brightness(1.1)}

.btn--primary{
  border:none;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  color:#020617;
}
.btn--primary:hover{filter:brightness(1.08)}

.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
}
.check input{margin-top:2px}

.alert{
  margin:12px 0 0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(239,68,68,.35);
  background: rgba(239,68,68,.15);
  color:#fecaca;
}

.list{
  margin:10px 0 0;
  padding-left:0;
  list-style:none;
  color:var(--muted);
}
.list li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  border-bottom:1px dashed var(--stroke);
}
.list li:last-child{border-bottom:none}

.dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#64748b;
}
.dot--ok{background:var(--ok)}
.dot--muted{background:#64748b}

.mini{
  border:1px dashed var(--stroke);
  background: var(--panel);
  border-radius:var(--r);
  padding:14px 16px;
}
.mini__label{
  font-size:12px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.mini__value{
  margin-top:6px;
  font-weight:900;
}

.pagehead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:24px 0 12px;
}
@media (max-width:680px){
  .pagehead{flex-direction:column}
}
.pagehead__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
  padding:12px 0 26px;
}
@media (max-width:980px){
  .grid{grid-template-columns:1fr}
}
.card--full{grid-column:1 / -1}

.score{
  display:flex;
  align-items:flex-end;
  gap:8px;
  margin-top:10px;
}
.score__num{
  font-size:46px;
  font-weight:1000;
}
.score__den{
  color:var(--muted);
  padding-bottom:10px;
}

.divider{
  height:1px;
  background:var(--stroke);
  margin:14px 0;
}

.badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  border:1px solid var(--stroke);
  background:#0a0f1f;
  color:var(--muted);
}
.badge--ok{color:var(--ok);background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.35)}
.badge--warn{color:var(--warn);background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.35)}
.badge--bad{color:var(--bad);background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.35)}

.kv{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:6px;
}
.kv__row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--stroke);
  border-radius:14px;
  background:#0a0f1f;
}

.chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}
.chip{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background:#0a0f1f;
  font-size:12px;
  font-weight:900;
  color:var(--muted);
}
.chip--ok{
  color:var(--ok);
  background:rgba(34,197,94,.15);
  border-color:rgba(34,197,94,.35);
}

.findings{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.finding{
  padding:14px;
  border:1px solid var(--stroke);
  border-radius:var(--r);
  background:#0a0f1f;
}
.finding__top{
  display:flex;
  align-items:center;
  gap:10px;
}
.finding__title{font-weight:1000}
.finding__fix{margin-top:10px}

.sev{
  font-size:11px;
  font-weight:1000;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background:#0a0f1f;
  color:var(--muted);
  text-transform:uppercase;
}
.sev--critical,
.sev--high{
  color:var(--bad);
  background:rgba(239,68,68,.15);
  border-color:rgba(239,68,68,.35);
}
.sev--medium{
  color:var(--warn);
  background:rgba(245,158,11,.15);
  border-color:rgba(245,158,11,.35);
}
.sev--low{
  color:#38bdf8;
  background:rgba(56,189,248,.15);
  border-color:rgba(56,189,248,.35);
}
.sev--info{color:var(--muted)}

.tablewrap{
  overflow:auto;
  border:1px solid var(--stroke);
  border-radius:var(--r);
  background:#0a0f1f;
}
.table{
  width:100%;
  border-collapse:collapse;
  min-width:360px;
}
.table th,.table td{
  padding:12px;
  border-bottom:1px solid var(--stroke);
}
.table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--muted);
  text-align:left;
}
.mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.empty{
  padding:14px;
  border-radius:var(--r);
  border:1px dashed var(--stroke);
  background:#0a0f1f;
}

.foot{
  border-top:1px solid var(--stroke);
  padding:22px 0 28px;
  background: rgba(11,16,32,.7);
}
.foot__inner{
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
