: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(.42 .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/.62);--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-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--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);--chart-1:oklch(55% .18 270);--chart-2:oklch(60% .15 195);--chart-3:oklch(60% .16 155);--chart-4:oklch(65% .15 75);--chart-5:oklch(60% .2 25);--chart-6:oklch(55% .18 290);--chart-7:oklch(60% .2 340);--chart-8:oklch(60% .12 175);--section-accent:oklch(60% .18 250);--section-accent-bg:oklch(96% .03 250);--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-6) var(--space-6);border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-header h2{font-size:var(--text-lg);color:var(--text-on-brand)}.sidebar-scroll{padding:var(--space-3) 0;scrollbar-color:oklch(100% 0 0/.15) transparent;flex:1;overflow-y:auto}.sidebar-scroll::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-track{background:0 0}.sidebar-scroll::-webkit-scrollbar-thumb{background:oklch(100% 0 0/.15);border-radius:3px}.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:oklch(100% 0 0/.25)}.sidebar-group{margin-bottom:var(--space-2)}.sidebar-group-heading{padding:var(--space-3) var(--space-6) var(--space-1);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:oklch(100% 0 0/.35);font-weight:700}.sidebar-links{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.sidebar-links button{text-align:left;width:100%;color:var(--sidebar-text-inactive);padding:var(--space-2) var(--space-6);align-items:center;gap:var(--space-3);cursor:pointer;transition:color var(--transition-fast), background-color var(--transition-fast);font-size:var(--text-xs);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 3px 0 0 var(--section-accent,var(--primary))}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-shrink:0}.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;position:relative}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}[data-section=pipeline]{--section-accent:oklch(55% .12 250);--section-accent-bg:oklch(97% .02 250)}[data-section=financial]{--section-accent:oklch(55% .12 155);--section-accent-bg:oklch(97% .02 155)}[data-section=portfolio-overview]{--section-accent:oklch(55% .12 250);--section-accent-bg:oklch(97% .02 250)}[data-section=system-production]{--section-accent:oklch(55% .12 80);--section-accent-bg:oklch(97% .02 80)}[data-section=financials]{--section-accent:oklch(55% .12 35);--section-accent-bg:oklch(97% .02 35)}[data-section=savings-utility]{--section-accent:oklch(55% .12 155);--section-accent-bg:oklch(97% .02 155)}[data-section=battery-upgrades]{--section-accent:oklch(55% .12 270);--section-accent-bg:oklch(97% .02 270)}[data-section=impact-compliance]{--section-accent:oklch(55% .12 150);--section-accent-bg:oklch(97% .02 150)}.no-data{padding:var(--space-12) var(--space-8);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.kpi-row{gap:var(--space-4);margin-bottom:var(--space-10);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-5) var(--space-6);gap:var(--space-2);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.kpi-value{font-size:var(--text-xl);letter-spacing:-.03em;color:var(--text-main);font-variant-numeric:tabular-nums;font-weight:700;line-height:1.1}.kpi-label{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.kpi-detail{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-muted);margin:0;padding:0;font-weight:500;display:flex}.kpi-trend-up{color:oklch(50% .14 150)}.kpi-trend-down{color:oklch(50% .14 25)}.filter-bar{align-items:flex-end;gap:var(--space-5);padding:var(--space-5) var(--space-8);border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);flex-wrap:wrap;display:flex}.filter-group{gap:var(--space-2);flex-direction:column;display:flex}.filter-group label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.filter-input,.filter-select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:var(--font-main);color:var(--text-main);background:var(--bg-surface);min-width:140px;transition:border-color var(--transition-fast)}.filter-input:focus,.filter-select:focus{border-color:var(--primary);outline:none}.multi-select{position:relative}.multi-select-trigger{justify-content:space-between;align-items:center;gap:var(--space-2);cursor:pointer;text-align:left;display:flex}.multi-select-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.multi-select-dropdown{z-index:20;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:200px;max-height:280px;animation:entrance .15s var(--ease-out);position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto}.multi-select-clear{text-align:left;width:100%;padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:600;font-family:var(--font-main);color:var(--primary);border:none;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background-color var(--transition-fast);background:0 0;display:block}.multi-select-clear:hover{background-color:var(--bg-canvas)}.multi-select-option{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-fast);display:flex}.multi-select-option:hover{background-color:var(--bg-canvas)}.multi-select-option input[type=checkbox]{accent-color:var(--primary);flex-shrink:0;width:14px;height:14px}.filter-clear{align-items:center;gap:var(--space-1);color:var(--error);font-size:var(--text-xs);cursor:pointer;padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);min-height:36px;transition:background-color var(--transition-fast);background:0 0;border:none;font-weight:600;display:flex}.filter-clear:hover{background-color:var(--error-bg)}.chart-grid{gap:var(--space-6);margin-bottom:var(--space-12);grid-template-columns:repeat(auto-fit,minmax(360px,1fr));display:grid}.chart-loading{min-height:200px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.table-toolbar{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.table-toolbar-left{align-items:center;gap:var(--space-4);display:flex}.table-toolbar-right{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.table-toolbar h3{border-bottom:none;margin:0;padding:0}.table-search{align-items:center;gap:var(--space-2);background:var(--bg-canvas);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);transition:border-color var(--transition-fast);display:flex}.table-search:focus-within{border-color:var(--primary)}.table-search svg{color:var(--text-muted);flex-shrink:0}.table-search input{font-size:var(--text-sm);font-family:var(--font-main);color:var(--text-main);background:0 0;border:none;outline:none;min-width:160px}.table-search input::placeholder{color:var(--text-muted)}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}th.sortable:hover{color:var(--section-accent,var(--primary))}.th-content{align-items:center;gap:var(--space-1);display:inline-flex}.th-drag-handle{opacity:0;color:var(--text-muted);cursor:grab;transition:opacity var(--transition-fast);flex-shrink:0}th:hover .th-drag-handle{opacity:.5}th:hover .th-drag-handle:hover{opacity:1}th.col-drag-over{box-shadow:inset 2px 0 0 var(--primary)}.th-resize-handle{cursor:col-resize;z-index:1;width:5px;height:100%;transition:background var(--transition-fast);background:0 0;position:absolute;top:0;right:-2px}.th-resize-handle:hover,.th-resize-handle:active{background:var(--primary);opacity:.5}.clickable-row{cursor:pointer}.clickable-row:hover td{background-color:oklch(.96 .02 var(--brand-hue))}.highlighted-row td{background-color:oklch(94% .03 250)!important}.no-data-cell{text-align:center;color:var(--text-muted);font-style:italic;padding:var(--space-12) var(--space-8)!important}.table-pagination{padding:var(--space-4) var(--space-8);border-top:1px solid var(--border-subtle);font-size:var(--text-xs);color:var(--text-muted);justify-content:space-between;align-items:center;display:flex}.table-pagination-info{font-weight:500}.table-pagination-controls{align-items:center;gap:var(--space-3);display:flex}.table-pagination-controls select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);min-height:32px;font-size:var(--text-xs);font-family:var(--font-main);color:var(--text-main);background:var(--bg-surface)}.table-pagination-controls button{padding:var(--space-2) var(--space-4);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-surface);min-height:32px;color:var(--text-main);font-size:var(--text-xs);cursor:pointer;transition:background-color var(--transition-fast);font-weight:600}.table-pagination-controls button:hover:not(:disabled){background-color:var(--bg-canvas)}.truncation-banner{color:oklch(35% .1 50);padding:var(--space-3) var(--space-6);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-6);background:oklch(95% .06 50);border:1px solid oklch(85% .1 50);font-weight:500}.empty-state{align-items:center;gap:var(--space-4);padding:var(--space-12);color:var(--text-muted);text-align:center;flex-direction:column;display:flex}.empty-state p{max-width:40ch;font-size:var(--text-sm);margin:0}.header-actions{align-items:center;gap:var(--space-3);display:flex}.table-toolbar-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-main);font-size:var(--text-xs);font-weight:600;font-family:var(--font-main);cursor:pointer;transition:border-color var(--transition-fast), background-color var(--transition-fast);white-space:nowrap;min-height:32px;display:flex}.table-toolbar-btn:hover{background-color:var(--bg-canvas);border-color:var(--primary)}.column-toggle{position:relative}.column-toggle-badge{background:var(--primary);color:var(--text-on-brand);border-radius:8px;padding:1px 5px;font-size:.65rem;font-weight:700;line-height:1.4}.column-toggle-menu{z-index:20;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:220px;max-height:360px;animation:entrance .15s var(--ease-out);position:absolute;top:calc(100% + 4px);right:0;overflow-y:auto}.column-toggle-actions{gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);display:flex}.column-toggle-action{font-size:var(--text-xs);color:var(--primary);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-weight:600;font-family:var(--font-main);transition:background-color var(--transition-fast);background:0 0;border:none}.column-toggle-action:hover{background-color:var(--bg-canvas)}.column-toggle-list{padding:var(--space-2) 0}.column-toggle-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-fast);display:flex}.column-toggle-item:hover{background-color:var(--bg-canvas)}.column-toggle-item input[type=checkbox]{accent-color:var(--primary);flex-shrink:0;width:14px;height:14px}.table-density-select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);min-height:32px;font-size:var(--text-xs);font-family:var(--font-main);color:var(--text-main);background:var(--bg-surface)}.table-container[data-density=compact] td{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.table-container[data-density=compact] th{padding:var(--space-2) var(--space-4);font-size:.65rem}.table-container[data-density=compact] .summary-row td{padding:var(--space-2) var(--space-4)}.table-container[data-density=comfortable] td{padding:var(--space-6) var(--space-8)}.table-container[data-density=comfortable] th{padding:var(--space-5) var(--space-8)}tfoot .summary-row td{background-color:var(--bg-canvas);border-top:2px solid var(--border-strong);font-size:var(--text-xs);padding:var(--space-3) var(--space-8);border-bottom:none;font-weight:600}tfoot .summary-row:hover td{background-color:var(--bg-canvas)}.summary-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.summary-value{font-variant-numeric:tabular-nums;color:var(--text-main)}.summary-tag{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-right:var(--space-1);font-size:.6rem;font-weight:700}.section-panel{background:var(--section-accent-bg,var(--bg-surface));border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-6) var(--space-8);margin-bottom:var(--space-10);box-shadow:var(--shadow-sm);border-left:3px solid var(--section-accent,var(--primary))}.section-panel-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-5);font-weight:700}.distribution-grid{gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.distribution-group-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-3);font-weight:700}.distribution-items{gap:var(--space-2);flex-direction:column;display:flex}.distribution-item{align-items:center;gap:var(--space-3);font-size:var(--text-sm);grid-template-columns:100px 1fr 32px;display:grid}.distribution-item-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.distribution-item-bar{background:var(--bg-canvas);border-radius:3px;height:16px;overflow:hidden}.distribution-item-fill{background:var(--section-accent,var(--primary));opacity:.7;height:100%;transition:width .5s var(--ease-out);border-radius:3px;display:block}.distribution-item-count{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-main);font-weight:700;font-size:var(--text-xs)}.range-grid{gap:var(--space-3);flex-direction:column;display:flex}.range-row{padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.range-row:last-child{border-bottom:none}.range-label{color:var(--text-main);min-width:160px;font-weight:500}.range-values{gap:var(--space-8);display:flex}.range-min,.range-avg,.range-max{font-variant-numeric:tabular-nums;color:var(--text-main);font-weight:600}.range-tag{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;margin-right:var(--space-2);font-weight:700}.range-min .range-tag{color:var(--text-muted)}.range-avg .range-tag{color:var(--section-accent,var(--primary))}.range-max .range-tag{color:var(--text-muted)}.cost-stack{border-radius:var(--radius-sm);height:32px;margin-bottom:var(--space-4);display:flex;overflow:hidden}.cost-stack-segment{transition:width .6s var(--ease-out);min-width:1px}.cost-stack-segment:hover{opacity:.85}.cost-stack-legend{gap:var(--space-3) var(--space-6);font-size:var(--text-xs);flex-wrap:wrap;display:flex}.cost-stack-legend-item{align-items:center;gap:var(--space-2);display:flex}.cost-stack-legend-swatch{border-radius:2px;flex-shrink:0;width:10px;height:10px}.cost-stack-legend-label{color:var(--text-muted);font-weight:500}.cost-stack-legend-value{color:var(--text-main);font-variant-numeric:tabular-nums;font-weight:700}.before-after{align-items:center;gap:var(--space-6);flex-wrap:wrap;display:flex}.ba-item{padding:var(--space-4) var(--space-6);background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);text-align:center;min-width:140px}.ba-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-1);font-weight:600}.ba-value{font-size:var(--text-lg);color:var(--text-main);font-variant-numeric:tabular-nums;font-weight:700}.ba-arrow{font-size:var(--text-xl);color:var(--section-accent,var(--primary));font-weight:300}.ba-delta{border-color:var(--section-accent,var(--primary))}.ba-delta-value{color:var(--section-accent,var(--primary))}.frequency-table{font-size:var(--text-sm)}.freq-header{gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-strong);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);grid-template-columns:140px 80px 1fr 100px;font-weight:700;display:grid}.freq-row{gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);grid-template-columns:140px 80px 1fr 100px;align-items:center;display:grid}.freq-row:last-child{border-bottom:none}.freq-name{color:var(--text-main);font-weight:500}.freq-count{font-variant-numeric:tabular-nums;color:var(--text-muted);font-weight:500}.freq-bar{background:var(--bg-canvas);border-radius:3px;height:14px;overflow:hidden}.freq-fill{background:var(--section-accent,var(--primary));opacity:.6;height:100%;transition:width .5s var(--ease-out);border-radius:3px;display:block}.freq-cost{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-main);font-weight:700}.paired-table{font-size:var(--text-sm)}.paired-header{gap:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-strong);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);grid-template-columns:80px 1fr 1fr;font-weight:700;display:grid}.paired-row{gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle);grid-template-columns:80px 1fr 1fr;display:grid}.paired-row:last-child{border-bottom:none}.paired-name{color:var(--section-accent,var(--text-main));font-weight:600}.paired-val{font-variant-numeric:tabular-nums;color:var(--text-main);font-weight:600}.headline-stats{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.headline-stat{text-align:center;padding:var(--space-4)}.headline-value{font-size:var(--text-xl);color:var(--text-main);font-variant-numeric:tabular-nums;letter-spacing:-.03em;font-weight:800;line-height:1.1}.headline-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:var(--space-2);font-weight:600}.headline-sublabel{font-size:var(--text-xs);color:var(--section-accent,var(--primary));margin-top:var(--space-1);font-weight:500}.scorecard-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.scorecard-cell{padding:var(--space-4) var(--space-5);background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.scorecard-value{font-size:var(--text-lg);font-variant-numeric:tabular-nums;color:var(--text-main);margin-bottom:var(--space-1);font-weight:700}.scorecard-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.waterfall{gap:var(--space-4);flex-direction:column;display:flex}.waterfall-step{align-items:center;gap:var(--space-4);font-size:var(--text-sm);grid-template-columns:120px 1fr 100px;display:grid}.waterfall-label{color:var(--text-muted);font-weight:500}.waterfall-track{background:var(--bg-canvas);border-radius:var(--radius-sm);height:24px;position:relative;overflow:hidden}.waterfall-fill{background:var(--section-accent,var(--primary));border-radius:var(--radius-sm);opacity:.75;height:100%;transition:left .5s var(--ease-out), width .5s var(--ease-out);position:absolute;top:0}.waterfall-value{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-main);font-weight:700}@media (width<=768px){.distribution-grid{grid-template-columns:1fr}.range-row{gap:var(--space-2);flex-direction:column;align-items:flex-start}.range-values{gap:var(--space-4)}.before-after{flex-direction:column}.ba-arrow{transform:rotate(90deg)}.freq-header,.freq-row{grid-template-columns:120px 60px 1fr 80px}.headline-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.scorecard-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.waterfall-step{grid-template-columns:100px 1fr 80px}}.error-boundary-screen{min-height:100vh;padding:var(--space-8);text-align:center;background:var(--bg-canvas);color:var(--error);flex-direction:column;justify-content:center;align-items:center;display:flex}.error-boundary-screen h1{margin-top:var(--space-6);color:var(--text-main)}.error-boundary-screen p{color:var(--text-muted);margin:var(--space-2) 0 var(--space-6)}.error-boundary-screen .error-detail{max-width:500px;margin-bottom:var(--space-6)}.error-boundary-screen .login-btn{max-width:300px}dl.kpi-card{margin:0}dl.kpi-card dt,dl.kpi-card dd{margin:0;padding:0}@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;max-height:none;overflow-x:auto}.sidebar-header{display:none}.sidebar-scroll{flex-direction:row;padding:0;display:flex;overflow:auto hidden}.sidebar-group{flex-direction:row;margin:0;display:flex}.sidebar-group-heading{display:none}.sidebar-links{padding:var(--space-2);flex-direction:row;gap:0}.sidebar-links button{white-space:nowrap;padding:var(--space-2) var(--space-3);min-height:44px;font-size:var(--text-xs)}.sidebar-links button.active{box-shadow:inset 0 -3px 0 var(--primary)}.sidebar-links button span{display:none}.sidebar-footer{padding:var(--space-2);flex-shrink:0}.logout-btn{margin:0}.logout-btn span{display:none}.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)}.filter-bar{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.kpi-row{gap:var(--space-3);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.chart-grid{margin-bottom:var(--space-8);grid-template-columns:1fr}.table-toolbar{padding:var(--space-3) var(--space-4);flex-direction:column;align-items:stretch}.table-toolbar-right{justify-content:flex-end}.table-toolbar-btn-label{display:none}.column-toggle-menu{left:0;right:auto}.table-pagination{gap:var(--space-2);flex-direction:column}}
