:root{--bg:#070b16;--bg2:#0b1120;--panel:#111a2e;--panel2:#16203a;--panel3:#1e2a49;--text:#e9f0fb;--muted:#8ea3c6;--faint:#5e7099;--brand:#2dd4bf;--brand2:#38bdf8;--accent:#818cf8;--warn:#f59e0b;--danger:#ef4444;--ok:#22c55e;--border:#1f2b47;--shadow:0 10px 30px rgba(0,0,0,.35);--r:16px;--sidebar-w:248px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased}a{color:var(--brand2);text-decoration:none}button{font-family:inherit}h1{font-size:24px;font-weight:800;margin:0 0 4px}h2{font-size:18px}h2,h3{font-weight:700}h3{font-size:15px;margin:0 0 10px}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:linear-gradient(180deg,#0c1426,#080d1a);border-right:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:calc(18px + env(safe-area-inset-top)) 14px calc(14px + env(safe-area-inset-bottom));gap:6px;z-index:40}.sidebar .brand{font-weight:900;font-size:22px;letter-spacing:.3px;padding:6px 10px 16px}.brand span{color:var(--brand)}.navlink{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;transition:.15s;position:relative}.navlink:hover{background:var(--panel);color:var(--text)}.navlink.active{background:linear-gradient(90deg,rgba(45,212,191,.16),rgba(56,189,248,.06));color:var(--text)}.navlink.active:before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--brand)}.navlink svg{width:19px;height:19px;flex-shrink:0}.sidebar .spacer{flex:1 1}.sidebar .ver{color:var(--faint);font-size:11px;padding:8px 12px}.main{flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{min-height:64px;box-sizing:content-box;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:env(safe-area-inset-top) 24px 0;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:30;background:rgba(7,11,22,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar .page-title{font-weight:700;font-size:15px;color:var(--muted)}.userchip{display:flex;align-items:center;gap:12px;cursor:pointer;padding:6px;border-radius:999px;transition:.15s}.userchip:hover{background:var(--panel)}.userchip .uinfo{text-align:right;line-height:1.15}.userchip .uname{font-weight:700;font-size:13px}.userchip .urole{color:var(--brand);font-size:11px;font-weight:700;text-transform:capitalize}.avatar{width:40px;height:40px;border-radius:999px;object-fit:cover;border:2px solid var(--brand);background:var(--panel2);display:grid;place-items:center;font-weight:800;color:var(--brand);font-size:15px}.content{padding:24px;max-width:1400px;width:100%;margin:0 auto}.hamburger{background:var(--panel);border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:10px;cursor:pointer;font-size:18px}.hamburger,.scrim{display:none}.grid{display:grid;grid-gap:16px;gap:16px}.kpis{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r);padding:18px}.card.glow{box-shadow:var(--shadow)}.kpi{display:flex;gap:14px;align-items:center}.kpi .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}.kpi .ic svg{width:22px;height:22px}.kpi .label{color:var(--muted);font-size:12.5px;font-weight:600}.kpi .value{font-size:26px;font-weight:800;margin-top:2px;line-height:1}.kpi .sub{color:var(--faint);font-size:11.5px;margin-top:3px}.tone-brand{background:rgba(45,212,191,.14);color:var(--brand)}.tone-blue{background:rgba(56,189,248,.14);color:var(--brand2)}.tone-violet{background:rgba(129,140,248,.16);color:var(--accent)}.tone-warn{background:rgba(245,158,11,.14);color:var(--warn)}.tone-danger{background:rgba(239,68,68,.14);color:var(--danger)}.tone-ok{background:rgba(34,197,94,.14);color:var(--ok)}.charts{grid-template-columns:2fr 1fr}.charts-2{grid-template-columns:1fr 1fr}.chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.chart-head .t{font-weight:700;font-size:14px}.chart-head .s{color:var(--faint);font-size:12px}table{width:100%;border-collapse:collapse;font-size:13px}td,th{text-align:left;padding:11px 12px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}tbody tr{transition:.12s}tbody tr:hover td{background:var(--panel2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700}.badge.ok{background:rgba(34,197,94,.15);color:var(--ok)}.badge.low{background:rgba(56,189,248,.15);color:var(--brand2)}.badge.high,.badge.pending{background:rgba(245,158,11,.15);color:var(--warn)}.badge.validated{background:rgba(34,197,94,.15);color:var(--ok)}.badge.rejected{background:rgba(239,68,68,.15);color:var(--danger)}.badge.neutral{background:var(--panel2)}.badge.neutral,.muted{color:var(--muted)}.faint{color:var(--faint)}label.fld{color:var(--muted);font-size:12.5px;font-weight:600;display:block;margin-bottom:6px}input,select,textarea{background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:14px;width:100%;outline:none;transition:.15s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(45,212,191,.12)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:10px;border:1px solid transparent;cursor:pointer;font-weight:700;font-size:13.5px;transition:.15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#06231f}.btn-primary:hover:not(:disabled){filter:brightness(1.07)}.btn-ghost{background:var(--panel2);color:var(--text);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--panel3)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:7px 11px;font-size:12.5px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.search{position:relative;flex:1 1;min-width:200px;max-width:360px}.search input{padding-left:36px}.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--faint)}.modal-scrim{position:fixed;inset:0;background:rgba(2,6,14,.66);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:80;padding:20px;animation:fade .15s ease}.modal{background:var(--panel);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);width:100%;max-width:640px;max-height:90vh;overflow:auto;animation:pop .16s ease}.modal.lg{max-width:860px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;background:var(--panel);z-index:2}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:22px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border);position:-webkit-sticky;position:sticky;bottom:0;background:var(--panel)}.x{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;line-height:1}.x:hover{color:var(--text)}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.notice{background:rgba(245,158,11,.1);border:1px solid var(--warn);color:#ffe9c2;padding:12px 14px;border-radius:12px;font-size:13px}.row-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.empty{text-align:center;color:var(--faint);padding:40px 0}.skel{background:linear-gradient(90deg,var(--panel2),var(--panel3),var(--panel2));background-size:200% 100%;animation:sh 1.2s infinite;border-radius:8px}@keyframes sh{to{background-position:-200% 0}}.section-title{font-size:15px;font-weight:700;margin:26px 0 12px}@media (max-width:900px){.charts,.charts-2,.row-2{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .2s;box-shadow:var(--shadow)}.sidebar.open{transform:translateX(0)}.hamburger,.scrim.show{display:block}.scrim.show{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:35}.content{padding:16px}}