: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; --violet:#B58BE0; --red:#E5685F;
  --maxw:1180px;
  --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:rgba(229,104,95,.12);border:1px solid rgba(229,104,95,.3);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}
.section-head .count{font-family:var(--mono);font-size:13px;color:var(--amber);margin-left:auto}

.ov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.ov{background:var(--panel);padding:16px 18px}
.ov .k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-dim);margin-bottom:7px}
.ov .v{font-family:var(--mono);font-size:15px;color:var(--paper);word-break:break-word;line-height:1.45}
.ov .v.amber{color:var(--amber)}

/* protocol breakdown bars */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:110px 1fr 92px;align-items:center;gap:14px;font-family:var(--mono);font-size:13px}
.bar-label{color:var(--paper)}
.bar-track{height:14px;background:var(--panel-2);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;background:var(--amber);opacity:.85}
.bar-val{color:var(--muted-dim);text-align:right;font-size:12px}

/* tables */
.tbl-wrap{border:1px solid var(--line);border-radius:10px;overflow:auto;background:var(--panel)}
table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:12.5px}
thead th{position:sticky;top:0;background:var(--panel-2);color:var(--muted-dim);text-align:left;font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:11px;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:8px 12px;border-top:1px solid var(--line-soft);color:var(--paper);white-space:nowrap;vertical-align:top}
tbody tr:hover{background:var(--panel-2)}
td.num{color:var(--muted-dim);text-align:right}
td.info{white-space:normal;color:var(--muted);min-width:240px;word-break:break-word}
td.len{text-align:right;color:var(--muted)}
.pkt-list .tbl-wrap{max-height:460px}
.conv-bytes{text-align:right}

/* protocol color chips */
.proto{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11.5px;border:1px solid transparent}
.p-tcp{color:var(--amber);background:var(--amber-soft);border-color:var(--amber-line)}
.p-udp{color:var(--green);background:rgba(91,191,138,.1);border-color:rgba(91,191,138,.3)}
.p-icmp,.p-icmpv6{color:var(--blue);background:rgba(106,169,224,.1);border-color:rgba(106,169,224,.3)}
.p-arp{color:var(--muted);background:var(--panel-2);border-color:var(--line)}
.p-dns,.p-mdns,.p-http,.p-tls,.p-ssh,.p-other{color:var(--violet);background:rgba(181,139,224,.1);border-color:rgba(181,139,224,.3)}

.more{font-family:var(--mono);font-size:12px;color:var(--muted-dim);padding:10px 12px;border-top:1px solid var(--line-soft)}
.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}
  .ov-grid{grid-template-columns:1fr 1fr}
  .bar-row{grid-template-columns:84px 1fr 70px;gap:10px}
}
