:root{--bg:#0b0f1a;--bg-2:#0a0e18;--surface:#141a29;--surface-2:#1b2236;--sidebar:#080b14;--sidebar-muted:#7c879e;--border:#232b3e;--text:#e7eaf3;--text-dim:#b9c0d4;--muted:#7e889f;--accent:#6366f1;--accent-2:#22d3ee;--accent-soft:rgba(99,102,241,.18);--success:#34d399;--success-soft:rgba(52,211,153,.15);--warn:#fbbf24;--warn-soft:rgba(251,191,36,.15);--danger:#f87171;--danger-soft:hsla(0,91%,71%,.15);--shadow:0 8px 30px rgba(0,0,0,.35);--radius:14px;--radius-sm:9px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,-apple-system,Segoe UI,Malgun Gothic,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);padding:18px 14px;display:flex;flex-direction:column;gap:4px;position:-webkit-sticky;position:sticky;top:0;height:100vh;border-right:1px solid var(--border)}.brand{display:flex;align-items:center;gap:9px;padding:6px 10px 16px;font-weight:800;font-size:16px}.brand .dot{width:22px;height:22px;border-radius:7px;background:linear-gradient(135deg,#6366f1,#22d3ee)}.side-link{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;color:var(--sidebar-muted);font-size:14px;font-weight:500;transition:.12s;cursor:pointer}.side-link:hover{background:hsla(0,0%,100%,.05);color:#fff}.side-link.active{background:var(--accent);color:#fff}.side-group{display:flex;flex-direction:column;gap:4px;margin-top:12px}.side-group:first-of-type{margin-top:2px}.side-group-label{font-size:11px;font-weight:700;letter-spacing:.05em;color:var(--sidebar-muted);opacity:.55;padding:4px 11px 2px}.side-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:12px;font-size:13px;color:var(--sidebar-muted)}.content{padding:26px 30px;max-width:1320px;width:100%}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:12px;flex-wrap:wrap}.topbar h1{font-size:22px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.card.pad{padding:18px}.grid{display:grid;grid-gap:16px;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width:1000px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-2,.cols-3{grid-template-columns:1fr}.shell{grid-template-columns:64px 1fr}.brand span,.side-foot,.side-group-label,.side-link span{display:none}.content{padding:16px}}.row{gap:10px;flex-wrap:wrap}.row,.spread{display:flex;align-items:center}.spread{justify-content:space-between;gap:12px}.kpi-card{padding:16px 18px;display:flex;flex-direction:column;gap:6px}.kpi-label{font-size:13px;color:var(--muted);font-weight:500}.kpi-value{font-size:27px;font-weight:800;letter-spacing:-.02em}.kpi-sub{font-size:12px;color:var(--muted)}.delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;padding:2px 7px;border-radius:999px}.delta.up{color:var(--success);background:var(--success-soft)}.delta.down{color:var(--danger);background:var(--danger-soft)}.delta.flat{color:var(--muted);background:var(--surface-2)}.btn{background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);padding:9px 14px;cursor:pointer;font-size:14px;font-weight:600}.btn:hover{filter:brightness(1.08)}.btn.secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn.ghost{background:transparent;color:var(--muted)}.btn.ghost:hover,input,select{color:var(--text)}input,select{padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface-2)}input::-webkit-calendar-picker-indicator{filter:invert(.7)}.segmented{display:inline-flex;background:var(--surface-2);border-radius:10px;padding:3px;gap:2px;border:1px solid var(--border)}.segmented button{border:0;background:transparent;padding:7px 13px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}.segmented button.active{background:var(--accent);color:#fff}table{width:100%;border-collapse:collapse;font-size:14px}thead th{text-align:left;padding:7px 12px;color:var(--muted);font-weight:600;font-size:12.5px;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}thead th:hover{color:var(--accent-2)}tbody td{padding:7px 12px;border-bottom:1px solid var(--border)}tbody tr:hover{background:var(--surface-2)}.rank{width:26px;height:26px;border-radius:8px;background:var(--accent-soft);color:#a5b4fc;font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.badge{padding:2px 9px;background:var(--accent-soft);color:#a5b4fc}.badge,.pill{border-radius:999px;font-size:12px;font-weight:600}.pill{padding:3px 9px}.pill.green{background:var(--success-soft);color:var(--success)}.pill.amber{background:var(--warn-soft);color:var(--warn)}.pill.red{background:var(--danger-soft);color:var(--danger)}.pill.gray{background:var(--surface-2)}.muted,.pill.gray{color:var(--muted)}.muted{font-size:13px}.warn{color:var(--danger)}.chart-title{font-size:14px;font-weight:700}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 37%,var(--surface) 63%);background-size:400% 100%;animation:sh 1.3s ease infinite;border-radius:8px}@keyframes sh{0%{background-position:100% 0}to{background-position:-100% 0}}.empty{padding:40px;text-align:center;color:var(--muted)}.barmini{height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden}.barmini>span{display:block;height:100%;background:var(--accent)}.mark{background:rgba(251,191,36,.35);color:#fde68a;border-radius:3px;padding:0 2px}.alert{display:flex;gap:10px;align-items:center;padding:12px 16px;border-radius:12px;border:1px solid var(--border);font-size:14px}.alert.danger{background:var(--danger-soft);border-color:hsla(0,91%,71%,.4);color:#fecaca}.alert.warn{background:var(--warn-soft);border-color:rgba(251,191,36,.4);color:#fde68a}.alert.ok{background:var(--success-soft);border-color:rgba(52,211,153,.35);color:#bbf7d0}.gauge{display:flex;align-items:center;gap:14px}.gauge-ring{--p:0;width:74px;height:74px;border-radius:50%;flex:0 0 auto;background:conic-gradient(var(--gc,#6366f1) calc(var(--p)*1%),var(--surface-2) 0);display:grid;place-items:center}.gauge-ring:after{content:"";width:56px;height:56px;border-radius:50%;background:var(--surface)}.gauge-val{position:absolute;font-size:15px;font-weight:800}.heat{display:grid;grid-template-columns:30px repeat(24,1fr);grid-gap:3px;gap:3px;align-items:center}.heat .hh{font-size:9px;color:var(--muted);text-align:center}.heat .hl{font-size:11px;color:var(--muted)}.heat .cell{height:16px;border-radius:3px;background:var(--surface-2)}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;justify-content:flex-end;z-index:50;animation:fade .15s ease}.drawer{width:min(640px,96vw);height:100%;background:var(--bg);padding:22px;overflow-y:auto;box-shadow:-8px 0 40px rgba(0,0,0,.5);border-left:1px solid var(--border);animation:slidein .2s ease}@keyframes slidein{0%{transform:translateX(30px);opacity:.4}to{transform:none;opacity:1}}@keyframes fade{0%{opacity:0}to{opacity:1}}.toast-wrap{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:8px;z-index:60}.toast{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:11px 16px;border-radius:10px;font-size:14px;box-shadow:var(--shadow);animation:slidein .2s ease}.toast.err{background:var(--danger);color:#fff;border:0}.toast.ok{background:var(--success);color:#06281c;border:0}.recharts-default-tooltip{background:var(--surface-2)!important;border:1px solid var(--border)!important;border-radius:8px!important;color:var(--text)!important}.recharts-tooltip-item{color:var(--text-dim)!important}