.help-modal{border:none;border-radius:12px;padding:0;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.help-modal::backdrop{background:#0009;backdrop-filter:blur(3px)}.help-modal-content{padding:2rem}.help-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.help-modal-title{margin:0;font-size:1.5rem;font-weight:600;color:#333;flex:1}.help-modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;padding:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;color:gray;transition:color .2s ease,background-color .2s ease;border-radius:6px;margin-left:1rem}.help-modal-close:hover{color:#333;background-color:#f0f0f0}.help-modal-close:focus{outline:2px solid #FFD700;outline-offset:2px}.help-modal-body{color:#555}.help-section{margin-bottom:2rem}.help-section:last-child{margin-bottom:0}.help-section h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#333}.help-section p{margin:0 0 .75rem;line-height:1.6}.help-highlight{background-color:#fff9e6;padding:.75rem 1rem;border-left:4px solid #FFD700;border-radius:4px;margin:1rem 0!important}.help-list{margin:1rem 0;padding-left:1.5rem;line-height:1.8}.help-list li{margin-bottom:.5rem}.help-modal-footer{display:flex;justify-content:center;padding-top:1.5rem;margin-top:1.5rem;border-top:2px solid #f0f0f0}.help-cta-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#ffffffe6;border:2px solid #ddd;color:#595959;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;text-decoration:none}.help-cta-button:hover{background:#ffd700e6;border-color:gold;color:#fff;transform:scale(1.05)}.help-cta-button:focus{outline:2px solid #FFD700;outline-offset:2px}@media (max-width: 600px){.help-modal{max-width:95%;width:95%;max-height:90vh}.help-modal-content{padding:1.5rem}.help-modal-title{font-size:1.25rem}.help-section h3{font-size:1rem}}@keyframes helpSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.help-modal[open]{animation:helpSlideIn .3s ease-out}.account-menu{position:relative;display:inline-block}.account-menu-button{display:flex;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;padding:.5rem .75rem;color:#333;transition:background-color .2s ease,color .2s ease;border-radius:8px}.account-menu-button:hover{background-color:#f0f0f0}.account-menu-button:focus{outline:2px solid #FFD700;outline-offset:2px}.account-menu-button .chevron{transition:transform .2s ease}.account-menu-button .chevron.open{transform:rotate(180deg)}.account-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:240px;padding:.5rem 0;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.account-menu-user{padding:.75rem 1rem;border-bottom:1px solid #e0e0e0}.account-menu-email{display:block;font-size:.875rem;color:#666;font-weight:500;word-break:break-word}.account-menu-divider{height:1px;background-color:#e0e0e0;margin:.5rem 0}.account-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:none;color:#333;font-size:.9375rem;text-align:left;cursor:pointer;transition:background-color .2s ease}.account-menu-item:hover{background-color:#f5f5f5}.account-menu-item:focus{outline:none;background-color:#f0f0f0}.account-menu-item.logout{color:#d32f2f}.account-menu-item.logout:hover{background-color:#fff5f5}@media (max-width: 600px){.account-menu-dropdown{min-width:200px;right:-.5rem}.account-menu-email{font-size:.8125rem}.account-menu-item{font-size:.875rem;padding:.625rem 1rem}}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#f5f5f5}.login-box{background:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 10px #0000001a;text-align:center}.login-box h1{margin-bottom:20px;color:#333}.login-box button{background-color:#007bff;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-size:16px}.login-box button:hover{background-color:#0056b3}.no-contracts{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.no-contracts-card{background:#fff;border-radius:12px;padding:3rem 2rem;box-shadow:0 4px 20px #0000001a;text-align:center;max-width:600px;border-top:4px solid #FFD700}.no-contracts-icon{margin-bottom:1.5rem;display:flex;justify-content:center}.no-contracts-title{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:1rem}.no-contracts-message{color:#666;font-size:1.1rem;margin-bottom:1.5rem;line-height:1.6}.no-contracts-cause{color:#777;font-size:1rem;margin-bottom:2rem;line-height:1.6}.no-contracts-solution{background:#f8f9fa;border-radius:8px;padding:1.5rem;border-left:4px solid #FFD700}.no-contracts-solution p{color:#555;margin-bottom:1rem;font-weight:500}.no-contracts-link{display:inline-block;background:gold;color:#333;text-decoration:none;padding:12px 24px;border-radius:6px;font-weight:600;transition:all .3s ease}.no-contracts-link:hover{background:#e6c200;transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.chart-card{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.chart-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.detail-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #eee}.detail-header h1{margin:0;color:#333}.back-btn{background:#ffffffe6;border:2px solid #ddd;color:#666;padding:12px;border-radius:50%;cursor:pointer;font-weight:700;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0}.back-btn:hover{background:#ffd700e6;border-color:gold;color:#fff;transform:scale(1.1)}.back-btn svg{width:20px;height:20px}.contract-info{display:flex;flex-direction:column;align-items:flex-start;gap:5px;font-size:14px;color:#666;flex:1;min-width:0}.contract-info h1{margin:0;color:#333}.contract-address{font-size:14px;color:#4a4a4a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;max-width:100%}.contracted-power{font-size:14px;color:#666}.detail-content{display:grid;grid-template-columns:1fr;gap:30px;width:100%;max-width:100%;overflow:hidden}.chart-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box;overflow:hidden}.chart-section h2{margin-top:0;margin-bottom:20px;color:#333}.chart-container{height:400px;width:100%;position:relative;overflow:hidden;min-height:250px;box-sizing:border-box;container-type:size}.table-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box;overflow:hidden}.data-table-container{width:100%}.table-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:20px}.table-header h3{margin:0;color:#333}.export-btn{background:#ffffffe6;border:2px solid #ddd;color:#595959;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:8px}.export-btn:hover{background:#ffd700e6;border-color:gold;color:#fff;transform:scale(1.05)}.table-wrapper{position:relative;margin:0 -20px;overflow:hidden}.table-wrapper:before,.table-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:20px;pointer-events:none;z-index:2}.table-wrapper:before{left:0;background:linear-gradient(to right,#fff,#fff0)}.table-wrapper:after{right:0;background:linear-gradient(to left,#fff,#fff0)}.table-scroll{overflow-x:auto;overflow-y:hidden;padding:0 20px}.data-table{width:100%;border-collapse:collapse;font-size:14px;font-family:Courier New,Courier,monospace;font-variant-numeric:tabular-nums}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #eee;line-height:1;white-space:nowrap}.data-table td:not(:first-child){text-align:right}.data-table th:not(:first-child){text-align:right}.data-table th{background-color:#f8f9fa;font-weight:600;color:#495057}.data-table tr:hover{background-color:#f8f9fa}.data-table .positive{color:#28a745}.data-table .negative{color:#dc3545}.data-table .warning{color:#ffc107;background-color:#fff3cd}.data-table .power-exceeded{background-color:#ff44441a;color:#dc3545}.data-table .power-warning{background-color:#ffd70026;color:#b8860b}.table-loading{text-align:center;padding:40px;color:#666}.date-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.date-selector.compact{margin-bottom:.75rem;padding:.5rem 0}.date-selector-label{display:flex;align-items:center;gap:.75rem;font-weight:600;color:#333;font-size:14px;white-space:nowrap;cursor:pointer}.date-selector-input{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;color:#333;min-width:140px;font-family:system-ui,-apple-system,sans-serif}.date-selector-input:focus{outline:none;border-color:gold;box-shadow:0 0 0 2px #ffd70033}.date-selector-input:hover{border-color:#bbb}@media (max-width: 768px){.container{padding:0 15px}.date-selector{flex-direction:column;align-items:flex-start;gap:.5rem}.date-selector.compact{margin-bottom:1rem}.date-selector-label{flex-direction:column;align-items:flex-start;gap:.5rem}.date-selector-input{min-width:120px;width:100%;max-width:200px}.detail-header{gap:15px;margin-bottom:25px}.detail-header h1{font-size:18px;line-height:1.2}.detail-content{gap:20px}.chart-section,.table-section{padding:15px;margin:0;width:100%;max-width:100%;box-sizing:border-box}.chart-section h2{font-size:18px}.chart-container{height:300px;min-height:250px;overflow-x:auto;overflow-y:hidden;width:100%;max-width:100%}.table-header{margin-bottom:15px;justify-content:center}.export-btn{padding:8px 12px;font-size:11px;min-width:auto;white-space:nowrap}.data-table{font-size:11px;min-width:100%}.data-table th,.data-table td{padding:6px 4px;min-width:60px}.data-table th:first-child,.data-table td:first-child{min-width:50px}.table-wrapper{margin:0 -15px}.table-scroll{-webkit-overflow-scrolling:touch;padding:0 15px}.back-btn{width:40px;height:40px;padding:10px}.back-btn svg{width:18px;height:18px}}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#fff;color:#333;padding:1rem 0;border-bottom:1px solid #e0e0e0}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;align-items:center;gap:.5rem}.logo{height:32px;width:auto}.header h1{margin:0;font-size:1.8rem;color:#333}.center-section{flex:1;display:flex;justify-content:center}.installation-select{padding:8px 16px;border:1px solid #ccc;border-radius:4px;font-size:14px;background-color:#fff;color:#666;min-width:200px}.user-info{display:flex;align-items:center;gap:1rem}.settings-btn{background-color:transparent;color:#666;border:none;padding:8px 16px;cursor:pointer;font-size:14px}.settings-btn:hover{color:#333}.logout-btn{background-color:transparent;color:#595959;border:none;padding:8px 16px;cursor:pointer;font-size:14px}.logout-btn:hover{color:#333}.main{flex:1;padding:2rem 0;background-color:#f5f5f5}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-bottom:2rem}.chart-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.chart-card h2{margin:0 0 1rem;font-size:1.1rem;color:#595959;font-weight:500}.chart-container{height:300px;position:relative}.chart-loading{height:100%;display:flex;align-items:center;justify-content:center;color:#666;font-style:italic}.chart-placeholder{height:300px;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa;border-radius:4px;color:#666}.footer{text-align:center;padding:2rem 0;color:#999;font-size:.9rem}.footer p{margin:0}.contracts-list h2{margin-bottom:1rem;color:#2c3e50}.contracts-scroll-container{position:relative;width:100%;display:flex;align-items:center}.contracts-grid{display:flex;flex-direction:row;align-items:center;gap:1rem;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;height:100%;padding:10px 0}.contracts-grid::-webkit-scrollbar{height:6px}.contracts-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.contracts-grid::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.contracts-grid::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.scroll-arrow{position:absolute;top:0;bottom:0;width:60px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:opacity .3s ease}.scroll-arrow-left{left:0;background:linear-gradient(to right,rgba(245,245,245,1) 0%,rgba(245,245,245,.7) 60%,transparent 100%)}.scroll-arrow-right{right:0;background:linear-gradient(to left,rgba(245,245,245,1) 0%,rgba(245,245,245,.7) 60%,transparent 100%)}.arrow-icon{font-size:2rem;color:#666;font-weight:700;background:#ffffffe6;border:2px solid #ddd;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.arrow-icon:hover{background:#ffd700e6;border-color:gold;color:#fff;transform:scale(1.1)}.contract-card{flex:1 1 auto;min-width:200px;max-width:300px;height:80px;padding:1rem;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left;border-radius:12px;border:2px solid #e0e0e0;background:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.contract-card:hover{border-color:gold;box-shadow:0 4px 12px #ffd7004d;transform:translateY(-2px)}.contract-card.selected{border-color:gold;background-color:gold;box-shadow:0 4px 16px #ffd70066;transform:translateY(-2px)}.contract-card h2{font-size:.85rem;font-weight:700;margin:0 0 .5rem;color:#2c3e50;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:1.2}.contract-card.selected h3{color:#2c3e50}.contract-card p{font-size:.8rem;margin:0;color:#595959;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.contract-card.selected p{color:#2c3e50}.dashboard-content{display:flex;flex-direction:column;gap:2rem}.controls{display:flex;gap:2rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.date-control,.months-control{display:flex;flex-direction:column;gap:.5rem}.date-control label,.months-control label{font-weight:600;color:#333}.date-control input,.months-control select{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.charts{display:flex;flex-direction:column;gap:2rem}.consumption-chart,.power-chart{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.consumption-chart h3,.power-chart h3{margin:0 0 1rem;color:#2c3e50}.chart-container{overflow-x:auto}.chart-header{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:1rem;background-color:#f8f9fa;border-radius:4px;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.power-chart .chart-header{grid-template-columns:repeat(3,1fr)}.chart-data{max-height:400px;overflow-y:auto}.chart-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #e0e0e0;align-items:center}.power-chart .chart-row{grid-template-columns:repeat(3,1fr)}.chart-row:nth-child(2n){background-color:#f8f9fa}.period{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600;text-align:center}.period.vazio{background-color:#d4edda;color:#155724}.period.cheias{background-color:#fff3cd;color:#856404}.period.vazionormal{background-color:#e8f5e9;color:#2e7d32}.period.supervazio{background-color:#f1f8e9;color:#558b2f}.period.ponta{background-color:#f8d7da;color:#721c24}@media (min-width: 768px) and (max-width: 1023px){.charts-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.chart-container{height:280px;min-height:200px}.header-content{flex-direction:row;gap:1rem}.installation-select{min-width:150px}}@media (max-width: 767px){.header-content{flex-direction:column;gap:1rem}.center-section{order:2}.user-info{order:3}.charts-grid{grid-template-columns:1fr;gap:1rem}.chart-container{height:250px;min-height:180px}.controls{flex-direction:column;gap:1rem}.chart-header,.chart-row{grid-template-columns:1fr;gap:.5rem}.chart-header{display:none}.chart-row{display:block;padding:1rem;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:.5rem}.chart-row>div{margin-bottom:.25rem}.installation-select{min-width:auto;width:100%}.dashboard{gap:1rem}.chart-card{padding:1rem}.chart-card h2{font-size:1rem}}.demo-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:12px 20px;box-shadow:0 2px 10px #0003;z-index:10000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.demo-banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:12px;justify-content:center}.demo-banner-icon{font-size:24px;flex-shrink:0}.demo-banner-text{font-size:14px;flex:1;text-align:center}.demo-banner-text strong{font-weight:700;font-size:16px}.demo-banner-close{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.demo-banner-close:hover{background:#ffffff4d;transform:scale(1.1)}.demo-banner-close:active{transform:scale(.95)}.demo-banner~.app-container{padding-top:56px}@media (max-width: 768px){.demo-banner-content{flex-direction:column;gap:8px;text-align:center}.demo-banner-text{font-size:12px}.demo-banner-text strong{font-size:14px}}.skip-link{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;z-index:10001;background:#000;color:#fff;padding:12px 16px;text-decoration:none;font-weight:600;border-radius:0 0 4px;transition:all .3s}.skip-link:focus{position:fixed;top:0;left:0;width:auto;height:auto;clip:auto;overflow:visible;outline:2px solid #fff;outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}body{margin:0;font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.container{max-width:1200px;margin:0 auto;padding:0 20px}.loading{display:flex;justify-content:center;align-items:center;height:200px}.error{color:#d32f2f;background-color:#ffebee;padding:16px;border-radius:4px;margin:16px 0}
