:root{
  --ink:#0C0E13; --panel:#13161E; --panel-2:#171B25; --line:#262C39; --line-soft:#1d222d;
  --paper:#ECE6DA; --muted:#9AA1AF; --muted-dim:#6E7585;
  --amber:#E9A23B; --amber-soft:rgba(233,162,59,.10); --amber-line:rgba(233,162,59,.40);
  --green:#5BBF8A; --blue:#6AA9E0; --red:#E5685F;
  --high:#E5685F; --high-soft:rgba(229,104,95,.12); --high-line:rgba(229,104,95,.42);
  --med:#E9A23B; --med-soft:rgba(233,162,59,.10); --med-line:rgba(233,162,59,.40);
  --low:#6AA9E0; --low-soft:rgba(106,169,224,.10); --low-line:rgba(106,169,224,.36);
  --info:#9AA1AF; --info-soft:rgba(154,161,175,.08); --info-line:rgba(154,161,175,.3);
  --maxw:980px;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:"IBM Plex Sans",system-ui,-apple-system,sans-serif;
  --disp:"Space Grotesk",var(--sans);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--ink);color:var(--paper);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.016) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.016) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(circle at 50% -5%,#000 0%,transparent 70%);-webkit-mask-image:radial-gradient(circle at 50% -5%,#000 0%,transparent 70%)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:1}
a{color:var(--amber);text-decoration:none}
::selection{background:var(--amber);color:#1a1206}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:3px}

header{padding:56px 0 28px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.eyebrow .off{color:var(--muted-dim)}
h1{font-family:var(--disp);font-weight:700;font-size:clamp(34px,6vw,56px);letter-spacing:-.02em;margin:14px 0 12px}
.tagline{color:var(--muted);max-width:64ch;font-size:clamp(15px,2vw,17px)}
.tagline code{font-family:var(--mono);font-size:.92em;color:var(--paper)}
.privacy{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-family:var(--mono);font-size:12.5px;color:var(--green);background:rgba(91,191,138,.08);border:1px solid rgba(91,191,138,.25);padding:7px 13px;border-radius:6px}
.privacy .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}

.drop{margin:30px 0 10px;border:1.5px dashed var(--line);border-radius:14px;background:var(--panel);padding:54px 28px;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .15s ease}
.drop:hover{border-color:var(--amber-line);background:var(--panel-2)}
.drop.drag{border-color:var(--amber);background:var(--amber-soft);transform:scale(1.005)}
.drop .icon{font-family:var(--mono);font-size:28px;color:var(--amber);margin-bottom:14px;letter-spacing:.05em}
.drop .big{font-family:var(--disp);font-weight:600;font-size:20px;margin-bottom:8px}
.drop .small{color:var(--muted);font-size:14px}
.drop .small b{color:var(--paper);font-weight:600}
input[type=file]{display:none}

.status{margin:18px 0;font-family:var(--mono);font-size:14px;color:var(--muted)}
.status.err{color:var(--red);background:var(--high-soft);border:1px solid var(--high-line);padding:14px 16px;border-radius:8px}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--line);border-top-color:var(--amber);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px;margin-right:9px}
@keyframes spin{to{transform:rotate(360deg)}}

#results{padding-bottom:80px}
.section{margin-top:34px}
.section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;border-bottom:1px solid var(--line);padding-bottom:10px}
.section-head .hx{font-family:var(--mono);font-size:12px;color:var(--muted-dim);letter-spacing:.08em}
.section-head h2{font-family:var(--disp);font-weight:600;font-size:22px;letter-spacing:-.01em}

/* score panel */
.score-panel{display:flex;align-items:center;gap:28px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px 28px;flex-wrap:wrap}
.grade{font-family:var(--disp);font-weight:700;font-size:72px;line-height:1;width:108px;height:108px;display:flex;align-items:center;justify-content:center;border-radius:14px;border:2px solid}
.grade.g-a,.grade.g-b{color:var(--green);border-color:rgba(91,191,138,.5);background:rgba(91,191,138,.08)}
.grade.g-c{color:var(--amber);border-color:var(--amber-line);background:var(--amber-soft)}
.grade.g-d,.grade.g-f{color:var(--high);border-color:var(--high-line);background:var(--high-soft)}
.score-meta{flex:1;min-width:200px}
.score-meta .pkg{font-family:var(--mono);font-size:15px;color:var(--paper);word-break:break-all}
.score-meta .ver{font-family:var(--mono);font-size:12.5px;color:var(--muted-dim);margin-top:3px}
.score-meta .num{font-family:var(--disp);font-weight:600;font-size:20px;margin-top:12px}
.sev-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.sev-chip{font-family:var(--mono);font-size:12px;padding:5px 10px;border-radius:6px;border:1px solid}
.sev-chip.high{color:var(--high);border-color:var(--high-line);background:var(--high-soft)}
.sev-chip.medium{color:var(--med);border-color:var(--med-line);background:var(--med-soft)}
.sev-chip.low{color:var(--low);border-color:var(--low-line);background:var(--low-soft)}
.sev-chip.info{color:var(--info);border-color:var(--info-line);background:var(--info-soft)}
.sev-chip.zero{opacity:.4}

/* findings */
.finding{background:var(--panel);border:1px solid var(--line);border-left-width:3px;border-radius:9px;padding:15px 18px;margin-bottom:11px}
.finding.high{border-left-color:var(--high)}
.finding.medium{border-left-color:var(--med)}
.finding.low{border-left-color:var(--low)}
.finding.info{border-left-color:var(--info)}
.finding .top{display:flex;align-items:center;gap:11px;margin-bottom:7px;flex-wrap:wrap}
.finding .badge{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:5px;border:1px solid}
.finding.high .badge{color:var(--high);border-color:var(--high-line);background:var(--high-soft)}
.finding.medium .badge{color:var(--med);border-color:var(--med-line);background:var(--med-soft)}
.finding.low .badge{color:var(--low);border-color:var(--low-line);background:var(--low-soft)}
.finding.info .badge{color:var(--info);border-color:var(--info-line);background:var(--info-soft)}
.finding .title{font-family:var(--disp);font-weight:600;font-size:16px}
.finding .desc{color:var(--muted);font-size:14.5px}
.finding .evidence{font-family:var(--mono);font-size:12.5px;color:var(--paper);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;padding:8px 11px;margin-top:9px;word-break:break-all}
.clean{font-family:var(--mono);font-size:14px;color:var(--green);background:rgba(91,191,138,.08);border:1px solid rgba(91,191,138,.25);border-radius:9px;padding:16px 18px}

.toolbar{margin-top:26px}
.btn{font-family:var(--mono);font-size:13.5px;padding:11px 20px;border-radius:7px;border:1px solid var(--line);color:var(--paper);background:var(--panel);cursor:pointer;transition:border-color .2s ease}
.btn:hover{border-color:var(--amber-line)}
footer{border-top:1px solid var(--line);padding:26px 0 40px}
.foot{font-family:var(--mono);font-size:12px;color:var(--muted-dim);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.hidden{display:none}

@media (max-width:560px){
  header{padding:40px 0 22px}
  .drop{padding:40px 18px}
  .grade{width:88px;height:88px;font-size:56px}
  .score-panel{gap:20px}
}
