@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";:root{--bg-primary: #030604;--bg-secondary: #050a08;--bg-card: rgba(3, 8, 6, .97);--bg-card-hover: rgba(6, 12, 10, .98);--bg-input: rgba(5, 10, 8, .95);--border-subtle: rgba(255, 255, 255, .1);--border-accent: rgba(255, 255, 255, .18);--border-glow: rgba(52, 211, 153, .3);--text-primary: #ffffff;--text-secondary: #d0ddd8;--text-muted: #a8b8b2;--accent-primary: #4ade80;--accent-secondary: #86efac;--accent-green: #4ade80;--accent-purple: #c4b5fd;--accent-orange: #fdba74;--accent-red: #fca5a5;--accent-yellow: #fde047;--glow-primary: 0 0 30px rgba(74, 222, 128, .15);--glow-accent: 0 0 40px rgba(134, 239, 172, .2);--spacing-unit: 24px;--card-radius: 16px;--transition-fast: .2s ease;--transition-normal: .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,#030705 0%,#050a08 50%,#071410 100%);background-attachment:fixed;min-height:100vh;color:var(--text-primary);line-height:1.6}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 20%,rgba(74,222,128,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(134,239,172,.02) 0%,transparent 50%);pointer-events:none;z-index:-1}.app-container{max-width:1500px;margin:0 auto;padding:var(--spacing-unit);display:flex;flex-direction:column;gap:var(--spacing-unit)}.top-banner{background:linear-gradient(90deg,#f0f0f0 0%,#d0d0d0 30%,#808080 70%,#3a3a3a 100%);margin:calc(var(--spacing-unit) * -1);margin-bottom:0;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);border-bottom:1px solid rgba(0,0,0,.2)}.banner-content{max-width:1500px;margin:0 auto;text-align:left}.banner-title{font-family:DM Sans,Segoe UI,sans-serif;font-size:clamp(1.6em,3.5vw,2.2em);font-weight:600;letter-spacing:-.01em;color:#2a2a2a;margin-bottom:4px}.banner-subtitle{font-family:DM Sans,Segoe UI,sans-serif;font-size:.95em;color:#4a4a4a;font-weight:500}.banner-divider{height:2px;background:linear-gradient(90deg,rgba(74,222,128,.6) 0%,rgba(74,222,128,.2) 50%,transparent 100%);margin:var(--spacing-unit) 0}.app-header{text-align:center;padding:calc(var(--spacing-unit) * 2) var(--spacing-unit);animation:fadeIn .8s ease}.app-header h1{font-size:clamp(2em,5vw,3em);font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#4ade80 0%,#86efac 50%,#bbf7d0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;text-shadow:var(--glow-primary)}.app-header p{font-size:1.15em;color:var(--text-secondary);font-weight:400}.timestamp{text-align:center;color:var(--text-muted);font-size:.9em;padding-bottom:var(--spacing-unit);border-bottom:1px solid var(--border-subtle)}.status-indicator{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:10px;animation:pulse 2s infinite;background-color:var(--accent-green);box-shadow:0 0 10px var(--accent-green)}.card,.analytics-card,.ercot-card,.kpi-card,.metric-card,.quick-stat{background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--card-radius);padding:var(--spacing-unit);box-shadow:0 4px 24px #0006,var(--glow-primary),inset 0 1px #ffffff0d;transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.card:hover,.analytics-card:hover,.ercot-card:hover{transform:translateY(-4px);border-color:var(--border-accent);box-shadow:0 8px 40px #00000080,var(--glow-accent),inset 0 1px #ffffff14}.card-title{font-size:1.25em;font-weight:700;color:var(--text-primary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.card-header-row .card-title{margin-bottom:0;padding-bottom:0;border-bottom:none}.download-csv-btn{padding:10px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#000;font-weight:600;font-size:.9em;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px;white-space:nowrap}.download-csv-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #22c55e66;background:linear-gradient(135deg,#4ade80,#22c55e)}.download-csv-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-unit)}.summary-stat{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.summary-stat:last-child{border-bottom:none}.summary-stat div{color:var(--text-secondary);font-size:.95em}.summary-stat strong{font-size:1.4em;font-weight:700;color:var(--accent-primary)}.filter-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:20px;background:rgba(15,23,42,.6);border-radius:12px;border:1px solid var(--border-subtle);margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{color:var(--text-primary);font-weight:600;font-size:.85em;text-transform:uppercase;letter-spacing:.5px}.filter-group select,.filter-group input,.input-group input,.input-group select,.zip-actions input{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:10px;font-size:.95em;color:var(--text-primary);transition:all var(--transition-fast)}.filter-group select:focus,.filter-group input:focus,.input-group input:focus,.input-group select:focus,.zip-actions input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #10b98126}.filter-group select option{background:var(--bg-secondary);color:var(--text-primary)}.filter-buttons{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}.filter-buttons button{flex:1;min-width:140px;padding:14px 24px;border:none;border-radius:12px;font-weight:600;font-size:.95em;cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary)}.filter-buttons button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.filter-buttons button:nth-child(2){background:linear-gradient(135deg,#475569,#334155);color:var(--text-primary)}.filter-buttons button:nth-child(3){background:linear-gradient(135deg,#22c55e,#16a34a);color:var(--bg-primary)}.filter-buttons button:disabled{opacity:.6;cursor:not-allowed;transform:none}.plans-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px}.plans-table th,.plans-table td{padding:14px 12px;text-align:left;border-bottom:1px solid var(--border-subtle)}.plans-table th{background:rgba(15,23,42,.8);font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:.8em;letter-spacing:.5px;position:sticky;top:0;z-index:10}.plans-table th:first-child{border-radius:8px 0 0}.plans-table th:last-child{border-radius:0 8px 0 0}.plans-table tbody tr{transition:background var(--transition-fast)}.plans-table tbody tr:hover{background:rgba(16,185,129,.08)}.plans-table td{color:var(--text-primary);font-size:.9em}.plans-table a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}.plans-table a:hover{color:var(--accent-secondary);text-decoration:underline}.plans-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}.rate-good{color:var(--accent-green)!important;font-weight:700}.rate-warning{color:var(--accent-yellow)!important;font-weight:700}.rate-high{color:var(--accent-red)!important;font-weight:700}.source-link-btn{display:inline-block;padding:4px 10px;background:rgba(16,185,129,.15);border-radius:6px;font-size:.85em;color:var(--accent-primary)!important;transition:all var(--transition-fast)}.source-link-btn:hover{background:rgba(16,185,129,.25);text-decoration:none!important}.tag{display:inline-block;margin-left:8px;padding:3px 10px;border-radius:20px;font-size:.7em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tag.time{background:rgba(251,191,36,.2);color:var(--accent-yellow);border:1px solid rgba(251,191,36,.3)}.tag.renewable{background:rgba(16,185,129,.2);color:var(--accent-green);border:1px solid rgba(16,185,129,.3)}.plan-row.time-of-use{background:rgba(251,191,36,.05)}.plan-row.renewable{border-left:3px solid var(--accent-green)}.pagination-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:16px 0;border-bottom:1px solid var(--border-subtle);margin-bottom:16px;color:var(--text-secondary)}.pagination-controls button{padding:10px 18px;border-radius:8px;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all var(--transition-fast);margin:0 4px}.pagination-controls button:hover:not(:disabled){background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.pagination-controls button:disabled{opacity:.4;cursor:not-allowed}.pagination-controls select{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);margin-left:8px}.zip-card{border:2px dashed var(--border-accent);background:linear-gradient(135deg,rgba(16,185,129,.05),rgba(52,211,153,.05))}.zip-card:hover{border-style:solid;border-color:var(--accent-primary)}.zip-actions{display:flex;gap:12px;align-items:center}.zip-actions button{padding:14px 28px;border:none;border-radius:12px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:700;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.zip-actions button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.zip-actions button:disabled{opacity:.6;cursor:not-allowed}.zip-actions button.loading{position:relative;padding-left:40px}.zip-actions .spinner{display:inline-block;width:16px;height:16px;margin-right:8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.zip-input-wrapper{position:relative;display:flex;align-items:center;flex:1}.zip-input-wrapper.filter-zip{max-width:120px}.zip-input-wrapper input{width:100%;padding-right:35px}.zip-input-wrapper input.zip-valid{border-color:var(--accent-green)!important;background:rgba(74,222,128,.08)}.zip-input-wrapper input.zip-invalid{border-color:var(--accent-red)!important;background:rgba(252,165,165,.08)}.zip-indicator{position:absolute;right:10px;font-size:1.1em;font-weight:700;transition:all var(--transition-fast)}.zip-indicator.valid{color:var(--accent-green);text-shadow:0 0 8px rgba(74,222,128,.5)}.zip-indicator.invalid{color:var(--accent-red);text-shadow:0 0 8px rgba(252,165,165,.5)}.zip-indicator.small{font-size:.9em;right:8px}.zip-message{display:flex;align-items:center;gap:10px;margin-top:12px;padding:12px 16px;border-radius:10px;font-size:.9em;font-weight:500}.zip-message.error{background:rgba(252,165,165,.1);border:1px solid rgba(252,165,165,.3);color:var(--accent-red)}.zip-message.success{background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.3);color:var(--accent-green)}.zip-message .message-icon{font-size:1.2em;font-weight:700}.zip-message .suggestion-btn{margin-left:auto;padding:6px 12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--text-primary);font-size:.85em;cursor:pointer;transition:all var(--transition-fast)}.zip-message .suggestion-btn:hover{background:rgba(255,255,255,.2);border-color:var(--accent-primary)}.filter-zip-error{display:block;margin-top:4px;font-size:.75em;color:var(--accent-red);font-weight:500}.helper-text{margin-top:12px;font-size:.85em;color:var(--text-muted);line-height:1.5}.error-text{margin-top:10px;color:var(--accent-red);font-weight:600}.warning-card{background:linear-gradient(135deg,rgba(251,191,36,.1),rgba(251,146,60,.1));border:1px solid rgba(251,191,36,.3)}.warning-card h3{color:var(--accent-yellow)}.info-box{background:rgba(3,8,6,.97);border:1px solid var(--border-accent);border-left:4px solid var(--accent-primary);padding:20px 24px;border-radius:12px}.info-box h3{color:var(--text-primary);margin-bottom:12px;font-size:1.1em}.info-box p{color:var(--text-secondary);font-size:.95em;line-height:1.7}.info-box a{color:var(--accent-primary);text-decoration:none;font-weight:500}.info-box a:hover{text-decoration:underline}.data-source-list{margin:12px 0 0 1.25rem;color:var(--text-secondary);line-height:1.8}.data-source-list li{margin-bottom:8px}.data-integrity-note{margin-top:16px;font-size:.9em;color:var(--accent-green);font-weight:600}.summary-section{background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(52,211,153,.08));border:1px solid var(--border-accent);padding:var(--spacing-unit);border-radius:var(--card-radius)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-top:20px}.summary-item{padding:20px;background:rgba(15,23,42,.6);border-radius:12px;text-align:center;border:1px solid var(--border-subtle)}.summary-label{font-size:.85em;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:2em;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.recommendations{margin-top:24px;padding:20px;background:rgba(15,23,42,.6);border-radius:12px;border:1px solid var(--border-subtle)}.recommendations h3{color:var(--accent-yellow);margin-bottom:12px;font-size:1.1em}.recommendations p{line-height:1.8;color:var(--text-secondary)}.calculator-summary-row{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-unit);align-items:stretch}.calculator-summary-row .calculator-section{flex:1}.calculator-summary-row .summary-section{flex:2}.calculator-section{background:linear-gradient(135deg,rgba(52,211,153,.1),rgba(16,185,129,.05));border:1px solid var(--border-accent)}.input-group{margin-bottom:16px}.input-group label{display:block;margin-bottom:8px;color:var(--text-muted);font-size:.9em;font-weight:600}.calculate-btn{background:linear-gradient(135deg,var(--accent-purple),#7c3aed);color:#fff;border:none;padding:14px 32px;border-radius:12px;font-size:1.05em;font-weight:600;cursor:pointer;transition:all var(--transition-fast);width:100%}.calculate-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #34d3994d}.result-display{margin-top:24px;padding:20px;background:rgba(15,23,42,.6);border-radius:12px;border:1px solid var(--border-accent)}.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.result-item p:first-child{color:var(--text-muted);font-size:.9em;margin-bottom:8px}.result-item p:last-child{font-size:2em;font-weight:700;color:var(--accent-primary)}.savings-badge{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:6px 14px;border-radius:20px;font-size:.85em;font-weight:600;display:inline-block}.loading{text-align:center;padding:48px;color:var(--text-secondary);font-weight:500}.loading-spinner{width:44px;height:44px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;margin:0 auto 20px;animation:spin 1s linear infinite}.ercot-dashboard{animation:fadeIn .6s ease}.ercot-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-unit);flex-wrap:wrap;gap:16px}.ercot-title-section{flex:1}.ercot-title{font-size:1.8em;font-weight:700;color:var(--text-primary);margin:0 0 8px;display:flex;align-items:center;gap:12px}.ercot-logo{font-size:1.2em}.ercot-subtitle{color:var(--text-secondary);font-size:.95em;margin:0}.ercot-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.last-updated{color:var(--text-muted);font-size:.85em}.source-link{color:var(--accent-primary);font-size:.85em;text-decoration:none;transition:color var(--transition-fast)}.source-link:hover{color:var(--accent-secondary);text-decoration:underline}.grid-status-hero{display:flex;gap:var(--spacing-unit);margin-bottom:var(--spacing-unit);flex-wrap:wrap}.grid-health-indicator{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:28px 36px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:160px;border:2px solid;box-shadow:var(--glow-primary)}.health-icon{font-size:2.8em;margin-bottom:10px}.health-status{font-size:1.5em;font-weight:700}.health-label{color:var(--text-muted);font-size:.85em;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.grid-metrics{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.metric-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid var(--border-subtle);transition:all var(--transition-normal)}.metric-card:hover{transform:translateY(-3px);border-color:var(--border-accent)}.metric-card.demand{border-left:4px solid #3b82f6}.metric-card.capacity{border-left:4px solid var(--accent-green)}.metric-card.reserves{border-left:4px solid var(--accent-purple)}.metric-card.margin{border-left:4px solid var(--accent-orange)}.metric-icon{font-size:2em}.metric-content{flex:1}.metric-value{font-size:1.6em;font-weight:700;color:var(--text-primary);line-height:1.2}.metric-label{color:var(--text-muted);font-size:.85em;margin-top:4px}.top-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-unit);margin-bottom:var(--spacing-unit)}.top-cards-row .card,.top-cards-row .system-health-card{margin-bottom:0}.best-plan-card{display:flex;flex-direction:column}.ercot-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-unit);margin-bottom:var(--spacing-unit)}.ercot-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--card-radius);padding:var(--spacing-unit);border:1px solid var(--border-subtle);box-shadow:var(--glow-primary)}.ercot-card .card-title{font-size:1.1em;font-weight:600;color:var(--text-primary);margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px}.title-icon{font-size:1.1em}.fuel-mix-content{display:flex;gap:24px;align-items:center;margin-bottom:20px}.fuel-chart-container{width:200px;height:200px;flex-shrink:0}.fuel-stats{display:flex;flex-direction:column;gap:16px}.fuel-stat{display:flex;flex-direction:column}.fuel-stat-value{font-size:2em;font-weight:700;color:var(--text-primary)}.fuel-stat.renewable .fuel-stat-value{color:var(--accent-green)}.fuel-stat-label{color:var(--text-muted);font-size:.85em}.fuel-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding-top:16px;border-top:1px solid var(--border-subtle)}.fuel-item{display:flex;align-items:center;gap:8px}.fuel-dot{width:10px;height:10px;border-radius:50%}.fuel-name{color:var(--text-muted);font-size:.9em;flex:1}.fuel-value{font-weight:600;color:var(--text-primary);font-size:.9em}.analyzer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.analyzer-header .card-title{margin:0;padding:0;border:none}.analyzer-stats-right{display:flex;gap:24px;text-align:right}.analyzer-stat{display:flex;flex-direction:column;gap:2px}.analyzer-stat-value{font-size:1.5em;font-weight:700;color:var(--text-primary)}.analyzer-stat-value.green{color:var(--accent-green)}.analyzer-stat-label{font-size:.75em;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.mckinsey-chart-container{display:flex;flex-direction:column;align-items:center;gap:24px;padding:16px 0}.mckinsey-pie-wrapper{width:180px;height:180px;flex-shrink:0}.mckinsey-legend{display:flex;flex-direction:row;gap:32px;justify-content:center;width:100%}.mckinsey-legend-item{display:flex;align-items:center;gap:10px}.mckinsey-legend-color{width:14px;height:14px;border-radius:50%;flex-shrink:0}.mckinsey-legend-text{display:flex;align-items:baseline;gap:8px}.mckinsey-legend-label{font-size:.9em;font-weight:500;color:var(--text-secondary)}.mckinsey-legend-value{font-size:.85em;color:var(--text-muted)}.mckinsey-legend-percent{font-size:1.1em;font-weight:700;color:var(--text-primary)}.prices-chart-container{height:200px;margin-bottom:16px}.price-summary{display:flex;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border-subtle)}.price-item{display:flex;flex-direction:column;gap:4px}.price-label{color:var(--text-muted);font-size:.85em}.price-value{font-weight:600;color:var(--text-primary);font-size:1.1em}.price-value.highlight{color:var(--accent-green)}.ercot-info-banner{background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(16,185,129,.05));border:1px solid var(--border-accent);border-radius:12px;padding:20px 24px;display:flex;gap:14px;align-items:flex-start}.info-icon{font-size:1.3em;flex-shrink:0}.info-content{color:var(--text-secondary);font-size:.9em;line-height:1.7}.info-content strong{color:var(--text-primary)}.ercot-loading,.ercot-error{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--card-radius);padding:60px;text-align:center;border:1px solid var(--border-subtle)}.retry-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);border:none;padding:12px 28px;border-radius:10px;font-weight:600;cursor:pointer;margin-top:20px;transition:all var(--transition-fast)}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.analytics-dashboard,.price-analytics-section{animation:fadeIn .6s ease}.section-title{color:var(--text-primary);font-size:1.8em;font-weight:700;margin-bottom:var(--spacing-unit);display:flex;align-items:center;gap:12px}.section-subtitle{color:var(--text-secondary);font-size:1em;margin-top:-16px;margin-bottom:var(--spacing-unit)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-unit);margin-bottom:var(--spacing-unit)}.kpi-card{display:flex;align-items:center;gap:16px;border-left:4px solid}.kpi-card.green{border-color:var(--accent-green)}.kpi-card.blue{border-color:var(--accent-primary)}.kpi-card.purple{border-color:var(--accent-purple)}.kpi-card.orange{border-color:var(--accent-orange)}.kpi-icon{font-size:2.5em;opacity:.9}.kpi-content{flex:1}.kpi-value{font-size:2em;font-weight:700;color:var(--text-primary);line-height:1.2}.kpi-label{font-size:.9em;color:var(--text-muted);font-weight:500;margin-top:4px}.quick-stats-row{display:flex;gap:16px;margin-bottom:var(--spacing-unit);flex-wrap:wrap}.quick-stat{flex:1;min-width:140px;text-align:center;padding:20px}.quick-stat-value{display:block;font-size:2em;font-weight:700;line-height:1.2}.quick-stat-value.green{color:var(--accent-green)}.quick-stat-value.blue{color:var(--accent-primary)}.quick-stat-value.purple{color:var(--accent-purple)}.quick-stat-value.orange{color:var(--accent-orange)}.quick-stat-label{display:block;color:var(--text-muted);font-size:.85em;margin-top:6px}.stats-grid,.charts-grid,.analytics-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:var(--spacing-unit);margin-bottom:var(--spacing-unit)}.analytics-card.wide{grid-column:span 2}.analytics-card.full-width{grid-column:1 / -1}.analytics-charts-row{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-unit);margin-bottom:var(--spacing-unit)}.analytics-card.two-thirds{min-height:320px;display:flex;flex-direction:column}.analytics-card.two-thirds .chart-wrapper{flex:1;height:auto;min-height:280px}.analytics-card.one-third{min-height:320px;display:flex;flex-direction:column}.mckinsey-pie-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 0}.mckinsey-pie-chart{width:200px;height:200px;margin:0 auto 24px}.mckinsey-legend-vertical{display:flex;flex-direction:column;gap:10px;width:100%;padding:0 16px}.mckinsey-legend-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:rgba(255,255,255,.03);border-radius:6px}.mckinsey-legend-left{display:flex;align-items:center;gap:10px}.mckinsey-legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.mckinsey-legend-label{color:var(--text-secondary);font-size:.85em;font-weight:500}.mckinsey-legend-value{color:var(--text-primary);font-weight:600;font-size:.9em}.card-header,.analytics-card-title{font-size:1.05em;font-weight:600;color:var(--text-primary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.chart-container,.chart-wrapper{height:300px;position:relative;overflow:hidden}.chart-container.small{height:180px}.chart-wrapper-doughnut{height:220px;position:relative}.chart-wrapper-tall{height:350px;position:relative}.chart-container canvas{max-width:100%!important;max-height:100%!important}.chart-footnote{color:var(--text-muted);font-size:.8em;margin-top:14px;text-align:center}.stat-rows{display:flex;flex-direction:column;gap:12px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.stat-row:last-child{border-bottom:none}.stat-label{color:var(--text-muted);font-size:.95em}.stat-value{font-weight:600;color:var(--text-primary);font-size:1.05em}.comparison-grid{display:flex;align-items:center;justify-content:space-around;gap:20px;margin-bottom:20px}.comparison-item{text-align:center;padding:20px;border-radius:12px;flex:1}.comparison-item.residential{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(59,130,246,.05));border:1px solid rgba(59,130,246,.3)}.comparison-item.commercial{background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(16,185,129,.05));border:1px solid rgba(16,185,129,.3)}.comparison-value{font-size:2.8em;font-weight:700;color:var(--text-primary)}.comparison-label{font-size:.9em;color:var(--text-muted);margin-top:6px}.comparison-avg{font-size:.85em;color:var(--accent-green);font-weight:600;margin-top:10px}.comparison-divider{font-size:1.8em;color:var(--text-muted);font-weight:600}.type-breakdown{display:flex;flex-direction:column;gap:16px}.type-item{display:flex;align-items:center;gap:12px}.type-bar{height:36px;background:linear-gradient(90deg,var(--accent-primary),#60a5fa);border-radius:8px;display:flex;align-items:center;justify-content:flex-end;padding-right:14px;min-width:50px;transition:width .5s ease}.type-bar.variable{background:linear-gradient(90deg,var(--accent-orange),#fb923c)}.type-bar.other{background:linear-gradient(90deg,var(--accent-purple),#a78bfa)}.type-count{color:#fff;font-weight:600;font-size:.9em}.type-label{font-size:.9em;color:var(--text-muted);min-width:100px}.rankings-table{width:100%}.rankings-header{display:grid;grid-template-columns:60px 1fr 100px 100px 80px;padding:14px 16px;background:rgba(15,23,42,.6);border-radius:10px;font-weight:600;color:var(--text-muted);font-size:.8em;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.rankings-row{display:grid;grid-template-columns:60px 1fr 100px 100px 80px;padding:16px;border-bottom:1px solid var(--border-subtle);align-items:center;transition:background var(--transition-fast)}.rankings-row:hover{background:rgba(16,185,129,.08)}.rankings-row:last-child{border-bottom:none}.rank{font-size:1.3em;font-weight:700}.rank-1{color:#fbbf24}.rank-2{color:#94a3b8}.rank-3{color:#cd7f32}.provider-name{font-weight:600;color:var(--text-primary)}.best-rate{color:var(--accent-green);font-weight:600}.avg-rate{color:var(--text-muted)}.plan-count{color:var(--text-muted);text-align:center}.term-distribution{display:flex;justify-content:space-around;align-items:flex-end;height:200px;padding:20px 0;gap:12px}.term-item{display:flex;flex-direction:column;align-items:center;flex:1;max-width:60px}.term-bar{width:100%;background:linear-gradient(180deg,var(--accent-primary),#60a5fa);border-radius:8px 8px 0 0;display:flex;align-items:flex-start;justify-content:center;padding-top:10px;min-height:30px;transition:height .5s ease}.term-count{color:#fff;font-weight:600;font-size:.85em}.term-label{margin-top:10px;font-size:.8em;color:var(--text-muted);font-weight:500}.service-type-stats{display:flex;justify-content:center;gap:40px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-subtle)}.service-stat{text-align:center}.service-count{display:block;font-size:1.6em;font-weight:700;color:var(--text-primary)}.service-label{color:var(--text-muted);font-size:.85em}.tdu-stats{display:flex;justify-content:center;flex-wrap:wrap;gap:24px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-subtle)}.tdu-stat{text-align:center;min-width:80px}.tdu-count{display:block;font-size:1.4em;font-weight:700;color:var(--text-primary)}.tdu-label{color:var(--text-muted);font-size:.8em}.tab-navigation{display:flex;gap:4px;background:rgba(15,23,42,.6);padding:6px;border-radius:12px;margin-bottom:var(--spacing-unit);border:1px solid var(--border-subtle)}.tab-btn{padding:14px 28px;border:none;background:transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;border-radius:10px;transition:all var(--transition-fast);font-size:1em}.tab-btn:hover{background:rgba(16,185,129,.1);color:var(--text-primary)}.tab-btn.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--bg-primary);font-weight:600;box-shadow:0 4px 16px #10b9814d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{opacity:1;box-shadow:0 0 10px var(--accent-green)}50%{opacity:.6;box-shadow:0 0 20px var(--accent-green)}to{opacity:1;box-shadow:0 0 10px var(--accent-green)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1200px){.analytics-card.wide{grid-column:span 1}.analytics-charts-row{grid-template-columns:1fr}}@media (max-width: 768px){:root{--spacing-unit: 16px}.app-header h1{font-size:1.8em}.dashboard,.kpi-grid,.stats-grid,.charts-grid,.analytics-charts-grid,.calculator-summary-row{grid-template-columns:1fr}.ercot-header{flex-direction:column;align-items:flex-start}.ercot-meta{align-items:flex-start}.grid-status-hero{flex-direction:column}.grid-health-indicator{width:100%}.ercot-charts-row,.top-cards-row{grid-template-columns:1fr}.fuel-mix-content{flex-direction:column}.fuel-chart-container{width:100%;max-width:250px;margin:0 auto}.rankings-header,.rankings-row{grid-template-columns:50px 1fr 70px 70px 60px;font-size:.8em;padding:12px}.comparison-grid{flex-direction:column}.comparison-divider{transform:rotate(90deg)}.filter-controls{grid-template-columns:1fr}.filter-buttons{flex-direction:column}.filter-buttons button{min-width:100%}.quick-stats-row{flex-direction:column}.quick-stat{min-width:100%}.zip-actions{flex-direction:column}.zip-actions button{width:100%}.plans-table{font-size:.85em}.plans-table th,.plans-table td{padding:10px 8px}.pagination-controls{flex-direction:column;align-items:stretch;text-align:center}.summary-grid{grid-template-columns:repeat(2,1fr)}.service-type-stats{flex-direction:column;gap:16px}}@media (max-width: 480px){.summary-grid,.result-grid{grid-template-columns:1fr}.price-summary{flex-direction:column;gap:16px}.fuel-breakdown{grid-template-columns:1fr}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:5px}::-webkit-scrollbar-thumb{background:var(--border-accent);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}*{scrollbar-width:thin;scrollbar-color:var(--border-accent) var(--bg-secondary)}.system-health-card{background:rgba(3,8,6,.97);border:1px solid rgba(16,185,129,.2);overflow:hidden}.health-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;gap:10px}.health-badge{animation:pulse-subtle 2s infinite}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}.health-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:16px}.health-metric{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(0,0,0,.3);border-radius:8px;border:1px solid var(--border-subtle);min-width:0}.metric-indicator{font-size:1.2em;width:24px;text-align:center}.metric-details{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.metric-label{font-size:.7em;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.metric-value{font-size:.85em;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.health-stats{display:flex;justify-content:space-around;padding:12px 8px;margin-bottom:12px;background:rgba(0,0,0,.4);border-radius:8px;flex-wrap:wrap;gap:8px}.health-stat-item{text-align:center;min-width:60px}.stat-number{display:block;font-size:1.3em;font-weight:700;color:#4ade80}.stat-label{font-size:.75em;color:var(--text-primary)}.health-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-subtle);flex-wrap:wrap;gap:8px}.last-check{font-size:.75em;color:var(--text-secondary)}.refresh-health-btn{padding:6px 16px;border:1px solid var(--border-accent);border-radius:8px;background:transparent;color:var(--accent-primary);font-size:.85em;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.refresh-health-btn:hover:not(:disabled){background:rgba(16,185,129,.1);border-color:var(--accent-primary)}.refresh-health-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.health-metrics{grid-template-columns:repeat(2,1fr)}.health-header{flex-direction:column;gap:12px;align-items:flex-start}.health-stats{flex-wrap:wrap;gap:16px}}
