:root{
  --bg:#f4f6f9; --surface:#ffffff; --ink:#16202e; --muted:#5b6878; --line:#e4e9f0;
  --brand:#1d6f8b; --brand-dark:#155467; --brand-soft:#e6f1f5;
  --ok:#1f7a4d; --ok-soft:#e3f3ea; --warn:#9a6b00; --warn-soft:#fbf0d4;
  --danger:#b23b2e; --danger-soft:#fbe7e3; --accent:#0f766e;
  --radius:12px; --shadow:0 1px 2px rgba(16,32,46,.05),0 6px 20px rgba(16,32,46,.06);
  --sans:'Public Sans',system-ui,sans-serif; --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--brand)}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* login */
.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 500px at 100% -10%,#e6f1f5,transparent 60%),var(--bg)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.login-card{width:100%;max-width:390px;padding:30px}
.brand{font-weight:800;letter-spacing:-.5px;font-size:24px}
.brand .dot{color:var(--brand)}
.brand .soft{color:var(--muted);font-weight:600}
label{display:block;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px}
input,select,textarea{width:100%;padding:10px 12px;font:inherit;color:var(--ink);background:#fbfcfe;border:1px solid var(--line);border-radius:9px;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.field{margin-bottom:14px}
button,.btn{font:inherit;font-weight:600;cursor:pointer;border:1px solid transparent;border-radius:9px;padding:9px 15px;background:var(--brand);color:#fff}
button:hover,.btn:hover{background:var(--brand-dark)}
button:disabled{background:var(--line);color:var(--muted);cursor:not-allowed}
.btn-ghost{background:transparent;color:var(--brand);border-color:var(--line)}
.btn-ghost:hover{background:var(--brand-soft)}
.btn-sm{padding:6px 10px;font-size:13px}
.btn-danger{background:var(--danger)}.btn-danger:hover{background:#8f2e23}
.msg{font-size:13px;margin-top:10px;min-height:16px}.msg.err{color:var(--danger)}.msg.ok{color:var(--ok)}

/* app shell */
.shell{display:flex;min-height:100vh}
.side{width:236px;background:#0f2230;color:#cdd9e3;display:flex;flex-direction:column;position:fixed;top:0;bottom:0}
.side .top{padding:20px 18px;border-bottom:1px solid #1c3242}
.side .b{font-weight:800;font-size:20px;color:#fff;letter-spacing:-.5px}
.side .b .dot{color:#4db6d6}
.side .client{font-size:12px;color:#86a0b3;margin-top:3px}
.nav{padding:10px;flex:1}
.nav a{display:flex;align-items:center;gap:10px;color:#cdd9e3;text-decoration:none;padding:10px 12px;border-radius:9px;font-weight:600;font-size:14px;margin-bottom:2px;cursor:pointer}
.nav a:hover{background:#172c3b}
.nav a.active{background:var(--brand);color:#fff}
.nav .badge{margin-left:auto;background:var(--danger);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px}
.side .foot{padding:14px 16px;border-top:1px solid #1c3242;font-size:13px}
.side .foot .u{color:#fff;font-weight:600}
.main{margin-left:236px;flex:1;padding:26px 30px 60px;max-width:1100px}
h1{font-size:24px;letter-spacing:-.4px;margin:0 0 3px}
.sub{color:var(--muted);margin:0 0 22px}
h2{font-size:17px;margin:0 0 12px}
.section{display:none}.section.active{display:block}

/* cards / stats */
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.stat{flex:1 1 150px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat .n{font-size:30px;font-weight:800;letter-spacing:-1px}
.stat .l{color:var(--muted);font-size:13px;font-weight:600}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar .spacer{flex:1}

/* tables */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
tbody tr:hover{background:#f8fafc;cursor:default}
td.r,th.r{text-align:right}
.tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;background:#eef2f7;color:var(--muted);display:inline-block}
.tag.ok{background:var(--ok-soft);color:var(--ok)}
.tag.soon{background:var(--warn-soft);color:var(--warn)}
.tag.expired{background:var(--danger-soft);color:var(--danger)}
.tag.brand{background:var(--brand-soft);color:var(--brand-dark)}
.empty{color:var(--muted);font-size:14px;padding:14px 2px}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(15,34,48,.45);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto}
.overlay.open{display:flex}
.modal{background:var(--surface);border-radius:14px;width:100%;max-width:560px;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal h3{margin:0 0 16px;font-size:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* compliance */
.audit-sec{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden}
.audit-sec h4{margin:0;padding:11px 14px;background:#f3f7fa;font-size:14px;display:flex;align-items:center;gap:8px;cursor:pointer}
.audit-sec .cnt{margin-left:auto;font-size:12px;color:var(--muted);font-weight:600}
.audit-items{padding:6px 14px 12px}
.aitem{display:flex;align-items:flex-start;gap:9px;padding:6px 0;border-bottom:1px solid #f0f3f7}
.aitem:last-child{border-bottom:none}
.aitem input[type=checkbox]{width:17px;height:17px;margin-top:2px;flex:0 0 auto}
.aitem .t{flex:1}
.aitem input.note{font-size:12px;padding:4px 8px;margin-top:3px}
.print-only{display:none}
@media print{
  .side,.toolbar,.no-print{display:none!important}
  .main{margin:0;max-width:none}
  .panel{box-shadow:none;border:none}
  .print-only{display:block}
}
