body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:var(--color-text-dark);font-size:28px;font-weight:600;margin-bottom:8px}.login-header p{color:var(--color-text-light);font-size:14px;margin:0}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-weight:500}.form-group input{border:2px solid var(--color-border);border-radius:8px;font-size:15px;padding:12px 16px;transition:all .3s ease}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0093c926;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 6px 20px #0093c966;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6}.main-dashboard-container{margin:0 auto;max-width:100%;padding:15px}.dashboard-header-section{align-items:center;border-bottom:3px solid var(--color-primary);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.header-content h2{color:var(--color-text-dark);font-size:28px;font-weight:700;margin:0 0 5px}.header-content .subtitle{color:var(--color-text-light);font-size:14px;font-weight:500;margin:0}.date-selector input{border:2px solid var(--color-border);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;min-width:160px;padding:10px 16px;transition:all .3s ease}.date-selector input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0093c926;outline:none}.header-controls{align-items:center;display:flex;gap:15px}.dashboard-table-wrapper{background:#fff;box-shadow:0 2px 8px #0000001a}.dashboard-table{border:3px solid #000;border-collapse:initial;border-spacing:0;font-size:14px;width:100%}.dashboard-table thead tr:first-child th{background-color:#fff;border-right:none;font-size:15px;font-weight:700;padding:16px 10px;text-align:center;z-index:9}.dashboard-table .metric-header,.dashboard-table thead tr:first-child th{border-bottom:none;position:-webkit-sticky;position:sticky;top:0;vertical-align:middle}.dashboard-table .metric-header{background-color:#e8eaed!important;border-right:2px solid #666!important;font-size:17px!important;font-weight:800!important;max-width:130px;min-width:130px;padding:16px!important;text-align:left!important;z-index:10}.dashboard-table .plant-header{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);color:#fff;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.dashboard-table .sub-header{background-color:#f8f9fa;border-bottom:3px solid #000;border-right:none;font-size:12px;font-weight:700;line-height:1.4;padding:10px 6px;text-align:center}.dashboard-table .sub-header,.dashboard-table thead tr:nth-child(2) th:first-child{color:var(--color-text-dark);position:-webkit-sticky;position:sticky;top:55px;z-index:9}.dashboard-table thead tr:nth-child(2) th:first-child{background-color:#e8eaed!important;border-bottom:3px solid #000!important;border-right:2px solid #666!important;font-size:17px!important;font-weight:800!important;max-width:130px;min-width:130px;padding-bottom:10px!important;padding-left:16px!important;padding-top:10px!important;text-align:left!important}.dashboard-table thead tr:nth-child(2) th:first-child:before{color:var(--color-text-dark);content:"Category";font-weight:800}.dashboard-table tbody .metric-label{background-color:#e8eaed!important;border-right:2px solid #666!important;font-weight:700;max-width:130px;min-width:130px;padding:12px 16px;text-align:left}.dashboard-table tbody .data-cell,.dashboard-table tbody .metric-label{border-bottom:1px solid #f0f0f0;color:var(--color-text-dark);font-size:13px}.dashboard-table tbody .data-cell{background-color:#fff;border-right:none;font-weight:500;padding:12px 10px;text-align:right}.dashboard-table tbody td:nth-child(11),.dashboard-table tbody td:nth-child(13),.dashboard-table tbody td:nth-child(15),.dashboard-table tbody td:nth-child(17),.dashboard-table tbody td:nth-child(3),.dashboard-table tbody td:nth-child(5),.dashboard-table tbody td:nth-child(7),.dashboard-table tbody td:nth-child(9),.dashboard-table thead tr:first-child th:nth-child(11),.dashboard-table thead tr:first-child th:nth-child(13),.dashboard-table thead tr:first-child th:nth-child(15),.dashboard-table thead tr:first-child th:nth-child(17),.dashboard-table thead tr:first-child th:nth-child(3),.dashboard-table thead tr:first-child th:nth-child(5),.dashboard-table thead tr:first-child th:nth-child(7),.dashboard-table thead tr:first-child th:nth-child(9),.dashboard-table thead tr:nth-child(2) th:nth-child(11),.dashboard-table thead tr:nth-child(2) th:nth-child(13),.dashboard-table thead tr:nth-child(2) th:nth-child(15),.dashboard-table thead tr:nth-child(2) th:nth-child(17),.dashboard-table thead tr:nth-child(2) th:nth-child(3),.dashboard-table thead tr:nth-child(2) th:nth-child(5),.dashboard-table thead tr:nth-child(2) th:nth-child(7),.dashboard-table thead tr:nth-child(2) th:nth-child(9){border-right:2px solid #666!important}.dashboard-table tbody .spacer-row{display:none!important}.dashboard-table tbody .color-blue .metric-label,.dashboard-table tbody .color-green .metric-label,.dashboard-table tbody .color-orange .metric-label,.dashboard-table tbody .color-purple .metric-label,.dashboard-table tbody .color-teal .metric-label,.dashboard-table tbody .color-yellow .metric-label{background-color:#e8eaed!important;border-left:none}.dashboard-table tbody tr:hover:not(.spacer-row) .metric-label{background-color:var(--color-primary)!important;color:#fff}.dashboard-table tbody tr:hover:not(.spacer-row) .data-cell{background-color:#e6f7ff!important;font-weight:600}.dashboard-table tbody tr:hover:not(.spacer-row) .data-cell.avg-col{background-color:#d9f0fa!important}@media (max-width:1024px){.main-dashboard-container{padding:12px}.dashboard-header-section{padding-bottom:12px}.header-content h2{font-size:24px}.header-content .subtitle{font-size:13px}.date-selector input{font-size:14px;min-width:150px;padding:10px 14px}.dashboard-table{border-width:2px;font-size:13px}.dashboard-table thead tr:first-child th{font-size:14px;padding:14px 8px}.dashboard-table .metric-header{font-size:16px!important}.dashboard-table .sub-header{border-bottom-width:2px;font-size:11px;padding:8px 5px;top:50px}.dashboard-table thead tr:nth-child(2) th:first-child{border-bottom-width:2px;font-size:16px!important;top:50px}.dashboard-table .metric-header,.dashboard-table tbody .metric-label{font-size:12px;max-width:130px;min-width:130px}.dashboard-table tbody .data-cell{font-size:12px;padding:10px 8px}}@media (max-width:768px){.main-dashboard-container{padding:10px}.dashboard-header-section{align-items:flex-start;flex-direction:column;gap:12px;padding-bottom:10px}.header-content h2{font-size:22px;margin-bottom:4px}.header-content .subtitle{font-size:12px}.date-selector{width:100%}.date-selector input{font-size:16px;min-width:0;padding:12px;width:100%}.dashboard-table{border-width:2px;font-size:12px}.dashboard-table thead tr:first-child th{font-size:13px;padding:12px 6px}.dashboard-table .metric-header{font-size:15px!important}.dashboard-table .plant-header{font-size:12px;min-width:90px;padding:12px 6px}.dashboard-table .sub-header{border-bottom-width:2px;font-size:10px;padding:8px 4px;top:45px}.dashboard-table thead tr:nth-child(2) th:first-child{border-bottom-width:2px;font-size:15px!important;top:45px}.dashboard-table .metric-header,.dashboard-table tbody .metric-label{font-size:12px;max-width:120px;min-width:120px;padding:10px 12px}.dashboard-table tbody .data-cell{font-size:12px;min-width:80px;padding:10px 6px}.message{font-size:12px;padding:10px 12px}.empty-state,.loading-state{padding:40px 16px}.loading-spinner{border-width:4px;height:40px;width:40px}.empty-state p,.loading-state p{font-size:14px}}@media (max-width:480px){.main-dashboard-container{padding:8px}.dashboard-header-section{border-bottom-width:2px;gap:10px;padding-bottom:8px}.header-content h2{font-size:20px}.header-content .subtitle{font-size:11px}.date-selector input{font-size:16px;padding:12px}.dashboard-table{border-width:2px;font-size:11px}.dashboard-table thead tr:first-child th{font-size:12px;padding:10px 4px}.dashboard-table .metric-header{font-size:14px!important}.dashboard-table .plant-header{font-size:11px;min-width:80px;padding:10px 5px}.dashboard-table .sub-header{border-bottom-width:2px;font-size:9px;padding:6px 3px;top:40px}.dashboard-table thead tr:nth-child(2) th:first-child{border-bottom-width:2px;font-size:14px!important;top:40px}.dashboard-table .metric-header,.dashboard-table tbody .metric-label{font-size:11px;max-width:110px;min-width:110px;padding:8px 10px}.dashboard-table tbody .data-cell{font-size:11px;min-width:70px;padding:8px 4px}.empty-state,.loading-state{padding:30px 12px}.loading-spinner{border-width:3px;height:35px;width:35px}.empty-state p,.loading-state p{font-size:13px;margin-top:15px}}@media print{.dashboard-header-section{border-bottom:2px solid #333}.dashboard-table{border-width:2px}.dashboard-table .metric-header,.dashboard-table .sub-header,.dashboard-table tbody .metric-label,.dashboard-table thead tr:first-child th,.dashboard-table thead tr:nth-child(2) th:first-child{position:static!important}.dashboard-table .plant-header{background:var(--color-primary)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.dashboard-table tbody tr:hover .data-cell,.dashboard-table tbody tr:hover .metric-label{background-color:inherit!important}.dashboard-table tbody .spacer-row{display:none!important}}.flash-report-form-container{margin:0 auto;max-width:1000px;padding:20px}.flash-report-form-container h2{color:var(--color-text-dark);font-size:28px;margin-bottom:8px}.subtitle{color:var(--color-text-light);font-size:14px;margin-bottom:20px}.flash-report-form{display:flex;flex-direction:column;gap:20px}.form-section h3{border-bottom:2px solid var(--color-primary-light)}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width:1024px){.flash-report-form-container{padding:16px}.flash-report-form-container h2{font-size:24px}.selection-section{gap:16px;padding:20px}.form-section{padding:20px}.form-row{gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:768px){.flash-report-form-container{padding:12px}.flash-report-form-container h2{font-size:22px}.subtitle{font-size:13px}.selection-section{flex-direction:column;gap:12px;padding:16px}.selection-section .form-group{width:100%}.btn-secondary{padding:14px 20px;width:100%}.form-section{padding:16px}.form-section h3{font-size:18px}.form-row{gap:16px;grid-template-columns:1fr}.form-group input,.form-group select{font-size:16px;padding:14px}.form-group label{font-size:15px}.previous-badge{font-size:.75rem;padding:4px 10px}.form-actions{flex-direction:column;gap:12px;padding:16px 0}.btn-clear,.btn-primary{font-size:16px;padding:16px;width:100%}}@media (max-width:480px){.flash-report-form-container{padding:10px}.flash-report-form-container h2{font-size:20px}.subtitle{font-size:12px}.selection-section{gap:10px;padding:14px}.form-section{padding:14px}.form-section h3{font-size:16px;margin-bottom:16px}.form-group{gap:6px}.form-group label{font-size:14px}.form-group input,.form-group select{font-size:16px;padding:12px}.previous-badge{font-size:.7rem;padding:3px 8px}.message,.permission-warning{font-size:13px;padding:12px 14px}}.flash-report-view-container{margin:0 auto;max-width:1400px}.report-header{align-items:center;flex-wrap:wrap;justify-content:space-between;margin-bottom:30px}.report-header h2{color:var(--color-text-dark);font-size:28px;margin:0}.report-controls{gap:20px}.report-controls label{color:var(--color-text-dark)}.report-controls input,.report-controls select{border:2px solid var(--color-border)}.report-controls input:focus,.report-controls select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0093c926}.empty-state p{color:var(--color-text-light)}.report-content{padding:30px}.plant-title{color:var(--color-text-dark);font-size:24px;margin:0 0 5px}.report-subtitle{color:var(--color-text-light);font-size:14px;margin:0 0 25px}.table-container{margin-top:20px;overflow-x:auto}.report-table{border-collapse:collapse;font-size:14px;width:100%}.report-table th{background-color:var(--color-primary);border-bottom:2px solid var(--color-primary-dark);color:#fff;font-weight:600;padding:12px 8px;text-align:left;white-space:nowrap}.report-table td{border-bottom:1px solid #e9ecef;padding:10px 8px;text-align:left}.report-table tbody tr:hover{background-color:#f0faff}.report-table tbody tr:nth-child(2n){background-color:#fafbfc}.report-table tbody tr:nth-child(2n):hover{background-color:#e6f7ff}.totals-row td{background-color:#fff3cd!important;border-top:2px solid var(--color-warning);padding:12px 8px}.averages-row td{background-color:#d1ecf1!important;border-top:2px solid var(--color-primary-light);padding:12px 8px}.report-controls{flex:1 1;gap:15px}@media (max-width:1024px){.flash-report-view-container{padding:16px}.report-header h2{font-size:24px}.date-selector{gap:12px}.date-selector input{font-size:14px;padding:10px 14px}.report-table-wrapper{padding:8px}.report-table{font-size:11px}.report-table td,.report-table th{padding:10px 6px}.report-table .metric-label{font-size:12px;max-width:140px;min-width:140px}}@media (max-width:768px){.flash-report-view-container{padding:12px}.report-header{align-items:flex-start;flex-direction:column;gap:12px;padding-bottom:12px}.report-header h2{font-size:22px}.date-selector{flex-direction:column;gap:10px;width:100%}.date-selector label{font-size:14px}.date-selector input{font-size:16px;padding:12px;width:100%}.report-table-wrapper{-webkit-overflow-scrolling:touch;border-radius:8px;overflow-x:auto;padding:6px}.report-table-wrapper:after{background:#f8f9fa;border-top:1px solid #e0e0e0;color:#666;content:"← Swipe to see more →";display:block;font-size:11px;font-style:italic;padding:8px;text-align:center}.report-table{font-size:10px}.report-table th{font-size:11px;padding:8px 4px}.report-table td{padding:8px 4px}.report-table .metric-label{font-size:11px;max-width:120px;min-width:120px;padding:8px}.report-table .week-header{font-size:10px;padding:8px 4px}.report-table .date-subheader{font-size:9px;padding:6px 4px}.message{font-size:13px;padding:12px 14px}}@media (max-width:480px){.flash-report-view-container{padding:10px}.report-header{gap:10px;padding-bottom:10px}.report-header h2{font-size:20px}.report-table-wrapper{padding:4px}.report-table{font-size:9px}.report-table th{font-size:10px;padding:6px 3px}.report-table td{padding:6px 3px}.report-table .metric-label{font-size:10px;max-width:100px;min-width:100px;padding:6px}.report-table .week-header{font-size:9px;min-width:70px;padding:6px 3px}.report-table .date-subheader{font-size:8px;padding:4px 2px}.report-table-wrapper:after{font-size:10px;padding:6px}.empty-state,.loading-state{padding:40px 16px}.empty-state p,.loading-state p{font-size:14px}}@media print{.report-header{border-bottom:2px solid #333}.report-table th{background-color:var(--color-primary)!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.report-table tbody tr:hover td{background-color:inherit!important}}.automated-field{align-items:center;background-color:#f0f4f8;border:1px solid #cbd5e0;border-radius:4px;color:#4a5568;display:flex;font-size:14px;min-height:38px;padding:8px 12px}.automated-badge{background-color:#ebf8ff;border:1px solid #bee3f8;border-radius:10px;color:#2b6cb0;font-size:11px;font-weight:500;margin-left:8px;padding:1px 6px}.utilities-form-container{margin:0 auto;max-width:900px;padding:20px}.utilities-form-container h2{color:var(--color-text-dark);font-size:28px;margin-bottom:8px}.permission-warning{background-color:#fff3cd;border:2px solid var(--color-warning);border-radius:8px;color:#856404;font-size:14px;margin-bottom:20px;padding:15px 20px}.permission-warning strong{font-weight:700}.selection-section{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;margin-bottom:20px;padding:25px}.selection-section .form-group{flex:1 1}.btn-secondary{background-color:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.btn-secondary:hover:not(:disabled){background-color:#5a6268;transform:translateY(-1px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.utilities-form{display:flex;flex-direction:column;gap:20px}.form-section{background:#fff;border-left:5px solid var(--color-primary);border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.form-section h3{border-bottom:2px solid #f0f0f0;color:var(--color-text-dark);font-size:20px;margin-bottom:20px;padding-bottom:10px}.section-water{border-left-color:#2196f3}.section-water h3{color:#2196f3}.section-gas{border-left-color:#ff9800}.section-gas h3{color:#ff9800}.section-electric{border-left-color:#ffc107}.section-electric h3{color:#f57c00}.form-row{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-row.single-column{grid-template-columns:1fr;max-width:300px}.form-group input:disabled,.form-group input:read-only,.form-group select:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.calculated-field{background-color:#e8f5e9!important;border-color:#81c784!important;color:#2e7d32;cursor:not-allowed;font-weight:700}.grand-total-section{align-items:center;background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);border-radius:12px;box-shadow:0 4px 12px #0093c94d;display:flex;justify-content:space-between;padding:25px}.grand-total-label{color:#fff;font-size:20px;font-weight:700}.grand-total-value{color:#fff;font-size:32px;font-weight:800;letter-spacing:1px}.form-actions{display:flex;gap:15px;justify-content:center;padding:20px 0}.btn-clear{background-color:#fff;border:2px solid var(--color-border);border-radius:8px;color:var(--color-text-light);cursor:pointer;font-size:16px;font-weight:600;padding:14px 30px;transition:all .3s ease}.btn-clear:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.btn-clear:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 40px;transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #0093c966;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.previous-badge{background-color:#dbeafe;border-radius:12px;color:#1e40af;flex:0 0 auto;font-size:.8rem;font-weight:600;padding:5px 12px;white-space:nowrap}.label-row{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px;width:100%}.label-row label{flex:0 0 auto;margin:0!important}@media (max-width:1024px){.utilities-form-container{padding:16px}.utilities-form-container h2{font-size:24px}.selection-section{gap:16px;padding:20px}.form-section{padding:20px}.form-row{gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grand-total-section{padding:20px}.grand-total-label{font-size:18px}.grand-total-value{font-size:28px}}@media (max-width:768px){.utilities-form-container{padding:12px}.utilities-form-container h2{font-size:22px}.selection-section{flex-direction:column;gap:12px;padding:16px}.selection-section .form-group{width:100%}.btn-secondary{padding:14px 20px;width:100%}.form-section{padding:16px}.form-section h3{font-size:18px}.form-row{gap:16px;grid-template-columns:1fr}.form-row.single-column{max-width:100%}.form-group input,.form-group select{font-size:16px;padding:14px}.form-group label{font-size:15px}.grand-total-section{flex-direction:column;gap:12px;padding:20px;text-align:center}.grand-total-label{font-size:18px}.grand-total-value{font-size:32px}.form-actions{flex-direction:column;gap:12px;padding:16px 0}.btn-clear,.btn-primary{font-size:16px;padding:16px;width:100%}}@media (max-width:480px){.utilities-form-container{padding:10px}.utilities-form-container h2{font-size:20px}.selection-section{gap:10px;padding:14px}.form-section{padding:14px}.form-section h3{font-size:16px;margin-bottom:16px}.form-group{gap:6px}.form-group label{font-size:14px}.form-group input,.form-group select{font-size:16px;padding:12px}.grand-total-section{gap:10px;padding:16px}.grand-total-label{font-size:16px}.grand-total-value{font-size:28px}.message,.permission-warning{font-size:13px;padding:12px 14px}}.utilities-report-view-container{margin:0 auto;max-width:100%;padding:20px}.report-header{align-items:flex-end;display:flex;gap:20px;margin-bottom:25px}.header-left h2{color:#333;font-size:28px;margin:0 0 5px}.header-left .subtitle{color:#666;font-size:14px;margin:0}.report-controls{align-items:flex-end;display:flex;flex-shrink:0;gap:12px;margin-left:auto}.report-controls .form-group{display:flex;flex-direction:column;gap:8px}.report-controls label{color:#333;font-size:14px;font-weight:600}.report-controls input,.report-controls select{border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:15px;min-width:180px;padding:10px 16px;transition:all .3s ease}.report-controls input:focus,.report-controls select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.loading-spinner{border-top-color:#667eea}.loading-state p{color:#666}.empty-state{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:60px 20px;text-align:center}.empty-state p{color:#666;font-size:16px;margin:0}.report-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.table-wrapper{overflow-x:auto;overflow-y:visible}.utilities-report-table{border-collapse:initial;border-spacing:0;font-size:13px;width:100%}.utilities-report-table thead th{background-color:#f8f9fa;border-bottom:2px solid #dee2e6;color:#333;font-size:12px;font-weight:700;padding:12px 10px;text-align:center;white-space:nowrap}.utilities-report-table thead .month-header{background-color:#fff;border:none;min-width:80px}.utilities-report-table thead .section-water{background-color:#e3f2fd;color:#1976d2}.utilities-report-table thead .section-gas{background-color:#fff3e0;color:#e65100}.utilities-report-table thead .section-electric{background-color:#fff9c4;color:#f57f17}.utilities-report-table tbody td{background-color:#fff;border-bottom:1px solid #e9ecef;border-right:1px solid #f0f0f0;padding:10px;text-align:right}.utilities-report-table tbody .label-row{background-color:#f0f0f0}.utilities-report-table tbody .label-row td{background-color:#f0f0f0;border-bottom:2px solid #dee2e6;font-weight:700}.utilities-report-table tbody .current-label{color:#333;font-size:14px;padding-left:15px;text-align:left}.utilities-report-table tbody .month-cell{background-color:#c8e6c9;color:#2e7d32;font-weight:700;padding-left:15px;text-align:left}.utilities-report-table tbody .section-water{background-color:#f1f8fe}.utilities-report-table tbody .section-gas{background-color:#fffbf0}.utilities-report-table tbody .section-electric{background-color:#fffef5}.utilities-report-table tbody .average-row{background-color:#fff9e6;border-top:3px solid #ffc107}.utilities-report-table tbody .average-row td{background-color:#fff9e6;border-bottom:2px solid #dee2e6;font-weight:700}.utilities-report-table tbody .average-row .avg-label{background-color:#ffeb3b;color:#333;font-size:14px;padding-left:15px;text-align:left}.utilities-report-table tbody .average-row .section-water{background-color:#e3f2fd}.utilities-report-table tbody .average-row .section-gas{background-color:#ffe0b2}.utilities-report-table tbody .average-row .section-electric{background-color:#fff9c4}.utilities-report-table tbody tr:hover:not(.label-row):not(.average-row) td{background-color:#f0f4ff!important;font-weight:600}.utilities-report-table tbody tr:hover:not(.label-row):not(.average-row) .month-cell{background-color:#81c784!important;color:#fff}@media (max-width:1400px){.utilities-report-table{font-size:12px}.utilities-report-table thead th{font-size:11px;padding:10px 8px}.utilities-report-table tbody td{padding:8px}}@media (max-width:1024px){.utilities-report-view-container{padding:16px}.report-header h2{font-size:24px}.month-selector{gap:12px}.month-selector input{font-size:14px;padding:10px 14px}.report-table-wrapper{padding:8px}.report-table{font-size:11px}.report-table td,.report-table th{padding:10px 6px}.report-table .metric-label{font-size:12px;max-width:140px;min-width:140px}}@media (max-width:768px){.utilities-report-view-container{padding:12px}.report-header{align-items:flex-start;flex-direction:column;gap:12px;padding-bottom:12px}.report-header h2{font-size:22px}.subtitle{font-size:13px}.month-selector{flex-direction:column;gap:10px;width:100%}.month-selector label{font-size:14px}.month-selector input{font-size:16px;padding:12px;width:100%}.report-table-wrapper{border-radius:8px;padding:6px}.report-table{font-size:10px}.report-table th{font-size:11px;padding:8px 4px}.report-table td{padding:8px 4px}.report-table .metric-label{font-size:11px;max-width:120px;min-width:120px;padding:8px}.report-table .month-header{font-size:10px;padding:8px 4px}.report-table .date-subheader{font-size:9px;padding:6px 4px}.report-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.report-table-wrapper:after{background:#f8f9fa;border-top:1px solid #e0e0e0;color:#666;content:"← Swipe to see more months →";display:block;font-size:11px;font-style:italic;padding:8px;text-align:center}.message{font-size:13px;padding:12px 14px}}@media (max-width:480px){.utilities-report-view-container{padding:10px}.report-header{gap:10px;padding-bottom:10px}.report-header h2{font-size:20px}.subtitle{font-size:12px}.month-selector{gap:8px}.month-selector label{font-size:13px}.month-selector input{font-size:16px;padding:12px}.report-table-wrapper{padding:4px}.report-table{font-size:9px}.report-table th{font-size:10px;padding:6px 3px}.report-table td{padding:6px 3px}.report-table .metric-label{font-size:10px;max-width:100px;min-width:100px;padding:6px}.report-table .month-header{font-size:9px;min-width:70px;padding:6px 3px}.report-table .date-subheader{font-size:8px;padding:4px 2px}.report-table-wrapper:after{font-size:10px;padding:6px}.empty-state,.loading-state{padding:40px 16px}.empty-state p,.loading-state p{font-size:14px}}@media print{.report-header{border-bottom:2px solid #333}.report-controls{display:none}.utilities-report-table{font-size:10px}.utilities-report-table tbody tr:hover td{background-color:inherit!important}}.header-controls-wrapper{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px}.user-management-container{margin:0 auto;max-width:1400px}.user-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.user-management-header h2{color:var(--color-text-dark);font-size:28px;margin:0}.btn-create{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-create:hover:not(:disabled){box-shadow:0 6px 20px #0093c966;transform:translateY(-2px)}.btn-create:disabled{cursor:not-allowed;opacity:.6}.loading-state{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-state p{color:var(--color-text-light);font-size:16px;margin-top:20px}.users-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;padding:20px}.users-table{border-collapse:collapse;font-size:14px;width:100%}.users-table th{background-color:var(--color-primary);border-bottom:2px solid var(--color-primary-dark);color:#fff;font-weight:600;padding:12px;text-align:left}.users-table td{border-bottom:1px solid #e9ecef;padding:12px}.users-table tbody tr:hover{background-color:#f0faff}.badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 10px}.badge-admin{background-color:#ffeaa7;color:#d63031}.badge-user{background-color:#dfe6e9;color:#2d3436}.badge-active{background-color:#d4edda;color:#155724}.badge-inactive{background-color:#f8d7da;color:#721c24}.plant-access-all{color:#155724;font-weight:600}.plant-access-none{color:#999;font-style:italic}.plant-access-list{display:flex;flex-wrap:wrap;gap:5px}.plant-badge{background-color:#e3f2fd;border-radius:8px;color:var(--color-primary);display:inline-block;font-size:12px;padding:3px 8px}.action-buttons{display:flex;gap:8px}.btn-deactivate,.btn-edit{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .3s ease}.btn-edit{background-color:var(--color-primary);color:#fff}.btn-edit:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-deactivate{background-color:var(--color-danger);color:#fff}.btn-deactivate:hover:not(:disabled){background-color:#c82333}.btn-deactivate:disabled,.btn-edit:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:700px;overflow-y:auto;width:90%}.modal-header{align-items:center;background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);border-bottom:2px solid #f0f0f0;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h3{color:#fff;font-size:22px;margin:0}.modal-close{background:none;border:none;color:#fff;cursor:pointer;font-size:32px;height:30px;line-height:1;opacity:.8;padding:0;width:30px}.modal-close:hover{opacity:1}.user-form{padding:25px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--color-text-dark);font-size:14px;font-weight:600}.form-group input,.form-group select{border:2px solid var(--color-border);border-radius:8px;font-size:15px;padding:12px 16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0093c926;outline:none}.form-group-checkbox{margin-bottom:15px}.form-group-checkbox label{align-items:center;cursor:pointer;display:flex;gap:10px}.form-group-checkbox input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:18px;width:18px}.form-group-checkbox span{color:var(--color-text-dark);font-size:14px}.permissions-section{border-top:2px solid #f0f0f0;margin-top:30px;padding-top:30px}.permissions-section h4{color:var(--color-text-dark);margin-bottom:8px}.permissions-hint{color:var(--color-text-light);font-size:13px;margin-bottom:20px}.permissions-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.permission-item{align-items:center;background-color:#f0faff;border-left:3px solid var(--color-primary-light);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.plant-name{color:var(--color-text-dark);font-weight:600}.permission-item select{border:2px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:14px;padding:6px 10px}.permission-item select:focus{border-color:var(--color-primary);outline:none}.modal-actions{border-top:2px solid #f0f0f0;display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px}.btn-cancel,.btn-save{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;padding:12px 30px;transition:all .3s ease}.btn-cancel{background-color:#e0e0e0;color:var(--color-text-light)}.btn-cancel:hover:not(:disabled){background-color:#d0d0d0}.btn-save{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);color:#fff}.btn-save:hover:not(:disabled){box-shadow:0 6px 20px #0093c966;transform:translateY(-2px)}.btn-cancel:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.6}@media (max-width:1024px){.user-management-container{padding:16px}.user-management-container h2{font-size:24px}}@media (max-width:768px){.user-management-container{padding:12px}.user-management-container h2{font-size:22px;margin-bottom:12px}.form-row{gap:12px;grid-template-columns:1fr}.form-group input,.form-group select{font-size:16px;padding:12px}.btn-create{font-size:16px;padding:14px;width:100%}.user-management-header{align-items:flex-start;flex-direction:column;gap:12px}.users-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto;padding:10px}.users-table{font-size:12px;min-width:600px}.users-table th{font-size:12px}.users-table td,.users-table th{padding:10px 6px}.action-buttons{flex-direction:column;gap:6px}.btn-deactivate,.btn-edit{font-size:12px;padding:8px 12px;width:100%}.modal-content{margin:20px auto;max-width:95%;width:95%}.modal-header h3{font-size:18px}.modal-actions{flex-direction:column;gap:10px}.btn-cancel,.btn-save{font-size:16px;padding:14px;width:100%}.message{font-size:13px;padding:12px 14px}}@media (max-width:480px){.user-management-container{padding:10px}.user-management-container h2{font-size:20px}.users-table{font-size:11px;min-width:550px}.users-table th{font-size:11px;padding:8px 4px}.users-table td{padding:8px 4px}.modal-content{margin:10px auto;width:98%}.modal-header{padding:16px 20px}.modal-header h3{font-size:16px}.user-form{padding:16px}.message{font-size:12px;padding:10px 12px}}@media print{.action-buttons,.btn-create,.modal-overlay{display:none!important}}.dashboard-container{background:#f5f5f5;min-height:100vh}.dashboard-header{align-items:center;background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;padding:20px 40px;position:relative;z-index:10}.header-left h1{color:#fff;font-size:28px;font-weight:700;margin:0}.header-right{align-items:center;display:flex;gap:15px}.header-logo{height:45px;margin-right:5px;object-fit:contain;width:auto}.user-menu-container{position:relative}.user-menu-button{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;padding:10px 16px;transition:all .3s ease}.user-menu-button:hover{background:#f0faff;border-color:var(--color-primary)}.user-menu-button svg:first-child{color:var(--color-primary)}.dropdown-arrow{margin-left:4px;transition:transform .3s ease}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{animation:dropdownFadeIn .2s ease;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary) 100%);color:#fff;padding:16px 20px}.user-name{font-size:16px;font-weight:700;margin-bottom:4px}.user-role{font-size:13px;opacity:.9}.user-dropdown-divider{background:#e0e0e0;height:1px}.user-dropdown-item{align-items:center;background:#fff;border:none;color:#333;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;padding:14px 20px;text-align:left;transition:all .2s ease;width:100%}.user-dropdown-item:hover{background:#f0faff;color:var(--color-primary)}.user-dropdown-item svg{flex-shrink:0}.user-dropdown-item.logout{border-top:1px solid #f0f0f0;color:var(--color-danger)}.user-dropdown-item.logout:hover{background:#ffebee}.tab-navigation{background:#fff;border-bottom:2px solid #f0f0f0;display:flex;gap:8px;overflow:visible;padding:0 40px;position:relative;z-index:5}.tab-button{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:6px;padding:16px 24px;transition:all .3s ease;white-space:nowrap}.tab-button:hover{background:#f0faff;color:var(--color-primary)}.tab-button.active{border-bottom-color:var(--color-primary);color:var(--color-primary)}.dropdown-container{align-items:center;display:flex;position:relative}.dropdown-trigger{align-items:center;display:flex;gap:6px}.dropdown-menu{animation:dropdownFadeIn .2s ease;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;left:0;margin-top:2px;min-width:200px;overflow:visible;position:absolute;top:100%;z-index:1001}.dropdown-item{background:#fff;border:none;color:#333;cursor:pointer;font-size:15px;font-weight:500;padding:14px 20px;text-align:left;transition:all .2s ease;width:100%}.dropdown-item.active,.dropdown-item:hover{background:#f0faff;color:var(--color-primary)}.dropdown-item.active{font-weight:600}.dashboard-content{background:#f5f5f5;min-height:calc(100vh - 200px);padding:30px 40px}.hamburger-button{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:8px;z-index:20}.hamburger-line{background:#fff;border-radius:3px;height:3px;transition:all .3s ease;width:24px}.hamburger-line.open:first-child{transform:rotate(45deg) translate(7px,7px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}@media (max-width:1024px){.hamburger-button{display:flex;margin-right:16px}.header-left{align-items:center;display:flex;gap:12px}.tab-navigation{background:#fff;border-bottom:none;box-shadow:2px 0 10px #0000001a;flex-direction:column;gap:0;height:calc(100vh - 70px);left:-100%;overflow-y:auto;padding:20px 0;position:fixed;top:70px;transition:left .3s ease;width:280px;z-index:100}.tab-navigation.mobile-open{left:0}.tab-button{border-bottom:none;border-left:4px solid #0000;justify-content:flex-start;padding:16px 24px;text-align:left;width:100%}.tab-button.active{background:#f0faff;border-bottom:none;border-left-color:var(--color-primary)}.tab-button:hover{background:#f0faff}.dropdown-container{display:block;width:100%}.dropdown-menu{animation:none;background:#0000;border-radius:0;box-shadow:none;display:block;margin:0;padding:0;position:static!important}.dropdown-item{background:#f0faff;border-left:4px solid #0000;font-size:14px;padding:14px 24px 14px 48px}.dropdown-item:hover{background:#d9f0fa}.dropdown-item.active{background:#d9f0fa;border-left-color:var(--color-primary);font-weight:600}.dashboard-content{padding:20px}}@media (max-width:768px){.dashboard-header{padding:12px 16px}.header-left h1{font-size:20px}.header-logo{height:35px}.tab-navigation{height:calc(100vh - 60px);top:60px;width:260px}.user-menu-button span{max-width:100px;overflow:hidden;text-overflow:ellipsis}}@media (max-width:480px){.dashboard-header{padding:10px 12px}.header-left h1{font-size:18px}.header-logo{height:30px}.user-menu-button span{display:none}.tab-navigation{width:240px}.tab-button{font-size:14px;padding:14px 20px}.dropdown-item{font-size:13px;padding:12px 20px 12px 44px}}:root{--color-primary:#0093c9;--color-primary-light:#4ac1e0;--color-primary-dark:#0078a8;--color-white:#fff;--color-text-dark:#333;--color-text-light:#666;--color-border:#e0e0e0;--color-bg-light:#f5f7fa;--color-success:#27ae60;--color-danger:#e74c3c;--color-warning:#ffc107}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;background-color:var(--color-bg-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.btn-print{align-items:center;background-color:#4ac1e0;background-color:var(--color-primary-light);border:none;border-radius:6px;box-shadow:0 2px 4px #4ac1e04d;color:#fff;color:var(--color-white);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:9px 18px;transition:all .2s ease;white-space:nowrap}.btn-print:hover:not(:disabled){background-color:#0093c9;background-color:var(--color-primary);box-shadow:0 4px 8px #0093c966;transform:translateY(-1px)}.btn-print:active:not(:disabled){box-shadow:0 1px 3px #0093c94d;transform:translateY(0)}.btn-print:disabled{background-color:#b0bec5;box-shadow:none;cursor:not-allowed;opacity:.7}.btn-export{align-items:center;background-color:#4ac1e0;background-color:var(--color-primary-light);border:none;border-radius:6px;box-shadow:0 2px 4px #4ac1e04d;color:#fff;color:var(--color-white);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:9px 18px;transition:all .2s ease;white-space:nowrap}.btn-export:hover:not(:disabled){background-color:#0093c9;background-color:var(--color-primary);box-shadow:0 4px 8px #0093c966;transform:translateY(-1px)}.btn-export:active:not(:disabled){box-shadow:0 1px 3px #0093c94d;transform:translateY(0)}.btn-export:disabled{background-color:#b0bec5;box-shadow:none;cursor:not-allowed;opacity:.7}.report-actions{align-items:center;display:flex;gap:10px}.loading-container{align-items:center;background-color:#f5f7fa;background-color:var(--color-bg-light);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:5px solid #f3f3f3;border-radius:50%;border-top-color:#0093c9;border-top:5px solid var(--color-primary);height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container p{color:#666;color:var(--color-text-light);font-size:16px;margin-top:20px}.message{border-radius:8px;font-size:14px;margin-bottom:20px;padding:15px 20px}.message-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}@media print{.btn-export,.btn-print,.header-controls,.header-controls-wrapper,.report-actions,.report-controls{display:none!important}}
/*# sourceMappingURL=main.5b5fe669.css.map*/