: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}*,*:before,*:after{box-sizing:border-box}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;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:#1f2937;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}}.header{position:relative;padding:0;width:100%;box-sizing:border-box;display:flex;justify-content:flex-start;margin-bottom:2rem}.logo-container{display:flex;align-items:center;gap:.5rem}.logo-animation{width:50px;height:50px;display:flex;align-items:center;justify-content:center}.header h1{margin:0;font-size:1.25rem;font-weight:700;background:linear-gradient(to right,#60a5fa,#34d399);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.header-controls{display:flex;gap:1rem;flex-wrap:wrap}.toggle-container{display:flex;background-color:var(--secondary-color);padding:4px;border-radius:8px}.toggle-btn{background:none;border:none;color:#9ca3af;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.toggle-btn.active{background-color:var(--primary-color);color:#fff;box-shadow:0 2px 4px #0000001a}.toggle-btn:hover:not(.active){color:#fff}@media (max-width: 640px){.header{flex-direction:column;align-items:flex-start}.header-controls{width:100%;justify-content:space-between}}.chart-container{background-color:var(--secondary-color);padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;height:450px;position:relative;transition:all .3s ease-in-out;box-sizing:border-box;display:flex;flex-direction:column}.chart-container.fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1000;border-radius:0;padding:2rem;background-color:var(--secondary-color);overflow:hidden}.chart-wrapper{flex:1;min-height:300px;min-width:200px;width:100%;position:relative}.fullscreen-toggle{position:absolute;top:1rem;right:1rem;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:2000;color:#fff;padding:0}.fullscreen-toggle:hover{background-color:#ffffff26;transform:scale(1.05)}.chart-footer-stats{position:absolute;bottom:5px;left:20px;font-size:11px;color:#fff9;pointer-events:none;display:flex;gap:15px;flex-wrap:wrap}.chart-footer-source{position:absolute;bottom:5px;right:20px;font-size:11px;color:#fff9;pointer-events:none}@media (max-width: 768px){.chart-footer-stats{position:static;margin-top:10px;justify-content:center;gap:10px}.chart-footer-source{position:static;text-align:center;margin-top:5px}}.fullscreen-toggle svg{display:block}.filter-chips-container{display:flex;justify-content:flex-start;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap;align-items:flex-start;width:100%}.filter-groups-wrapper{display:flex;flex-direction:column;gap:1.5rem;width:100%}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group-label{font-size:.8rem;color:#9ca3af;font-weight:400;margin-left:.5rem;margin-bottom:.25rem;line-height:1.4}.filter-group-items{display:flex;flex-direction:column;gap:.5rem}.filter-chip{background-color:#1f2937;border:1px solid #374151;color:#9ca3af;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;cursor:pointer;transition:all .2s ease;outline:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;width:fit-content}.filter-chip:hover{background-color:#374151;color:#e5e7eb}.filter-chip.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.filter-chip.active:hover{background-color:#2563eb;border-color:#2563eb}.edit-icon{font-size:.8rem;opacity:.7;transition:opacity .2s;padding:2px;border-radius:50%}.edit-icon:hover{opacity:1;background-color:#fff3}@media (min-width: 768px) and (max-width: 1279px){.filter-groups-wrapper{flex-direction:row;align-items:flex-start;gap:2rem}.filter-group{flex:1;min-width:0}.filter-group-items{flex-direction:row;flex-wrap:wrap}.filter-chip{width:auto}}@media (max-width: 767px){.filter-group-items{flex-direction:row;flex-wrap:wrap}.filter-chip{width:auto}.fixed-mode-toggle{width:100%}}.fixed-mode-toggle{margin-top:.5rem;text-align:left}.toggle-link{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease;text-decoration:underline}.toggle-link:hover{color:#60a5fa;text-decoration:none}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog-content{background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:dialog-slide-in .2s ease-out}@keyframes dialog-slide-in{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-title{color:#f3f4f6;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.dialog-body{margin-bottom:1.5rem}.dialog-label{display:block;color:#9ca3af;font-size:.875rem;margin-bottom:.5rem}.dialog-input{width:100%;background-color:#111827;border:1px solid #374151;border-radius:6px;padding:.75rem;color:#f3f4f6;font-size:1rem;outline:none;transition:border-color .2s;box-sizing:border-box}.dialog-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.dialog-footer{display:flex;justify-content:flex-end;gap:.75rem}.dialog-button{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.dialog-button.cancel{background-color:transparent;color:#9ca3af;border:1px solid #374151}.dialog-button.cancel:hover{background-color:#374151;color:#f3f4f6}.dialog-button.save{background-color:#3b82f6;color:#fff}.dialog-button.save:hover{background-color:#2563eb}.dialog-link-container{margin-top:.75rem;text-align:right}.dialog-link{color:#3b82f6;font-size:.875rem;cursor:pointer;text-decoration:underline}.dialog-link:hover{color:#60a5fa}.dual-tariff-form{display:flex;flex-direction:column;gap:1rem}.tariff-row{display:flex;flex-direction:column;gap:.5rem}.tariff-label{color:#f3f4f6;font-weight:600;font-size:.9rem}.tariff-inputs{display:flex;gap:.5rem}.input-group{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.input-group label{color:#9ca3af;font-size:.75rem}.input-group input{width:100%;background-color:#111827;border:1px solid #374151;border-radius:6px;padding:.5rem;color:#f3f4f6;font-size:.9rem;outline:none;transition:border-color .2s;box-sizing:border-box}.input-group input:focus{border-color:#3b82f6}.input-group.small{flex:0 0 110px}.settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.settings-modal-content{background-color:#1f2937;border:1px solid #374151;border-radius:12px;width:100%;max-width:500px;max-height:90vh;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:settings-modal-slide-up .3s ease-out;display:flex;flex-direction:column}@keyframes settings-modal-slide-up{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.settings-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #374151}.settings-modal-title{color:#f3f4f6;font-size:1.25rem;font-weight:600;margin:0}.settings-modal-close{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;margin-left:.5rem}.settings-modal-close:hover{background-color:#ffffff1a;color:#f3f4f6}.settings-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.appliance-stats-wrapper{display:flex;flex-direction:column;justify-content:space-between;height:100%}.appliance-stats-container{padding:1.5rem;background-color:#1f2937;border-radius:12px;border:1px solid #374151;height:350px;overflow-y:auto;overflow-x:hidden;margin-bottom:.75rem}.show-all-btn{width:100%;padding:.75rem;background-color:#374151;color:#f3f4f6;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s;font-size:.9rem}.show-all-btn:hover{background-color:#4b5563}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:9999;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#1f2937;border-radius:16px;border:1px solid #374151;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:1.5rem;border-bottom:1px solid #374151;display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.25rem;font-weight:600;color:#f3f4f6;margin:0}.modal-close-btn{background:none;border:none;color:#9ca3af;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.modal-close-btn:hover{background-color:#374151;color:#f3f4f6}.modal-body{padding:1.5rem;overflow-y:auto}.modal-body .appliance-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.appliance-stats-container::-webkit-scrollbar{width:8px}.appliance-stats-container::-webkit-scrollbar-track{background:#111827;border-radius:4px}.appliance-stats-container::-webkit-scrollbar-thumb{background:#374151;border-radius:4px}.appliance-stats-container::-webkit-scrollbar-thumb:hover{background:#4b5563}.appliance-stats-title{margin:0 0 1rem;font-size:1.1rem;color:#9ca3af;font-weight:500}.appliance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.appliance-grid-full{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;padding:1.5rem;background-color:#1f2937;border-radius:12px;border:1px solid #374151;margin-bottom:1rem}@media (max-width: 640px){.appliance-grid-full{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));padding:1rem;gap:.75rem}}.appliance-item{background-color:#111827;border:1px solid #374151;border-radius:8px;padding:1rem;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .2s,border-color .2s}.appliance-item:hover{transform:translateY(-2px);border-color:#4b5563}.appliance-icon{font-size:2rem;margin-bottom:.5rem}.appliance-info{display:flex;flex-direction:column;gap:.25rem}.appliance-name{color:#9ca3af;font-size:.875rem}.appliance-consumption{color:#6b7280;font-size:.75rem;font-style:italic}.appliance-cost{color:#f3f4f6;font-size:1.1rem;font-weight:600}:root{--bg-color: #111827;--text-color: #f3f4f6;--primary-color: #3b82f6;--secondary-color: #1f2937;--accent-color: #10b981;--danger-color: #ef4444}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-color);color:var(--text-color);-webkit-font-smoothing:antialiased}#root{width:100%}.app-container{max-width:900px;margin:0 auto;padding:2rem;min-height:100vh;display:flex;flex-direction:column}@media (min-width: 1024px){.app-container{padding-top:4rem}}@media (max-width: 640px){.app-container{padding:1rem}}.main-content{flex:1;display:flex;flex-direction:column;gap:2rem}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem;color:#9ca3af}.error{color:var(--danger-color)}.footer{margin-top:auto;padding-top:2rem;text-align:center;color:#6b7280;font-size:.875rem;display:flex;flex-direction:column;align-items:center;gap:1rem;position:relative;z-index:10}.footer-animation{width:150px;height:auto;opacity:1}.chart-disclaimer-text{font-size:.8rem;color:#9ca3af;margin-bottom:.5rem;text-align:left;min-height:2.4em;line-height:1.4;display:flex;align-items:flex-start}.three-column-layout{display:flex;flex-direction:column;gap:2rem;width:100%}.left-sidebar,.center-content,.right-sidebar{width:100%}@media (min-width: 1280px){.app-container{max-width:1600px;padding:2rem 3rem}.three-column-layout{display:grid;grid-template-columns:320px 1fr 260px;gap:2rem;align-items:start}.left-sidebar{position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto;background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem}.center-content{min-width:0}.right-sidebar{position:sticky;top:2rem;max-height:calc(100vh - 4rem);display:flex;flex-direction:column}}@media (min-width: 768px) and (max-width: 1279px){.app-container{max-width:100%;padding:2rem}.three-column-layout{display:flex;flex-direction:column;gap:2rem}.left-sidebar,.center-content,.right-sidebar{width:100%}}.column-title{font-size:1.1rem;font-weight:500;color:#9ca3af;margin:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;min-height:32px}.toggle-container.compact{display:flex;background-color:var(--secondary-color);padding:2px;border-radius:6px;box-sizing:border-box}.toggle-container.compact .toggle-btn{padding:4px 10px;font-size:.75rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.header-controls-compact{display:flex;gap:.5rem;align-items:center}@media (max-width: 767px){.sidebar-header{flex-direction:column;align-items:flex-start;gap:.5rem;width:100%;max-width:100%;overflow:hidden}}.sidebar-mobile-toggle{display:none;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;margin-left:auto}.sidebar-mobile-toggle:hover{background-color:#ffffff1a;color:#f3f4f6}.sidebar-mobile-toggle svg{display:block}.sidebar-collapsible-content{max-height:2000px;overflow:hidden;transition:max-height .3s ease-in-out}.sidebar-collapsible-content.collapsed{max-height:0}@media (max-width: 1279px){.sidebar-mobile-toggle{display:flex;align-items:center;justify-content:center}.sidebar-content{background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem}.sidebar-content:has(.sidebar-collapsible-content.collapsed){padding-bottom:1.5rem}}.sidebar-toggle-btn{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.sidebar-toggle-btn:hover{background-color:#ffffff1a;color:#f3f4f6}.sidebar-toggle-tab{display:none}@media (min-width: 1280px){.left-sidebar{background-color:transparent;border:none;padding:0;overflow:visible;position:sticky;top:2rem;max-height:calc(100vh - 4rem)}.sidebar-content{background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem;max-height:calc(100vh - 4rem);overflow-y:auto}.sidebar-toggle-tab{display:flex;position:absolute;top:50%;right:-24px;transform:translateY(-50%);width:24px;height:48px;background-color:#1f2937;border:1px solid #374151;border-left:0;border-radius:0 8px 8px 0;align-items:center;justify-content:center;cursor:pointer;color:#f3f4f6;z-index:1000;padding:0;margin:0}.sidebar-toggle-tab:before{content:"";position:absolute;left:-2px;top:0;bottom:0;width:2px;background-color:#1f2937;z-index:1001}.sidebar-toggle-tab svg{stroke:currentColor;display:block;width:16px;height:16px;position:relative;z-index:1002}.sidebar-content{position:relative;z-index:1}.sidebar-toggle-tab:hover{background-color:#374151;color:#f3f4f6}.collapsed-sidebar-tab{position:fixed;left:0;top:50%;transform:translateY(-50%);width:32px;min-height:140px;background-color:#1f2937;border:1px solid #374151;border-left:0;border-radius:0 8px 8px 0;display:flex;flex-direction:column-reverse;align-items:center;justify-content:center;gap:12px;cursor:pointer;color:#f3f4f6;z-index:1000;transition:background-color .2s,color .2s;padding:12px 0;margin:0}.collapsed-sidebar-tab:before{content:"";position:absolute;left:-2px;top:0;bottom:0;width:2px;background-color:#1f2937;z-index:1001}.tab-text{writing-mode:vertical-rl;transform:rotate(180deg);font-size:.9rem;white-space:nowrap;font-weight:500;letter-spacing:.5px;position:relative;z-index:1002}.collapsed-sidebar-tab svg{stroke:currentColor;display:block;width:16px;height:16px;flex-shrink:0}.collapsed-sidebar-tab:hover{background-color:#374151;color:#f3f4f6}.three-column-layout.sidebar-collapsed{grid-template-columns:1fr 260px}.left-sidebar.collapsed{display:none}}@media (max-width: 1279px){.left-sidebar.collapsed{display:none}.sidebar-content{background-color:transparent;border:none;padding:0}}.mobile-settings-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;background-color:#374151;border:1px solid #4b5563;padding:.75rem 1rem;border-radius:8px;cursor:pointer;color:#f3f4f6;font-family:inherit;font-size:1rem;font-weight:500;text-align:left;transition:all .2s}.mobile-settings-trigger:hover{background-color:#4b5563;border-color:#6b7280}.mobile-settings-trigger svg{color:#9ca3af;flex-shrink:0;transition:color .2s}.mobile-settings-trigger:hover svg{color:#f3f4f6}.copyright{position:fixed;bottom:1rem;right:1rem;font-size:.75rem;color:#6b7280;opacity:.6;z-index:100;pointer-events:none;font-family:system-ui,-apple-system,sans-serif}@media (max-width: 640px){.copyright{position:static;margin-top:1rem;text-align:center;width:100%;padding-bottom:1rem}}
