body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f7fa;color:#333;font-family:Sarabun,Kanit,sans-serif;line-height:1.5}.app{flex-direction:column}.app,.login-container{display:flex;min-height:100vh}.login-container{align-items:center;background-color:#f0f7ff;background-position:50%;background-size:cover;justify-content:center}.login-form{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;max-width:400px;padding:2rem;width:100%}.login-form h2{color:#1d4ed8;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.error-message{background-color:#fee2e2;border-radius:.375rem;color:#b91c1c;font-size:.875rem;padding:.75rem}.error-message,.form-group{margin-bottom:1rem}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem .75rem;width:100%}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d;outline:none}.btn-primary{background-color:#2563eb;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:block;font-weight:500;margin-top:1.5rem;padding:.5rem 1rem;width:100%}.btn-primary:hover{background-color:#1d4ed8}.dashboard-container{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{align-items:center;background-color:#1e40af;box-shadow:0 1px 3px 0 #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.dashboard-header h1{font-size:1.5rem;font-weight:700}.user-controls{align-items:center;color:#fff;display:flex;gap:1rem}.user-info{align-items:flex-end;display:flex;flex-direction:column}.role-badge{background-color:#fff3;border-radius:.25rem;font-size:.75rem;padding:.125rem .5rem}.logout-btn{background-color:#ffffff1a;border:1px solid #fff3;border-radius:.25rem;color:#fff;cursor:pointer;padding:.375rem .75rem}.logout-btn:hover{background-color:#fff3}.village-selector{align-items:center;color:#000;display:flex;gap:.5rem}.village-selector select{border:1px solid #d1d5db;border-radius:.25rem;padding:.25rem .5rem}.dashboard-content{display:flex;flex:1 1}.sidebar{background-color:#f8fafc;border-right:1px solid #e2e8f0;padding:1.5rem 0;width:240px}.nav-menu ul{list-style:none}.nav-link{align-items:center;color:#475569;display:flex;gap:.75rem;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .2s}.nav-link:hover{background-color:#f1f5f9}.nav-link.active{background-color:#e0e7ff;border-right:3px solid #1e40af;color:#1e40af;font-weight:500}.icon{font-size:1.25rem}.main-content{flex:1 1;overflow-y:auto;padding:1.5rem}.dashboard-overview h2{color:#1e293b;font-size:1.5rem;margin-bottom:1.5rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-bottom:2rem}.stat-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem}.stat-card h3{color:#64748b;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.stat-value{font-size:1.875rem;font-weight:700}.stat-info{color:#64748b;font-size:.875rem;margin-top:.5rem}.dashboard-section{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;margin-bottom:1.5rem;padding:1.5rem}.dashboard-section h3{color:#1e293b;font-size:1.125rem;margin-bottom:1rem}.activity-list,.alerts-list{display:flex;flex-direction:column;gap:.75rem}.activity-item,.alert-item{background-color:#f8fafc;border-radius:.375rem;display:flex;gap:.75rem;padding:.75rem}.activity-icon,.alert-icon{font-size:1.5rem}.activity-title,.alert-title{color:#1e293b;font-weight:500}.activity-info,.alert-info{color:#64748b;font-size:.875rem}.alert-warning{background-color:#fef9c3}.alert-danger{background-color:#fee2e2}.dashboard-welcome{margin-bottom:1.5rem}.dashboard-welcome h2{color:#1e293b;font-size:1.5rem;margin-bottom:.5rem}.dashboard-welcome p{color:#64748b}.meter-info{margin-bottom:1.5rem}.meter-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem}.meter-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.meter-header h4{color:#1e293b;font-size:1.125rem}.meter-status{background-color:#dcfce7;border-radius:.25rem;color:#166534;font-size:.875rem;font-weight:500;padding:.25rem .5rem}.meter-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.meter-item{display:flex;flex-direction:column}.meter-label{color:#64748b;font-size:.875rem;margin-bottom:.25rem}.meter-value{color:#1e293b;font-size:1.125rem;font-weight:500}.bills-table{border-collapse:collapse;margin-bottom:1.5rem;width:100%}.bills-table td,.bills-table th{border-bottom:1px solid #e2e8f0;padding:.75rem 1rem;text-align:left}.bills-table th{background-color:#f8fafc;color:#64748b;font-weight:500}.status-badge{border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.status-paid{background-color:#dcfce7;color:#166534}.status-unpaid{background-color:#fee2e2;color:#b91c1c}.status-pending{background-color:#fef9c3;color:#854d0e}.status-verified{background-color:#dbeafe;color:#1e40af}.status-active{background-color:#dcfce7;color:#166534}.status-inactive{background-color:#f3f4f6;color:#4b5563}.usage-chart{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;margin-bottom:1.5rem;padding:1.5rem}.chart-container{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.chart-bar{background-color:#3b82f6;border-radius:.25rem .25rem 0 0;display:flex;height:100px;justify-content:center}.bar-value{color:#1e293b;font-size:.875rem}.bar-label{color:#64748b;font-size:.875rem;margin-top:.5rem;text-align:center}.chart-legend{margin-top:1rem}.legend-color{background-color:#3b82f6;border-radius:.25rem;height:16px;width:16px}.legend-label{color:#64748b;font-size:.875rem}.announcements-list{display:flex;flex-direction:column;gap:1rem}.announcement-card{background-color:#f8fafc;border-left:4px solid #3b82f6;border-radius:.5rem;padding:1rem}.announcement-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.announcement-header h4{color:#1e293b;font-size:1rem}.announcement-date{color:#64748b;font-size:.875rem}.announcement-content{color:#1e293b;font-size:.875rem}.page-header{margin-bottom:1.5rem;padding-bottom:1rem}.page-header h1{color:#1e293b;font-size:1.5rem}.back-link{margin-right:1rem}.add-btn,.add-user-btn,.generate-bills-btn,.print-btn,.receive-payment-btn{align-items:center;background-color:#2563eb;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem}.add-btn:hover,.add-user-btn:hover,.generate-bills-btn:hover,.print-btn:hover,.receive-payment-btn:hover{background-color:#1d4ed8}.complete-btn,.edit-btn,.read-btn,.verify-btn,.view-btn{background-color:#e0e7ff;color:#1e40af}.cancel-btn,.complete-btn,.deactivate-btn,.edit-btn,.read-btn,.verify-btn,.view-btn{border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem;padding:.25rem .5rem}.cancel-btn,.deactivate-btn{background-color:#fee2e2;color:#b91c1c}.activate-btn,.confirm-btn,.save-btn,.submit-btn{background-color:#dcfce7;border:none;border-radius:.25rem;color:#166534;cursor:pointer;font-size:.75rem;padding:.25rem .5rem}.search-btn{background-color:#2563eb;border:none;border-radius:0 .25rem .25rem 0;color:#fff;cursor:pointer;padding:.375rem .75rem}.action-btn{margin-right:.5rem}.actions-cell{white-space:nowrap}.search-bar{align-items:center;display:flex;margin-right:1rem}.search-bar input{border:1px solid #d1d5db;border-radius:.25rem 0 0 .25rem;border-right:none;padding:.375rem .75rem;width:300px}.filter-group{align-items:center;display:flex;gap:.5rem;margin-right:1rem}.filter-group label{color:#64748b;font-size:.875rem}.filter-group select{border:1px solid #d1d5db;border-radius:.25rem;padding:.375rem .75rem}.billing-filters,.equipment-filters,.maintenance-filters,.meter-filters,.payment-filters,.reading-filters,.user-filters{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.bills-table,.data-table,.equipment-table,.maintenance-table,.meters-table,.payments-table,.readings-table,.users-table{border-collapse:collapse;width:100%}.bills-table td,.bills-table th,.data-table td,.data-table th,.equipment-table td,.equipment-table th,.maintenance-table td,.maintenance-table th,.meters-table td,.meters-table th,.payments-table td,.payments-table th,.readings-table td,.readings-table th,.users-table td,.users-table th{border-bottom:1px solid #e2e8f0;padding:.75rem;text-align:left}.bills-table th,.data-table th,.equipment-table th,.maintenance-table th,.meters-table th,.payments-table th,.readings-table th,.users-table th{background-color:#f8fafc;color:#64748b;font-weight:500}.inactive-row td{color:#9ca3af}.maintenance-required-row td{background-color:#fef9c3}.billing-period-selector,.payment-period-selector,.period-selector{align-items:center;background-color:#f8fafc;border-radius:.5rem;display:flex;margin-bottom:1.5rem;padding:1rem}.period-label{color:#1e293b;font-weight:500;margin-right:1rem}.period-controls{display:flex;gap:.5rem}.period-controls select{border:1px solid #d1d5db;border-radius:.25rem;padding:.375rem .75rem}.billing-stats,.payment-stats,.reading-stats{display:flex;gap:1rem;margin-left:auto}.stat-box{align-items:center;background-color:#fff;border-radius:.25rem;display:flex;flex-direction:column;min-width:100px;padding:.5rem 1rem}.stat-label{color:#64748b;font-size:.75rem}.stat-value{color:#1e293b;font-size:1.125rem;font-weight:600}.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-container{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.modal-header h2{color:#1e293b;font-size:1.25rem}.close-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:1.5rem}.modal-content{padding:1.5rem}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.bill-info,.meter-info{background-color:#f8fafc;border-radius:.25rem;margin-bottom:1.5rem;padding:1rem}.bill-info div,.meter-info div{margin-bottom:.5rem}.modal-container form{padding:1.5rem}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-row .form-group{flex:1 1}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.form-section{margin-bottom:1.5rem}.form-section h3{border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:1.125rem;margin-bottom:.75rem;padding-bottom:.5rem}.field-value{background-color:#f8fafc;border-radius:.25rem;color:#1e293b;padding:.5rem}.checkbox-group{align-items:center;display:flex}.checkbox-group input[type=checkbox]{margin-right:.5rem;width:auto}.checkbox-group label{align-items:center;display:flex;margin-bottom:0}.warning-message{background-color:#fef9c3;border-radius:.25rem;color:#854d0e;margin-bottom:1.5rem;padding:.75rem}.hint{color:#64748b;font-size:.75rem;margin-top:.25rem}.payment-method{border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.payment-method.cash{background-color:#e0e7ff;color:#1e40af}.payment-method.transfer{background-color:#dcfce7;color:#166534}.payment-method.promptpay{background-color:#dbeafe;color:#1e40af}.unpaid-bills-section{margin-bottom:1.5rem}.unpaid-bills-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:1rem}.unpaid-bill-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;padding:1rem;transition:all .2s}.unpaid-bill-item:hover{background-color:#f0f9ff;border-color:#3b82f6}.unpaid-bill-item.selected{background-color:#e0f2fe;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.bill-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.meter-number{color:#1e293b;font-weight:500}.bill-amount{color:#1e40af;font-weight:600}.resident-name{color:#1e293b;font-weight:500;margin-bottom:.25rem}.bill-address,.bill-period{color:#64748b;font-size:.75rem}.no-unpaid-bills{background-color:#f8fafc;border-radius:.375rem;color:#64748b;padding:1.5rem;text-align:center}.equipment-tabs{border-bottom:1px solid #e2e8f0;display:flex;margin-bottom:1.5rem}.tab-btn{background:none;border:none;color:#64748b;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;position:relative}.tab-btn.active{border-bottom:2px solid #1e40af;color:#1e40af}.alert-badge{background-color:#ef4444;border-radius:50%;color:#fff;font-size:.75rem;font-weight:600;height:1.25rem;justify-content:center;position:absolute;right:.5rem;top:.5rem;width:1.25rem}.alert-badge,.section-header{align-items:center;display:flex}.section-header{justify-content:space-between;margin-bottom:1rem}.section-header h2{color:#1e293b;font-size:1.25rem}.reports-sidebar{background-color:#f8fafc;width:3000px}.reports-nav h3{font-size:.875rem}.report-nav-btn{border-radius:.25rem;color:#1e293b;display:block}.period-tab{border:1px solid #e2e8f0}.period-tab:first-child{border-radius:.25rem 0 0 .25rem}.period-tab:last-child{border-radius:0 .25rem .25rem 0}.period-tab.active{background-color:#e0e7ff;border-color:#c7d2fe}.period-inputs select{border:1px solid #d1d5db;border-radius:.25rem;flex:1 1;padding:.375rem .75rem}.date-input label{width:70px}.date-input input{border:1px solid #d1d5db;border-radius:.25rem;flex:1 1;padding:.375rem .75rem}.export-options{margin-top:1.5rem}.export-btn{background-color:#f1f5f9;border-radius:.25rem;display:block;padding:.5rem 1rem}.export-btn:hover{background-color:#e0e7ff}.report-header h2{margin-bottom:.5rem}.report-period{font-size:.875rem}.report-summary{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.summary-card{box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem}.summary-title{font-size:.875rem}.chart-container{box-shadow:0 1px 3px 0 #0000001a;margin-bottom:1.5rem}.bar-chart,.chart-container h3{margin-bottom:1rem}.chart-column{width:60px}.maintenance-bar{background-color:#ef4444}.pipes-color{background-color:#f59e0b}.other-color{background-color:#a855f7}.pie-chart-placeholder{border-radius:50%;height:200px;margin:0 auto;overflow:hidden;position:relative;width:200px}.pie-segment.pipes{background-color:#f59e0b}.pie-segment.other{background-color:#a855f7}.data-table-container{box-shadow:0 1px 3px 0 #0000001a;margin-bottom:1.5rem;overflow-x:auto;padding:1.5rem}.data-table-container h3{color:#1e293b;font-size:1.125rem;margin-bottom:1rem}.setup-container{background-color:#f0f9ff;display:flex;flex-direction:column;min-height:100vh;padding:2rem}.setup-header{margin-bottom:2rem;text-align:center}.setup-header h1{color:#1e293b;font-size:1.875rem;margin-bottom:2rem}.progress-indicator{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:600px}.step-indicator{flex-direction:column;position:relative;z-index:1}.step-indicator,.step-number{align-items:center;display:flex}.step-number{background-color:#fff;border:2px solid #e2e8f0;border-radius:50%;color:#64748b;font-weight:600;height:2.5rem;justify-content:center;margin-bottom:.5rem;width:2.5rem}.step-indicator.active .step-number{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.step-label{color:#64748b;font-size:.875rem}.step-indicator.active .step-label{color:#1e293b;font-weight:500}.step-connector{background-color:#e2e8f0;flex:1 1;height:2px;margin:0 .5rem;position:relative;top:-1.25rem;z-index:0}.setup-content{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;margin:0 auto;max-width:800px;padding:2rem}.setup-step{margin:0 auto;max-width:600px}.setup-step h2{color:#1e293b;font-size:1.5rem;margin-bottom:.5rem}.step-description{color:#64748b;margin-bottom:2rem}.step-actions{border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.finish-btn,.next-btn{background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.finish-btn:hover,.next-btn:hover{background-color:#2563eb}.back-btn{background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;color:#64748b;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.back-btn:hover{background-color:#f8fafc}.checkbox-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.checkbox-list label{align-items:center;display:flex;gap:.5rem}.checkbox-list input[type=checkbox]{width:auto}@media (max-width:1024px){.dashboard-content{flex-direction:column}.sidebar{border-bottom:1px solid #e2e8f0;border-right:none;padding:.75rem 1.5rem;width:100%}.nav-menu ul{display:flex;flex-wrap:wrap;gap:.5rem}.nav-link{padding:.5rem .75rem}.reports-content{flex-direction:column}.reports-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;width:100%}}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:1rem}.user-controls{justify-content:space-between;width:100%}.village-selector{align-items:flex-start;flex-direction:column}.report-summary,.stats-grid{grid-template-columns:1fr}.billing-period-selector,.payment-period-selector,.period-selector{align-items:flex-start;flex-direction:column;gap:1rem}.billing-stats,.payment-stats,.reading-stats{flex-wrap:wrap;margin-left:0}.form-row{flex-direction:column}.search-bar input{width:100%}.billing-filters,.equipment-filters,.maintenance-filters,.meter-filters,.payment-filters,.reading-filters,.user-filters{align-items:flex-start;flex-direction:column}.bar-chart{justify-content:flex-start;overflow-x:auto;padding-bottom:1rem}.modal-container{width:90%}}@media (max-width:480px){.setup-container{padding:1rem}.step-actions{flex-direction:column;gap:.75rem}.back-btn,.finish-btn,.next-btn{width:100%}.progress-indicator{flex-direction:column;gap:1rem}.step-connector{height:1.5rem;margin:0;top:0;width:2px}}.settings-container{display:flex;flex-direction:column;min-height:100vh}.settings-header{align-items:center;background-color:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.settings-content{background-color:#f8fafc;flex:1 1;padding:1.5rem}.settings-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;overflow:hidden}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.card-header h2{color:#1e293b;font-size:1.25rem}.settings-card form{padding:1.5rem}.form-group textarea{border:1px solid #d1d5db;border-radius:.375rem;min-height:100px;padding:.5rem .75rem;resize:vertical;width:100%}.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d;outline:none}.form-group select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem .75rem;width:100%}.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d;outline:none}.reports-container{background-color:#f8fafc;display:flex;flex-direction:column;min-height:100vh}.reports-content{display:flex;flex:1 1;overflow:hidden}.reports-sidebar{background-color:#fff;border-right:1px solid #e2e8f0;box-shadow:2px 0 5px #00000008;width:40%}.report-main,.reports-sidebar{overflow-y:auto;padding:1.5rem}.report-main{flex:1 1}.page-header{background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 4px #00000008;justify-content:space-between;padding:1rem 1.5rem}.header-content,.page-header{align-items:center;display:flex}.header-content{gap:1rem}.header-actions{align-items:center;display:flex;gap:1.5rem}.current-village{align-items:center;color:#64748b;display:flex;font-size:.9rem;gap:.5rem}.village-name{color:#1e40af;font-weight:600}.back-link{align-items:center;color:#64748b;display:flex;font-size:.9rem;text-decoration:none;transition:all .2s}.back-link:hover{color:#1e40af}.print-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;color:#1e293b;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.print-btn:hover{background-color:#f8fafc;border-color:#cbd5e1}.icon{font-size:1.1rem}.reports-nav h3{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;margin-top:1.5rem;text-transform:uppercase}.reports-nav ul{list-style:none;margin-bottom:1.5rem}.report-nav-btn{align-items:center;background:none;border:none;border-radius:.375rem;color:#475569;cursor:pointer;display:flex;font-size:.95rem;margin-bottom:.25rem;padding:.75rem 1rem;text-align:left;transition:all .2s;width:100%}.report-nav-btn:hover{background-color:#f1f5f9;color:#1e40af}.report-nav-btn.active{background-color:#e0e7ff;color:#1e40af;font-weight:500}.nav-icon{font-size:1.1rem;margin-right:.75rem}.period-type-tabs{background-color:#f1f5f9;border-radius:.375rem;display:flex;margin-bottom:.75rem;padding:.25rem}.period-tab{background:none;border:none;border-radius:.25rem;color:#475569;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem;text-align:center;transition:all .2s}.period-tab.active{background-color:#fff;box-shadow:0 1px 2px #0000000d;color:#1e40af}.period-inputs{display:flex;gap:.5rem;margin-bottom:1rem}.select-styled{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25rem;border:1px solid #e2e8f0;border-radius:.375rem;color:#1e293b;flex:1 1;font-size:.875rem;padding:.5rem 2rem .5rem .5rem}.date-input{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.date-input label{color:#64748b;font-size:.875rem;width:60px}.date-picker{border:1px solid #e2e8f0;border-radius:.375rem;color:#1e293b;flex:1 1;font-size:.875rem;padding:.5rem}.custom-period{flex-direction:column}.export-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;color:#475569;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;margin-bottom:.5rem;padding:.75rem 1rem;text-align:left;transition:all .2s;width:100%}.export-btn:hover{background-color:#f8fafc;border-color:#cbd5e1;color:#1e40af}.report-header{border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:1.5rem}.report-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.report-period{color:#64748b;font-size:.95rem}.report-summary{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-bottom:2rem}.summary-card{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;padding:1.25rem;transition:all .3s}.summary-card:hover{border-color:#cbd5e1;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.summary-icon{color:#3b82f6;font-size:2rem;margin-right:1rem}.summary-info{flex:1 1}.summary-title{color:#64748b;font-size:.85rem;font-weight:500;margin-bottom:.5rem}.summary-value{color:#1e293b;font-size:1.5rem;font-weight:700}.chart-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:1.5rem}.chart-container h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.bar-chart{align-items:flex-end;display:flex;height:250px;justify-content:space-around;margin-bottom:1.5rem}.user-chart{justify-content:flex-start;overflow-x:auto;padding-bottom:.5rem}.chart-column{align-items:center;display:flex;flex-direction:column;margin:0 .5%;min-width:60px}.chart-bar-container{align-items:flex-end;display:flex;height:200px;position:relative;width:50px}.chart-bar{border-radius:4px 4px 0 0;position:relative;transition:height .5s ease;width:50px}.bar-value{color:#475569;font-size:.75rem;font-weight:500;left:50%;position:absolute;top:-25px;transform:translateX(-50%);white-space:nowrap}.chart-label{color:#64748b;font-size:.8rem;margin-top:.75rem;max-width:80px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.usage-bar{background-color:#3b82f6}.income-bar{background-color:#10b981}.maintenance-bar{background-color:#f97316}.stacked-bar-chart{align-items:flex-end;display:flex;height:280px;justify-content:space-around;margin-bottom:1.5rem}.stacked-bar{display:flex;flex-direction:column;height:200px;position:relative;width:50px}.collected-bar{background-color:#10b981;bottom:0;position:absolute}.collected-bar,.pending-bar{border-radius:4px 4px 0 0;width:100%}.pending-bar{background-color:#f59e0b}.stacked-bar-labels{display:flex;flex-direction:column;gap:.25rem;left:50%;position:absolute;top:-55px;transform:translateX(-50%)}.collected-label,.pending-label{font-size:.75rem;font-weight:500;white-space:nowrap}.collected-label{color:#10b981}.pending-label{color:#f59e0b}.chart-row{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:2rem}.half-width{flex:1 1;min-width:300px}.pie-chart-container{align-items:center;display:flex;flex-direction:column}.pie-chart{border-radius:50%;height:200px;margin:0 auto 2rem;overflow:hidden;position:relative;width:200px}.pie-segment{height:100%;position:absolute;transform-origin:50% 50%;width:100%}.pie-segment.pumps{background-color:#3b82f6}.pie-segment.chlorinator{background-color:#10b981}.pie-segment.pipes{background-color:#f97316}.pie-segment.other{background-color:#8b5cf6}.pie-legend{max-width:300px;width:100%}.chart-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.legend-item{align-items:center;display:flex;gap:.5rem;margin-right:1rem}.legend-color{border-radius:3px;height:12px;width:12px}.legend-label{color:#475569;font-size:.75rem}.usage-color{background-color:#3b82f6}.collected-color,.income-color{background-color:#10b981}.pending-color{background-color:#f59e0b}.pumps-color{background-color:#3b82f6}.chlorinator-color{background-color:#10b981}.pipes-color{background-color:#f97316}.other-color{background-color:#8b5cf6}.data-table-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;overflow:hidden}.table-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.table-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.table-actions{align-items:center;display:flex;gap:.75rem}.search-input{width:200px}.btn-export,.search-input{border:1px solid #e2e8f0;border-radius:.375rem;font-size:.875rem;padding:.5rem .75rem}.btn-export{align-items:center;background-color:#fff;color:#475569;cursor:pointer;display:flex;gap:.5rem;transition:all .2s}.btn-export:hover{background-color:#f8fafc;border-color:#cbd5e1;color:#1e40af}.table-responsive{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e2e8f0;font-size:.9rem;padding:.75rem 1rem;text-align:left}.data-table th{color:#64748b;font-weight:600}.data-table tbody tr:hover,.data-table th{background-color:#f8fafc}.data-table tfoot{font-weight:600}.data-table tfoot th{background-color:#f1f5f9;color:#1e293b}.progress-bar{background-color:#f1f5f9;border-radius:4px;height:8px;overflow:hidden;position:relative;width:100%}.progress-value{background-color:#3b82f6;border-radius:4px;height:100%}.progress-bar span{color:#475569;font-size:.75rem;font-weight:500;position:absolute;right:0;top:-1px}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px}.loading-spinner{animation:spin 1s ease-in-out infinite;border:4px solid #3b82f633;border-radius:50%;border-top-color:#3b82f6;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{color:#64748b;font-size:.9rem}@media (max-width:1024px){.reports-content{flex-direction:column}.reports-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;padding:1rem;width:100%}.period-type-tabs{margin:0 auto;max-width:600px}.report-summary{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.chart-row{flex-direction:column;gap:1rem}.half-width{width:100%}}@media (max-width:768px){.header-actions,.header-content{align-items:flex-start;flex-direction:column;gap:.5rem}.header-actions{margin-top:.5rem;width:100%}.report-summary{grid-template-columns:1fr}.summary-card{max-width:100%}.bar-chart{height:200px;justify-content:flex-start;overflow-x:auto;padding-bottom:1rem}.chart-column{min-width:50px}.table-header{align-items:flex-start;flex-direction:column;gap:.75rem}.search-input,.table-actions{width:100%}.btn-export{flex:1 1;justify-content:center}.stacked-bar-labels{top:-65px}}@media (max-width:480px){.period-inputs{flex-direction:column}.select-styled{width:100%}.date-input{align-items:flex-start;flex-direction:column}.date-picker{width:100%}.export-options{display:flex;gap:.5rem}.export-btn{flex:1 1;font-size:.75rem;justify-content:center;margin-bottom:0;padding:.5rem}.chart-bar-container{height:150px;width:40px}.chart-bar{width:40px}.stacked-bar{height:150px;width:40px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.report-content{animation:fadeIn .5s ease}.summary-card{animation:slideUp .5s ease;animation-fill-mode:both}.summary-card:first-child{animation-delay:.1s}.summary-card:nth-child(2){animation-delay:.2s}.summary-card:nth-child(3){animation-delay:.3s}.summary-card:nth-child(4){animation-delay:.4s}.chart-column:hover .chart-bar{filter:brightness(1.1);transform:scaleY(1.05);transform-origin:bottom;transition:all .3s}.chart-column:hover .chart-label{color:#1e40af;font-weight:500;transition:all .3s}.data-table tbody tr:hover{background-color:#f1f5f9;transition:background-color .2s}@media print{.btn-export,.export-btn,.header-actions,.page-header,.print-btn,.reports-sidebar,.table-actions{display:none!important}.reports-content{display:block}.report-main{width:100%}.chart-container,.data-table-container,.summary-card{break-inside:avoid;page-break-inside:avoid}.chart-bar,.collected-bar,.pending-bar,.pie-segment{-webkit-print-color-adjust:exact;print-color-adjust:exact}.legend-color{border:1px solid #ddd}}.readings-list{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:20px 0;max-height:calc(100vh - 300px);overflow-x:auto;overflow-y:auto}.readings-table{border-collapse:collapse;position:relative;width:100%}.readings-table thead{background-color:#f8fafc;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.readings-table thead th{background-color:#f8fafc;border-bottom:2px solid #dee2e6;color:#495057;font-size:14px;font-weight:600;padding:12px 8px;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:101}.readings-table thead.scrolled{box-shadow:0 2px 8px #00000026}.readings-table td{background-color:#fff;border-bottom:1px solid #dee2e6;font-size:14px;padding:10px 8px;vertical-align:middle}.readings-table tbody tr:hover td{background-color:#f8f9fa}.readings-table td:first-child,.readings-table th:first-child{min-width:110px;width:110px}.readings-table td:nth-child(2),.readings-table th:nth-child(2){min-width:180px;width:180px}.readings-table td:nth-child(3),.readings-table th:nth-child(3){min-width:200px;width:200px}.readings-table td:nth-child(4),.readings-table td:nth-child(5),.readings-table td:nth-child(6),.readings-table th:nth-child(4),.readings-table th:nth-child(5),.readings-table th:nth-child(6){min-width:90px;text-align:right;width:90px}.readings-table td:nth-child(7),.readings-table th:nth-child(7){min-width:100px;width:100px}.readings-table td:nth-child(8),.readings-table th:nth-child(8){min-width:120px;width:120px}.readings-table td:nth-child(9),.readings-table th:nth-child(9){min-width:60px;text-align:center;width:60px}.readings-table td:nth-child(10),.readings-table th:nth-child(10){min-width:100px;text-align:center;width:100px}.readings-table td:nth-child(11),.readings-table th:nth-child(11){min-width:120px;text-align:center;width:120px}@media (max-width:768px){.readings-list{max-height:calc(100vh - 200px)}.readings-table{font-size:12px}.readings-table td,.readings-table th{padding:8px 4px}.readings-table td:nth-child(2),.readings-table td:nth-child(3),.readings-table th:nth-child(2),.readings-table th:nth-child(3){min-width:150px;width:150px}}
/*# sourceMappingURL=main.1fb5d039.css.map*/