:root{--radius:14px;--radius-sm:9px;--shadow:0 1px 2px #1018280f, 0 1px 3px #1018281a;--shadow-lg:0 12px 32px #10182829;--sidebar-w:244px;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}:root,[data-theme=light]{--bg:#f4f6fb;--surface:#fff;--surface-2:#f8fafc;--border:#e6e9f0;--text:#16202e;--text-soft:#5b6878;--text-faint:#98a2b3;--brand:#4f46e5;--brand-soft:#eef2ff;--green:#16a34a;--green-soft:#e7f7ec;--red:#dc2626;--red-soft:#fdeaea;--amber:#d97706;--amber-soft:#fdf2e0;--blue:#2563eb;--blue-soft:#e8f0fe}[data-theme=dark]{--bg:#0e131b;--surface:#171e29;--surface-2:#1d2632;--border:#2a3543;--text:#e7ecf3;--text-soft:#9aa7b8;--text-faint:#6b7888;--brand:#7c83ff;--brand-soft:#20243a;--green:#4ade80;--green-soft:#173026;--red:#f87171;--red-soft:#321c1e;--amber:#fbbf24;--amber-soft:#322512;--blue:#60a5fa;--blue-soft:#16263f}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);transition:background .2s,color .2s}a{color:var(--brand);text-decoration:none}h1,h2,h3{letter-spacing:-.01em;margin:0;font-weight:700}button{font-family:inherit}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:9px 15px;font-size:14px;font-weight:600;transition:filter .15s,background .15s,transform 50ms;display:inline-flex}.btn:hover{filter:brightness(.98)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-ghost{background:0 0}.btn-sm{padding:6px 11px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--text-soft);font-size:13px;font-weight:600}.input,.select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);width:100%;color:var(--text);outline:none;padding:10px 12px;font-size:14px}.input:focus,.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.table-wrap{border-radius:var(--radius);overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:14px}table.data th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:700}table.data td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:13px 16px}table.data tr:last-child td{border-bottom:none}table.data tbody tr:hover{background:var(--surface-2)}.mono{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px}.badge{text-transform:capitalize;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.badge .dot{background:currentColor;border-radius:50%;width:7px;height:7px}.badge-green{color:var(--green);background:var(--green-soft)}.badge-red{color:var(--red);background:var(--red-soft)}.badge-amber{color:var(--amber);background:var(--amber-soft)}.badge-blue{color:var(--blue);background:var(--blue-soft)}.badge-gray{color:var(--text-soft);background:var(--surface-2)}.shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:40;flex-direction:column;flex-shrink:0;transition:transform .22s;display:flex;position:fixed;inset:0 auto 0 0}.sidebar .brand{align-items:center;gap:10px;padding:20px 20px 16px;font-size:17px;font-weight:800;display:flex}.sidebar .brand .logo{background:var(--brand);color:#fff;border-radius:8px;place-items:center;width:30px;height:30px;font-size:15px;display:grid}.nav{flex-direction:column;gap:2px;padding:8px 12px;display:flex;overflow-y:auto}.nav a{border-radius:var(--radius-sm);color:var(--text-soft);align-items:center;gap:11px;padding:10px 12px;font-size:14px;font-weight:600;display:flex}.nav a:hover{background:var(--surface-2);color:var(--text)}.nav a.active{background:var(--brand-soft);color:var(--brand)}.nav a .ico{text-align:center;width:18px;font-size:16px}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.topbar{z-index:30;background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 24px;display:flex;position:sticky;top:0}.topbar h1{font-size:19px}.topbar .spacer{flex:1}.icon-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;place-items:center;width:38px;height:38px;font-size:16px;display:grid}.hamburger{display:none}.content{width:100%;max-width:1280px;padding:24px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-top:20px;display:grid}.section{margin-top:24px}.section-head{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.section-head h2{font-size:16px}.section-head .spacer{flex:1}.row-actions{flex-wrap:wrap;gap:8px;display:flex}.stat{flex-direction:column;gap:10px;padding:18px;display:flex}.stat .top{justify-content:space-between;align-items:center;display:flex}.stat .label{color:var(--text-soft);font-size:13px;font-weight:600}.stat .emoji{background:var(--surface-2);border-radius:10px;place-items:center;width:40px;height:40px;font-size:20px;display:grid}.stat .value{letter-spacing:-.02em;font-size:28px;font-weight:800}.stat .hint{color:var(--text-faint);font-size:12px}.empty{text-align:center;color:var(--text-soft);padding:40px 20px}.empty .big{margin-bottom:8px;font-size:30px}.spinner{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}.center-pad{place-items:center;padding:48px;display:grid}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:var(--radius-sm);margin-bottom:14px;padding:12px 14px;font-size:14px}.alert-error{background:var(--red-soft);color:var(--red)}.alert-ok{background:var(--green-soft);color:var(--green)}.modal-backdrop{z-index:60;background:#080c128c;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal.wide{max-width:720px}.modal-head{border-bottom:1px solid var(--border);align-items:center;padding:18px 20px;display:flex}.modal-head h3{flex:1;font-size:16px}.modal-body{padding:20px}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 20px;display:flex}.login-wrap{background:radial-gradient(900px 500px at 80% -10%, var(--brand-soft), transparent), var(--bg);place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{width:100%;max-width:400px;padding:30px}.login-card .brand{align-items:center;gap:10px;margin-bottom:4px;font-size:20px;font-weight:800;display:flex}.login-card .sub{color:var(--text-soft);margin-bottom:22px;font-size:14px}.chart{padding:18px}.chart h3{margin-bottom:4px;font-size:15px}.chart .chart-sub{color:var(--text-faint);margin-bottom:12px;font-size:12px}.legend{color:var(--text-soft);flex-wrap:wrap;gap:10px 16px;margin-top:10px;font-size:12px;display:flex}.legend span{align-items:center;gap:6px;display:inline-flex}.legend i{border-radius:3px;width:10px;height:10px;display:inline-block}.scrim{display:none}@media (width<=900px){.sidebar{box-shadow:var(--shadow-lg);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.hamburger{display:grid}.scrim.show{z-index:35;background:#080c1266;display:block;position:fixed;inset:0}.content{padding:16px}.topbar{padding:12px 16px}}
