:root{--text:#1e293b;--text-h:#0f172a;--bg:#fff;--border:#e2e8f0;--code-bg:#f8f9fa;--accent:#1d4ed8;--accent-bg:#1d4ed81a;--accent-border:#1d4ed880;--social-bg:#f1f5f9cc;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.page-title{color:var(--text-h);margin:0;font-size:20px;font-weight:700}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.count-badge{color:#475569;margin-left:auto;font-size:14px}.row-2{gap:12px;display:flex}@media (width<=767px){.row-2{flex-direction:column;gap:0}}.overlay{z-index:1000;background:#000000a6;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=768px){.overlay{align-items:center}}.modal-box{border:1px solid var(--border);background:#fff;border-radius:12px 12px 0 0;width:100%;max-height:92vh;padding:20px 16px 32px;overflow-y:auto}@media (width>=768px){.modal-box{border-radius:12px;margin:0 auto}}.modal-title{color:var(--text-h);margin:0 0 16px;font-size:20px;font-weight:700}.modal-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.input-base{border:1px solid var(--border);width:100%;color:var(--text);box-sizing:border-box;background:#fff;border-radius:6px;outline:none;min-height:52px;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .2s}.input-base:focus{border-color:var(--accent)}select.input-base{appearance:auto}.btn{cursor:pointer;box-sizing:border-box;border:none;border-radius:6px;justify-content:center;align-items:center;gap:8px;font-family:inherit;transition:opacity .2s;display:inline-flex}.btn:hover{opacity:.9}.btn-primary{background:var(--accent);color:#fff;min-height:52px;padding:14px 20px;font-size:17px;font-weight:600}.btn-secondary{color:#334155;border:1px solid var(--border);background:#e2e8f0;min-height:52px;padding:14px 20px;font-size:17px}.btn-danger{color:#fff;background:#dc2626;min-height:52px;padding:14px 20px;font-size:17px;font-weight:600}.btn-ghost{color:#475569;background:0 0;border:none;min-height:44px;margin:0;padding:8px 14px;font-size:16px}.btn-ghost:hover{background:#0000000d}.btn-sm{min-height:40px;padding:8px 14px;font-size:14px}.section-label{color:#475569;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);margin-top:14px;margin-bottom:8px;padding-bottom:4px;font-size:13px;font-weight:700}.warn-box{color:#9a3412;background:#fff7ed;border:1px solid #fdba74;border-radius:6px;margin-bottom:14px;padding:12px 16px;font-size:15px}.muted{color:#475569;font-size:16px}.badge{white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:13px;font-weight:600;display:inline-block}.info-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:9px 0;display:flex}.info-row-label{color:#475569;flex-shrink:0;width:110px;padding-top:1px;font-size:14px}.info-row-value{color:var(--text-h);flex:1;font-size:16px;font-weight:500}.field-container{flex:1;margin-bottom:14px}.field-label{color:#475569;margin-bottom:6px;font-size:14px;font-weight:600;display:block}.field-error{color:#dc2626;margin-top:5px;font-size:14px}.card{border:1px solid var(--border);background:#fff;border-radius:8px;margin-bottom:10px;padding:14px 16px}.card-title{color:var(--text-h);margin-bottom:6px;font-size:17px;font-weight:600}.card-meta{color:#475569;font-size:14px;line-height:1.7}.card-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.tbl{border-collapse:collapse;width:100%;font-size:15px}.tbl thead{background:#f8f9fa}.tbl th{text-align:left;color:#475569;border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 12px;font-size:14px;font-weight:600}.tbl td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:11px 12px;font-size:15px}.tbl tbody tr:nth-child(2n){background:#fff}.tbl tbody tr:nth-child(odd){background:#f1f5f9}.tv-wrap{border-top:1px solid var(--border);margin-top:16px;padding-top:14px}.tv-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.tv-header-left{align-items:center;gap:8px;display:flex}.tv-title{color:var(--text-h);font-size:13px;font-weight:700}.tv-count-badge{color:#475569;background:#e2e8f0;border-radius:10px;padding:1px 8px;font-size:11px}.tv-member-row{background:#fff;border-radius:6px;align-items:center;gap:10px;margin-bottom:4px;padding:8px 10px;display:flex}.tv-avatar{text-align:center;flex-shrink:0;width:24px;font-size:16px}.tv-member-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.tv-member-name{color:var(--text-h);font-size:13px;font-weight:600}.tv-member-meta{color:#475569;flex-wrap:wrap;gap:8px;margin-top:2px;font-size:11px;display:flex}.tv-toast{border:1px solid;border-radius:6px;margin-bottom:10px;padding:8px 12px;font-size:12px}.tv-dang-o-badge{color:#34d399;background:#064e3b;border-radius:4px;margin-right:4px;padding:2px 8px;font-size:10px;font-weight:700}.tv-da-ra-badge{color:#475569;background:#e2e8f0;border-radius:4px;margin-right:4px;padding:2px 6px;font-size:10px}.tv-quan-he-badge{color:#93c5fd;background:#1e3a5f;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.tv-btn-leave{color:#fed7aa;background:#431407}.tv-empty-text{color:#475569;padding:8px 0;font-size:12px;font-style:italic}.tv-note-box{border:1px solid var(--border);color:#475569;background:#e2e8f0;border-radius:6px;margin:8px 0 12px;padding:8px 12px;font-size:12px}.phong-badge{color:#93c5fd;background:#1e3a5f;border-radius:4px;margin-right:4px;padding:2px 8px;font-size:11px;display:inline-block}.form-row{gap:12px;display:flex}.section-label{color:#475569;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.info-row{border-bottom:1px solid var(--border);gap:8px;padding:6px 0;display:flex}.info-row-label{color:#475569;flex-shrink:0;width:100px;font-size:12px}.info-row-value{color:var(--text);font-size:13px;font-weight:500}.state-box{border:1px dashed var(--border);text-align:center;color:#475569;border-radius:10px;margin-bottom:16px;padding:48px 24px}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-bottom:20px;display:grid}.dv-card{border:1px solid var(--border);background:#fff;border-radius:10px;flex-direction:column;gap:8px;padding:20px;display:flex}.note-box{border:1px solid var(--border);background:#fff;border-radius:8px;padding:14px 18px}.current-box{border:1px solid var(--border);background:#fff;border-radius:6px;align-items:baseline;gap:8px;margin-bottom:20px;padding:10px 14px;display:flex}.info-box{border:1px solid var(--border);background:#fff;border-radius:6px;margin-bottom:14px;padding:4px 12px}.login-wrap{color:#fff;background-color:#0d1117;justify-content:center;align-items:center;height:100vh;padding:20px;font-family:Arial,sans-serif;display:flex}.login-card{background-color:#161b22;border:1px solid #30363d;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 25px #00000080}.login-input{color:#fff;box-sizing:border-box;background-color:#0d1117;border:1px solid #30363d;border-radius:6px;width:100%;padding:12px;font-size:1rem}.login-input:focus{border-color:#1d4ed8;outline:none}.login-alert{color:#f85149;text-align:center;background-color:#f8514926;border:1px solid #f85149;border-radius:6px;margin-bottom:20px;padding:10px;font-size:.9rem}.flex-col{flex-direction:column;display:flex}.gap-4{gap:16px}.toast{border:1px solid;border-radius:8px;margin-bottom:14px;padding:12px 16px;font-size:16px}.toast-success{color:#6ee7b7;background:#064e3b;border-color:#10b981}.toast-error{color:#fca5a5;background:#7f1d1d;border-color:#ef4444}.search-input-wrapper{margin-bottom:12px;position:relative}.search-input-wrapper .input-base{padding-left:44px}.search-icon{color:#475569;pointer-events:none;font-size:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-clear-btn{color:#475569;cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.tab-btn{color:#475569;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #cbd5e1;border-radius:20px;align-items:center;gap:6px;min-height:40px;padding:8px 14px;font-family:inherit;font-size:14px;font-weight:400;transition:all .2s;display:flex}.tab-btn:hover{color:#1d4ed8;border-color:#1d4ed8}.tab-btn.active{color:#fff;background:#1d4ed8;border:none;font-weight:600}.tab-badge{text-align:center;border-radius:10px;min-width:20px;padding:0 7px;font-size:12px;font-weight:600;line-height:20px}.tab-btn .tab-badge{color:#fff;background:#ffffff40}.tab-btn:not(.active) .tab-badge{color:#475569;background:#e2e8f0}@media (width<=768px){.tab-btn{padding:8px 12px;font-size:13px}}.empty-state{text-align:center;color:#475569;padding:60px 20px}.empty-state-icon{margin-bottom:12px;font-size:48px}.empty-state-text{color:#475569;margin-bottom:6px;font-size:17px}.table-responsive{display:block;overflow-x:auto}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:#f1f5f9}.table-responsive::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.rental-card{background:#fff;border-radius:12px;overflow:hidden}.rental-card-header{cursor:pointer;padding:14px 16px}.rental-card-title{color:#1e293b;letter-spacing:-.02em;font-size:20px;font-weight:800}.rental-card-khu{color:#475569;margin-left:8px;font-size:14px}.rental-card-content{align-items:center;gap:8px;margin-bottom:10px;display:flex}.rental-card-avatar{font-size:16px}.rental-card-name{color:#1e293b;font-size:17px;font-weight:600}.rental-card-phone{color:#475569;font-size:14px}.rental-card-chips{flex-wrap:wrap;gap:8px;display:flex}.rental-card-alert{color:#fed7aa;background:#431407;border-radius:8px;align-items:center;gap:8px;margin-top:10px;padding:8px 12px;font-size:14px;display:flex}.rental-card-alert.debt{color:#fca5a5;background:#4a0000}.rental-card-deposit{color:#475569;align-items:center;gap:6px;margin-top:8px;font-size:13px;display:flex}.rental-card-deposit-amount{color:#34d399;font-size:14px;font-weight:600}.rental-card-footer{background:#f1f5f9;border-top:1px solid #e2e8f0;display:flex}.rental-card-footer.inactive{color:#475569;background:#fff;border-top:1px solid #e2e8f0;padding:10px 16px;font-size:13px;display:block}.btn-action{cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px;font-family:inherit;font-size:11px;font-weight:600;transition:background-color .2s;display:flex}.btn-action:active{background-color:#0000000d}.btn-action+.btn-action:before{content:"";background:#e2e8f0;width:1px;position:absolute;top:0;bottom:0;left:0}.btn-action-icon{font-size:20px}.info-chip{color:#475569;align-items:center;gap:4px;font-size:14px;display:inline-flex}.info-chip-icon{font-size:14px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.btn-close{color:#475569;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px 8px;font-size:24px;transition:color .2s;display:flex}.btn-close:hover{color:#1e293b}.info-box-header{border:1px solid var(--border);background:#fff;border-radius:8px;align-items:center;gap:12px;margin-bottom:14px;padding:10px 14px;display:inline-flex}.info-box-icon{flex-shrink:0;font-size:18px}.info-box-text{flex-direction:column;gap:2px;display:flex}.info-box-title{color:#1e293b;font-size:16px;font-weight:600}.info-box-subtitle{color:#475569;font-size:14px}.skeleton-pulse{animation:1.4s ease-in-out infinite bgtPulse}.action-btn{cursor:pointer;border:none;border-radius:6px;padding:14px 20px;font-family:inherit;font-weight:600;transition:opacity .2s}.action-btn:hover{opacity:.9}.action-btn-detail{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.action-btn-warning{color:#b45309;background:#fffbeb;border:1px solid #fde68a}.action-btn-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.action-btn-danger{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.phong-indicator{border-radius:2px;flex-shrink:0;width:3px;height:32px}.phong-name{color:#1e293b;font-size:14px;font-weight:700}.phong-khu{color:#475569;font-size:11px}.count-text{color:#475569;padding:8px 4px;font-size:12px}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;font-size:17px}body{-webkit-tap-highlight-color:transparent;margin:0;font-family:system-ui,-apple-system,sans-serif;line-height:1.5}h1,h2,h3{line-height:1.3}input,select,textarea{border-radius:8px;min-height:48px;padding:10px 12px;font-family:inherit;font-size:16px!important}button{cursor:pointer;min-height:44px;font-family:inherit;font-size:16px}input[type=checkbox],input[type=radio]{min-height:unset;accent-color:#1d4ed8;cursor:pointer;width:22px;height:22px}a{color:inherit;text-decoration:none}.scroll-smooth{-webkit-overflow-scrolling:touch;overflow-y:auto}@media (width<=768px){html{font-size:17px}table{-webkit-overflow-scrolling:touch;width:100%;display:block;overflow-x:auto}input[type=text],input[type=number],input[type=email],input[type=date],input[type=month],input[type=password],select,textarea{width:100%;min-height:52px;padding:12px 14px;font-size:16px!important}button{min-height:52px;padding:12px 20px;font-size:17px}button.btn-sm{min-height:40px;padding:8px 14px;font-size:15px}}
