:root{--bg:#f4f6fb;--panel:#fff;--panel2:#f8fafc;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--primary:#4f46e5;--primary-soft:#eef2ff;--ok:#16a34a;--warn:#d97706;--danger:#dc2626;--info:#0284c7;--shadow:0 1px 3px #0f172a14, 0 4px 16px #0f172a0d;--radius:12px}[data-theme=dark]{--bg:#0b1120;--panel:#111a2e;--panel2:#0e1627;--text:#e2e8f0;--muted:#94a3b8;--border:#1e2a44;--primary:#818cf8;--primary-soft:#1e2249;--ok:#4ade80;--warn:#fbbf24;--danger:#f87171;--info:#38bdf8;--shadow:0 1px 3px #0006}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font:14px/1.5 Inter,-apple-system,Segoe UI,Roboto,sans-serif}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:var(--text);background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:-1px}.shell{min-height:100vh;display:flex}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:232px;height:100vh;padding:16px 12px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;padding:6px 10px 18px;font-size:15px;font-weight:700;display:flex}.brand .logo{background:var(--primary);color:#fff;border-radius:9px;place-items:center;width:34px;height:34px;font-size:16px;display:grid}.nav-item{width:100%;color:var(--muted);text-align:left;background:0 0;border:0;border-radius:9px;align-items:center;gap:10px;margin:2px 0;padding:10px 12px;font-weight:500;display:flex}.nav-item:hover{background:var(--panel2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--panel);border-bottom:1px solid var(--border);z-index:30;align-items:center;gap:12px;padding:12px 24px;display:flex;position:sticky;top:0}.topbar h1{flex:1;margin:0;font-size:17px}.content{width:100%;max-width:1400px;margin:0 auto;padding:24px}.cards{grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:14px;display:grid}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}.card .label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.card .value{margin-top:4px;font-size:26px;font-weight:700}.card .sub{color:var(--muted);margin-top:2px;font-size:12px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-h{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px;font-weight:600;display:flex}.panel-b{padding:18px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 12px}th{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:var(--panel);font-size:11px;position:sticky;top:0}tbody tr:hover{background:var(--panel2);cursor:pointer}tbody tr.static:hover{cursor:default}.badge{color:#fff;text-transform:capitalize;border-radius:999px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.btn{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:8px;align-items:center;gap:6px;padding:7px 13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--panel2)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn.danger:hover{background:var(--danger);color:#fff}.btn.sm{border-radius:7px;padding:4px 9px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.field{flex-direction:column;gap:4px;display:flex}.field>span{color:var(--muted);font-size:12px;font-weight:600}.row{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.grid2{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.overlay{z-index:100;background:#0206178c;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--bg);width:min(860px,100%);height:100%;animation:.18s slidein;overflow-y:auto}@keyframes slidein{0%{opacity:0;transform:translate(40px)}}.drawer-h{z-index:5;background:var(--panel);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 22px;display:flex;position:sticky;top:0}.drawer-b{flex-direction:column;gap:18px;padding:20px 22px;display:flex}.tabs{flex-wrap:wrap;gap:4px;display:flex}.tab{color:var(--muted);background:0 0;border:0;border-radius:8px;padding:8px 13px;font-weight:600}.tab.active{background:var(--primary-soft);color:var(--primary)}.kv{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px 18px;display:grid}.kv .k{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.kv .v{text-overflow:ellipsis;font-weight:600;overflow:hidden}.toast{background:var(--text);color:var(--bg);z-index:300;box-shadow:var(--shadow);border-radius:10px;max-width:90vw;padding:10px 18px;font-weight:600;position:fixed;bottom:22px;left:50%;transform:translate(-50%)}.login-wrap{place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{text-align:center;width:400px;max-width:100%;padding:40px 32px}.login-card .logo{background:var(--primary);color:#fff;border-radius:14px;place-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:26px;display:grid}.gbtn{color:#1f1f1f;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:12px;width:100%;padding:14px;font-size:16px;font-weight:700;display:flex;box-shadow:0 2px 10px #00000059}.gbtn:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 16px #4f46e573}.gbtn:active{transform:translateY(0)}.charts{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;display:grid}.chart-title{margin-bottom:10px;font-size:13px;font-weight:600}.legend{color:var(--muted);flex-wrap:wrap;gap:8px 14px;margin-top:10px;font-size:12px;display:flex}.legend i{border-radius:3px;width:10px;height:10px;margin-right:5px;display:inline-block}.menu-btn{display:none}@media (width<=900px){.sidebar{z-index:200;box-shadow:var(--shadow);transition:transform .2s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.menu-btn{display:inline-flex}.content{padding:14px}.drawer{width:100%}}
