@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-base:#fafafa;--bg-surface:#fff;--bg-elevated:#f5f5f5;--bg-overlay:#0006;--text-primary:#1a1a2e;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-inverse:#fff;--border-default:#e5e7eb;--border-hover:#d1d5db;--border-active:#3b82f6;--accent-primary:#3b82f6;--accent-primary-hover:#2563eb;--accent-primary-soft:#3b82f614;--color-positive:#10b981;--color-positive-soft:#10b9811a;--color-negative:#ef4444;--color-negative-soft:#ef44441a;--color-warning:#f59e0b;--color-warning-soft:#f59e0b1a;--chart-blue:#3b82f6;--chart-blue-soft:#3b82f626;--chart-green:#10b981;--chart-green-soft:#10b98126;--chart-amber:#f59e0b;--chart-amber-soft:#f59e0b26;--chart-red:#ef4444;--chart-red-soft:#ef444426;--chart-violet:#8b5cf6;--chart-violet-soft:#8b5cf626;--chart-cyan:#06b6d4;--chart-cyan-soft:#06b6d426;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 1px 3px #0000000f;--shadow-lg:0 4px 12px #00000014;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--sidebar-width:240px;--sidebar-bg:#fff;--sidebar-border:#e5e7eb;--sidebar-item-hover:#f3f4f6;--sidebar-item-active:#3b82f614;--sidebar-text:#6b7280;--sidebar-text-active:#3b82f6;--topbar-height:64px;--topbar-bg:#fff;--topbar-border:#e5e7eb;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--focus-ring:0 0 0 2px #3b82f666;--input-bg:#fff;--input-border:#d1d5db;--input-border-focus:#3b82f6;--input-text:#1a1a2e;--input-placeholder:#9ca3af;--table-header-bg:#f9fafb;--table-row-alt:#fafafa;--table-row-hover:#f3f4f6}[data-theme=dark]{--bg-base:#0f1117;--bg-surface:#1a1d27;--bg-elevated:#232733;--bg-overlay:#0009;--text-primary:#e8e8ed;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-inverse:#0f1117;--border-default:#2d3141;--border-hover:#3d4255;--border-active:#60a5fa;--accent-primary:#60a5fa;--accent-primary-hover:#93c5fd;--accent-primary-soft:#60a5fa1a;--color-positive:#34d399;--color-positive-soft:#34d3991a;--color-negative:#f87171;--color-negative-soft:#f871711a;--color-warning:#fbbf24;--color-warning-soft:#fbbf241a;--shadow-sm:none;--shadow-md:none;--shadow-lg:0 4px 16px #0000004d;--sidebar-bg:#1a1d27;--sidebar-border:#2d3141;--sidebar-item-hover:#232733;--sidebar-item-active:#60a5fa1a;--sidebar-text:#9ca3af;--sidebar-text-active:#60a5fa;--topbar-bg:#1a1d27;--topbar-border:#2d3141;--input-bg:#232733;--input-border:#3d4255;--input-border-focus:#60a5fa;--input-text:#e8e8ed;--input-placeholder:#6b7280;--table-header-bg:#232733;--table-row-alt:#1e2130;--table-row-hover:#282c3a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:14px}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-base);transition:background-color var(--transition-slow), color var(--transition-slow);min-height:100vh;font-weight:400;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}ul,ol{list-style:none}img,svg{max-width:100%;display:block}table{border-collapse:collapse;width:100%}::selection{background:var(--accent-primary);color:var(--text-inverse)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}:focus-visible{box-shadow:var(--focus-ring);outline:none}.text-mono{font-family:var(--font-mono)}.text-sm{font-size:.857rem;line-height:1.4}.text-xs{font-size:.786rem;line-height:1.3}.text-lg{font-size:1.143rem;font-weight:600}.text-xl{font-size:1.5rem;font-weight:700}.text-2xl{letter-spacing:-.02em;font-size:2rem;font-weight:700}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-positive{color:var(--color-positive)}.text-negative{color:var(--color-negative)}.app-shell{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topbar-height) 1fr;grid-template-areas:"sidebar topbar""sidebar main";min-height:100vh;display:grid}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:var(--space-md) 0;width:var(--sidebar-width);z-index:50;height:100vh;transition:background-color var(--transition-slow), border-color var(--transition-slow);flex-direction:column;grid-area:sidebar;display:flex;position:fixed;top:0;left:0}.sidebar-brand{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);margin-bottom:var(--space-lg);display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:var(--accent-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebar-brand-name{color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:700;overflow:hidden}.sidebar-nav{padding:0 var(--space-sm);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:var(--space-md) var(--space-md) var(--space-xs);font-size:.714rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);font-size:.929rem;font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--sidebar-item-active);color:var(--sidebar-text-active);font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent-primary);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link.disabled{opacity:.35;pointer-events:none}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--sidebar-border);flex-direction:column;gap:2px;display:flex}.sidebar-footer-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--sidebar-text);transition:all var(--transition-fast);width:100%;font-size:.857rem;font-weight:500;display:flex}.sidebar-footer-btn:hover{background:var(--sidebar-item-hover);color:var(--text-primary)}.sidebar-footer-btn svg{width:16px;height:16px}.topbar{background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);padding:0 var(--space-xl);top:0;left:var(--sidebar-width);height:var(--topbar-height);z-index:40;transition:background-color var(--transition-slow), border-color var(--transition-slow);grid-area:topbar;justify-content:space-between;align-items:center;display:flex;position:fixed;right:0}.topbar-left{align-items:center;gap:var(--space-md);display:flex}.topbar-title{color:var(--text-primary);letter-spacing:-.01em;font-size:1.143rem;font-weight:700}.topbar-right{align-items:center;gap:var(--space-md);display:flex}.topbar-user{align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.857rem;font-weight:500;display:flex}.topbar-avatar{background:var(--accent-primary-soft);width:32px;height:32px;color:var(--accent-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.857rem;font-weight:600;display:flex}.main-content{padding:var(--space-xl);min-height:calc(100vh - var(--topbar-height));grid-area:main;max-width:1400px}.page-grid{gap:var(--space-lg);display:grid}.kpi-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.chart-grid-2{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=1024px){.chart-grid-2{grid-template-columns:1fr}}@media (width<=768px){.app-shell{grid-template-columns:1fr;grid-template-areas:"topbar""main"}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.topbar{left:0}.main-content{padding:var(--space-md);margin-left:0}.kpi-grid{grid-template-columns:repeat(2,1fr)}}.card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);transition:background-color var(--transition-slow), border-color var(--transition-slow), box-shadow var(--transition-fast)}.card:hover{border-color:var(--border-hover)}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.857rem;font-weight:600}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);gap:var(--space-sm);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--kpi-accent,var(--accent-primary));opacity:0;height:2px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0;right:0}.kpi-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.kpi-card:hover:before{opacity:1}.kpi-card-header{justify-content:space-between;align-items:center;display:flex}.kpi-card-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.786rem;font-weight:600}.kpi-card-icon{border-radius:var(--radius-sm);background:var(--kpi-accent-soft,var(--accent-primary-soft));width:36px;height:36px;color:var(--kpi-accent,var(--accent-primary));justify-content:center;align-items:center;display:flex}.kpi-card-icon svg{width:18px;height:18px}.kpi-card-value{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;font-size:1.714rem;font-weight:700;line-height:1.2}.kpi-card-delta{border-radius:100px;align-items:center;gap:4px;padding:2px 8px;font-size:.786rem;font-weight:600;display:inline-flex}.kpi-card-delta.positive{color:var(--color-positive);background:var(--color-positive-soft)}.kpi-card-delta.negative{color:var(--color-negative);background:var(--color-negative-soft)}.kpi-card-delta svg{width:12px;height:12px}.kpi-card-footer{color:var(--text-muted);font-size:.786rem}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap;font-size:.857rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-primary-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--sidebar-item-hover);border-color:var(--border-hover)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-icon{padding:var(--space-sm)}.btn svg{width:16px;height:16px}.btn:disabled{opacity:.5;pointer-events:none}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-label{color:var(--text-secondary);font-size:.857rem;font-weight:500}.input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);color:var(--input-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px;font-size:.929rem}.input::placeholder{color:var(--input-placeholder)}.input:focus{border-color:var(--input-border-focus);box-shadow:var(--focus-ring)}.input-error{border-color:var(--color-negative)}.input-error-text{color:var(--color-negative);font-size:.786rem}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:100px;align-items:center;gap:4px;padding:2px 10px;font-size:.714rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-primary-soft);color:var(--accent-primary)}.badge-green{background:var(--color-positive-soft);color:var(--color-positive)}.badge-red{background:var(--color-negative-soft);color:var(--color-negative)}.badge-amber{background:var(--color-warning-soft);color:var(--color-warning)}.data-table-wrapper{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:var(--table-header-bg)}.data-table th{padding:var(--space-sm) var(--space-md);text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-default);white-space:nowrap;font-size:.714rem;font-weight:600}.data-table td{padding:var(--space-sm) var(--space-md);color:var(--text-primary);border-bottom:1px solid var(--border-default);font-size:.857rem}.data-table tbody tr:nth-child(2n){background:var(--table-row-alt)}.data-table tbody tr:hover{background:var(--table-row-hover)}.data-table tbody tr:last-child td{border-bottom:none}.spinner{border:2.5px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-overlay{justify-content:center;align-items:center;width:100%;min-height:200px;display:flex}.empty-state{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-2xl);text-align:center;color:var(--text-muted);flex-direction:column;display:flex}.empty-state svg{opacity:.4;width:48px;height:48px}.empty-state-title{color:var(--text-secondary);font-size:1rem;font-weight:600}.empty-state-text{max-width:320px;font-size:.857rem}.period-selector{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:2px;display:flex}.period-btn{color:var(--text-secondary);transition:all var(--transition-fast);border-radius:4px;padding:6px 12px;font-size:.786rem;font-weight:500}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm);font-weight:600}.filter-bar{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);flex-wrap:wrap;display:flex}.filter-select{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);padding:6px 12px;font-size:.857rem;font-weight:500}.filter-select:focus{border-color:var(--input-border-focus)}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-2xl);gap:var(--space-lg);flex-direction:column;width:100%;max-width:400px;display:flex}.login-header{text-align:center;align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.login-logo{border-radius:var(--radius-md);background:var(--accent-primary);color:#fff;width:48px;height:48px;margin-bottom:var(--space-sm);justify-content:center;align-items:center;display:flex}.login-logo svg{width:24px;height:24px}.login-title{color:var(--text-primary);font-size:1.286rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.857rem}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.login-btn{background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);width:100%;transition:background var(--transition-fast);padding:12px;font-size:.929rem;font-weight:600}.login-btn:hover{background:var(--accent-primary-hover)}.login-btn:disabled{opacity:.6;pointer-events:none}.login-error{background:var(--color-negative-soft);color:var(--color-negative);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;font-size:.857rem;font-weight:500}.pagination{padding:var(--space-md);justify-content:space-between;align-items:center;display:flex}.pagination-info{color:var(--text-muted);font-size:.786rem}.pagination-controls{align-items:center;gap:var(--space-xs);display:flex}.pagination-btn{border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:6px 10px;font-size:.786rem;font-weight:500}.pagination-btn:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary)}.pagination-btn:disabled{opacity:.3;cursor:default}.ranking-bar-wrapper{align-items:center;gap:var(--space-sm);display:flex}.ranking-bar{background:var(--bg-elevated);border-radius:3px;flex:1;height:6px;overflow:hidden}.ranking-bar-fill{background:var(--accent-primary);height:100%;transition:width var(--transition-slow);border-radius:3px}.ranking-pct{font-family:var(--font-mono);color:var(--text-muted);text-align:right;min-width:40px;font-size:.714rem;font-weight:500}.chart-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-lg);transition:background-color var(--transition-slow), border-color var(--transition-slow)}.chart-card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-md);font-size:.857rem;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease both}.animate-slide-in{animation:slideIn var(--transition-slow) ease both}.kpi-card:first-child{animation-delay:0s}.kpi-card:nth-child(2){animation-delay:50ms}.kpi-card:nth-child(3){animation-delay:.1s}.kpi-card:nth-child(4){animation-delay:.15s}.kpi-card:nth-child(5){animation-delay:.2s}
