:root{
  --navy:#0f4c81; --blue:#1565c0; --blue-l:#eff6ff; --blue-b:#bfdbfe;
  --ink:#1f2733; --mut:#64748b; --line:#e2e8f0; --bg:#f1f5f9;
  --hi:#b91c1c; --hi-bg:#fef2f2; --med:#b45309; --med-bg:#fffbeb;
  --ok:#15803d; --ok-bg:#f0fdf4; --info:#1565c0;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"PingFang SC","Microsoft YaHei",system-ui,sans-serif;color:var(--ink);
  background:var(--bg);font-size:14px;line-height:1.6}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* nav */
.nav{background:var(--navy);color:#fff;padding:0 22px;display:flex;align-items:center;
  height:52px;box-shadow:0 1px 6px rgba(0,0,0,.15)}
.nav .brand{font-weight:800;font-size:16px;letter-spacing:.5px;margin-right:26px}
.nav .brand small{font-weight:400;opacity:.7;font-size:11px;margin-left:6px}
.nav a{color:#dbeafe;margin-right:18px;font-size:13.5px}
.nav a:hover{color:#fff;text-decoration:none}
.nav a.active{color:#fff;font-weight:600;border-bottom:2px solid #fff;padding-bottom:14px}
.nav .right{margin-left:auto;display:flex;align-items:center;gap:14px;font-size:13px}
.nav .right .u{opacity:.85}

.wrap{max-width:1080px;margin:24px auto;padding:0 18px}
.page-title{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:4px}
.page-sub{color:var(--mut);font-size:13px;margin-bottom:18px}

/* cards */
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px 20px;
  margin-bottom:18px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.card h2{font-size:15px;color:var(--navy);margin-bottom:12px;padding-left:9px;
  border-left:4px solid var(--blue)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* upload */
.drop{border:2px dashed var(--blue-b);border-radius:10px;background:var(--blue-l);
  padding:26px;text-align:center;color:var(--mut)}
.drop input[type=file]{margin:10px 0}
.btn{display:inline-block;background:var(--navy);color:#fff;border:none;border-radius:7px;
  padding:9px 18px;font-size:13.5px;font-weight:600;cursor:pointer}
.btn:hover{background:#0c3e6a;text-decoration:none;color:#fff}
.btn.sm{padding:5px 12px;font-size:12px}
.btn.gray{background:#64748b}
.btn.green{background:var(--ok)}

/* stat chips */
.stats{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0}
.chip{border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;border:1px solid}
.chip .n{font-size:20px;display:block}
.chip.hi{color:var(--hi);background:var(--hi-bg);border-color:#fecaca}
.chip.med{color:var(--med);background:var(--med-bg);border-color:#fde68a}
.chip.low{color:#a16207;background:#fefce8;border-color:#fef08a}
.chip.info{color:var(--info);background:var(--blue-l);border-color:var(--blue-b)}
.chip.ok{color:var(--ok);background:var(--ok-bg);border-color:#bbf7d0}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{border:1px solid var(--line);padding:8px 10px;text-align:left;vertical-align:top}
th{background:#f8fafc;color:var(--navy);font-weight:700;font-size:12.5px}
tr:hover td{background:#fbfdff}
.sev{font-weight:700;white-space:nowrap}
.sev.高{color:var(--hi)} .sev.中{color:var(--med)} .sev.低{color:#a16207} .sev.提示{color:var(--info)}

/* verdict badges */
.vb{display:inline-block;border-radius:5px;padding:1px 8px;font-size:11.5px;font-weight:700;white-space:nowrap}
.vb.PASS{color:var(--ok);background:var(--ok-bg);border:1px solid #bbf7d0}
.vb.FLAG{color:#fff;background:var(--hi);border:1px solid var(--hi)}
.vb.QUALITATIVE{color:var(--mut);background:#f1f5f9;border:1px solid var(--line)}
.vb.NA{color:#94a3b8;background:#f8fafc;border:1px solid var(--line)}
.vb.MANUAL{color:var(--med);background:var(--med-bg);border:1px solid #fde68a}
tr.flag td{background:#fef2f2}

.muted{color:var(--mut)}
.mono{font-family:"SF Mono",Menlo,monospace;font-size:12px;background:#0f172a;color:#cbd5e1;
  border-radius:7px;padding:12px 14px;overflow-x:auto;white-space:pre-wrap}
.num-list{font-family:"SF Mono",Menlo,monospace;font-size:11.5px;color:var(--navy)}

/* flash */
.flash{padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13px}
.flash.error{background:var(--hi-bg);color:var(--hi);border:1px solid #fecaca}
.flash.ok{background:var(--ok-bg);color:var(--ok);border:1px solid #bbf7d0}

/* login */
.login-box{max-width:360px;margin:80px auto;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:30px;box-shadow:0 4px 20px rgba(15,23,42,.08)}
.login-box h1{font-size:19px;color:var(--navy);text-align:center;margin-bottom:4px}
.login-box .sub{text-align:center;color:var(--mut);font-size:12px;margin-bottom:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;color:var(--mut);margin-bottom:4px}
.field input,.field select{width:100%;padding:9px 11px;border:1px solid var(--line);
  border-radius:7px;font-size:14px}
.field input:focus{outline:none;border-color:var(--blue)}
.w100{width:100%}

.tag{display:inline-block;font-size:11px;padding:1px 7px;border-radius:9px;font-weight:600}
.tag.role{background:var(--blue-l);color:var(--blue)}
small.src{color:var(--mut);font-size:11px}
.help{background:var(--blue-l);border:1px solid var(--blue-b);border-radius:8px;
  padding:10px 13px;font-size:12.5px;color:#334155;line-height:1.6}
