/* ===== VRVS design system — Ventota house style ===== */
:root{
  --ink:#0d1b39; --ink-2:#16294f; --primary:#1f4fd8; --primary-600:#1a44bd;
  --gold:#c8a24a; --teal:#0f7c6c; --danger:#d64545;
  --danger-bg:#fdecec; --ok-bg:#e8f5ef; --amber-bg:#fbf4e2;
  --bg:#eef1f6; --card:#fff; --line:#e4e8f0; --line-2:#d7dce6;
  --text:#1a2338; --muted:#697089; --hint:#8b91a6; --radius:10px;
  --shadow:0 1px 2px rgba(13,27,57,.06),0 6px 20px rgba(13,27,57,.05);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
h1,h2,h3,h4{font-family:'Archivo','Inter',sans-serif;margin:0;letter-spacing:-.01em}
a{color:var(--primary);text-decoration:none} a:hover{text-decoration:underline}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.86em;background:#eef1f7;padding:1px 6px;border-radius:5px;color:var(--ink-2)}
.hint{color:var(--hint);font-size:12px} .muted{color:var(--muted)}
.flagtxt{color:var(--danger);font-weight:600} .oktxt{color:var(--teal);font-weight:600}

/* ---- top chrome ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--ink);color:#fff;padding:11px 18px;gap:12px}
.brandwrap{display:flex;align-items:center;gap:12px;min-width:0}
.brandlogo{height:28px;width:auto;display:block;filter:brightness(0) invert(1)}
.brandsep{width:1px;height:26px;background:rgba(255,255,255,.22);flex:0 0 1px}
.brand{font-family:'Archivo';font-weight:800;font-size:14.5px;color:#fff;line-height:1.15}
.brand .abbr{color:#9fb0d6;font-weight:700}
.motto{font-size:10.5px;color:#a9b4cd;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}
.userbox{display:flex;align-items:center;gap:9px;font-size:13px;color:#c9d2e6;white-space:nowrap}
.userbox a{color:#c9d2e6}.userbox a:hover{color:#fff}
.ubadge{font-size:10px;font-weight:700;letter-spacing:.06em;padding:3px 8px;border-radius:5px;background:var(--gold);color:#3a2d05}
.ubadge.admin{background:var(--gold);color:#3a2d05} .ubadge.member{background:#2b4a86;color:#dfe8fb}
.subbar{background:var(--ink-2);color:#aeb9d4;font-size:11.5px;padding:6px 18px;letter-spacing:.02em}

/* ---- nav ---- */
.mainnav{display:flex;gap:2px;background:#fff;border-bottom:1px solid var(--line);padding:0 12px;overflow-x:auto;white-space:nowrap}
.mainnav a{padding:13px 12px;font-size:13px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;text-decoration:none}
.mainnav a:hover{color:var(--ink);text-decoration:none}
.mainnav a.on{color:var(--ink);border-bottom-color:var(--gold)}
.mainnav a b{color:var(--gold);font-family:'Archivo';font-weight:800;margin-right:5px;font-size:12px}
.navsep{align-self:center;font-size:10px;letter-spacing:.12em;color:var(--hint);padding:0 6px 0 14px;font-weight:700}

.wrap{max-width:1120px;margin:0 auto;padding:22px 18px 64px}
.foot{max-width:1120px;margin:10px auto 0;padding:20px 18px;color:var(--hint);font-size:12px;text-align:center;border-top:1px solid var(--line)}

/* ---- headings / modules ---- */
h2.mod{font-size:19px;font-weight:800;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
h2.mod span{font-family:'Archivo';font-size:11px;font-weight:800;letter-spacing:.06em;color:#3a2d05;background:var(--gold);padding:4px 9px;border-radius:6px}
h3{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:10px}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:16px;box-shadow:var(--shadow)}
.card.ok{border-color:#bfe0cc;background:var(--ok-bg)}
.card.err{border-color:#f0cccc;background:var(--danger-bg)}
.card.muted{background:#f7f9fc}
.card.warn{border-color:#eddcae;background:var(--amber-bg)}
.cols{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font:inherit;font-weight:600;font-size:13.5px;
  border-radius:var(--radius);border:1px solid var(--line-2);background:#fff;color:var(--ink);padding:9px 15px;cursor:pointer;transition:.15s;text-decoration:none}
.btn:hover{background:#f6f8fc;border-color:var(--line);text-decoration:none}
.btn:active{transform:scale(.985)}
.btn.sm{padding:6px 10px;font-size:12.5px;border-radius:8px}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-600)}
.btn.ok{background:var(--ok-bg);border-color:#bfe0cc;color:var(--teal)}
.btn.ok:hover{background:#dcefe7}
.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn.danger:hover{background:#c33b3b}
.btn.block{width:100%}
.x{border:0;background:transparent;color:var(--danger);font-size:17px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:6px}
.x:hover{background:var(--danger-bg)}

/* ---- forms ---- */
label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin:0 0 6px}
input,select,textarea{width:100%;height:42px;border:1px solid var(--line-2);border-radius:10px;padding:0 12px;font:inherit;font-size:14px;background:#fbfcfe;color:var(--text);margin-bottom:14px;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(31,79,216,.12);background:#fff}
select{cursor:pointer}
.filterform{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.filterform input,.filterform select{margin-bottom:0;height:38px}
.inline{display:inline-flex;gap:6px;align-items:center;margin:0}
.inline input,.inline select{margin-bottom:0}
.row3{display:flex;gap:10px}.row3>div{flex:1}
.row3 label{margin-bottom:4px}
.assignbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.assignbar label{margin:0;font-weight:600} .assignbar select{margin-bottom:0;min-width:180px;height:38px}
.offsel{min-width:170px;margin-bottom:0;height:38px}

/* ---- tables ---- */
table.grid{width:100%;border-collapse:collapse}
table.grid th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--hint);
  font-weight:700;padding:10px 10px;border-bottom:1px solid var(--line)}
table.grid td{padding:11px 10px;border-bottom:1px solid #eef1f6;vertical-align:middle}
table.grid tr:last-child td{border-bottom:0}
table.grid tr:hover td{background:#fafbfd}
table.grid.tight td,table.grid.tight th{padding:7px 8px;font-size:13px}
.st-flagged td:first-child{box-shadow:inset 3px 0 0 var(--danger)}
.st-cleared td:first-child{box-shadow:inset 3px 0 0 var(--teal)}

/* ---- pills / status / severity ---- */
.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;text-transform:capitalize}
.pill.pending,.pill.open{background:#eef2f8;color:#4a5578}
.pill.in_review,.pill.under_review,.pill.recovery_pending{background:var(--amber-bg);color:#8a6410}
.pill.cleared,.pill.recovered{background:var(--ok-bg);color:var(--teal)}
.pill.flagged{background:var(--danger-bg);color:#a53030}
.pill.closed,.pill.waived{background:#e7e9f0;color:#565f7d}
[class^="sev-"],[class*=" sev-"]{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:capitalize}
.sev-high{background:#fbe3e3;color:#a12b2b}
.sev-medium,.sev-med{background:var(--amber-bg);color:#8a6410}
.sev-low{background:#eef2f8;color:#4a5578}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:#f7f9fc;border-radius:12px;padding:14px 16px}
.kpi .n{font-family:'Archivo';font-size:23px;font-weight:800;color:var(--ink);line-height:1.1}
.kpi .l{font-size:11.5px;color:var(--muted);margin-top:4px;font-weight:600}
.kpi.flag .n{color:var(--danger)} .kpi.ok .n{color:var(--teal)} .kpi.rec .n{color:var(--gold)}

/* ---- tabs ---- */
.tabs{display:flex;gap:4px;align-items:center;border-bottom:1px solid var(--line);margin-bottom:16px;flex-wrap:wrap}
.tab{padding:9px 12px;font-size:13px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer}
.tab:hover{color:var(--ink);text-decoration:none}
.tab.on{color:var(--ink);border-bottom-color:var(--gold)}
.tabs .filterform{margin-left:auto}

/* ---- flash ---- */
.flash{padding:11px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:14px}
.flash.ok{background:var(--ok-bg);color:#0c5f4c;border:1px solid #bfe0cc}
.flash.err{background:var(--danger-bg);color:#9e2b2b;border:1px solid #f0cccc}

/* ---- reviewer ---- */
.reviewhead{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.reviewcols{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.reviewcols>.card{flex:1;min-width:330px}
.meta{display:flex;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--text);margin-top:6px}
.meta b{color:var(--hint);font-weight:600;font-size:10.5px;text-transform:uppercase;margin-right:4px;letter-spacing:.03em}
.navbtns{display:flex;gap:8px;flex-wrap:wrap}
.progress{margin-top:8px;font-size:12px;font-weight:600;color:#8a6410;background:var(--amber-bg);border:1px solid #efe2bf;border-radius:8px;padding:6px 10px;display:inline-block}

.bill-lines,.miss-lines{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.line{display:flex;align-items:center;gap:12px;padding:9px 10px;border:1px solid var(--line);border-radius:12px;background:#fff}
.line.miss{background:var(--danger-bg);border-color:#f3c9c9}
.thumb{width:52px;height:52px;flex:0 0 52px;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:#fff}
.noimg{width:52px;height:52px;flex:0 0 52px;border-radius:10px;background:#f0f3f9;display:grid;place-items:center;color:#b9c1d4;border:1px solid var(--line)}
.line-main{flex:1;min-width:0}
.line-name{font-weight:600;font-size:13.5px;line-height:1.25;color:var(--text);word-break:break-word}
.line-sub{font-size:11px;color:var(--hint);margin-top:3px}
.line-stats{display:flex;flex-direction:column;align-items:flex-end;gap:1px;font-size:11.5px;color:var(--muted);white-space:nowrap}
.line-stats .qty{font-family:'Archivo';font-weight:800;font-size:15px;color:var(--ink)}
.line-stats .amt{font-weight:600;color:var(--text)}

.rectotal{float:right;font-family:'Archivo';font-weight:800;font-size:14px;color:var(--danger)}
.addbox{margin-top:14px;border-top:1px dashed var(--line-2);padding-top:14px}
.addbox h4{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:8px}
.skures{border:1px solid var(--line);border-radius:10px;max-height:260px;overflow:auto;margin-top:6px;background:#fff}
.skures:empty{display:none}
.skurow{display:flex;gap:10px;align-items:center;padding:8px 10px;cursor:pointer;border-bottom:1px solid #eef1f6}
.skurow:last-child{border-bottom:0}
.skurow:hover{background:#f4f7fc}
.skurow img,.picked img{width:38px;height:38px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.picked{display:flex;align-items:center;gap:10px;background:#f4f7fc;border:1px solid var(--line);border-radius:10px;padding:8px 10px;margin-bottom:12px}
.decide{margin-top:14px;border-top:1px solid var(--line);padding-top:14px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.flagform{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.flagform select,.flagform input{margin-bottom:0;height:40px}
.flagform input[name=summary]{min-width:200px}
.hidden{display:none}

/* ---- casefile bits ---- */
.evitem{display:inline-block;margin:4px;border:1px solid var(--line);border-radius:10px;padding:6px;background:#fff;font-size:12px;text-align:center}
.evitem img{width:120px;height:90px;object-fit:cover;border-radius:6px;display:block}
.filetag{display:inline-block;background:#eef2f8;color:#4a5578;font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px}
.fineprint{font-size:11.5px;color:var(--hint);margin-top:14px}
.chip{display:inline-flex;align-items:center;gap:6px;background:#eff2f8;border:1px solid var(--line);border-radius:8px;padding:4px 9px;font-size:12px;margin:2px}
.chip .x{font-size:14px}

/* ============ LOGIN ============ */
.loginpage{background:radial-gradient(120% 120% at 0% 0%,#1a3163 0%,var(--ink) 55%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login{display:grid;grid-template-columns:1.05fr .95fr;width:100%;max-width:940px;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.login .hero{background:radial-gradient(120% 120% at 0% 0%,#1a3163 0%,var(--ink) 60%);color:#fff;padding:42px 40px}
.login .hero .brandlogo{height:32px;margin-bottom:32px}
.login .hero h2{font-size:28px;font-weight:800;line-height:1.15}
.login .hero .tag{color:#aeb9d4;font-size:14.5px;margin:14px 0 26px;line-height:1.6}
.feat{display:flex;align-items:center;gap:12px;margin:13px 0;color:#dbe2f2;font-size:13.5px}
.feat .fic{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.09);display:grid;place-items:center;color:var(--gold);flex:0 0 34px}
.feat svg{width:18px;height:18px}
.trust{margin-top:28px;display:inline-flex;gap:8px;align-items:center;font-size:12px;color:#9fb0d6;background:rgba(255,255,255,.06);padding:8px 12px;border-radius:8px}
.login .panel{padding:44px 42px;display:flex;flex-direction:column;justify-content:center}
.login .panel h1{font-size:22px;font-weight:800;color:var(--ink)}
.login .panel .welcome{color:var(--muted);font-size:14px;margin:6px 0 24px}
.login .panel label{font-size:12.5px}
.login .panel input{height:46px;font-size:15px}
.login .panel .btn.primary{height:48px;font-size:15px;margin-top:4px}
.login .fineprint{text-align:center;margin-top:16px}
@media(max-width:820px){
  .login{grid-template-columns:1fr;max-width:440px}
  .login .hero{display:none}
}

/* ---- mobile ---- */
@media (max-width:720px){
  .topbar{padding:10px 12px}
  .brand{font-size:12.5px}
  .brand .abbr{display:none}
  .motto,.subbar{display:none}
  .userbox{font-size:12px}
  .brandlogo{height:24px}
  .wrap{padding:16px 12px 60px}
  .reviewcols{flex-direction:column;gap:12px}
  .reviewcols>.card{min-width:0;width:100%}
  .reviewhead{flex-direction:column;gap:8px}
  .navbtns{width:100%}.navbtns .btn{flex:1}
  .row3{flex-direction:column;gap:0}
  input,select,textarea{font-size:16px;height:46px}
  .btn{min-height:44px}.btn.sm{min-height:36px}
  .decide{position:sticky;bottom:0;background:#fff;margin:14px -18px -16px;padding:12px 16px;
    border-top:2px solid var(--line);box-shadow:0 -6px 18px rgba(13,27,57,.08);z-index:5;flex-direction:column;align-items:stretch}
  .decide .btn,.decide form{width:100%}.decide .btn{width:100%}
  .flagform{flex-direction:column;align-items:stretch}
  .flagform input[name=summary]{min-width:0;width:100%}
  .thumb,.noimg{width:60px;height:60px;flex-basis:60px}
  .skures{max-height:50vh}
  .cols>.card{flex:1 1 100%!important}
}
