:root{
  --bg:#0f1720; --panel:#172230; --panel2:#1e2c3c; --line:#2b3c50;
  --text:#e6edf3; --muted:#93a4b7; --accent:#3d8bfd; --accent2:#2563eb;
  --ok:#2ea043; --ok-bg:#0f2a17; --warn:#d29922; --warn-bg:#2a2109;
  --bad:#f85149; --bad-bg:#2a1010; --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font:15px/1.5 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1100px;margin:0 auto;padding:24px 20px 80px}

/* Topbar */
.topbar{display:flex;align-items:center;gap:22px;padding:12px 22px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{font-weight:700;font-size:17px;color:var(--text);display:flex;align-items:center;gap:8px}
.logo{font-size:20px}
.topbar nav{display:flex;gap:18px;flex:1}
.topbar nav a{color:var(--muted);font-weight:500}
.topbar nav a:hover{color:var(--text);text-decoration:none}
.user{display:flex;align-items:center;gap:10px}
.uname{color:var(--muted)}
.role{font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;
  border-radius:20px;background:var(--panel2);border:1px solid var(--line)}
.role-admin{color:#d29922;border-color:#5a4a10}
.inline{display:inline}

/* Buttons */
button,.btn{font:inherit;cursor:pointer;border-radius:9px;border:1px solid var(--line);
  background:var(--panel2);color:var(--text);padding:9px 16px;font-weight:600}
button:hover,.btn:hover{border-color:var(--accent);text-decoration:none}
.btn-primary{background:var(--accent2);border-color:var(--accent2);color:#fff}
.btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.btn-ghost{background:transparent;padding:6px 12px}
.btn-danger{color:var(--bad);border-color:#5a1f1f;background:transparent}
.btn-danger:hover{background:var(--bad-bg);border-color:var(--bad)}
.btn-sm{padding:5px 11px;font-size:13px}

/* Cards / panels */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin-bottom:20px}
.card h2{margin:0 0 4px}
h1{margin:0 0 20px;font-size:26px}
.muted{color:var(--muted)}
.row{display:flex;gap:16px;flex-wrap:wrap}
.grow{flex:1}

/* Forms */
label{display:block;font-size:13px;color:var(--muted);margin:0 0 5px;font-weight:600}
input,select,textarea{width:100%;padding:10px 12px;background:var(--bg);
  border:1px solid var(--line);border-radius:9px;color:var(--text);font:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
.field{margin-bottom:14px}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:1fr 1fr 1fr}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:720px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Flash */
.flash{padding:12px 16px;border-radius:9px;margin-bottom:16px;border:1px solid}
.flash-error{background:var(--bad-bg);border-color:#5a1f1f;color:#ffb4ab}
.flash-ok{background:var(--ok-bg);border-color:#1f5a2f;color:#93e6a8}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:13px;font-weight:600}
tr:hover td{background:var(--panel2)}

/* Badges */
.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;border:1px solid}
.b-ok{background:var(--ok-bg);color:#93e6a8;border-color:#1f5a2f}
.b-warn{background:var(--warn-bg);color:#f0cd6b;border-color:#5a4a10}
.b-bad{background:var(--bad-bg);color:#ffb4ab;border-color:#5a1f1f}
.b-pending{background:var(--panel2);color:var(--muted);border-color:var(--line)}

/* Login */
.login-wrap{max-width:380px;margin:9vh auto}
.login-wrap .logo{font-size:40px;display:block;text-align:center;margin-bottom:6px}
.login-wrap h1{text-align:center;font-size:22px}

/* Line item */
.line{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}
.line.found{border-left:4px solid var(--warn)}
.line.not_found{border-left:4px solid var(--ok)}
.line.pending{border-left:4px solid var(--muted)}
.line-head{display:flex;gap:14px;align-items:center;padding:14px 18px;background:var(--panel2)}
.line-head img{width:46px;height:46px;object-fit:contain;background:#fff;border-radius:6px}
.line-body{padding:16px 18px}
.ids{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.id-chip{font-size:12px;background:var(--bg);border:1px solid var(--line);
  border-radius:6px;padding:2px 8px;color:var(--muted)}
.id-chip b{color:var(--text)}
.verdict{padding:12px 16px;border-radius:9px;margin:10px 0;border:1px solid}
.verdict.warn{background:var(--warn-bg);border-color:#5a4a10}
.verdict.ok{background:var(--ok-bg);border-color:#1f5a2f}
.verdict-title{font-weight:700;margin-bottom:4px}
.src-line{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);margin:3px 0}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.dot-hit{background:var(--warn)} .dot-miss{background:var(--ok)}

/* Dropzone */
.dropzone{border:2px dashed var(--line);border-radius:10px;padding:18px;text-align:center;
  color:var(--muted);cursor:pointer;transition:.15s;margin-top:8px}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--panel2);color:var(--text)}
.filelist{list-style:none;padding:0;margin:8px 0 0}
.filelist li{display:flex;justify-content:space-between;align-items:center;
  padding:6px 10px;border:1px solid var(--line);border-radius:8px;margin-bottom:6px;font-size:13px}
.req-note{font-size:13px;color:var(--warn);margin-top:6px}

/* Analysis */
.analysis{margin-top:12px;padding:14px 16px;background:var(--bg);border:1px solid var(--line);border-radius:10px}
.signal{padding:8px 0;border-bottom:1px solid var(--line)}
.signal:last-child{border-bottom:none}
.sev{font-size:11px;font-weight:700;text-transform:uppercase;padding:1px 7px;border-radius:12px;margin-right:8px}
.sev-high{background:var(--bad-bg);color:#ffb4ab}
.sev-medium{background:var(--warn-bg);color:#f0cd6b}
.sev-low{background:var(--panel2);color:var(--muted)}
.ai-box{margin-top:12px;padding:14px 16px;border-radius:10px;
  background:linear-gradient(180deg,#12233a,#0f1c2e);border:1px solid #274063}
.ai-box .ai-label{font-size:12px;color:#7db3ff;font-weight:700;letter-spacing:.5px}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--muted);
  border-top-color:transparent;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.hr{height:1px;background:var(--line);border:0;margin:18px 0}
.right{text-align:right}
.nowrap{white-space:nowrap}
.small{font-size:13px}
