.login-page{justify-content:center;align-items:center;min-height:80vh;padding:2rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow);padding:2rem}.login-title{font-family:var(--font-display);color:var(--text);text-align:center;margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-muted);text-align:center;margin:0 0 1.5rem;font-size:.95rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-error{background:var(--danger-soft);color:var(--danger);border-radius:var(--radius);padding:.75rem 1rem;font-size:.9rem}.login-field label{color:var(--text);margin-bottom:.35rem;font-size:.875rem;font-weight:500;display:block}.login-field input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;padding:.65rem 1rem;font-size:.95rem}.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.login-field input:disabled{opacity:.7;cursor:not-allowed}.login-submit{width:100%;margin-top:.5rem;padding:.75rem}.login-submit:disabled{opacity:.8;cursor:not-allowed}.login-hint{border-top:1px solid var(--border);color:var(--text-muted);text-align:center;margin:1.5rem 0 0;padding-top:1rem;font-size:.8rem}.login-hint strong{color:var(--text)}.login-db-status{color:var(--text-muted);margin:.75rem 0 0;font-size:.75rem}.login-db-status.db-online{color:var(--accent)}.login-db-status.db-offline,.login-db-status .db-offline{color:var(--danger)}.topnav{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:1rem;height:56px;padding:0 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000a}.topnav-brand{font-family:var(--font-display);color:var(--accent);white-space:nowrap;background:0 0;border:none;padding:0;font-size:1.15rem;font-weight:700}.topnav-links{gap:.25rem;margin-left:1.5rem;display:flex}.topnav-link{color:var(--text-muted);background:0 0;border:none;border-radius:8px;padding:.4rem .85rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.topnav-link:hover{background:var(--bg);color:var(--text)}.topnav-link--active{background:var(--accent-soft);color:var(--accent);font-weight:600}.topnav-right{align-items:center;gap:.75rem;margin-left:auto;display:flex}.topnav-user{color:var(--text-muted);font-size:.85rem}.lang-select{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;padding:.25rem .5rem;font-size:.82rem;font-weight:600}.login-lang-row{justify-content:flex-end;margin-bottom:.5rem;display:flex}.app-main{max-width:1200px;margin:0 auto;padding:1.5rem}.page-content{flex-direction:column;gap:1rem;display:flex}.page-title{font-family:var(--font-display);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.section-heading{font-family:var(--font-display);margin:.75rem 0 .5rem;font-size:1.1rem;font-weight:700}.dashboard{padding:2rem 0}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-title{font-family:var(--font-display);margin:0;font-size:2rem;font-weight:700}.dashboard-subtitle{color:var(--text-muted);margin:.25rem 0 0;font-size:1rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;display:grid}.module-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;box-shadow:var(--shadow);cursor:pointer;flex-direction:column;gap:.75rem;padding:2rem 1.5rem;transition:box-shadow .2s,border-color .2s,transform .15s;display:flex}.module-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 30px #1a19171a}.module-icon{color:var(--accent)}.module-title{font-family:var(--font-display);margin:0;font-size:1.15rem;font-weight:700}.module-desc{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.5}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.85rem 1.25rem;display:flex}.card-section-header h3{margin:0;font-size:1rem;font-weight:700}.bm-layout{align-items:flex-start;gap:1.25rem;display:flex}.bm-sidebar{flex-shrink:0;width:300px}.bm-main{flex:1;min-width:0}.group-list{max-height:400px;margin:0;padding:0;list-style:none;overflow-y:auto}.group-empty{text-align:center;color:var(--text-muted);padding:1.5rem 1rem;font-size:.9rem}.group-item{cursor:pointer;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.6rem 1rem;transition:background .15s;display:flex}.group-item:last-child{border-bottom:none}.group-item:hover{background:var(--bg)}.group-item--active{background:var(--accent-soft);border-left:3px solid var(--accent)}.group-item-info{flex-direction:column;gap:.05rem;min-width:0;display:flex}.group-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.group-item-count{color:var(--text-muted);font-size:.78rem}.group-item-actions{flex-shrink:0;gap:.2rem;display:flex}.btn-icon{cursor:pointer;width:1.6rem;height:1.6rem;color:var(--text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:.82rem;transition:background .15s,color .15s;display:flex}.btn-icon:hover{background:var(--border);color:var(--text)}.btn-icon--danger:hover{background:var(--danger-soft);color:var(--danger)}.renter-table-wrap{overflow-x:auto}.renter-table{border-collapse:collapse;width:100%}.renter-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg);padding:.65rem 1rem;font-size:.78rem;font-weight:600}.renter-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:.7rem 1rem;font-size:.92rem}.renter-table tr:last-child td{border-bottom:none}.renter-table tr:hover td{background:#fafaf8}.renter-name{font-weight:600}.renter-price{color:var(--accent);font-weight:600}.renter-actions{gap:.3rem;display:flex}.th-payment{text-align:center}.td-payment{text-align:center;vertical-align:middle}.payment-amount-main{color:var(--accent);font-size:.92rem;font-weight:600}.total-amount{color:var(--accent);font-size:.95rem;font-weight:700}.bill-input-group{justify-content:center;align-items:center;gap:.3rem;display:flex}.bill-input{border:1px solid var(--border);background:var(--surface);text-align:right;border-radius:6px;width:80px;padding:.3rem .5rem;font-size:.85rem}.bill-input:focus{border-color:var(--accent);outline:none}.td-wa-status{white-space:nowrap;font-size:.78rem}.wa-sent-badge{background:var(--accent-soft);color:var(--accent);border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.report-block-total{color:var(--text);margin-top:.5rem;font-size:.88rem}.receipt-buttons{flex-wrap:wrap;gap:.3rem;display:flex}.pm-controls{flex-wrap:wrap;align-items:center;gap:1rem;padding:.85rem 1.25rem;display:flex}.pm-control-group{align-items:center;gap:.4rem;display:flex}.pm-control-group label{color:var(--text-muted);white-space:nowrap;font-size:.85rem;font-weight:600}.pm-control-group select{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:.4rem .75rem;font-size:.9rem;font-weight:500}.badge-toggle{cursor:pointer;border:none;border-radius:999px;align-items:center;padding:.2rem .6rem;font-size:.78rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex}.badge-toggle--paid{background:var(--accent-soft);color:var(--accent)}.badge-toggle--paid:hover{background:var(--accent);color:#fff}.badge-toggle--unpaid{background:var(--danger-soft);color:var(--danger)}.badge-toggle--unpaid:hover{background:var(--danger);color:#fff}.badge-static{border-radius:999px;padding:.2rem .55rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-static--paid{background:var(--accent-soft);color:var(--accent)}.badge-static--unpaid{background:var(--danger-soft);color:var(--danger)}.btn-receipt{border:1.5px solid var(--accent);background:var(--accent-soft);color:var(--accent);cursor:pointer;border-radius:6px;align-items:center;padding:.25rem .55rem;font-size:.75rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex}.btn-receipt:hover{background:var(--accent);color:#fff}.btn-whatsapp{color:#128c7e;cursor:pointer;white-space:nowrap;background:#e8fce8;border:1.5px solid #25d366;border-radius:6px;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.78rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex}.btn-whatsapp:hover{color:#fff;background:#25d366}.report-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.report-block-card{text-align:left;cursor:pointer;border:2px solid #0000;padding:1.25rem;transition:border-color .2s,box-shadow .2s}.report-block-card:hover{border-color:var(--accent);box-shadow:0 6px 24px #1a191714}.report-block-card--active{border-color:var(--accent);background:#fafff8}.report-block-name{font-family:var(--font-display);margin:0 0 .25rem;font-size:1.1rem;font-weight:700}.report-block-meta{color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem}.report-type-grid{gap:.75rem;display:flex}.report-type{background:var(--bg);border-radius:8px;flex-direction:column;flex:1;gap:.1rem;padding:.5rem .65rem;display:flex}.report-type-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.03em;font-size:.72rem;font-weight:600}.report-type-paid{color:var(--accent);font-size:.82rem;font-weight:600}.report-type-unpaid{color:var(--danger);font-size:.82rem;font-weight:600}.drill-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.btn{border-radius:var(--radius);border:none;justify-content:center;align-items:center;padding:.55rem 1.15rem;font-size:.92rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{background:var(--border);color:var(--text)}.btn-danger{color:var(--danger);background:0 0}.btn-danger:hover{background:var(--danger-soft)}.btn-sm{padding:.3rem .7rem;font-size:.82rem}.empty-state{text-align:center;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:3rem 2rem}.empty-state-inline{text-align:center;color:var(--text-muted);padding:2rem 1rem}.error-banner{background:var(--danger-soft);color:var(--danger);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.85rem 1rem;display:flex}.dismiss-btn{cursor:pointer;color:inherit;background:0 0;border:none;font-size:.85rem;text-decoration:underline}.text-muted{color:var(--text-muted)}.text-sm{font-size:.82rem}.modal-overlay{z-index:100;background:#1a191766;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #1a191726}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.15rem 1.5rem;display:flex}.modal-header h2{font-family:var(--font-display);margin:0;font-size:1.15rem;font-weight:700}.btn-close{width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;display:flex}.btn-close:hover{background:var(--border);color:var(--text)}.modal-form{padding:1.5rem}.field{margin-bottom:1rem}.field label{color:var(--text);margin-bottom:.3rem;font-size:.85rem;font-weight:500;display:block}.field input,.field select,.field textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;padding:.6rem .9rem;font-size:.92rem}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);outline:none}.modal-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:.85rem;display:flex}.pm-tabs{border-bottom:2px solid var(--border);display:flex}.pm-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.55rem 1.25rem;font-size:.92rem;font-weight:600;transition:color .15s,border-color .15s}.pm-tab:hover{color:var(--text)}.pm-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.utility-import{flex-direction:column;gap:1rem;display:flex}.ui-controls{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.ui-control-group{align-items:center;gap:.5rem;display:flex}.ui-control-group label{color:var(--text-muted);font-size:.85rem;font-weight:600}.ui-type-toggle{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.ui-type-btn{background:var(--surface);color:var(--text-muted);cursor:pointer;border:none;padding:.4rem .9rem;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.ui-type-btn+.ui-type-btn{border-left:1px solid var(--border)}.ui-type-btn.active{background:var(--accent);color:#fff;font-weight:600}.ui-dropzone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);-webkit-user-select:none;user-select:none;padding:2.5rem 1.5rem;transition:border-color .2s,background .2s}.ui-dropzone:hover,.ui-dropzone--over{border-color:var(--accent);background:var(--accent-soft)}.ui-dropzone--has-file{border-style:solid;border-color:var(--accent)}.ui-dropzone-prompt{color:var(--text-muted);flex-direction:column;align-items:center;gap:.5rem;display:flex}.ui-dropzone-prompt p{margin:0}.ui-file-info{justify-content:center;align-items:center;gap:1rem;display:flex}.ui-file-icon{align-items:center;display:flex}.ui-file-details{text-align:left}.ui-file-name{word-break:break-all;font-size:.95rem;font-weight:600}.ui-actions{justify-content:flex-end;display:flex}.ui-progress{margin:.25rem 0}.ui-progress-label{color:var(--text-muted);margin-bottom:.4rem;font-size:.85rem}.ui-progress-bar{background:var(--border);border-radius:999px;height:8px;overflow:hidden}.ui-progress-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .25s}.ui-results{padding:1.25rem}.ui-results-summary{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.ui-unmatched{margin-top:1.25rem}.ui-unmatched-title{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:0 0 .5rem;font-size:.85rem;font-weight:600}.ui-confirm-details{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.4rem;padding:.85rem 1rem;font-size:.9rem;display:flex}.payment-status{white-space:nowrap;border-radius:999px;padding:.25rem .65rem;font-size:.78rem;font-weight:600;display:inline-block}.payment-status--fully-paid{color:#16a34a;background:#22c55e26}.payment-status--partially-paid{color:#b45309;background:#eab30826}.payment-status--not-paid{color:#dc2626;background:#ef444426}.upload-guide{margin-bottom:1.5rem;padding:1.25rem 1.5rem}.upload-guide-title{margin:0 0 1rem;font-size:.95rem;font-weight:600}.upload-guide-note{color:var(--text-muted);margin:.75rem 0 0;font-size:.82rem}.col-required{color:var(--success);font-size:.85rem}.upload-error-list{flex-direction:column;gap:.25rem;margin:.5rem 0 0;padding-left:1.25rem;display:flex}@media (width<=768px){.topnav{flex-wrap:wrap;height:auto;padding:.75rem 1rem}.topnav-links{order:3;width:100%;margin-left:0}.bm-layout{flex-direction:column}.bm-sidebar{width:100%}.dashboard-grid,.report-grid{grid-template-columns:1fr}}:root{--bg:#f5f3f0;--surface:#fff;--text:#1a1917;--text-muted:#5c5854;--accent:#2d6a4f;--accent-hover:#1b4332;--accent-soft:#d8f3dc;--border:#e8e4df;--danger:#9d0208;--danger-soft:#ffcdd2;--radius:12px;--shadow:0 2px 12px #1a19170f;--font-sans:"DM Sans", system-ui, sans-serif;--font-display:"Fraunces", Georgia, serif}*,:before,:after{box-sizing:border-box}body{min-height:100vh;font-family:var(--font-sans);color:var(--text);background:var(--bg);margin:0;font-size:16px;line-height:1.5}#root{min-height:100vh}button{font-family:var(--font-sans);cursor:pointer}input,select,textarea{font-family:var(--font-sans)}
