*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:#0f172a;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;border:none;border-radius:8px;padding:.5rem 1rem;background:#2563eb;color:#fff}button:disabled{opacity:.5;cursor:not-allowed}button.btn-secondary{background:#e2e8f0;color:#334155}button.btn-danger{background:#ef4444}input,select{font:inherit;padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:8px;width:100%}label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#475569}.loading,.error,.empty{text-align:center;padding:2rem;color:#64748b}.error{color:#dc2626}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2563eb)}.auth-card{background:#fff;padding:2rem;border-radius:16px;width:100%;max-width:400px;box-shadow:0 20px 60px #0003}.auth-card h1{margin:0;font-size:2rem}.auth-card .subtitle{color:#64748b;margin:.25rem 0 1.5rem}.auth-card form{display:flex;flex-direction:column;gap:1rem}.auth-card button[type=submit]{margin-top:.5rem;padding:.75rem}.link-btn{background:none;color:#2563eb;margin-top:1rem;width:100%}.page{max-width:1400px;margin:0 auto;padding:1.5rem}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.header h1{margin:0;font-size:1.75rem}.user-info{color:#64748b;margin:.25rem 0 0;font-size:.875rem}.back-link{color:#2563eb;font-size:.875rem}.actions{margin-bottom:1rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014}.property-card{transition:transform .15s,box-shadow .15s}.property-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.property-card h2{margin:0 0 .5rem;font-size:1.125rem}.property-card p{margin:0;color:#64748b;font-size:.875rem}.form-card{margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem;max-width:400px}.property-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}.sidebar{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #00000014}.sidebar h3{margin:0 0 .75rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.floor-list,.unit-list{list-style:none;padding:0;margin:0 0 1rem}.floor-list button,.unit-list button{width:100%;text-align:left;background:none;color:#334155;padding:.5rem .75rem;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.floor-list button.active,.unit-list button.active{background:#eff6ff;color:#2563eb}.floor-add{display:flex;gap:.5rem;margin-bottom:1rem}.floor-add input{width:60px}.plan-upload{margin-bottom:1rem}.draw-controls{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.draw-controls .hint{font-size:.75rem;color:#64748b;margin:0}.unit-details{margin-top:1rem}.unit-details h4{margin:0 0 .5rem}.status{font-size:.75rem;padding:.125rem .5rem;border-radius:999px;background:#f1f5f9}.status-available{background:#dcfce7;color:#166534}.status-rented{background:#dbeafe;color:#1e40af}.status-reserved{background:#fef9c3;color:#854d0e}.status-maintenance{background:#fee2e2;color:#991b1b}.plan-view{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #00000014;min-height:500px}.plan-container{position:relative;width:100%}.plan-image{width:100%;display:block;border-radius:8px}.plan-overlay{position:absolute;top:0;left:0;width:100%;height:100%;cursor:crosshair}.unit-label{font-size:12px;fill:#0f172a;pointer-events:none;font-weight:600}.empty-plan{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#64748b;text-align:center;padding:2rem}.empty-plan h2{margin:0 0 1rem;color:#0f172a}.empty-plan .steps{text-align:left;max-width:420px;margin:0 0 1.5rem;line-height:1.7}.upload-big{display:inline-block;padding:.75rem 1.5rem;background:#2563eb;color:#fff;border-radius:8px;cursor:pointer;font-weight:500}.upload-big:hover{background:#1d4ed8}.unit-form-block{margin-bottom:.75rem}.unit-form{display:flex;flex-direction:column;gap:.5rem}.form-row{display:flex;gap:.5rem}.form-row button{flex:1}.unit-details label{margin-bottom:.5rem}.unit-details button{width:100%;margin-top:.5rem}.unit-list small{color:#94a3b8;font-weight:400}@media(max-width:768px){.property-layout{grid-template-columns:1fr}}.header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.app-header .app-title{margin:0;font-size:1.5rem}.main-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.main-nav a{padding:.5rem 1rem;border-radius:8px;color:#475569;background:#fff;box-shadow:0 1px 2px #0000000f}.main-nav a.active{background:#2563eb;color:#fff}.page-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.page-header-row h2{margin:0}.btn-link{display:inline-block;padding:.5rem 1rem;background:#2563eb;color:#fff!important;border-radius:8px}.muted{color:#64748b;font-size:.875rem}.list-cards{display:flex;flex-direction:column;gap:.75rem}.tenant-card .tenant-header{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.75rem}.office-list{list-style:none;padding:0;margin:0 0 .75rem}.office-list li{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;border-bottom:1px solid #f1f5f9}.link-btn-sm{background:none;color:#dc2626;padding:.25rem .5rem;font-size:.8rem}.assign-form{display:flex;flex-direction:column;gap:.5rem}.ticket-card{display:block;transition:box-shadow .15s}.ticket-card:hover{box-shadow:0 4px 12px #0000001a}.ticket-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.ticket-meta{font-size:.875rem;color:#64748b;margin:.25rem 0}.ticket-desc{margin:.5rem 0}.ticket-description{white-space:pre-wrap;margin:1rem 0}.ticket-photos{display:flex;gap:.5rem;flex-wrap:wrap;margin:1rem 0}.ticket-photos img{width:120px;height:120px;object-fit:cover;border-radius:8px}.assign-block,.status-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.form-card-wide{max-width:560px}.voice-input textarea{width:100%;margin-bottom:.5rem}.voice-btn{background:#f1f5f9;color:#334155;width:100%}.voice-btn.active{background:#fee2e2;color:#991b1b}.chat-block{margin-top:1rem}.chat-messages{max-height:400px;overflow-y:auto;margin-bottom:1rem}.chat-msg{background:#f8fafc;border-radius:8px;padding:.75rem;margin-bottom:.5rem}.chat-msg.mine{background:#eff6ff}.chat-msg-head{display:flex;justify-content:space-between;font-size:.8rem;margin-bottom:.25rem;color:#64748b}.chat-form{display:flex;flex-direction:column;gap:.5rem}.settings-list{list-style:none;padding:0;margin:1rem 0 0}.settings-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.empty-card{text-align:center}.pwa-prompts{margin-bottom:1rem}.pwa-banner{background:#2563eb;color:#fff;padding:.75rem 1rem;border-radius:10px;display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.pwa-banner p{margin:0;flex:1;min-width:200px}.pwa-banner button{background:#fff;color:#2563eb;white-space:nowrap}.pwa-banner-info{background:#eff6ff;color:#1e40af}.pwa-banner-warn{background:#fef3c7;color:#92400e}.ok-text{color:#059669}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0f172aa6;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn .25s ease}@media(min-width:480px){.onboarding-overlay{align-items:center;padding:1rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.onboarding-modal{background:#fff;width:100%;max-width:420px;border-radius:20px 20px 0 0;padding:1.5rem 1.25rem 2rem;box-shadow:0 -8px 40px #0003;animation:slideUp .3s ease;max-height:90vh;overflow-y:auto}@media(min-width:480px){.onboarding-modal{border-radius:20px}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.onboarding-progress{display:flex;gap:6px;justify-content:center;margin-bottom:1.25rem}.onboarding-progress span{width:8px;height:8px;border-radius:50%;background:#e2e8f0}.onboarding-progress span.active{background:#2563eb;width:24px;border-radius:4px}.onboarding-progress span.done{background:#93c5fd}.onboarding-icon{font-size:2.5rem;text-align:center;margin-bottom:.5rem}.onboarding-modal h2{margin:0 0 .75rem;font-size:1.35rem;text-align:center}.onboarding-modal p{margin:0 0 1rem;color:#475569;text-align:center;line-height:1.6}.onboarding-steps{text-align:left;margin:0 0 1.25rem;padding-left:1.25rem;color:#334155;line-height:1.8}.onboarding-steps li{margin-bottom:.35rem}.ios-share{display:inline-block;background:#e2e8f0;padding:0 .35rem;border-radius:4px}.onboarding-btn-primary{width:100%;padding:.9rem 1rem;font-size:1rem;font-weight:600;margin-bottom:.5rem}.onboarding-btn-secondary{width:100%;padding:.75rem;background:#f1f5f9;color:#334155;margin-bottom:.5rem}.onboarding-btn-link{width:100%;background:none;color:#64748b;padding:.5rem;font-size:.9rem}.onboarding-ok{color:#059669!important;font-weight:500}.onboarding-hint{color:#2563eb!important;font-size:.9rem}.onboarding-warn,.onboarding-error{background:#fef3c7;color:#92400e!important;padding:.75rem;border-radius:8px;font-size:.9rem;text-align:left!important}.onboarding-error{background:#fee2e2;color:#991b1b!important}
