@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", monospace;--bg-main:#070a13;--bg-card:#0d1426b3;--bg-card-hover:#141e3acc;--border-glow:#3b82f633;--border-color:#ffffff0f;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--color-wind:#00d2ff;--color-solar:#f59e0b;--color-psp-charge:#ec4899;--color-psp-discharge:#8b5cf6;--color-rtm:#fb923c;--color-target:#10b981;--color-curtail:#ef444426;--shadow-premium:0 10px 30px -15px #000000b3;--glow-blue:0 0 15px #3b82f64d;--glow-green:0 0 15px #10b98166;--glow-red:0 0 15px #ef444466;box-sizing:border-box}*,:before,:after{box-sizing:inherit}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 0 0,#1d4ed826 0,#0000 50%),radial-gradient(at 100% 0,#8b5cf61a 0,#0000 50%),radial-gradient(at 50% 100%,#10b9810d 0,#0000 50%);background-attachment:fixed;min-height:100vh;margin:0;padding:0;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0d142680}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.glass-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);box-shadow:var(--shadow-premium);border-radius:16px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.glass-panel:hover{background:var(--bg-card-hover);border-color:#3b82f626}.dashboard-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.header-title-area h1{letter-spacing:-.5px;background:linear-gradient(135deg,#fff 0%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:700}.header-title-area p{color:var(--text-secondary);margin:4px 0 0;font-size:14px;font-weight:400}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{flex-direction:column;justify-content:space-between;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--accent-color,var(--color-wind));width:4px;height:100%;position:absolute;top:0;left:0}.kpi-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;font-weight:500;display:flex}.kpi-value{letter-spacing:-.5px;color:var(--text-primary);align-items:baseline;gap:4px;font-size:26px;font-weight:700;display:flex}.kpi-unit{color:var(--text-secondary);font-size:14px;font-weight:400}.kpi-subtitle{color:var(--text-muted);margin-top:6px;font-size:12px}.badge-compliance{letter-spacing:.3px;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:flex}.badge-compliance.compliant{color:#10b981;box-shadow:var(--glow-green);background:#10b9811a;border:1px solid #10b98133}.badge-compliance.shortfall{color:#ef4444;box-shadow:var(--glow-red);background:#ef44441a;border:1px solid #ef444433}.main-layout{flex:1;grid-template-columns:320px minmax(0,1fr);gap:20px;max-width:100%;display:grid;overflow:hidden}.config-group{margin-bottom:24px}.config-label-area{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.config-label{color:var(--text-primary);font-size:14px;font-weight:500}.config-value{color:var(--color-wind);font-size:16px;font-weight:700}.config-input-wrapper{align-items:center;display:flex;position:relative}.range-slider{appearance:none;background:#ffffff1a;border-radius:3px;outline:none;width:100%;height:6px;transition:background .3s}.range-slider::-webkit-slider-thumb{appearance:none;background:var(--color-wind);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 0 10px #3b82f680}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.range-slider::-moz-range-thumb{background:var(--color-wind);cursor:pointer;border:0;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 0 10px #3b82f680}.range-slider::-moz-range-thumb:hover{transform:scale(1.2)}.date-select{width:100%;color:var(--text-primary);border:1px solid var(--border-color);font-family:var(--font-sans);cursor:pointer;background:#111827;border-radius:8px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .3s}.date-select:focus{border-color:#3b82f680}.visuals-container{grid-template-columns:minmax(0,1fr) 220px;gap:24px;max-width:100%;margin-bottom:24px;display:grid;overflow:hidden}@media (width<=1200px){.visuals-container{grid-template-columns:1fr}}.chart-panel{flex-direction:column;min-width:0;min-height:400px;display:flex;overflow:hidden}.chart-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.legend-group{flex-wrap:wrap;gap:12px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.legend-color{border-radius:3px;width:12px;height:12px}.psp-tank-panel{flex-direction:column;justify-content:space-between;align-items:center;padding:24px 16px;display:flex}.tank-container{background:#0f172a99;border:4px solid #1e293b;border-radius:60px/20px;align-items:flex-end;width:120px;height:240px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #00000080}.tank-container:before{content:"";z-index:10;background:#1e293bcc;border:4px solid #1e293b;border-radius:50%;height:20px;position:absolute;top:0;left:0;right:0}.tank-glass-highlight{z-index:9;background:linear-gradient(90deg,#ffffff26 0%,#fff0 100%);border-radius:6px;width:12px;height:calc(100% - 40px);position:absolute;top:20px;left:10px}.tank-liquid{width:100%;height:var(--fill-percent,50%);background:linear-gradient(#8b5cf6cc 0%,#3b82f6cc 100%);border-radius:0 0 56px 56px/0 0 16px 16px;transition:height .6s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 0 20px #8b5cf666}.tank-liquid:after{content:"";background:#a78bfae6;border-radius:50%;height:20px;animation:4s ease-in-out infinite alternate wave-motion;position:absolute;top:-10px;left:0;right:0}@keyframes wave-motion{0%{transform:translateY(0)scaleY(.9)}to{transform:translateY(-2px)scaleY(1.1)}}.tank-label{text-align:center;color:#fff;text-shadow:0 2px 4px #000c;z-index:12;pointer-events:none;font-size:20px;font-weight:700;position:absolute;top:45%;left:0;right:0}.tank-label-sub{opacity:.9;text-transform:uppercase;margin-top:2px;font-size:11px;font-weight:500;display:block}.psp-metrics{border-top:1px solid var(--border-color);width:100%;margin-top:16px;padding-top:12px}.psp-metric-row{color:var(--text-secondary);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.psp-metric-row span:last-child{color:var(--text-primary);font-weight:600}.table-panel{flex-direction:column;max-height:480px;display:flex}.table-header-wrapper{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.table-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.table-container{border:1px solid var(--border-color);border-radius:8px;flex:1;overflow-y:auto}table.schedule-table{border-collapse:collapse;text-align:left;width:100%;font-size:13px}.schedule-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);z-index:10;background:#111827;padding:12px 16px;font-weight:600;position:sticky;top:0}.schedule-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:10px 16px}.schedule-table tr{transition:background-color .2s}.schedule-table tr:hover{background-color:#ffffff05}.schedule-table tr.curtailed-row{background-color:#ef444408}.schedule-table tr.curtailed-row:hover{background-color:#ef44440d}.schedule-table tr.shortfall-row{background-color:#dc262614}.cell-badge{text-align:center;border-radius:12px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-block}.cell-badge.ok{color:#10b981;background:#10b9811a;border:1px solid #10b98133}.cell-badge.warn{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.cell-badge.curtail{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33}.psp-action-badge{font-size:11px;font-family:var(--font-mono);border-radius:4px;padding:2px 6px;font-weight:500}.psp-action-badge.charge{color:#f472b6;background:#ec489926;border:1px solid #ec48994d}.psp-action-badge.discharge{color:#a78bfa;background:#8b5cf626;border:1px solid #8b5cf64d}.psp-action-badge.idle{color:var(--text-muted)}.mono-col{font-family:var(--font-mono);font-size:13px;font-weight:500}@media (width<=992px){.main-layout{grid-template-columns:1fr}}.gen-input-table input[type=number]:focus{box-shadow:0 0 0 2px #00d2ff26}.gen-input-table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.gen-input-table input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.gen-input-table input[type=number]{appearance:textfield}.schedule-table tr.gen-modified-row td:first-child{border-left:3px solid #f59e0bb3}.app-shell{flex-direction:column;min-height:100vh;display:flex}.page-content{flex:1;width:100%;max-width:1440px;margin:0 auto;padding:20px 24px 24px;overflow-x:hidden}.top-nav{-webkit-backdrop-filter:blur(16px);z-index:100;background:#0d1426d9;border-bottom:1px solid #ffffff0f;position:sticky;top:0}.top-nav-inner{justify-content:space-between;align-items:center;gap:24px;max-width:1440px;height:60px;margin:0 auto;padding:0 24px;display:flex}.nav-brand{flex-shrink:0;align-items:center;gap:12px;display:flex}.nav-logo{object-fit:contain;width:auto;height:36px}.nav-brand-text{flex-direction:column;display:flex}.nav-title{letter-spacing:.5px;background:linear-gradient(135deg,#fff 0%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:700}.nav-tabs{align-items:center;gap:4px;display:flex}.nav-actions{align-items:center;gap:20px;min-width:0;margin-left:auto;display:flex}.nav-tab{color:#64748b;white-space:nowrap;border-radius:8px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-tab:hover{color:#94a3b8;background:#ffffff0a}.nav-tab-active{border:1px solid #6366f140;font-weight:600;color:#e2e8f0!important;background:#6366f11f!important}.nav-config-btn{color:#94a3b8;white-space:nowrap;background:#ffffff08;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;margin-left:8px;padding:6px 14px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.nav-config-btn:hover{color:#e2e8f0;background:#ffffff0f;border-color:#ffffff2e}.nav-config-btn-active{color:#fbbf24!important;background:#fbbf241a!important;border-color:#fbbf244d!important}.nav-right{flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}.user-profile-menu{position:relative}.user-profile-menu__trigger{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:box-shadow .2s,transform .12s;display:inline-flex}.user-profile-menu__trigger:hover,.user-profile-menu__trigger--open{box-shadow:0 0 0 3px #6366f138}.user-profile-menu__trigger:hover .user-profile-menu__avatar,.user-profile-menu__trigger--open .user-profile-menu__avatar{background:linear-gradient(135deg,#2563eb 0%,#4f46e5 100%);border-color:#a5b4fc73}.user-profile-menu__avatar{color:#fff;letter-spacing:.04em;background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);border:2px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:800;transition:background .2s,border-color .2s;display:inline-flex}.user-profile-menu__dropdown{-webkit-backdrop-filter:blur(14px);z-index:200;background:#0a1020eb;border:1px solid #ffffff14;border-radius:14px;min-width:240px;padding:10px;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 18px 40px #00000073,inset 0 1px #ffffff0a}.user-profile-menu__header{align-items:center;gap:12px;padding:8px 10px;display:flex}.user-profile-menu__header-avatar{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#4f46e5 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:13px;font-weight:800;display:inline-flex}.user-profile-menu__header-text{flex-direction:column;gap:2px;min-width:0;display:flex}.user-profile-menu__label{letter-spacing:.12em;text-transform:uppercase;color:#64748b;font-size:10px;font-weight:600}.user-profile-menu__username{color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;overflow:hidden}.user-profile-menu__divider{background:#ffffff0f;height:1px;margin:6px 4px}.user-profile-menu__item{color:#cbd5e1;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:13px;font-weight:600;transition:background .15s,color .15s;display:flex}.user-profile-menu__item:hover:not(:disabled){color:#f8fafc;background:#ffffff0d}.user-profile-menu__item--disabled{opacity:.72;cursor:not-allowed}.user-profile-menu__item--danger{color:#fca5a5}.user-profile-menu__item--danger:hover{color:#fecaca;background:#ef44441f}.user-profile-menu__badge{color:#64748b;letter-spacing:.08em;text-transform:uppercase;background:#ffffff0f;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:700}.page-header-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-heading{color:var(--text-primary);letter-spacing:-.3px;margin:0;font-size:22px;font-weight:700}.status-badge{letter-spacing:.3px;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.status-error{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.status-ok{color:#10b981;box-shadow:var(--glow-green);background:#10b9811a;border:1px solid #10b98133}.status-warn{color:#ef4444;box-shadow:var(--glow-red);background:#ef44441a;border:1px solid #ef444433}.sidebar-toggle{color:#94a3b8;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:none}.view-toggles{background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:2px;padding:2px;display:flex}.view-toggle-pill{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:28px;transition:all .15s;display:flex}.view-toggle-pill:hover{color:#94a3b8;background:#ffffff0f}.view-toggle-pill.active{color:#a5b4fc;background:#6366f11f}.sidebar-overlay{display:none}.sidebar-wrapper{min-width:0;max-width:320px}.main-layout.sidebar-hidden,.visuals-container.tank-hidden{grid-template-columns:minmax(0,1fr)}.content-column{flex-direction:column;gap:24px;min-width:0;display:flex}.btn-primary{color:#fff;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-sans);letter-spacing:.3px;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 24px;transition:all .2s;display:flex;box-shadow:0 4px 14px #6366f159}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#818cf8,#6366f1);transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.multiday-page,.multiday-page-wrapper{flex-direction:column;gap:20px;display:flex}.multiday-config-bar{padding:14px 20px}.multiday-config-grid{grid-template-columns:repeat(auto-fit,minmax(175px,1fr));align-items:end;gap:16px 20px;display:grid}.multiday-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.multiday-kpi-card{padding:16px}.suggestion-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}@media (width<=960px){.suggestion-grid{grid-template-columns:1fr}}.chart-view-tabs{border:1px solid var(--border-color);background:#ffffff08;border-radius:10px;gap:6px;padding:4px;display:flex}.chart-view-tab{color:#64748b;cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-radius:8px;flex:1;padding:8px 16px;transition:all .2s}.chart-view-tab:hover{color:#94a3b8;background:#ffffff08}.chart-view-tab-active{border:1px solid #6366f133;font-weight:600;color:#e2e8f0!important;background:#6366f11f!important}.generation-page{flex-direction:column;gap:16px;display:flex}.generation-input-panel{flex-direction:column;gap:14px;display:flex}.generation-input-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.generation-input-toolbar__left,.generation-input-toolbar__right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.generation-input-toolbar__left{flex-direction:column;align-items:flex-start}.generation-input-title{margin:0;font-size:20px;font-weight:600}.generation-input-subtitle{color:#64748b;margin:4px 0 0;font-size:13px}.generation-input-badges{flex-wrap:wrap;gap:8px;display:flex}.generation-badge{border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600}.generation-badge--date{color:#00d2ff;background:#00d2ff1a;border:1px solid #00d2ff40}.generation-badge--modified{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b4d}.generation-badge--stored{color:#a78bfa;background:#8b5cf61f;border:1px solid #8b5cf64d}.generation-control{color:#94a3b8;align-items:center;gap:8px;font-size:12px;display:flex}.date-range-picker{background:#ffffff08;border:1px solid #ffffff12;border-radius:8px;align-items:center;gap:8px;padding:5px 10px;display:flex}.date-input{color:var(--text-primary);font-size:12px;font-family:var(--font-mono);cursor:pointer;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:0 0;border:1px solid #ffffff1a;border-radius:6px;outline:none;min-width:120px;padding:4px 8px;transition:border-color .2s,box-shadow .2s}.date-input:focus{border-color:#00d2ff66;box-shadow:0 0 0 2px #00d2ff14}.generation-action-btn{color:#cbd5e1;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:7px;align-items:center;gap:6px;padding:7px 12px;font-size:12px;font-weight:600;display:inline-flex}.generation-action-btn:hover{background:#ffffff14;border-color:#ffffff29}.generation-action-btn--danger{color:#f87171;background:#ef44441a;border-color:#ef44444d}.generation-upload-message{border-radius:8px;padding:10px 12px;font-size:12px;font-weight:600}.generation-upload-message--success{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e40}.generation-upload-message--error{color:#f87171;background:#ef44441a;border:1px solid #ef444440}.generation-input-help{color:#64748b;background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;flex-wrap:wrap;gap:12px 20px;padding:10px 12px;font-size:11px;display:flex}.generation-input-help strong{color:#94a3b8}.generation-input-table__grid th:first-child{width:52px}.generation-input-table__grid th:nth-child(2){width:64px}.generation-input-table__grid th:nth-child(3),.generation-input-table__grid th:nth-child(4){color:#00d2ff;width:130px}.generation-input-table__grid th:nth-child(5){width:130px;color:var(--color-solar)}.generation-input-table__grid th:nth-child(6){color:#64748b;width:90px;font-size:11px}.generation-readonly-value{color:#475569;background:#ffffff05;border:1px solid #ffffff0a;border-radius:5px;padding:4px 7px;font-family:JetBrains Mono,monospace;font-size:12px}.generation-readonly-value--active{color:#00d2ff;background:#00d2ff0f;border-color:#00d2ff40;font-weight:700}.generation-readonly-value--wind{color:var(--color-wind);pointer-events:none;cursor:default;-webkit-user-select:text;user-select:text;font-weight:600}.generation-readonly-value--solar{color:var(--color-solar);pointer-events:none;cursor:default;-webkit-user-select:text;user-select:text;font-weight:600}.generation-curtailed-label,.generation-status-default{color:#334155;font-family:JetBrains Mono,monospace;font-size:11px}.generation-edited-badge{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d;font-size:10px}.generation-input-footer{color:#475569;font-size:11px}.gen-input-table{max-height:520px}.config-page{flex-direction:column;gap:16px;display:flex}.config-page-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:24px;display:grid}@media (width<=1024px){.config-page-grid{grid-template-columns:1fr}}.single-day-page{flex-direction:column;gap:16px;display:flex}@media (width<=1024px){.top-nav-inner{gap:12px;height:56px;padding:0 16px}.nav-actions{gap:12px}.nav-brand-text,.nav-tab span,.nav-config-btn span{display:none}.nav-tab{padding:8px 12px}.page-content{padding:16px}.main-layout{grid-template-columns:1fr;padding:0}.sidebar-toggle{display:flex}.sidebar-collapse-btn{display:none}.view-toggles{order:1}.sidebar-wrapper{z-index:200;background:#070a13f7;border-right:1px solid #ffffff0f;width:340px;max-width:85vw;padding:16px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:56px;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar-wrapper.sidebar-open{transform:translate(0)}.sidebar-overlay{z-index:199;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:block;position:fixed;inset:56px 0 0}.visuals-container{grid-template-columns:1fr}.multiday-config-grid{grid-template-columns:1fr 1fr}.page-heading{font-size:18px}}@media (width<=640px){.top-nav-inner{height:50px;padding:0 12px}.nav-actions{gap:8px}.user-profile-menu__avatar{width:32px;height:32px;font-size:11px}.nav-logo{height:28px}.nav-tab{padding:6px 10px;font-size:12px}.page-content{padding:12px}.glass-panel{border-radius:12px;padding:16px}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-value{font-size:20px}.multiday-config-grid{grid-template-columns:1fr}.multiday-kpi-grid{grid-template-columns:1fr 1fr;gap:8px}.multiday-kpi-card{padding:12px}.chart-view-tabs{flex-direction:column}.page-header-bar{flex-direction:column;align-items:flex-start}.page-heading{font-size:16px}.table-header-wrapper{flex-direction:column;align-items:flex-start;gap:10px}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.power-wastage-panel{margin-bottom:24px}.pw-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:20px;display:flex}.pw-title-group{align-items:center;gap:8px;display:flex}.pw-title{color:var(--text-primary);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.pw-subtitle{color:var(--text-muted);font-size:12px;font-weight:400}.pw-kpi-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width<=1100px){.pw-kpi-row{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.pw-kpi-row{grid-template-columns:1fr}}.pw-kpi-card{border:1px solid var(--border-color);background:#ffffff08;border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;transition:border-color .25s,background .25s;display:flex;position:relative;overflow:hidden}.pw-kpi-card:before{content:"";background:var(--pw-card-glow,transparent);opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0}.pw-kpi-card:hover{border-color:var(--pw-card-border,#ffffff1a)}.pw-kpi-card:hover:before{opacity:1}.pw-kpi-card--warn{--pw-card-border:#f59e0b4d;--pw-card-glow:radial-gradient(ellipse at top left, #f59e0b0f 0%, transparent 70%);border-left:3px solid #f59e0b}.pw-kpi-card--info{--pw-card-border:#00d2ff4d;--pw-card-glow:radial-gradient(ellipse at top left, #00d2ff0f 0%, transparent 70%);border-left:3px solid #00d2ff}.pw-kpi-card--success{--pw-card-border:#10b9814d;--pw-card-glow:radial-gradient(ellipse at top left, #10b9810f 0%, transparent 70%);border-left:3px solid #10b981}.pw-kpi-card--neutral{--pw-card-border:#8b5cf64d;--pw-card-glow:radial-gradient(ellipse at top left, #8b5cf60f 0%, transparent 70%);border-left:3px solid #8b5cf6}.pw-kpi-card-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.pw-kpi-card-value{color:var(--text-primary);letter-spacing:-.5px;align-items:baseline;gap:4px;font-size:24px;font-weight:700;display:flex}.pw-kpi-unit{color:var(--text-secondary);font-size:13px;font-weight:400}.pw-kpi-hint{color:var(--text-muted);font-size:11px;line-height:1.4}.pw-breakdown{border-top:1px solid var(--border-color);padding-top:16px}.pw-breakdown-label{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;font-weight:500;display:flex}.pw-breakdown-total{color:var(--text-muted);font-size:11px}.pw-bar-track{background:#ffffff0d;border-radius:7px;height:14px;margin-bottom:12px;display:flex;position:relative;overflow:hidden}.pw-bar-segment{min-width:0;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.pw-bar-actual{background:linear-gradient(90deg,#10b981,#34d399);border-radius:7px 0 0 7px;box-shadow:0 0 8px #10b98166}.pw-bar-compliance{background:linear-gradient(90deg,#f59e0b,#fbbf24);box-shadow:0 0 8px #f59e0b66}.pw-bar-soc{background:linear-gradient(90deg,#ef4444,#f87171);border-radius:0 7px 7px 0;box-shadow:0 0 8px #ef444466}.pw-legend{flex-wrap:wrap;gap:16px;display:flex}.pw-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.pw-legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.pw-legend-dot--actual{background:#10b981}.pw-legend-dot--compliance{background:#f59e0b}.pw-legend-dot--soc{background:#ef4444}.pw-no-shortfall{color:#34d399;text-align:center;background:#10b9810f;border:1px solid #10b98126;border-radius:8px;padding:12px 16px;font-size:13px;font-weight:500}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page__backdrop{z-index:0;background-position:50%;background-repeat:no-repeat;background-size:cover;position:fixed;inset:0}.login-page__overlay{z-index:1;background:radial-gradient(circle at 20% 20%,#00d2ff14,#0000 40%),linear-gradient(#050a188c 0%,#050a18d1 100%);position:fixed;inset:0}.login-card{z-index:2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1020d1;border:1px solid #ffffff14;border-radius:18px;width:min(100%,420px);padding:36px 32px 28px;position:relative;box-shadow:0 24px 60px #00000073,inset 0 1px #ffffff0a}.login-card__logo{justify-content:center;margin-bottom:28px;display:flex}.login-card__logo img{object-fit:contain;width:auto;height:56px}.login-card__heading{text-align:center;margin-bottom:28px}.login-card__heading h1{letter-spacing:.08em;color:#f8fafc;margin:0 0 8px;font-size:28px;font-weight:800}.login-card__heading p{letter-spacing:.22em;color:#64748b;margin:0;font-size:11px;font-weight:600}.login-form{flex-direction:column;gap:18px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-field__label{letter-spacing:.16em;color:#64748b;font-size:10px;font-weight:700}.login-field__input-wrap{background:#050a14bf;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:10px;min-height:48px;padding:0 14px;transition:border-color .15s,box-shadow .15s;display:flex}.login-field__input-wrap:focus-within{border-color:#3b82f673;box-shadow:0 0 0 3px #3b82f61f}.login-field__icon{color:#64748b;flex-shrink:0}.login-field__input-wrap input{color:#e2e8f0;min-width:0;font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1}.login-field__input-wrap input::placeholder{color:#475569}.login-field__toggle{color:#64748b;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.login-field__toggle:hover{color:#94a3b8}.login-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444440;border-radius:8px;padding:10px 12px;font-size:12px}.login-submit{color:#fff;letter-spacing:.14em;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;min-height:50px;margin-top:4px;font-size:12px;font-weight:800;transition:transform .12s,box-shadow .12s,opacity .12s;display:flex;box-shadow:0 10px 24px #2563eb59}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #2563eb6b}.login-submit:disabled{opacity:.7;cursor:wait}.login-footer{text-align:center;letter-spacing:.18em;color:#475569;margin:22px 0 0;font-size:10px;font-weight:600}.admin-shell{color:#e2e8f0;background:#060a14;min-height:100vh;display:flex}.admin-sidebar{background:#0a1020f2;border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;width:260px;padding:20px 14px;display:flex}.admin-sidebar__brand{border-bottom:1px solid #ffffff0f;align-items:center;gap:12px;margin-bottom:16px;padding:8px 10px 24px;display:flex}.admin-sidebar__logo{width:auto;height:36px}.admin-sidebar__title{letter-spacing:.04em;font-size:14px;font-weight:800}.admin-sidebar__subtitle{color:#64748b;font-size:11px}.admin-sidebar__nav{flex-direction:column;gap:4px;display:flex}.admin-sidebar__link{color:#94a3b8;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.admin-sidebar__link:hover{color:#e2e8f0;background:#ffffff0a}.admin-sidebar__link--active{color:#93c5fd;background:#3b82f624;border:1px solid #3b82f638}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0d1426d9;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex}.admin-topbar__title{color:#cbd5e1;letter-spacing:.06em;text-transform:uppercase;font-size:14px;font-weight:700}.admin-topbar__user{align-items:center;gap:12px;display:flex}.admin-topbar__avatar{background:linear-gradient(135deg,#1d4ed8,#4f46e5);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:800;display:inline-flex}.admin-topbar__username{font-size:13px;font-weight:600}.admin-topbar__logout{color:#fca5a5;cursor:pointer;background:#ef444414;border:1px solid #ef444440;border-radius:8px;align-items:center;gap:6px;padding:7px 12px;font-size:12px;font-weight:600;display:inline-flex}.admin-content{flex:1;padding:24px}.admin-page__header h1{margin:0 0 6px;font-size:24px;font-weight:800}.admin-page__header p{color:#64748b;margin:0;font-size:13px}.admin-page__header--row{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.admin-stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.admin-stat-card{background:#0d1426bf;border:1px solid #ffffff0f;border-radius:14px;align-items:center;gap:14px;padding:18px;display:flex}.admin-stat-card__icon{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.admin-stat-card__value{font-size:28px;font-weight:800;line-height:1}.admin-stat-card__label{color:#64748b;margin-top:4px;font-size:12px}.admin-placeholder-card{text-align:center;color:#64748b;letter-spacing:.12em;border:1px dashed #ffffff1f;border-radius:14px;margin-top:20px;padding:48px;font-weight:700}.admin-login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.admin-login-page__backdrop{filter:brightness(1.2)saturate(1.08);z-index:0;background-position:50%;background-repeat:no-repeat;background-size:cover;position:fixed;inset:0}.admin-login-page__overlay{z-index:1;background:radial-gradient(circle at 18% 22%,#3b82f624,#0000 42%),radial-gradient(circle at 82% 78%,#6366f11a,#0000 40%),linear-gradient(#050a1861 0%,#050a18ad 100%);position:fixed;inset:0}.admin-login-card{z-index:2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:center;background:#0a1020d1;border:1px solid #ffffff14;border-radius:18px;width:min(100%,420px);padding:40px 36px 32px;position:relative;box-shadow:0 24px 60px #00000073,inset 0 1px #ffffff0a}.admin-login-card__badge{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f640;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex}.admin-login-card__heading{margin-bottom:28px}.admin-login-card__heading h1{letter-spacing:.04em;color:#f8fafc;margin:0 0 8px;font-size:28px;font-weight:800}.admin-login-card__heading p{color:#64748b;letter-spacing:.18em;text-transform:uppercase;margin:0;font-size:11px;font-weight:600}.admin-login-form{text-align:left;flex-direction:column;gap:20px;display:flex}.admin-login-field{flex-direction:column;gap:8px;display:flex}.admin-login-field__label{letter-spacing:.14em;text-transform:uppercase;color:#64748b;font-size:10px;font-weight:700}.admin-login-field__input-wrap{background:#050a14bf;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:10px;min-height:48px;padding:0 14px;transition:border-color .15s,box-shadow .15s;display:flex}.admin-login-field__input-wrap:focus-within{border-color:#3b82f673;box-shadow:0 0 0 3px #3b82f61f}.admin-login-field__icon{color:#64748b;flex-shrink:0}.admin-login-field__input-wrap input{color:#e2e8f0;min-width:0;font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1;padding:12px 0}.admin-login-field__input-wrap input::placeholder{color:#475569}.admin-login-field__toggle{color:#64748b;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.admin-login-field__toggle:hover{color:#94a3b8}.admin-login-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444440;border-radius:8px;padding:10px 12px;font-size:12px}.admin-login-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;border-radius:10px;width:100%;min-height:50px;margin-top:4px;padding:13px;font-size:14px;font-weight:700;transition:transform .12s,box-shadow .12s,opacity .12s;box-shadow:0 10px 24px #2563eb59}.admin-login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #2563eb6b}.admin-login-submit:disabled{opacity:.7;cursor:wait}.admin-login-footer{letter-spacing:.16em;color:#475569;margin:24px 0 0;font-size:10px;font-weight:600}.admin-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-search{color:#64748b;background:#0a102099;border:1px solid #ffffff14;border-radius:10px;flex:1;align-items:center;gap:8px;max-width:420px;padding:8px 12px;display:flex}.admin-search input{color:#e2e8f0;background:0 0;border:none;outline:none;flex:1;font-size:13px}.admin-toolbar__meta{color:#64748b;font-size:12px}.admin-btn{color:#cbd5e1;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;display:inline-flex}.admin-btn--primary{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#3b82f666}.admin-btn--danger{color:#fca5a5;background:#ef44441f;border-color:#ef44444d}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-table-wrap{background:#0a102099;border:1px solid #ffffff0f;border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid #ffffff0a;padding:12px 14px}.admin-table th{text-transform:uppercase;letter-spacing:.08em;color:#64748b;background:#ffffff05;font-size:11px}.admin-table__empty{text-align:center;color:#64748b;padding:32px!important}.admin-badge{letter-spacing:.06em;border-radius:999px;padding:3px 10px;font-size:10px;font-weight:800;display:inline-block}.admin-badge--active{color:#34d399;background:#10b9811f}.admin-badge--inactive{color:#fbbf24;background:#fbbf241f}.admin-badge--locked{color:#f87171;background:#ef44441f}.admin-actions{flex-wrap:wrap;gap:4px;display:flex}.admin-actions button{color:#94a3b8;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.admin-actions button:hover{color:#e2e8f0;background:#ffffff0f}.admin-actions__danger:hover{color:#fca5a5;border-color:#ef44444d}.admin-pagination{color:#94a3b8;justify-content:center;align-items:center;gap:16px;margin-top:16px;font-size:13px;display:flex}.admin-alert{border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:13px}.admin-alert--error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444440}.admin-alert--success{color:#6ee7b7;background:#10b9811a;border:1px solid #10b98140}.admin-modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-modal{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1020f5;border:1px solid #ffffff14;border-radius:14px;width:min(100%,440px);padding:20px;box-shadow:0 24px 60px #00000080}.admin-modal__header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.admin-modal__header h2{margin:0;font-size:18px}.admin-modal__close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:24px;line-height:1}.admin-form{flex-direction:column;gap:14px;display:flex}.admin-form label{color:#94a3b8;flex-direction:column;gap:6px;font-size:12px;font-weight:600;display:flex}.admin-form input,.admin-form select{color:#e2e8f0;background:#050a14cc;border:1px solid #ffffff14;border-radius:8px;padding:10px 12px;font-size:13px}.admin-form__actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}@media (width<=900px){.admin-shell{flex-direction:column}.admin-sidebar{flex-direction:row;align-items:center;width:100%;padding:12px;overflow-x:auto}.admin-sidebar__brand{border-bottom:none;margin-bottom:0;margin-right:12px;padding-bottom:0}.admin-sidebar__nav{flex-direction:row}.admin-topbar__username{display:none}}
