:root{
  --ink:#0b0f17; --panel:#121826; --panel2:#1b2333; --edge:#243049;
  --txt:#e6edf7; --mut:#8aa0c0; --accent:#4da3ff; --ok:#37d399; --warn:#ffb84d;
  --crit:#ff4d5e;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ink);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;}
a{color:var(--accent)}
button{font:inherit;cursor:pointer}
.hidden{display:none!important}
.center{display:flex;align-items:center;justify-content:center}

/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.card{background:var(--panel);border:1px solid var(--edge);border-radius:14px;padding:22px;width:100%;max-width:360px}
.brand{font-weight:800;letter-spacing:1px;font-size:22px;margin-bottom:2px}
.brand b{color:var(--accent)}
.sub{color:var(--mut);font-size:12px;margin-bottom:18px}
label{font-size:12px;color:var(--mut);display:block;margin:10px 0 4px}
input,select{width:100%;background:var(--ink);border:1px solid var(--edge);color:var(--txt);
  border-radius:8px;padding:11px;font-size:15px;outline:none}
input:focus,select:focus{border-color:var(--accent)}
.btn{background:var(--accent);color:#04101f;border:none;border-radius:8px;padding:11px 14px;font-weight:700;width:100%;margin-top:14px}
.btn.sm{width:auto;padding:7px 12px;font-size:13px;margin:0}
.btn.ghost{background:transparent;border:1px solid var(--edge);color:var(--txt)}
.btn.danger{background:transparent;border:1px solid var(--crit);color:var(--crit)}
.err{background:rgba(255,77,94,.12);border:1px solid rgba(255,77,94,.4);color:#ffd0d4;
  padding:9px 12px;border-radius:8px;font-size:13px;margin-top:10px}

/* shell */
.top{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:10px;
  padding:12px 14px;background:var(--panel);border-bottom:1px solid var(--edge)}
.top .brand{font-size:16px;margin:0}
.top .who{margin-left:auto;color:var(--mut);font-size:12px}
.tabs{display:flex;gap:6px;padding:10px 12px;overflow-x:auto;background:var(--ink);
  border-bottom:1px solid var(--edge);position:sticky;top:49px;z-index:9}
.tab{white-space:nowrap;background:var(--panel2);border:1px solid var(--edge);color:var(--mut);
  padding:8px 14px;border-radius:999px;font-size:13px}
.tab.active{background:var(--accent);color:#04101f;border-color:var(--accent);font-weight:700}
.wrap{padding:14px;max-width:920px;margin:0 auto}
h1{font-size:17px;margin:2px 0 12px}

/* scanner */
.cam{position:relative;background:#000;border-radius:14px;overflow:hidden;aspect-ratio:3/4;max-height:62vh;margin:auto}
.cam video,.cam canvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cam canvas{pointer-events:none}
.scanbar{display:flex;gap:8px;align-items:center;margin:12px 0}
.pill{font-size:12px;color:var(--mut);background:var(--panel2);border:1px solid var(--edge);
  padding:5px 10px;border-radius:999px}
.pill.live{color:var(--ok);border-color:rgba(55,211,153,.4)}
.lastplate{font-family:ui-monospace,Menlo,monospace;font-weight:800;font-size:26px;letter-spacing:2px}
.flash{animation:flash 1s ease}
@keyframes flash{0%{background:rgba(255,77,94,.35)}100%{background:transparent}}

/* tables / cards */
.panel{background:var(--panel);border:1px solid var(--edge);border-radius:12px;overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:13px}
th{ text-align:left;color:var(--mut);text-transform:uppercase;font-size:10px;letter-spacing:.5px;
  padding:9px 10px;background:var(--panel2)}
td{padding:9px 10px;border-top:1px solid var(--edge)}
.mono{font-family:ui-monospace,Menlo,monospace;font-weight:700}
.tag{font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px}
.tag.CRITICAL{background:var(--crit);color:#fff}.tag.HIGH{background:#ff7a1a;color:#fff}
.tag.MEDIUM{background:var(--warn);color:#1a1205}.tag.LOW{background:#586079;color:#fff}
.hit{color:var(--crit);font-weight:800}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.stat{background:var(--panel);border:1px solid var(--edge);border-radius:12px;padding:14px}
.stat .n{font-size:26px;font-weight:800}.stat .l{color:var(--mut);font-size:12px}
.row{display:flex;gap:8px;flex-wrap:wrap;align-items:end}
.row>div{flex:1;min-width:120px}
.note{color:var(--mut);font-size:12px;margin:8px 0}
.banner{font-size:12px;border-radius:8px;padding:9px 12px;margin-bottom:12px}
.banner.warn{background:rgba(255,184,77,.12);border:1px solid rgba(255,184,77,.4);color:#ffe1b0}
.banner.ok{background:rgba(55,211,153,.12);border:1px solid rgba(55,211,153,.35);color:#bff3df}
