:root{--brand-hue:220;--bg-surface:oklch(.98 .01 var(--brand-hue));--bg-canvas:oklch(.96 .02 var(--brand-hue));--text-main:oklch(.25 .02 var(--brand-hue));--text-muted:oklch(.45 .02 var(--brand-hue));--text-on-brand:oklch(.99 .01 var(--brand-hue));--primary:oklch(60% .18 250);--primary-hover:oklch(55% .2 250);--accent:oklch(70% .15 150);--accent-hover:oklch(65% .18 150);--error:oklch(60% .18 25);--error-bg:oklch(97% .02 25);--error-bg-deep:oklch(99% .01 25);--error-text:oklch(35% .12 25);--error-heading:oklch(40% .12 25);--warning:oklch(70% .15 25);--border-subtle:oklch(.9 .02 var(--brand-hue));--border-strong:oklch(.85 .04 var(--brand-hue));--sidebar-bg:oklch(.18 .04 var(--brand-hue));--sidebar-border:oklch(100% 0 0/.05);--sidebar-text-inactive:oklch(100% 0 0/.5);--sidebar-hover:oklch(100% 0 0/.05);--sidebar-active:oklch(100% 0 0/.1);--row-hover:oklch(.98 .02 var(--brand-hue));--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-6:1.5rem;--space-8:2rem;--space-12:3rem;--font-main:"Geist", "Inter", system-ui, -apple-system, sans-serif;--font-display:"Geist Mono", "SF Mono", monospace;--text-xs:clamp(.7rem, .65rem + .25vw, .75rem);--text-sm:clamp(.8rem, .75rem + .25vw, .875rem);--text-base:clamp(.95rem, .9rem + .25vw, 1rem);--text-lg:clamp(1.1rem, 1rem + .5vw, 1.25rem);--text-xl:clamp(1.5rem, 1.25rem + 1vw, 2.25rem);--radius-sm:.4rem;--radius-md:.75rem;--radius-lg:1.25rem;--shadow-sm:0 2px 8px oklch(0% 0 0/.04);--shadow-md:0 8px 32px oklch(0% 0 0/.1);--ease-out:cubic-bezier(.16, 1, .3, 1);--transition-fast:.2s var(--ease-out);--transition-normal:.4s var(--ease-out)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-main);background-color:var(--bg-canvas);color:var(--text-main);-webkit-font-smoothing:antialiased;margin:0;line-height:1.6}h1,h2,h3,h4{letter-spacing:-.03em;color:var(--text-main);margin:0;font-weight:600}button{font-family:inherit}:focus-visible{outline:2px solid var(--primary);outline-offset:4px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-canvas)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.login-container{min-height:100vh;padding:var(--space-4);background:radial-gradient(circle at 10% 10%, oklch(90% .05 250/.2), transparent 40%), radial-gradient(circle at 90% 90%, oklch(90% .05 150/.2), transparent 40%), var(--bg-canvas);place-items:center;display:grid}.login-card{background:var(--bg-surface);padding:var(--space-12);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-subtle);text-align:center;width:100%;max-width:480px;animation:entrance var(--transition-normal)}@keyframes entrance{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.brand{margin-bottom:var(--space-8);align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.brand h1{font-size:var(--text-xl);line-height:1.1}.login-card p{color:var(--text-muted);font-size:var(--text-base);margin-top:0;margin-bottom:var(--space-8);max-width:32ch;margin-left:auto;margin-right:auto}.login-btn{background-color:var(--primary);color:var(--text-on-brand);padding:var(--space-4) var(--space-8);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;width:100%;margin-bottom:var(--space-4);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;font-weight:600;box-shadow:0 4px 12px oklch(60% .18 250/.2)}.login-btn:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px oklch(60% .18 250/.3)}.login-btn:active{transform:translateY(0)}.demo-btn{color:var(--text-muted);border:1px solid var(--border-strong);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;width:100%;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);background-color:#0000}.demo-btn:hover{background-color:var(--bg-canvas);color:var(--text-main);border-color:var(--text-main)}.demo-btn:active{transform:translateY(1px)}.auth-error{background-color:var(--error-bg);border:1px solid var(--error);color:var(--error-text);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-6);text-align:left}.footer-note{margin-top:var(--space-8);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.02em}.dashboard-container{grid-template-columns:280px 1fr;height:100vh;display:grid;overflow:hidden}@media (width<=768px){.dashboard-container{grid-template-rows:auto 1fr;grid-template-columns:1fr}}.sidebar{background-color:var(--sidebar-bg);color:var(--text-on-brand);border-right:1px solid var(--sidebar-border);flex-direction:column;display:flex}.sidebar-header{padding:var(--space-8) var(--space-6);border-bottom:1px solid var(--sidebar-border)}.sidebar-header h2{font-size:var(--text-lg);color:var(--text-on-brand)}.sidebar-links{padding:var(--space-6) 0;gap:var(--space-1);flex-direction:column;flex:1;margin:0;list-style:none;display:flex}.sidebar-links button{text-align:left;width:100%;color:var(--sidebar-text-inactive);padding:var(--space-3) var(--space-6);align-items:center;gap:var(--space-4);cursor:pointer;transition:color var(--transition-fast), background-color var(--transition-fast);font-size:var(--text-sm);background:0 0;border:none;font-weight:500;display:flex}.sidebar-links button:hover{color:var(--text-on-brand);background-color:var(--sidebar-hover)}.sidebar-links button.active{color:var(--text-on-brand);background-color:var(--sidebar-active);box-shadow:inset 4px 0 0 var(--primary)}.logout-btn{margin:var(--space-4);color:var(--warning);padding:var(--space-3);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-xs);transition:background-color var(--transition-fast), border-color var(--transition-fast);background:oklch(100% 0 0/.03);border:1px solid oklch(100% 0 0/.08);font-weight:600;display:flex}.logout-btn:hover{background-color:oklch(70% .15 25/.1);border-color:oklch(70% .15 25/.3)}.main-content{background-color:var(--bg-canvas);flex:1;overflow-y:auto}.main-header{background:oklch(.98 .01 var(--brand-hue) / .85);padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--border-subtle);z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.export-btn{background-color:var(--accent);color:var(--text-on-brand);padding:var(--space-2) var(--space-6);border-radius:var(--radius-sm);align-items:center;gap:var(--space-2);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:filter var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;display:flex}.export-btn:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 12px oklch(70% .15 150/.2)}.export-btn:active:not(:disabled){transform:translateY(0)}.export-btn.success{background-color:var(--accent-hover);pointer-events:none}.content-area{padding:var(--space-8);max-width:1400px;margin:0 auto}.chart-container,.table-container{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);margin-bottom:var(--space-8)}.chart-container{padding:var(--space-8)}.chart-container h3,.table-container h3{text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-6);font-weight:700}.table-container h3{padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--border-subtle);margin-bottom:0}table{border-collapse:separate;border-spacing:0;width:100%}th{background-color:var(--bg-canvas);color:var(--text-muted);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.1em;padding:var(--space-4) var(--space-8);border-bottom:1px solid var(--border-strong);text-align:left;white-space:nowrap;font-weight:700}td{padding:var(--space-4) var(--space-8);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);transition:background var(--transition-fast);text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}tr:last-child td{border-bottom:none}tr:hover td{background-color:var(--row-hover)}.table-wrapper{overflow-x:auto}.loader{gap:var(--space-4);padding:var(--space-12) var(--space-8);color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.loader p{font-size:var(--text-sm);margin:0;font-weight:500}.spin{animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-screen{gap:var(--space-4);background-color:var(--bg-canvas);flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex}.loading-screen span{font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-weight:500}.error-container{background-color:var(--error-bg-deep);border:1px solid var(--error);padding:var(--space-8);border-radius:var(--radius-md);gap:var(--space-6);align-items:flex-start;display:flex;box-shadow:0 4px 20px oklch(60% .18 25/.1)}.error-container>svg{color:var(--error);flex-shrink:0}.error-container h3{color:var(--error-heading);margin-bottom:var(--space-2)}.error-container p{color:var(--text-muted);font-size:var(--text-sm);margin:0 0 var(--space-4)}.error-detail{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-muted);background:var(--error-bg);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);margin-bottom:var(--space-4);word-break:break-word}.retry-btn{background:var(--error);color:var(--text-on-brand);padding:var(--space-2) var(--space-6);border-radius:var(--radius-sm);font-size:var(--text-sm);cursor:pointer;transition:filter var(--transition-fast), transform var(--transition-fast);border:none;font-weight:600}.retry-btn:hover{filter:brightness(1.1)}.retry-btn:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}.export-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.no-data{padding:var(--space-12) var(--space-8);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (width<=768px){.sidebar{flex-direction:row;overflow-x:auto}.sidebar-header{display:none}.sidebar-links{padding:var(--space-2);gap:var(--space-2);flex-direction:row}.sidebar-links button{white-space:nowrap;padding:var(--space-2) var(--space-4);min-height:44px}.sidebar-links button.active{box-shadow:inset 0 -3px 0 var(--primary)}.sidebar-footer{padding:var(--space-2)}.logout-btn{margin:0}.main-header{padding:var(--space-4) var(--space-6);gap:var(--space-3);flex-wrap:wrap}.main-header h1{font-size:var(--text-lg)}.content-area{padding:var(--space-4)}}
