*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-8{margin-left:2rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-20{height:5rem}.w-20{width:5rem}.flex-1{flex:1 1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.bg-gray-500{--tw-bg-opacity:1;background-color:#6b7280;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-gray-600{--tw-bg-opacity:1;background-color:#4b5563;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:#1f2937;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:#f0fdf4;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:#22c55e;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:#ef4444;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:#eab308;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.italic{font-style:italic}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:#166534;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.shadow-green-500\/50{--tw-shadow-color:#22c55e80;--tw-shadow:var(--tw-shadow-colored)}.shadow-red-500\/50{--tw-shadow-color:#ef444480;--tw-shadow:var(--tw-shadow-colored)}.shadow-yellow-500\/50{--tw-shadow-color:#eab30880;--tw-shadow:var(--tw-shadow-colored)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.time-range-selector{-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border-radius:0;box-shadow:none;flex-wrap:nowrap;gap:12px;margin:0;overflow-x:auto;overflow-y:hidden;padding:var(--spacing-lg);scrollbar-gutter:stable}.time-range-button,.time-range-selector{display:flex;flex-shrink:0;justify-content:center}.time-range-button{align-items:center;background:linear-gradient(135deg,#f5f5f5,#eee);border:2px solid #0000;border-radius:10px;box-shadow:0 2px 6px #00000014;color:#333;cursor:pointer;flex-direction:column;gap:2px;min-width:80px;padding:12px 20px;position:relative;transition:all .3s ease;white-space:nowrap}.time-range-button:hover:not(.disabled){background:linear-gradient(135deg,#fff,#f5f5f5);box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.time-range-button.active{border-color:#0000;color:#fff;cursor:default}.time-range-button.active,.time-range-button.active:hover{box-shadow:0 4px 12px #2196f366}.time-range-button.active,.time-range-button.active:active,.time-range-button.active:hover{background:linear-gradient(135deg,#2196f3,#1976d2);transform:translateY(-1px)}.time-range-button.active .button-sublabel{opacity:.9}.time-range-button.disabled{background-color:#f9f9f9;cursor:not-allowed;opacity:.5}.button-label{font-size:15px;font-weight:600;line-height:1}.button-sublabel{font-size:11px;font-weight:400;line-height:1;opacity:.7}@media (prefers-color-scheme:dark){.time-range-selector{background:#0000;box-shadow:none}.time-range-button{background:linear-gradient(135deg,#2a2a2a,#252525);box-shadow:0 2px 6px #0000004d;color:#e0e0e0}.time-range-button:hover:not(.disabled){background:linear-gradient(135deg,#3a3a3a,#333);box-shadow:0 4px 12px #0006}.time-range-button.active{color:#fff;cursor:default}.time-range-button.active,.time-range-button.active:hover{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 4px 12px #2196f399}.time-range-button.active:hover{transform:translateY(-1px)}.time-range-button.active:active{background:linear-gradient(135deg,#2196f3,#1976d2);transform:translateY(-1px)}.time-range-button.active .button-sublabel{opacity:.9}.time-range-button.disabled{background:linear-gradient(135deg,#1a1a1a,#151515);opacity:.4}}@media (max-width:768px){.time-range-selector{box-sizing:border-box;flex-shrink:0;gap:6px;justify-content:flex-start;margin:0;padding:var(--spacing-md);padding-left:var(--spacing-md);padding-right:var(--spacing-md);width:100%}.time-range-selector::-webkit-scrollbar{display:none}.time-range-selector{-ms-overflow-style:none;scrollbar-width:none}.time-range-button{flex:0 0 auto;min-width:60px;padding:8px 12px}.button-label{font-size:13px}.button-sublabel{font-size:10px}}@media (max-width:480px){.time-range-selector{gap:4px;padding:var(--spacing-sm)}.time-range-button{min-width:55px;padding:6px 10px}.button-label{font-size:12px}.button-sublabel{font-size:9px}}*{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}body{-webkit-overflow-scrolling:touch}section{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}section>*{flex-shrink:0;width:100%}.forecast-info-box,.info-card,.traffic-light-card{box-sizing:border-box;contain:layout;overflow:hidden;position:relative}.chart-container{box-sizing:border-box}.energy-chart rect{transform-origin:bottom}@media (max-width:768px){.chart-container,.forecast-info-box,.info-card,.traffic-light-card{margin-left:0!important;margin-right:0!important;max-width:100%!important;position:relative!important;width:100%!important}}:root{--sat:env(safe-area-inset-top,0);--sar:env(safe-area-inset-right,0);--sab:env(safe-area-inset-bottom,0);--sal:env(safe-area-inset-left,0);--color-primary:#1976d2;--color-secondary:#ffa726;--color-success:#66bb6a;--color-warning:#ffca28;--color-danger:#ef5350;--color-dark:#212121;--color-gray-900:#424242;--color-gray-700:#616161;--color-gray-500:#9e9e9e;--color-gray-300:#e0e0e0;--color-gray-100:#f5f5f5;--color-white:#fff;--shadow-sm:0 2px 4px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--shadow-xl:0 16px 48px #00000029;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:16px;--radius-full:9999px;--transition-fast:150ms ease;--transition-normal:300ms ease;--transition-slow:500ms ease}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;background-color:var(--color-gray-100);color:#212121;color:var(--color-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(90deg,#4caf50 0,#ffeb3b 50%,#2196f3)!important;box-shadow:0 8px 32px #0000001a;color:#fff;color:var(--color-white);margin-bottom:0;overflow:hidden;position:relative}.global-time-selector-wrapper{background:#fff;background:var(--color-white);box-shadow:0 2px 8px #0000001a;margin-bottom:3rem;margin-bottom:var(--spacing-2xl);position:relative;transition:all .3s ease;z-index:0}.global-time-selector-wrapper.is-sticky{box-shadow:0 4px 12px #00000026}.global-time-selector-wrapper .time-range-selector{margin:0 auto;max-width:1200px}@media (max-width:768px){.global-time-selector-wrapper{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}}@media (prefers-color-scheme:dark){.global-time-selector-wrapper{background:#1a1a1a;box-shadow:0 2px 8px #00000080}}.app-header:before{background:#0000004d;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header-content{margin:0 auto;max-width:1200px;padding:3rem 1rem;padding:var(--spacing-2xl) var(--spacing-md);position:relative;text-align:center}.header-content h1{background:#fffffff2;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 16px #0003;font-size:clamp(2.5rem,7vw,4rem);font-weight:700;letter-spacing:-.03em;margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:.3rem 1.5rem;position:relative;white-space:nowrap}.header-content h1,.header-lightning{align-items:center;display:inline-flex}.header-lightning{animation:pulse 2s ease-in-out infinite;margin-right:.5rem}@keyframes pulse{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.logo-strom{color:#388e3c}.logo-mix,.logo-strom{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:800}.logo-mix{color:#1565c0}.logo-info{color:#424242;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:300}.header-content p{background:#0003;border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:inline-block;font-size:clamp(1.1rem,2.5vw,1.4rem);font-weight:500;letter-spacing:.01em;margin:0 auto;max-width:700px;padding:.5rem 1.5rem;text-shadow:0 2px 6px #0006}.app-main{flex:1 1;margin:0 auto;max-width:1200px;padding:1.5rem;padding:var(--spacing-lg);width:100%}.traffic-light-section{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.traffic-light-card{background:#fff;background:var(--color-white);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);padding:2rem;padding:var(--spacing-xl);text-align:center;transition:transform .3s ease;transition:transform var(--transition-normal)}.traffic-light-card:hover{box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.traffic-light-card h2{color:#424242;color:var(--color-gray-900);font-size:1.5rem;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.traffic-light-display{border-radius:9999px;border-radius:var(--radius-full);height:120px;margin:0 auto 1.5rem;margin:0 auto var(--spacing-lg);position:relative;transition:all .5s ease;transition:all var(--transition-slow);width:120px}.traffic-light-display.green{background:radial-gradient(circle at 30% 30%,#81c784,#4caf50);box-shadow:0 0 40px #4caf5099}.traffic-light-display.yellow{background:radial-gradient(circle at 30% 30%,#ffd54f,#ffc107);box-shadow:0 0 40px #ffc10799}.traffic-light-display.red{background:radial-gradient(circle at 30% 30%,#e57373,#f44336);box-shadow:0 0 40px #f4433699}.traffic-light-display.gray{background:radial-gradient(circle at 30% 30%,#bdbdbd,#757575)}.traffic-light-bulb{background:#ffffff4d;border-radius:9999px;border-radius:var(--radius-full);filter:blur(10px);height:30%;left:20%;position:absolute;top:20%;width:30%}.traffic-light-info h3{color:#424242;color:var(--color-gray-900);font-size:1.25rem;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.traffic-light-stats{display:flex;gap:2rem;gap:var(--spacing-xl);justify-content:center;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.stat{text-align:center}.stat-label{color:#616161;color:var(--color-gray-700);display:block;font-size:.875rem;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.stat-value{color:#1976d2;color:var(--color-primary);display:block;font-size:1.5rem;font-weight:600}.traffic-light-hint{color:#616161;color:var(--color-gray-700);font-size:.875rem;line-height:1.5;margin:0 auto;max-width:400px}.chart-section{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.chart-section>*{flex-shrink:0}.chart-header{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.chart-header h2{color:#424242;color:var(--color-gray-900);font-size:1.75rem;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.chart-header p{color:#616161;color:var(--color-gray-700);font-size:.875rem}.chart-wrapper{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg);width:100%}.chart-wrapper>.chart-container:first-child{background:#fff!important;background:var(--color-white)!important;border-radius:16px!important;border-radius:var(--radius-lg)!important;box-shadow:0 4px 12px #0000001a!important;box-shadow:var(--shadow-md)!important;padding:1.5rem!important;padding:var(--spacing-lg)!important}.chart-container{background:#fff;background:var(--color-white);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);display:flex;flex-direction:column;margin-bottom:2rem;margin-bottom:var(--spacing-xl);min-height:-webkit-fit-content;min-height:fit-content;overflow:hidden;padding:1.5rem;padding:var(--spacing-lg);position:relative;width:100%}.bar-chart-container{height:auto!important;min-height:500px!important}.renewable-price-chart{display:flex;flex-direction:column;height:100%;min-height:350px}svg text{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;shape-rendering:geometricPrecision;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;text-rendering:optimizeLegibility}.x-axis text,.y-axis text{shape-rendering:crispEdges;text-rendering:geometricPrecision}.chart-svg-container{-webkit-tap-highlight-color:transparent;cursor:crosshair;display:block;height:600px;margin-bottom:0;position:relative;touch-action:pan-x pan-y;width:100%}.chart-tooltip{animation:tooltipFadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;background:var(--color-white);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 16px 48px #00000029;box-shadow:var(--shadow-xl);font-size:.875rem;max-width:90vw;min-width:200px;padding:1rem;padding:var(--spacing-md);pointer-events:none;position:fixed!important;z-index:2147483647!important}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chart-tooltip,.tooltip,[class*=tooltip]{z-index:2147483647!important}.tooltip-header{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--color-gray-300);color:#424242;color:var(--color-gray-900);font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);padding-bottom:.5rem;padding-bottom:var(--spacing-sm)}.tooltip-content{display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.tooltip-item{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-sm)}.tooltip-color{border-radius:4px;flex-shrink:0;height:16px;transition:transform .2s ease;width:16px}.tooltip-item:hover .tooltip-color{transform:scale(1.1)}.tooltip-name{color:#616161;color:var(--color-gray-700);flex:1 1}.tooltip-total,.tooltip-value{color:#424242;color:var(--color-gray-900);font-weight:600}.tooltip-total{justify-content:space-between;margin-top:.5rem;margin-top:var(--spacing-sm);padding-top:.5rem;padding-top:var(--spacing-sm)}.chart-legend-wrapper,.tooltip-total{border-top:1px solid #e0e0e0;border-top:1px solid var(--color-gray-300);display:flex}.chart-legend-wrapper{align-items:center;background:#0000;box-sizing:border-box;flex-direction:column;flex-shrink:0;margin-top:auto;padding:1rem;padding:var(--spacing-md);position:relative;z-index:1}.chart-legend{flex-shrink:0;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);margin:0 auto;padding:0;width:100%}.chart-legend,.legend-item{align-items:center;display:flex;justify-content:center}.legend-item{font-size:.875rem;gap:.5rem;gap:var(--spacing-sm)}.legend-color{border-radius:4px;border-radius:var(--radius-sm);height:16px;width:16px}.legend-name{color:#616161;color:var(--color-gray-700)}.legend-title{color:#9e9e9e;color:var(--color-gray-500);font-size:.75rem;font-weight:500;letter-spacing:.05em;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);text-align:center;text-transform:uppercase;width:100%}.legend-info{-webkit-tap-highlight-color:transparent;align-items:center;background:#e0e0e0;background:var(--color-gray-300);border-radius:50%;color:#616161;color:var(--color-gray-700);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;height:20px;justify-content:center;margin-left:6px;transition:all .15s ease;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;width:20px}.legend-info:hover{background:#1976d2;background:var(--color-primary);color:#fff;color:var(--color-white);transform:scale(1.1)}@media (max-width:768px){.legend-info{font-size:16px;height:24px;margin-left:8px;width:24px}}.info-section{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.info-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.info-card{background:#fff;background:var(--color-white);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);padding:2rem;padding:var(--spacing-xl);text-align:center;transition:transform .3s ease;transition:transform var(--transition-normal)}.info-card:hover{box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.info-icon{font-size:3rem;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.info-card h3{color:#424242;color:var(--color-gray-900);font-size:1.125rem;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.info-card p{color:#616161;color:var(--color-gray-700);font-size:.875rem;line-height:1.5}.app-footer{background:#424242;background:var(--color-gray-900);color:#fff;color:var(--color-white);margin-top:auto;padding:2rem 1rem;padding:var(--spacing-xl) var(--spacing-md)}.footer-content{margin:0 auto;max-width:1200px;text-align:center}.footer-content p{font-size:.875rem;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.footer-credits{color:#e0e0e0;opacity:.95}.footer-links{color:#b0b0b0}.footer-links a{color:#e0e0e0;font-weight:500;opacity:.95;padding:0 .25rem;padding:0 var(--spacing-xs);text-decoration:none;transition:all .3s ease;transition:all var(--transition-normal)}.footer-links a:hover{color:#fff;opacity:1;text-decoration:underline}@media (prefers-color-scheme:dark){.footer-credits{color:#f0f0f0;opacity:1}.footer-links{color:#d0d0d0}.footer-links a{color:#f0f0f0;opacity:1}.footer-content p{opacity:.95}.footer-recommendation{color:#f0f0f0;font-weight:500;opacity:1}}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg);justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-top-color:#1976d2;border:4px solid var(--color-gray-300);border-radius:9999px;border-radius:var(--radius-full);border-top-color:var(--color-primary);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.error-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;padding:var(--spacing-xl);text-align:center}.error-icon{font-size:4rem;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.error-container h2{color:#424242;color:var(--color-gray-900);font-size:1.5rem;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.error-container p{color:#616161;color:var(--color-gray-700);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.error-container button{background:#1976d2;background:var(--color-primary);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;color:var(--color-white);cursor:pointer;font-size:1rem;font-weight:500;padding:.5rem 2rem;padding:var(--spacing-sm) var(--spacing-xl);transition:background .15s ease;transition:background var(--transition-fast)}.error-container button:hover{background:#1565c0}@media (min-width:769px){.chart-legend-wrapper{padding-bottom:2rem;padding-bottom:var(--spacing-xl)}.header-content{align-items:center;display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}.header-content h1{margin-bottom:0}.header-content p{margin-top:.5rem;margin-top:var(--spacing-sm)}.chart-section,.info-section,.traffic-light-section{gap:1.5rem;gap:var(--spacing-lg);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}section>*{margin-bottom:0!important}}@media (max-width:768px) and (orientation:portrait){.bar-chart-container{height:400px!important}.bar-chart-container,.chart-container{min-height:400px!important}.renewable-price-container{height:auto!important;min-height:auto!important}.renewable-price-container .renewable-price-chart{height:400px!important;min-height:400px!important}}@media (max-width:768px){.app-main{overflow-x:hidden;padding:.5rem;padding:var(--spacing-sm)}section{display:flex;flex-direction:column;gap:1rem!important;gap:var(--spacing-md)!important;margin-bottom:1.5rem!important;margin-bottom:var(--spacing-lg)!important}section>*{flex-shrink:0;margin-bottom:0!important;max-width:100%;width:100%}.chart-wrapper{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);overflow:hidden;width:100%}.chart-container{box-sizing:border-box!important;display:flex!important;flex-direction:column!important;margin:0;margin-bottom:.5rem!important;margin-bottom:var(--spacing-sm)!important;max-width:100%;overflow:hidden!important;padding:.5rem!important;padding:var(--spacing-sm)!important;position:relative!important;width:100%}.chart-container,.renewable-price-container.chart-container{height:auto!important;min-height:auto!important}.chart-wrapper{display:block!important;overflow:visible!important;padding-bottom:0!important;position:relative!important;width:100%!important}.chart-wrapper>.chart-container:first-child{background:#fff!important;background:var(--color-white)!important;border-radius:16px!important;border-radius:var(--radius-lg)!important;box-shadow:0 4px 12px #0000001a!important;box-shadow:var(--shadow-md)!important;padding:.5rem!important;padding:var(--spacing-sm)!important}.bar-chart-container,.energy-chart-container{margin-bottom:0!important;position:relative!important}.traffic-light-stats{gap:1.5rem;gap:var(--spacing-lg)}.chart-svg-container{display:block!important;height:350px!important}.bar-chart-container,.chart-svg-container{margin-bottom:0!important;width:100%!important}.bar-chart-container{display:flex!important;flex-direction:column!important;height:500px!important}.renewable-price-container{height:auto!important;min-height:auto!important}.renewable-price-container .renewable-price-chart{display:flex!important;flex-direction:column!important;height:350px!important;min-height:350px!important}svg{display:block!important;max-width:100%!important}.chart-legend-wrapper{background:#0000!important;box-sizing:border-box!important;display:flex!important;flex-shrink:0!important;margin-bottom:0!important;margin-top:auto!important;padding:4px 8px!important;position:relative!important;width:100%!important;z-index:1!important}.chart-legend{font-size:.75rem;gap:.25rem;gap:var(--spacing-xs);margin:0;padding:0}.legend-item{flex:0 0 calc(50% - 0.5rem);flex:0 0 calc(50% - var(--spacing-sm));justify-content:flex-start}.info-grid{gap:1rem;gap:var(--spacing-md);grid-template-columns:1fr}.info-card,.traffic-light-card{box-sizing:border-box;margin:0;padding:1.5rem;padding:var(--spacing-lg);width:100%}.chart-tooltip{font-size:.75rem;min-width:180px;z-index:2147483647!important}.chart-section,.info-section,.traffic-light-section{gap:1rem;gap:var(--spacing-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);overflow:hidden;width:100%}.forecast-info-box{box-sizing:border-box;margin:1rem 0;margin:var(--spacing-md) 0;padding:1rem;padding:var(--spacing-md);width:100%}.chart-header{margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:0 .5rem;padding:0 var(--spacing-sm)}*{max-width:100%!important}}@media (max-width:480px){.header-content{padding:1rem;padding:var(--spacing-md)}.chart-tooltip{z-index:2147483647!important}.header-content h1{font-size:1.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-content h1,.header-lightning{align-items:center;display:inline-flex}.header-lightning{flex-shrink:0;margin-right:.25rem}.traffic-light-display{height:100px;width:100px}.stat-value{font-size:1.25rem}.chart-svg-container{height:350px!important;min-height:350px!important}.chart-container{height:auto!important;min-height:500px!important}.renewable-price-container.chart-container{height:auto!important;min-height:auto!important}.bar-chart-container,.renewable-price-container .bar-chart-container{height:450px!important;min-height:450px!important}}@media (hover:none) and (pointer:coarse){.chart-svg-container{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}}@media (prefers-color-scheme:dark){:root{--color-gray-100:#121212;--color-white:#1e1e1e;--color-dark:#fff;--color-gray-900:#f5f5f5;--color-gray-700:#bdbdbd;--color-gray-500:#9e9e9e;--color-gray-300:#424242}body{background-color:#f5f5f5;background-color:var(--color-gray-100)}.chart-container,.info-card,.traffic-light-card{background:#fff;background:var(--color-white);box-shadow:0 4px 12px #0000004d}.chart-tooltip{background:#2c2c2c;box-shadow:0 8px 24px #0006;z-index:2147483647!important}.app-footer{background:#0a0a0a}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chart-container,.forecast-info-box,.info-card,.traffic-light-card{animation:fadeIn .6s ease-out}.forecast-info-box{align-items:flex-start;background:linear-gradient(135deg,#f0f7ff,#e8f4f8);border:1px solid #d0e2f0;border-radius:12px;box-shadow:0 2px 6px #0000000d;clear:both;display:flex;flex-shrink:0;gap:16px;margin-bottom:0;margin-top:2rem;margin-top:var(--spacing-xl);padding:20px;position:relative;z-index:1}.forecast-info-icon{flex-shrink:0;font-size:24px}.forecast-info-content{flex:1 1}.forecast-info-content p{color:#444;font-size:14px;line-height:1.6;margin:0}.forecast-info-content p:first-child{margin-bottom:8px}.forecast-start-info{color:#1976d2;font-weight:500}@media (prefers-color-scheme:dark){.forecast-info-box{background:linear-gradient(135deg,#1a2332,#1e2a38);border-color:#2a3a4a}.forecast-info-content p{color:#ccc}.forecast-start-info{color:#4fc3f7}}.info-card:first-child{animation-delay:.1s}.info-card:nth-child(2){animation-delay:.2s}.info-card:nth-child(3){animation-delay:.3s}.traffic-light-share{border-top:1px solid #e0e0e0;border-top:1px solid var(--color-gray-300);flex-shrink:0;margin:0;padding:1.5rem;padding:var(--spacing-lg);position:relative;z-index:1}.share-header{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.share-subtitle{color:#616161;color:var(--color-gray-700);font-size:.9rem;font-weight:500}.share-controls{align-items:center;display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}.day-selector{background:#f5f5f5;background:var(--color-gray-100);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:.5rem;gap:var(--spacing-sm);padding:.25rem;padding:var(--spacing-xs)}.day-button{background:#0000;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#616161;color:var(--color-gray-700);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);transition:all .15s ease;transition:all var(--transition-fast)}.day-button.active{background:#fff;background:var(--color-white);box-shadow:0 2px 4px #00000014;box-shadow:var(--shadow-sm);color:#1976d2;color:var(--color-primary)}.day-button:disabled{cursor:not-allowed;opacity:.5}.action-buttons{display:flex;gap:1rem;gap:var(--spacing-md)}.share-button{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;gap:var(--spacing-sm);padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);transition:all .15s ease;transition:all var(--transition-fast)}.share-button.primary{background:#1976d2;background:var(--color-primary);color:#fff;color:var(--color-white);font-size:1rem;padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl)}.share-button.primary:hover:not(:disabled){background:#1565c0;box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.availability-notice{align-items:center;background:#f5f5f5;background:var(--color-gray-100);border-radius:8px;border-radius:var(--radius-md);color:#616161;color:var(--color-gray-700);display:flex;font-size:.875rem;gap:.5rem;gap:var(--spacing-sm);justify-content:center;margin:1rem 0;margin:var(--spacing-md) 0;padding:1rem;padding:var(--spacing-md)}.notice-icon{font-size:1.125rem}.share-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.button-icon{font-size:1.125rem}@media (max-width:768px){.share-controls{width:100%}.day-selector{justify-content:center;width:100%}.day-button{flex:1 1;text-align:center}.action-buttons{justify-content:center;width:100%}.share-button{flex:1 1;justify-content:center}}@media (prefers-color-scheme:dark){.traffic-light-share{border-top-color:#e0e0e0;border-top-color:var(--color-gray-300)}.day-selector{background:#2c2c2c}.day-button.active{background:#3c3c3c}.availability-notice{background:#2c2c2c;color:#9e9e9e;color:var(--color-gray-500)}}@media print{.app-footer,.app-header{display:none}.chart-container,.info-card,.traffic-light-card{box-shadow:none;break-inside:avoid;page-break-inside:avoid}}
/*# sourceMappingURL=main.58976ec9.css.map*/