:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.turbine-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;padding:1.5rem;transition:all .2s ease;box-shadow:var(--shadow-sm);position:relative;min-height:320px;display:flex;flex-direction:column;align-items:center;text-align:center}.turbine-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-medium)}.turbine-svg-container{flex-shrink:0;margin-bottom:1.5rem}.turbine-svg{width:140px;height:210px;transition:opacity .2s ease}.turbine-blades{animation:spin linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.turbine-info{flex:1;display:flex;flex-direction:column;align-items:center;width:100%}.turbine-name{font-size:.875rem;font-weight:500;color:var(--text-muted);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.power-output{font-size:1.125rem;font-weight:300;margin:0 0 1rem;line-height:1.3;transition:color .2s ease;display:inline}.power-output.high{color:var(--accent-green)}.power-output.medium{color:var(--accent-blue)}.power-output.low{color:#ea580c}.turbine-stats{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:200px}.stat{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;border-bottom:1px solid var(--border-light)}.stat:last-child{border-bottom:none}.stat-label{font-size:.7rem;color:var(--text-muted);font-weight:300;text-align:left}.stat-value{font-size:.2rem;color:var(--text-primary);font-weight:100;white-space:nowrap}@media (max-width: 479px){.turbine-card{min-height:260px;padding:1rem}.turbine-svg{width:70px;height:105px}.power-output{font-size:1.25rem}.turbine-stats{max-width:160px}.stat{padding:.375rem 0}.stat-label{font-size:.625rem}.stat-value{font-size:.1rem}}@media (min-width: 480px) and (max-width: 767px){.turbine-card{min-height:300px;padding:1.25rem}.turbine-svg{width:90px;height:135px}.power-output{font-size:1.375rem}.turbine-stats{max-width:180px}}@media (min-width: 768px) and (max-width: 1023px){.turbine-card{min-height:340px;padding:1.5rem}.turbine-svg{width:110px;height:165px}.power-output{font-size:1.5rem}}@media (min-width: 1440px) and (max-width: 2559px){.turbine-card{min-height:380px;padding:2rem}.turbine-svg{width:160px;height:240px}.power-output{font-size:1.875rem}.turbine-stats{max-width:240px}.stat-label{font-size:.875rem}.stat-value{font-size:.1rem}}@media (min-width: 2560px){.turbine-card{min-height:480px;padding:3rem}.turbine-svg{width:200px;height:300px}.power-output{font-size:2.25rem}.turbine-name{font-size:1rem;margin-bottom:1rem}.turbine-stats{max-width:280px;gap:1rem}.stat{padding:.75rem 0}.stat-label{font-size:1rem}.stat-value{font-size:.1rem}}.summary-stats{margin-bottom:3rem}.stats-header{display:flex;justify-content:center;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.stats-title{font-size:1.75rem;font-weight:500;color:var(--text-primary);margin:0}.last-updated{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:.375rem;border:1px solid var(--border-light);transition:all .3s ease}body.background-enabled .last-updated{background:#e0f2fecc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-color:#e5e7eb99}.update-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.update-time{font-size:.875rem;color:var(--text-primary);font-weight:600;font-family:ui-monospace,SF Mono,Cascadia Code,Roboto Mono,monospace}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-indicator.active{background:var(--accent-green);animation:pulse 2s infinite}.status-indicator.warning{background:var(--accent-amber)}.status-indicator.stale{background:var(--accent-red)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;max-width:1000px;margin:0 auto}.stat-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;padding:1.5rem;transition:all .2s ease;box-shadow:var(--shadow-sm);position:relative;text-align:center}body.background-enabled .stat-card{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-color:#e5e7ebcc}.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--border-medium)}.stat-label{font-size:.7rem;font-weight:400;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.25rem;font-weight:400;color:var(--text-primary);line-height:1.2;display:flex;align-items:baseline;justify-content:center;gap:.25rem;white-space:nowrap}.stat-card.primary .stat-value{color:var(--accent-blue)}.stat-card.success .stat-value{color:var(--accent-green)}.stat-card.warning .stat-value{color:var(--accent-amber)}.stat-unit{font-size:.8rem;font-weight:400;color:var(--text-muted);align-self:flex-end;margin-bottom:.125rem}.summary-stats.loading .stats-grid{pointer-events:none}.loading-skeleton{position:relative;overflow:hidden}.loading-bar{height:2rem;background:#ffffff1a;border-radius:.25rem;margin:2rem 0}@media (max-width: 479px){.stats-header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:1.5rem}.stats-title{font-size:1.5rem;text-align:center}.last-updated{justify-content:center;padding:.5rem .75rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:1rem}.stat-unit{font-size:.875rem}.update-label,.update-time{font-size:.7rem}}@media (min-width: 480px) and (max-width: 767px){.stats-header{flex-direction:column;align-items:center;margin-bottom:1.5rem}.stats-title{font-size:1.625rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem}.stat-value{font-size:1.125rem}}@media (min-width: 768px) and (max-width: 1023px){.stats-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.stat-card{padding:1.25rem}.stat-value{font-size:1.25rem}}@media (min-width: 1440px) and (max-width: 2559px){.stats-header{margin-bottom:2.5rem}.stats-title{font-size:2rem}.stats-grid{gap:1.5rem;max-width:1200px}.stat-card{padding:2rem}.stat-value{font-size:1.5rem}.stat-unit{font-size:1.125rem}}@media (min-width: 2560px){.stats-header{margin-bottom:3rem}.stats-title{font-size:2.5rem}.last-updated{padding:1rem 1.5rem}.update-label{font-size:.875rem}.update-time{font-size:1rem}.stats-grid{gap:2rem;max-width:1400px}.stat-card{padding:3rem}.stat-label{font-size:.875rem;margin-bottom:1rem}.stat-value{font-size:1.75rem}.stat-unit{font-size:1.5rem}}.recent-days{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:2rem}.recent-title{font-size:1.125rem;font-weight:500;color:var(--text-primary);margin:0 0 1rem;text-align:center}.days-list{display:flex;flex-direction:column;gap:.75rem}.day-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-light);transition:background-color .2s ease}.day-item:last-child{border-bottom:none}.day-item:hover{background:var(--bg-tertiary);margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;border-radius:.25rem}.day-info{display:flex;flex-direction:column;gap:.125rem}.day-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.day-date{font-size:.75rem;color:var(--text-muted)}.day-output{display:flex;align-items:baseline;gap:.25rem;font-size:1rem;font-weight:500;color:var(--accent-blue)}.output-unit{font-size:.75rem;color:var(--text-muted);font-weight:400}.day-item.loading-skeleton{position:relative;overflow:hidden}.day-item.loading-skeleton:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,0,0,.05),transparent);animation:loading-shimmer 2s infinite}.day-item .loading-bar{height:1rem;background:var(--bg-tertiary);border-radius:.125rem}.day-item .loading-bar.short{width:60px}.day-item .loading-bar.medium{width:80px}@media (max-width: 767px){.recent-days{padding:1rem;margin-bottom:1.5rem}.recent-title{font-size:1rem;margin-bottom:.75rem}.days-list{gap:.5rem}.day-item{padding:.5rem 0}.day-name{font-size:.8rem}.day-date{font-size:.7rem}.day-output{font-size:.9rem}.output-unit{font-size:.7rem}}@media (min-width: 768px) and (max-width: 1023px){.recent-days{padding:1.25rem}}@media (min-width: 2560px){.recent-days{padding:2rem;margin-bottom:3rem}.recent-title{font-size:1.5rem;margin-bottom:1.5rem}.days-list{gap:1rem}.day-item{padding:1rem 0}.day-name{font-size:1rem}.day-date{font-size:.875rem}.day-output{font-size:1.25rem}.output-unit{font-size:.875rem}}.weekly-output{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:2rem}.weekly-title{font-size:1.125rem;font-weight:500;color:var(--text-primary);margin:0 0 1.5rem;text-align:center}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}.day-card{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:.375rem;padding:.75rem .5rem;text-align:center;transition:all .2s ease}.day-card:hover{background:var(--bg-accent);border-color:var(--accent-blue);transform:translateY(-1px)}.day-name{font-size:.75rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.day-date{font-size:.625rem;color:var(--text-muted);margin-bottom:.5rem}.day-output{font-size:.8rem;font-weight:400;color:var(--accent-blue);display:flex;flex-direction:column;align-items:center;gap:.125rem}.output-unit{font-size:.6rem;color:var(--text-muted);font-weight:300}.day-card.loading-skeleton{position:relative;overflow:hidden}.day-card.loading-skeleton:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,0,0,.05),transparent);animation:loading-shimmer 2s infinite}.day-card .loading-bar{height:.75rem;background:var(--bg-secondary);border-radius:.125rem;margin-bottom:.5rem}.day-card .loading-bar.short{width:80%;margin:0 auto .25rem}.day-card .loading-bar.medium{width:60%;margin:0 auto}@media (max-width: 767px){.weekly-output{padding:1rem}.weekly-title{font-size:1rem;margin-bottom:1rem}.days-grid{grid-template-columns:repeat(7,1fr);gap:.5rem}.day-card{padding:.5rem .25rem}.day-name{font-size:.65rem}.day-date{font-size:.55rem}.day-output{font-size:.7rem}.output-unit{font-size:.55rem}}@media (min-width: 1440px){.weekly-output{padding:2rem}.weekly-title{font-size:1.25rem;margin-bottom:2rem}.days-grid{gap:1rem}.day-card{padding:1rem .75rem}.day-name{font-size:.875rem}.day-date{font-size:.75rem}.day-output{font-size:.9rem}.output-unit{font-size:.7rem}}@media (min-width: 2560px){.weekly-output{padding:3rem}.weekly-title{font-size:1.5rem;margin-bottom:2.5rem}.days-grid{gap:1.5rem}.day-card{padding:1.5rem 1rem}.day-name{font-size:1rem}.day-date{font-size:.875rem}.day-output{font-size:1.125rem}.output-unit{font-size:.875rem}}.weather-forecast{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow-sm);margin-bottom:2rem}.weather-title{font-size:1.125rem;font-weight:500;color:var(--text-primary);margin:0 0 1.5rem;text-align:center}.weather-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.weather-card{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:.75rem;padding:1rem;text-align:center;transition:all .2s ease;min-height:280px;display:flex;flex-direction:column}.weather-card:hover{background:var(--bg-accent);border-color:var(--accent-blue);transform:translateY(-1px)}.weather-card.today{border-color:var(--accent-blue);background:var(--bg-accent)}.weather-date{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.weather-periods{display:flex;flex:1;gap:1px;background:var(--border-light);border-radius:.5rem;overflow:hidden}.weather-period{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.75rem}.day-period{color:#1f2937}.day-period.sunny{background:linear-gradient(135deg,#fef3c7,#fbbf24);color:#92400e}.day-period.partly-cloudy{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#374151}.day-period.cloudy{background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#374151}.day-period.overcast{background:linear-gradient(135deg,#9ca3af,#6b7280);color:#f9fafb}.day-period.rain{background:linear-gradient(135deg,#7dd3fc,#0ea5e9);color:#0c4a6e}.day-period.drizzle{background:linear-gradient(135deg,#bae6fd,#38bdf8);color:#0c4a6e}.day-period.thunderstorm{background:linear-gradient(135deg,#475569,#1e293b);color:#e2e8f0}.day-period.snow{background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:#1e293b}.day-period.fog{background:linear-gradient(135deg,#f1f5f9,#cbd5e1);color:#475569}.night-period{background:linear-gradient(135deg,#1e293b,#0f172a);color:#cbd5e1}.night-period.clear{background:linear-gradient(135deg,#0c4a6e,#082f49);color:#bae6fd}.night-period.partly-cloudy{background:linear-gradient(135deg,#334155,#1e293b);color:#94a3b8}.night-period.cloudy{background:linear-gradient(135deg,#475569,#334155);color:#94a3b8}.night-period.rain{background:linear-gradient(135deg,#1e40af,#1e3a8a);color:#dbeafe}.night-period.drizzle{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#dbeafe}.night-period.thunderstorm{background:linear-gradient(135deg,#312e81,#1e1b4b);color:#c7d2fe}.night-period.snow{background:linear-gradient(135deg,#64748b,#475569);color:#f1f5f9}.night-period.fog{background:linear-gradient(135deg,#52525b,#3f3f46);color:#d4d4d8}.weather-card.night-only .night-period{background:linear-gradient(135deg,#1e293b,#334155);color:#e2e8f0;border-radius:.5rem}.period-header{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.period-icon{font-size:1rem}.period-content{display:flex;flex-direction:column;align-items:center;gap:1rem;flex:1;justify-content:center}.wind-primary{display:flex;flex-direction:column;align-items:center;gap:.75rem}.wind-speed{display:flex;align-items:baseline;gap:.5rem;text-align:center}.wind-value{font-size:2.5rem;font-weight:400;line-height:1}.wind-unit{font-size:.875rem;font-weight:500;opacity:.8}.wind-direction{display:flex;flex-direction:column;align-items:center;gap:.25rem}.wind-compass{width:36px;height:36px;border-radius:50%;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:900;transform-origin:center;transition:transform .3s ease;line-height:1}.wind-dir-text{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.wind-secondary{display:flex;justify-content:center;width:100%}.wind-gust{display:flex;flex-direction:column;align-items:center;gap:.125rem}.gust-label{font-size:.625rem;font-weight:500;opacity:.7;text-transform:uppercase;letter-spacing:.025em}.gust-value{font-size:.875rem;font-weight:600}.weather-compact{display:flex;align-items:center;justify-content:space-around;width:100%;padding:.5rem;background:#0000000d;border-radius:.375rem;gap:.5rem}.compact-temp{font-size:.875rem;font-weight:500}.compact-icon{width:24px;height:24px;opacity:.8}.compact-rain{font-size:.875rem;font-weight:500;opacity:.8}.compact-rain:after{content:" 💧";font-size:.7rem}.weather-error{text-align:center;color:var(--text-muted);padding:2rem;font-size:.875rem}.weather-card.loading-skeleton{position:relative;overflow:hidden}.weather-card.loading-skeleton:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,0,0,.05),transparent);animation:loading-shimmer 2s infinite}.weather-card .loading-bar{height:.75rem;background:var(--bg-secondary);border-radius:.125rem;margin-bottom:.5rem}.weather-card .loading-bar.short{width:60%;margin:0 auto .5rem}.weather-card .loading-bar.medium{width:80%;margin:0 auto .5rem}.weather-card .loading-bar.long{width:100%}@media (max-width: 767px){.weather-forecast{padding:1rem}.weather-title{font-size:1rem;margin-bottom:1rem}.weather-grid{grid-template-columns:1fr;gap:.75rem}.weather-card{min-height:200px;padding:.75rem}.weather-periods{flex-direction:row}.weather-period{padding:.75rem .5rem;gap:.5rem}.weather-date{font-size:.75rem;margin-bottom:.75rem}.period-header{font-size:.65rem}.wind-value{font-size:2rem}.wind-unit{font-size:.75rem}.wind-compass{width:32px;height:32px;font-size:1.5rem}.wind-dir-text{font-size:.65rem}.gust-label{font-size:.55rem}.gust-value,.compact-temp,.compact-rain{font-size:.75rem}.compact-icon{width:20px;height:20px}}@media (min-width: 768px) and (max-width: 1023px){.weather-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.weather-card{min-height:260px;padding:.875rem}.wind-value{font-size:2.25rem}.wind-compass{width:34px;height:34px;font-size:1.625rem}.compact-icon{width:22px;height:22px}}@media (min-width: 1440px){.weather-forecast{padding:2rem}.weather-title{font-size:1.25rem;margin-bottom:2rem}.weather-grid{gap:1.5rem}.weather-card{min-height:320px;padding:1.5rem}.weather-period{padding:1.25rem 1rem;gap:1rem}.period-header{font-size:.875rem}.wind-value{font-size:3rem}.wind-unit{font-size:1rem}.wind-compass{width:40px;height:40px;font-size:2rem}.wind-dir-text{font-size:.875rem}.gust-label{font-size:.7rem}.gust-value,.compact-temp,.compact-rain{font-size:1rem}.compact-icon{width:28px;height:28px}}@media (min-width: 2560px){.weather-forecast{padding:3rem}.weather-title{font-size:1.5rem;margin-bottom:2.5rem}.weather-grid{gap:2rem}.weather-card{min-height:400px;padding:2rem}.weather-period{padding:1.5rem 1.25rem;gap:1.25rem}.period-header{font-size:1rem}.wind-value{font-size:3.5rem}.wind-unit{font-size:1.125rem}.wind-compass{width:44px;height:44px;font-size:2.25rem}.wind-dir-text{font-size:1rem}.gust-label{font-size:.8rem}.gust-value,.compact-temp,.compact-rain{font-size:1.125rem}.compact-icon{width:32px;height:32px}}.background-toggle{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem}.toggle-button{display:flex;align-items:center;gap:.375rem;background:#fffffff2;border:1px solid rgba(37,99,235,.2);border-radius:1.5rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;min-width:120px}.toggle-button:hover{background:#fffffffa;border-color:var(--accent-blue);box-shadow:var(--shadow-md);transform:translateY(-1px)}.toggle-button:active{transform:translateY(0);transition-duration:.1s}.toggle-button.enabled{background:#2563eb1a;border-color:var(--accent-blue);color:var(--accent-blue)}.toggle-button.enabled:hover{background:#2563eb26}.toggle-slider{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1rem;background:#6b728033;border-radius:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.toggle-button.enabled .toggle-slider{background:var(--accent-blue)}.toggle-icon{display:flex;align-items:center;justify-content:center;width:.875rem;height:.875rem;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;left:.0625rem}.toggle-button.enabled .toggle-icon{left:.5625rem;color:var(--accent-blue)}.toggle-text{font-weight:500;letter-spacing:.025em}@media (max-width: 767px){.background-toggle{top:.75rem;right:.75rem;gap:.375rem}.toggle-button{padding:.3rem .6rem;font-size:.7rem;gap:.3rem;min-width:100px}.toggle-slider{width:1.25rem;height:.875rem}.toggle-icon{width:.75rem;height:.75rem}.toggle-button.enabled .toggle-icon{left:.4375rem}.toggle-icon svg{width:10px;height:10px}}@media (min-width: 768px){.background-toggle{top:1.5rem;right:1.5rem}}@media (prefers-contrast: high){.toggle-button{border-width:2px;background:#fff}.toggle-button.enabled{background:var(--accent-blue);color:#fff}}:root{--bg-primary: #ffffff;--bg-secondary: #f0f9ff;--bg-tertiary: #e0f2fe;--bg-accent: #dbeafe;--border-light: #e5e7eb;--border-medium: #d1d5db;--text-primary: #111827;--text-secondary: #374151;--text-muted: #6b7280;--accent-blue: #2563eb;--accent-green: #059669;--accent-amber: #d97706;--accent-red: #dc2626;--accent-light-blue: #eff6ff;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 25px -5px rgba(0, 0, 0, .1)}*{box-sizing:border-box}#root{width:100%;min-height:100vh;margin:0;padding:0}body{margin:0;padding:0;background:linear-gradient(135deg,#dbeafe,#bfdbfe,#93c5fd);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;min-height:100vh;transition:background .5s ease-in-out}body.background-enabled{background-image:linear-gradient(135deg,#dbeafeb3,#bfdbfe99,#93c5fdb3);background-size:cover;background-position:left center;background-attachment:fixed;background-repeat:no-repeat}body.background-enabled:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/background-optimized.jpg);background-size:cover;background-position:left center;background-repeat:no-repeat;background-attachment:fixed;z-index:-1}@media (max-width: 767px){body.background-enabled:before{background-image:url(/background-mobile.jpg);background-position:left center;background-attachment:scroll}}@media (min-width: 1440px) and (-webkit-min-device-pixel-ratio: 2){body.background-enabled:before{background-image:url(/background.jpg)}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:1rem .75rem;position:relative;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(59,130,246,.1);transition:all .5s ease-in-out}body.background-enabled .app-header{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}body.transparency-enabled .turbine-card,body.transparency-enabled .stat-card,body.transparency-enabled .weekly-output,body.transparency-enabled .weather-forecast{background:#ffffff4d;transition:background .3s ease}body.transparency-enabled .day-card,body.transparency-enabled .weather-card{background:#e0f2fe4d;transition:background .3s ease}body.background-enabled.transparency-enabled .turbine-card,body.background-enabled.transparency-enabled .stat-card,body.background-enabled.transparency-enabled .weekly-output,body.background-enabled.transparency-enabled .weather-forecast{background:#ffffff4d}body.background-enabled.transparency-enabled .day-card,body.background-enabled.transparency-enabled .weather-card{background:#e0f2fe4d}.app-header:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:1px;background:var(--border-medium)}.app-title{font-size:3rem;font-weight:500;margin:0;color:var(--text-primary);letter-spacing:-.025em}.app-subtitle{font-size:1.125rem;color:var(--text-secondary);margin:.5rem 0 0;font-weight:400}.app-main{flex:1;padding:0 2rem;max-width:1400px;margin:0 auto;width:100%}.turbines-section{margin-bottom:4rem}.mobile-recent-days{display:none}.bottom-sections{margin-top:2rem;width:100%;max-width:1400px;margin-left:auto;margin-right:auto}.section-title{font-size:1.5rem;font-weight:500;color:var(--text-primary);margin:0 0 1.5rem;text-align:left}.turbines-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.app.error{justify-content:center;align-items:center;padding:2rem}.error-container{text-align:center;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:1rem;padding:3rem;max-width:500px}.error-container h1{color:var(--turbine-danger);margin:0 0 1rem;font-size:1.5rem}.error-container p{color:var(--turbine-muted);margin-bottom:1rem}.error-container code{background:#0000004d;padding:.5rem;border-radius:.25rem;font-size:.875rem;display:block;margin-top:1rem;color:var(--turbine-danger)}.loading-skeleton{background:var(--turbine-bg);border:1px solid var(--turbine-border);border-radius:1rem;padding:2rem;min-height:400px;position:relative;overflow:hidden}.loading-skeleton:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:loading-shimmer 2s infinite}@keyframes loading-shimmer{0%{left:-100%}to{left:100%}}.loading-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.loading-svg{width:140px;height:210px;background:#ffffff1a;border-radius:.5rem}.loading-text{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:200px}.loading-bar{height:1.5rem;background:#ffffff1a;border-radius:.25rem}.loading-bar.short{width:60%;height:1rem;align-self:center}.loading-bar.long{width:100%;height:2rem}.loading-bar.medium{width:80%}.no-data{grid-column:1 / -1;text-align:center;color:var(--turbine-muted);font-size:1.125rem;padding:4rem}.app-footer{margin-top:auto;padding:1.5rem 2rem;text-align:center;border-top:1px solid var(--border-light);background:var(--bg-primary)}.app-footer p{margin:0;font-size:.875rem;color:var(--text-muted)}@media (max-width: 479px){.app-header{padding:1rem .75rem}.app-title{font-size:1.75rem}.app-subtitle{font-size:.875rem}.app-main{padding:0 1rem}.section-title{font-size:1.125rem;margin-bottom:1rem}.turbines-grid{grid-template-columns:1fr;gap:1rem}}@media (min-width: 480px) and (max-width: 767px){.app-header{padding:1rem .75rem}.app-title{font-size:2.25rem}.app-subtitle{font-size:1rem}.app-main{padding:0 1.5rem}.turbines-grid{grid-template-columns:1fr;gap:1.25rem}}@media (min-width: 768px) and (max-width: 1023px){.app-header{padding:1.5rem .75rem}.app-title{font-size:2.5rem}.turbines-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:700px}}@media (min-width: 1024px) and (max-width: 1439px){.turbines-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:900px}}@media (min-width: 1440px) and (max-width: 2559px){.app-header{padding:1.5rem .75rem}.app-title{font-size:3.5rem}.app-subtitle{font-size:1.25rem}.turbines-grid{grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px}.section-title{font-size:1.75rem}}@media (min-width: 2560px){.app-header{padding:2rem .75rem}.app-title{font-size:4.5rem}.app-subtitle{font-size:1.5rem}.app-main{padding:0 3rem}.turbines-grid{grid-template-columns:repeat(3,1fr);gap:3rem;max-width:1600px}.section-title{font-size:2.25rem}.turbines-section{margin-bottom:6rem}}
