.login-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem}.login-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text);margin:0 0 .25rem;text-align:center}.login-subtitle{color:var(--text-muted);font-size:.95rem;margin:0 0 1.5rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1rem}.login-error{padding:.75rem 1rem;background:var(--danger-soft);color:var(--danger);border-radius:var(--radius);font-size:.9rem}.login-field label{display:block;font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:.35rem}.login-field input{width:100%;padding:.65rem 1rem;font-size:.95rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.login-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.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{margin:1.5rem 0 0;padding-top:1rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);text-align:center}.login-hint strong{color:var(--text)}.login-db-status{margin:.75rem 0 0;font-size:.75rem;color:var(--text-muted)}.login-db-status.db-online{color:var(--accent)}.login-db-status.db-offline,.login-db-status .db-offline{color:var(--danger)}.topnav{display:flex;align-items:center;gap:1rem;padding:0 1.5rem;height:56px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 1px 4px #0000000a;position:sticky;top:0;z-index:50}.topnav-brand{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--accent);background:none;border:none;padding:0;white-space:nowrap}.topnav-links{display:flex;gap:.25rem;margin-left:1.5rem}.topnav-link{padding:.4rem .85rem;font-size:.9rem;font-weight:500;border:none;background:transparent;color:var(--text-muted);border-radius:8px;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{margin-left:auto;display:flex;align-items:center;gap:.75rem}.topnav-user{font-size:.85rem;color:var(--text-muted)}.lang-select{padding:.25rem .5rem;font-size:.82rem;font-weight:600;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer}.login-lang-row{display:flex;justify-content:flex-end;margin-bottom:.5rem}.app-main{max-width:1200px;margin:0 auto;padding:1.5rem}.page-content{display:flex;flex-direction:column;gap:1rem}.page-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.section-heading{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin:.75rem 0 .5rem}.dashboard{padding:2rem 0}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:0}.dashboard-subtitle{color:var(--text-muted);font-size:1rem;margin:.25rem 0 0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.module-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.5rem;text-align:left;box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s,transform .15s;cursor:pointer;display:flex;flex-direction:column;gap:.75rem}.module-card:hover{box-shadow:0 8px 30px #1a19171a;border-color:var(--accent);transform:translateY(-2px)}.module-icon{color:var(--accent)}.module-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:0}.module-desc{color:var(--text-muted);font-size:.9rem;margin:0;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{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;border-bottom:1px solid var(--border)}.card-section-header h3{margin:0;font-size:1rem;font-weight:700}.bm-layout{display:flex;gap:1.25rem;align-items:flex-start}.bm-sidebar{width:300px;flex-shrink:0}.bm-main{flex:1;min-width:0}.group-list{list-style:none;margin:0;padding:0;max-height:400px;overflow-y:auto}.group-empty{padding:1.5rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.group-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border)}.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{display:flex;flex-direction:column;gap:.05rem;min-width:0}.group-item-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-item-count{font-size:.78rem;color:var(--text-muted)}.group-item-actions{display:flex;gap:.2rem;flex-shrink:0}.btn-icon{width:1.6rem;height:1.6rem;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:6px;font-size:.82rem;cursor:pointer;color:var(--text-muted);transition:background .15s,color .15s}.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{width:100%;border-collapse:collapse}.renter-table th{text-align:left;padding:.65rem 1rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg);font-weight:600}.renter-table td{padding:.7rem 1rem;font-size:.92rem;border-bottom:1px solid var(--border);vertical-align:middle}.renter-table tr:last-child td{border-bottom:none}.renter-table tr:hover td{background:#fafaf8}.renter-name{font-weight:600}.renter-price{font-weight:600;color:var(--accent)}.renter-actions{display:flex;gap:.3rem}.th-payment{text-align:center}.td-payment{text-align:center;vertical-align:middle}.payment-amount-main{font-weight:600;color:var(--accent);font-size:.92rem}.total-amount{font-weight:700;color:var(--accent);font-size:.95rem}.bill-input-group{display:flex;align-items:center;gap:.3rem;justify-content:center}.bill-input{width:80px;padding:.3rem .5rem;font-size:.85rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);text-align:right}.bill-input:focus{outline:none;border-color:var(--accent)}.td-wa-status{font-size:.78rem;white-space:nowrap}.wa-sent-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:.75rem;font-weight:600;border-radius:999px;background:var(--accent-soft);color:var(--accent)}.report-block-total{font-size:.88rem;margin-top:.5rem;color:var(--text)}.receipt-buttons{display:flex;gap:.3rem;flex-wrap:wrap}.pm-controls{display:flex;gap:1rem;padding:.85rem 1.25rem;align-items:center;flex-wrap:wrap}.pm-control-group{display:flex;align-items:center;gap:.4rem}.pm-control-group label{font-size:.85rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.pm-control-group select{padding:.4rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-weight:500}.badge-toggle{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.78rem;font-weight:600;border:none;border-radius:999px;cursor:pointer;transition:background .2s,color .2s}.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{display:inline-block;padding:.2rem .55rem;font-size:.75rem;font-weight:600;border-radius:999px}.badge-static--paid{background:var(--accent-soft);color:var(--accent)}.badge-static--unpaid{background:var(--danger-soft);color:var(--danger)}.btn-receipt{display:inline-flex;align-items:center;padding:.25rem .55rem;font-size:.75rem;font-weight:600;border:1.5px solid var(--accent);border-radius:6px;background:var(--accent-soft);color:var(--accent);cursor:pointer;transition:background .2s,color .2s}.btn-receipt:hover{background:var(--accent);color:#fff}.btn-whatsapp{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.78rem;font-weight:600;border:1.5px solid #25d366;border-radius:6px;background:#e8fce8;color:#128c7e;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}.btn-whatsapp:hover{background:#25d366;color:#fff}.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.report-block-card{text-align:left;cursor:pointer;padding:1.25rem;border:2px solid transparent;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);font-size:1.1rem;font-weight:700;margin:0 0 .25rem}.report-block-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.report-type-grid{display:flex;gap:.75rem}.report-type{display:flex;flex-direction:column;gap:.1rem;background:var(--bg);border-radius:8px;padding:.5rem .65rem;flex:1}.report-type-label{font-size:.72rem;text-transform:uppercase;font-weight:600;color:var(--text-muted);letter-spacing:.03em}.report-type-paid{font-size:.82rem;font-weight:600;color:var(--accent)}.report-type-unpaid{font-size:.82rem;font-weight:600;color:var(--danger)}.drill-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1.15rem;font-size:.92rem;font-weight:600;border:none;border-radius:var(--radius);transition:background .2s,color .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--border);color:var(--text)}.btn-danger{background:transparent;color:var(--danger)}.btn-danger:hover{background:var(--danger-soft)}.btn-sm{padding:.3rem .7rem;font-size:.82rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.empty-state-inline{text-align:center;color:var(--text-muted);padding:2rem 1rem}.error-banner{padding:.85rem 1rem;background:var(--danger-soft);color:var(--danger);border-radius:var(--radius);display:flex;align-items:center;justify-content:space-between}.dismiss-btn{background:none;border:none;cursor:pointer;text-decoration:underline;color:inherit;font-size:.85rem}.text-muted{color:var(--text-muted)}.text-sm{font-size:.82rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191766;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:100}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 20px 60px #1a191726;width:100%;max-width:420px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.15rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:0}.btn-close{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius)}.btn-close:hover{background:var(--border);color:var(--text)}.modal-form{padding:1.5rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.85rem;font-weight:500;color:var(--text);margin-bottom:.3rem}.field input,.field select,.field textarea{width:100%;padding:.6rem .9rem;font-size:.92rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem;padding-top:.85rem;border-top:1px solid var(--border)}@media (max-width: 768px){.topnav{flex-wrap:wrap;height:auto;padding:.75rem 1rem}.topnav-links{margin-left:0;width:100%;order:3}.bm-layout{flex-direction:column}.bm-sidebar{width:100%}.dashboard-grid,.report-grid{grid-template-columns:1fr}}:root{--bg: #f5f3f0;--surface: #ffffff;--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 rgba(26, 25, 23, .06);--font-sans: "DM Sans", system-ui, sans-serif;--font-display: "Fraunces", Georgia, serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-size:16px;color:var(--text);background:var(--bg);line-height:1.5}#root{min-height:100vh}button{font-family:var(--font-sans);cursor:pointer}input,select,textarea{font-family:var(--font-sans)}
