*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{width:100%;min-height:100vh}.layout{background:#f5f7fa;min-height:100vh}.layout-header{z-index:10;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:28px;padding:12px 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 2px #00000008}.brand{cursor:pointer;align-items:center;gap:10px;display:flex}.brand-mark{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:8px;place-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:grid}.brand-name{color:#111827;font-size:15px;font-weight:600}.layout-nav{flex:1;gap:4px;display:flex}.nav-link{color:#4b5563;border-radius:6px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.nav-link:hover{color:#111827;background:#f3f4f6}.nav-link.active{color:#4f46e5;background:#eef2ff}.layout-user{align-items:center;gap:12px;display:flex}.user-email{color:#6b7280;font-size:13px}.logout-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:6px 14px;font-size:13px}.logout-btn:hover{background:#f9fafb}.layout-main{max-width:1280px;margin:0 auto;padding:24px}.page-title{color:#111827;margin:0 0 16px;font-size:22px}@media (width<=720px){.layout-header{flex-wrap:wrap;gap:12px}.layout-nav{flex-basis:100%;order:3;overflow-x:auto}.brand-name{display:none}}.dashboard-page{flex-direction:column;gap:20px;display:flex}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.stat-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px;transition:all .15s}.stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.stat-card.tone-warn{border-left:4px solid #f59e0b}.stat-card.tone-danger{border-left:4px solid #ef4444}.stat-card.tone-good{border-left:4px solid #10b981}.stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.stat-value{color:#111827;margin-top:6px;font-size:24px;font-weight:700}.panel{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.panel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.panel-header h2{color:#111827;margin:0;font-size:16px}.link-btn{color:#4f46e5;cursor:pointer;background:0 0;border:none;font-size:13px}.mini-table{border-collapse:collapse;width:100%}.mini-table th,.mini-table td{text-align:left;border-bottom:1px solid #f3f4f6;padding:10px 8px;font-size:14px}.mini-table th{color:#6b7280;text-transform:uppercase;font-size:12px;font-weight:500}.mini-table tr.clickable:hover{cursor:pointer;background:#fafafa}.empty-mini{text-align:center;color:#9ca3af;padding:16px}.customer-form{padding:24px}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}@media (width<=500px){.form-row{grid-template-columns:1fr}}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:#374151;font-size:14px;font-weight:500}.form-field input,.form-field select{border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-field input:focus,.form-field select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-field input.error,.form-field select.error{border-color:#ef4444}.error-text{color:#ef4444;font-size:12px}.checkbox-field{justify-content:center}.checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;display:flex}.btn-cancel,.btn-save{cursor:pointer;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.btn-cancel:hover{background:#f9fafb}.info-banner{color:#075985;background:#e0f2fe;border-radius:6px;margin-top:10px;padding:10px 14px;font-size:13px}.error-banner{color:#991b1b;background:#fee2e2;border-radius:6px;margin-bottom:10px;padding:10px 14px;font-size:14px}.units-page{flex-direction:column;gap:16px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-input,.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px;font-size:14px}.search-input{min-width:240px}.add-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:6px;margin-left:auto;padding:8px 16px;font-size:14px;font-weight:500}.add-btn:hover{background:#4338ca}.error-banner{color:#991b1b;background:#fee2e2;border-radius:6px;padding:10px 14px;font-size:14px}.table-container{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid #f3f4f6;padding:12px 14px;font-size:14px}.data-table th{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;background:#fafafa;font-size:12px;font-weight:500}.data-table tbody tr:hover{background:#fafafa}.data-table tbody tr:last-child td{border-bottom:none}.mono{font-family:ui-monospace,SFMono-Regular,monospace}.empty{text-align:center;color:#9ca3af;padding:32px}.pill{text-transform:capitalize;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:500}.pill.vacant{color:#065f46;background:#d1fae5}.pill.occupied{color:#1e40af;background:#dbeafe}.pill.maintenance{color:#92400e;background:#fef3c7}.link-btn{color:#4f46e5;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:13px}.link-btn:hover{text-decoration:underline}.link-btn.danger{color:#ef4444}.loading{text-align:center;color:#6b7280;padding:40px}.pill.paid{color:#065f46;background:#d1fae5}.pill.pending{color:#3730a3;background:#e0e7ff}.pill.overdue{color:#991b1b;background:#fee2e2}.pill.partial{color:#92400e;background:#fef3c7}.pill.active,.pill.renewed{color:#1e40af;background:#dbeafe}.pill.expired,.pill.cancelled{color:#991b1b;background:#fee2e2}.pill.finished{color:#374151;background:#f3f4f6}.clickable{cursor:pointer}.detail-container{background:#f3f4f6;min-height:100vh}.detail-header{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.back-link{color:#fff;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:8px 0;font-size:14px;transition:opacity .2s;display:flex}.back-link:hover{opacity:.8}.header-actions{align-items:center;gap:12px;display:flex}.action-dropdown{position:relative}.action-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:all .2s}.action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.dropdown-menu{z-index:100;background:#fff;border-radius:8px;min-width:180px;margin-top:8px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 10px 40px #0003}.dropdown-item{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:12px 16px;font-size:14px;transition:background .2s;display:block}.dropdown-item:hover{background:#f3f4f6}.dropdown-item.renew{color:#16a34a}.dropdown-item.renew:hover{background:#dcfce7}.dropdown-item.finish{color:#2563eb}.dropdown-item.finish:hover{background:#dbeafe}.dropdown-item.cancel{color:#dc2626}.dropdown-item.cancel:hover{background:#fee2e2}.edit-btn,.delete-btn{cursor:pointer;border-radius:6px;padding:8px 16px;font-size:14px;transition:all .2s}.edit-btn{color:#1a1a2e;background:#fff;border:none}.edit-btn:hover{background:#f3f4f6}.delete-btn{color:#fca5a5;background:0 0;border:1px solid #ef444480}.delete-btn:hover{background:#ef44441a;border-color:#ef4444}.detail-main{max-width:1000px;margin:0 auto;padding:24px}.customer-header-card{background:#fff;border-radius:12px;align-items:center;gap:24px;margin-bottom:24px;padding:32px;display:flex;box-shadow:0 1px 3px #0000001a}.customer-avatar{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:28px;font-weight:600;display:flex}.customer-header-info h1{color:#1f2937;margin:0 0 4px;font-size:28px}.customer-id{color:#6b7280;margin:0 0 12px;font-size:14px}.status-badge.large{padding:6px 16px;font-size:14px}.detail-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (width<=768px){.detail-grid{grid-template-columns:1fr}.customer-header-card{text-align:center;flex-direction:column}}.detail-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.detail-card h3{color:#1f2937;border-bottom:1px solid #e5e7eb;margin:0 0 20px;padding-bottom:12px;font-size:16px;font-weight:600}.detail-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#6b7280;font-size:14px}.detail-row .value{color:#1f2937;text-align:right;font-size:14px;font-weight:500}.detail-row .value a{color:#3b82f6;text-decoration:none}.detail-row .value a:hover{text-decoration:underline}.detail-row .value.highlight{color:#3b82f6;font-size:18px}.unit-type-badge{text-transform:uppercase;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.unit-type-badge.apartment{color:#1d4ed8;background:#dbeafe}.unit-type-badge.room{color:#b45309;background:#fef3c7}.status-text{font-weight:500}.status-text.active{color:#16a34a}.status-text.inactive{color:#dc2626}.contract-status{text-transform:uppercase;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.contracts-section{background:#fff;border-radius:12px;margin-top:24px;padding:24px;box-shadow:0 1px 3px #0000001a}.contracts-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.contracts-header h3{color:#1f2937;margin:0;font-size:18px}.add-contract-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:background .2s}.add-contract-btn:hover{background:#2563eb}.no-contracts{text-align:center;color:#6b7280;padding:40px 20px}.no-contracts button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;margin-top:12px;padding:8px 16px}.contracts-list{flex-direction:column;gap:16px;display:flex}.contract-card{border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:box-shadow .2s}.contract-card:hover{box-shadow:0 4px 12px #0000001a}.contract-card.active{border-left:4px solid #16a34a}.contract-card.renewed{border-left:4px solid #3b82f6}.contract-card.finished{border-left:4px solid #6b7280}.contract-card.cancelled{border-left:4px solid #dc2626}.contract-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.contract-number{color:#1f2937;font-size:16px;font-weight:600}.contract-status{text-transform:capitalize;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.contract-status.active{color:#16a34a;background:#dcfce7}.contract-status.renewed{color:#1d4ed8;background:#dbeafe}.contract-status.finished{color:#6b7280;background:#f3f4f6}.contract-status.cancelled{color:#dc2626;background:#fee2e2}.contract-details{flex-direction:column;gap:8px;display:flex}.contract-unit{align-items:center;gap:8px;margin-bottom:4px;display:flex}.contract-unit .unit-number{color:#1f2937;font-weight:600}.contract-dates{gap:24px;display:flex}.contract-dates div,.contract-rent,.contract-notes{color:#6b7280;font-size:14px}.contract-dates .label,.contract-rent .label,.contract-notes .label{margin-right:8px}.contract-rent .amount{color:#1f2937;font-weight:600}.contract-form{padding:24px}.contract-form .form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.contract-form .form-field{flex-direction:column;gap:6px;display:flex}.contract-form label{color:#374151;font-size:14px;font-weight:500}.contract-form input,.contract-form textarea{border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:14px}.contract-form input:focus,.contract-form textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.contract-form textarea{resize:vertical}.contract-form .form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;display:flex}.btn-cancel,.btn-save{cursor:pointer;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500}.btn-cancel{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-save{color:#fff;background:#3b82f6;border:none}.btn-save:hover{background:#2563eb}.form-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.form-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.form-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.form-header h2{color:#1f2937;margin:0;font-size:20px}.close-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:0;font-size:28px;line-height:1}.close-btn:hover{color:#1f2937}.status-badge{cursor:pointer;border:none;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .2s}.status-badge.active{color:#16a34a;background:#dcfce7}.status-badge.active:hover{background:#bbf7d0}.status-badge.inactive{color:#dc2626;background:#fee2e2}.status-badge.inactive:hover{background:#fecaca}.loading{color:#6b7280;justify-content:center;align-items:center;min-height:100vh;font-size:16px;display:flex}.error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.error-state h2{color:#1f2937;margin:0 0 8px}.error-state p{color:#6b7280;margin:0 0 24px}.back-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:10px 20px;font-size:14px}.back-btn:hover{background:#2563eb}.login-container{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 25px 50px -12px #00000040}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#1a1a2e;margin:0 0 8px;font-size:28px;font-weight:700}.login-header p{color:#6b7280;margin:0;font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:14px;font-weight:500}.form-group input{border:1px solid #d1d5db;border-radius:8px;padding:12px 16px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input::placeholder{color:#9ca3af}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border:none;border-radius:8px;margin-top:8px;padding:14px 24px;font-size:16px;font-weight:600;transition:transform .2s,box-shadow .2s}.login-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px -10px #3b82f680}.login-btn:active{transform:translateY(0)}.error-message{color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;font-size:14px}.dashboard{color:#fff;text-align:center;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.dashboard h1{color:#fff;margin:0 0 16px;font-size:32px}.dashboard p{color:#9ca3af;margin:0 0 32px;font-size:16px}.logout-btn{color:#fff;cursor:pointer;background:0 0;border:2px solid #fff;border-radius:8px;padding:12px 32px;font-size:16px;font-weight:600;transition:background .2s,color .2s}.logout-btn:hover{color:#1a1a2e;background:#fff}
