:root{
 /* ComplyOne brand palette — aligned to the logo (blue shield, navy wordmark) */
 --ink:#16263f;--ink2:#1f3a5f;--brand:#2a5fa8;--brand-d:#1f4e8f;--brand-l:#e9f1fb;
 --accent:#3f8fd0;--bg:#f4f7fb;--panel:#fff;--line:#e6ebf2;--line2:#d2dbe8;
 --tx:#16263f;--mut:#56657c;--faint:#64748b;
 --ok:#1f9d57;--ok-bg:#e7f6ec;--warn:#c9810a;--warn-bg:#fdf3df;--bad:#d6453d;--bad-bg:#fcebea;
 --crit:#9a1b14;--info:#2563c9;--info-bg:#e9f0fe;--neu:#eef1f5;
 --r:11px;--r-sm:7px;--sh:0 1px 3px rgba(22,38,63,.08),0 6px 18px rgba(22,38,63,.06);
}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:"Segoe UI",system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--tx);font-size:14px;line-height:1.5}
button,input,select,textarea{font-family:inherit;font-size:14px}
a{color:var(--brand);text-decoration:none;cursor:pointer}
.hidden{display:none!important}
.muted{color:var(--mut)}.faint{color:var(--faint);font-size:12px}
.row{display:flex;gap:10px;align-items:center}.row.wrap{flex-wrap:wrap}.spacer{flex:1}

/* Auth */
#auth{position:fixed;inset:0;background:linear-gradient(135deg,#16263f,#1f3a5f 45%,#2a5fa8 100%);display:flex;align-items:center;justify-content:center;z-index:500}
.authcard{background:#fff;border-radius:16px;padding:34px 30px;width:392px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.authcard .authlogo{width:230px;max-width:100%;height:auto;display:block;margin:0 auto 8px}
.authcard p.sub{margin:0 0 18px;color:var(--mut);font-size:13px;text-align:center}
.authcard input{width:100%;padding:11px 13px;border:1px solid var(--line2);border-radius:9px;margin-bottom:10px}
.authcard button{width:100%;padding:11px;border:none;border-radius:9px;background:var(--brand);color:#fff;font-weight:600;cursor:pointer}
.authcard button:hover{background:var(--brand-d)}
.authcard .err{color:var(--bad);font-size:13px;min-height:18px;margin:4px 0}
.authcard .toggle{text-align:center;margin-top:12px;font-size:13px}

/* Shell */
#app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
aside{background:var(--ink);color:#cdd8e6;padding:16px 12px;position:sticky;top:0;height:100vh;overflow:auto}
aside .brand{display:flex;align-items:center;gap:9px;font-weight:800;color:#fff;font-size:17px;padding:6px 8px 16px}
aside .brand .navmark{width:28px;height:auto}
nav a{display:block;padding:9px 12px;border-radius:8px;color:#cdd8e6;margin-bottom:2px;font-weight:500}
nav a:hover{background:rgba(255,255,255,.06)}
nav a.active{background:var(--brand);color:#fff}
aside .who{margin-top:14px;border-top:1px solid rgba(255,255,255,.12);padding-top:12px;font-size:12px;color:#9fb0c4}
main{padding:24px 30px;overflow:auto;max-height:100vh}
header.page{display:flex;align-items:center;gap:12px;margin-bottom:18px}
header.page h1{font-size:21px;margin:0}

/* Cards / KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-top:3px solid var(--brand);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh)}
.kpi .n{font-size:26px;font-weight:800;color:var(--ink2)}.kpi .l{color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);margin-bottom:16px}
.card .hd{padding:12px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.card .hd h3{margin:0;font-size:15px}.card .bd{padding:14px 16px}

/* Buttons */
.btn{padding:8px 14px;border:1px solid var(--line2);border-radius:8px;background:#fff;cursor:pointer;font-weight:600;color:var(--tx)}
.btn:hover{background:var(--bg)}
.btn.pri{background:var(--brand);border-color:var(--brand);color:#fff}.btn.pri:hover{background:var(--brand-d)}
.btn.sm{padding:5px 10px;font-size:13px}
.btn.danger{color:var(--bad);border-color:#f0c3bf}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut)}
tr:hover td{background:#fafcfe}

/* Inputs */
label{display:block;font-size:12px;color:var(--mut);margin:8px 0 3px;font-weight:600}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line2);border-radius:8px;background:#fff}
textarea{min-height:90px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Badges */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600}
.b-low{background:var(--ok-bg);color:var(--ok)}.b-medium{background:var(--warn-bg);color:var(--warn)}
.b-high{background:var(--bad-bg);color:var(--bad)}.b-critical{background:#f6dcd9;color:var(--crit)}
.b-open{background:var(--info-bg);color:var(--info)}.b-complete,.b-done{background:var(--ok-bg);color:var(--ok)}
.b-in_progress,.b-waiting{background:var(--warn-bg);color:var(--warn)}.b-retired,.b-closed{background:var(--neu);color:var(--mut)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(11,31,51,.5);display:flex;align-items:center;justify-content:center;z-index:400;padding:20px}
.modal{background:#fff;border-radius:14px;width:640px;max-width:100%;max-height:90vh;overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.modal .mh{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center}
.modal .mh h3{margin:0}.modal .mb{padding:18px 20px}.modal .mf{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}

/* Policy editor / track changes */
.editor{border:1px solid var(--line2);border-radius:8px;min-height:300px;padding:14px;background:#fff;overflow:auto}
.editor:focus{outline:2px solid var(--brand-l)}
.diff ins{background:#d8f5e3;text-decoration:none;color:#0a5b34}
.diff del{background:#fcdedb;color:#9a1b14;text-decoration:line-through}
.vlist{max-height:300px;overflow:auto}
.toast{position:fixed;bottom:20px;right:20px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:10px;box-shadow:var(--sh);z-index:600;opacity:0;transition:opacity .2s}
.toast.show{opacity:1}
.pill-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.pill-tabs button{padding:6px 12px;border:1px solid var(--line2);background:#fff;border-radius:20px;cursor:pointer}
.pill-tabs button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.choice{display:block;padding:9px 12px;border:1px solid var(--line2);border-radius:8px;margin-bottom:7px;cursor:pointer}
.choice:hover{background:var(--bg)}.choice input{width:auto;margin-right:8px}
.score-ring{font-size:30px;font-weight:800;color:var(--brand)}

/* Accessibility & polish (WCAG 2.1 AA) */
a,button,input,select,textarea{outline-offset:2px}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}
.btn,.choice,nav a{min-height:38px;display:inline-flex;align-items:center}
nav a{display:flex}
.btn.pri:focus-visible{outline-color:#fff}
@media (max-width:820px){#app{grid-template-columns:1fr}aside{position:static;height:auto}main{max-height:none}.grid2{grid-template-columns:1fr}}
.card .hd h3{font-weight:700;color:var(--ink2)}
header.page h1{color:var(--ink2);letter-spacing:-.3px}
