#root{width:100%;min-height:100vh}body{margin:0}:root{--bg:#f8fafc;--surface:#fff;--surface-hover:#f1f5f9;--border:#e2e8f0;--text:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#dbeafe;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.app-loading,.app-error{min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;height:64px;box-shadow:var(--shadow-sm);align-items:center;gap:24px;padding:0 32px;display:flex;position:sticky;top:0}.header-left{align-items:baseline;gap:12px;display:flex}.logo{color:var(--primary);letter-spacing:-.5px;font-size:22px;font-weight:700}.logo-sub{color:var(--text-muted);font-size:13px;font-weight:400}.header-nav{gap:4px;margin-left:32px;display:flex}.nav-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.nav-btn:hover{background:var(--surface-hover);color:var(--text)}.nav-btn.active{background:var(--primary-light);color:var(--primary)}.header-actions{align-items:center;gap:8px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover)}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:32px}.stats-bar{grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:32px;display:grid}.stat-item{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;transition:box-shadow .2s}.stat-item:hover{box-shadow:var(--shadow)}.stat-value{color:var(--text);margin-bottom:4px;font-size:24px;font-weight:700}.stat-label{color:var(--text-muted);font-size:13px;font-weight:500}.dashboard-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;display:grid}.chart-section,.detail-section{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px}.section-title{color:var(--text);margin-bottom:4px;font-size:18px;font-weight:600}.section-subtitle{color:var(--text-muted);margin-bottom:16px;font-size:13px}.chart-container{position:relative}.chart-center-label{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%)}.center-total{color:var(--text);font-size:28px;font-weight:700;line-height:1.2}.center-sub{color:var(--text-muted);font-size:12px;font-weight:500}.chart-legend{flex-direction:column;gap:8px;margin-top:8px;display:flex}.legend-item{border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:10px;width:100%;padding:10px 14px;font-family:inherit;transition:all .2s;display:flex}.legend-item:hover{background:var(--surface-hover);border-color:var(--border)}.legend-item.active{background:var(--surface-hover);border-color:var(--primary);box-shadow:var(--shadow-sm)}.legend-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.legend-label{color:var(--text);flex:1;font-size:14px;font-weight:600}.legend-pct{color:var(--text);text-align:right;min-width:48px;font-size:14px;font-weight:700}.legend-sqft{color:var(--text-muted);text-align:right;min-width:100px;font-size:13px}.chart-tooltip{background:var(--text);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:12px 16px;font-size:13px}.tooltip-title{margin-bottom:8px;font-size:14px;font-weight:600}.tooltip-row{justify-content:space-between;gap:16px;padding:2px 0;display:flex}.drill-down-panel{animation:.3s slideIn}@keyframes slideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.drill-down-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.drill-down-header h2{font-size:18px;font-weight:600}.close-btn{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1;transition:all .2s}.close-btn:hover{color:var(--text);background:var(--surface-hover)}.drill-down-body{flex-direction:column;gap:12px;max-height:520px;padding-right:4px;display:flex;overflow-y:auto}.empty-msg{color:var(--text-muted);text-align:center;padding:32px;font-size:14px}.unit-card{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);padding:16px;transition:box-shadow .2s}.unit-card:hover{box-shadow:var(--shadow)}.unit-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.unit-card-header-right{align-items:center;gap:10px;display:flex}.unit-number{color:var(--text);font-size:16px;font-weight:700}.unit-sqft{color:var(--text-secondary);font-size:14px;font-weight:500}.unit-details{flex-direction:column;gap:8px;display:flex}.offer-block{border-bottom:1px solid var(--border);padding:10px 0}.offer-block:last-child{border-bottom:none;padding-bottom:0}.detail-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.detail-label{color:var(--text-muted);flex-shrink:0;font-size:13px;font-weight:500}.detail-value{color:var(--text);text-align:right;font-size:14px;font-weight:600}.detail-value.tenant-name{color:var(--primary)}.detail-value.rent{color:var(--success);font-size:16px}.detail-value.proposed{color:var(--warning)}.detail-value.their-rate{color:var(--text-secondary)}.detail-value.gap{color:var(--danger)}.detail-value.asking{color:var(--success)}.detail-value.notes{color:var(--text-secondary);max-width:200px;font-weight:400}.empty-state{text-align:center;height:100%;min-height:300px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-icon{opacity:.4;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:16px;font-weight:600}.empty-state p{max-width:280px;font-size:14px;line-height:1.6}.units-overview{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px}.units-table-wrapper{overflow-x:auto}.units-table{border-collapse:collapse;width:100%;font-size:14px}.units-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}.units-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:12px 16px}.units-table tr{cursor:pointer;transition:background .15s}.units-table tbody tr:hover{background:var(--surface-hover)}.units-table .row-leased td{border-left:3px solid var(--primary)}.units-table .row-available td{border-left:3px solid var(--success)}.units-table .row-under-review td{border-left:3px solid var(--warning)}.status-badge{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.status-badge.leased{background:var(--primary-light);color:var(--primary)}.status-badge.available{background:var(--success-light);color:#059669}.status-badge.under_review{background:var(--warning-light);color:#b45309}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.3s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:18px;font-weight:600}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--bg);padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-section{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.form-section h3{color:var(--text);margin-bottom:16px;font-size:15px;font-weight:600}.report-container{max-width:900px;margin:0 auto}.report-header{text-align:center;border-bottom:2px solid var(--border);margin-bottom:40px;padding-bottom:24px}.report-header h1{color:var(--text);margin-bottom:4px;font-size:28px;font-weight:700}.report-date{color:var(--text-muted);font-size:16px}.report-section{margin-bottom:32px}.report-section h2{color:var(--text);margin-bottom:8px;font-size:20px;font-weight:600}.building-address{color:var(--text-muted);margin-bottom:16px;font-size:14px}.report-table{border-collapse:collapse;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);width:100%;font-size:14px;overflow:hidden}.report-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg);border-bottom:2px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}.report-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:10px 16px}.report-table .row-leased td{border-left:3px solid var(--primary)}.report-table .row-available td{border-left:3px solid var(--success)}.report-table .row-review td{border-left:3px solid var(--warning)}.report-table .row-revenue td{color:var(--success);font-weight:600}.report-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);padding-top:24px;font-size:13px}.building-list{flex-direction:column;gap:8px;display:flex}.building-list-item{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;transition:box-shadow .2s;display:flex}.building-list-item:hover{box-shadow:var(--shadow)}.building-list-name{color:var(--text);font-size:15px;font-weight:600}.building-list-address{color:var(--text-muted);margin-top:2px;font-size:13px}.building-list-actions{gap:8px;display:flex}.btn-sm{padding:6px 12px;font-size:12px}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.app-header{flex-wrap:wrap;gap:12px;height:auto;min-height:64px;padding:0 16px}.logo-sub{display:none}.header-nav{margin-left:auto}.header-actions{margin-left:0}.header-user{gap:6px;margin-left:0}.user-email{max-width:120px}.main-content{padding:16px}.stats-bar{grid-template-columns:repeat(2,1fr);gap:8px}.stat-item{padding:14px}.stat-value{font-size:20px}.dashboard-grid{grid-template-columns:1fr}.units-table{font-size:13px}.units-table th,.units-table td{padding:8px 10px}.form-grid{grid-template-columns:1fr}}@media (width<=480px){.stats-bar{grid-template-columns:1fr}.nav-btn{padding:6px 12px;font-size:13px}.btn{padding:8px 16px;font-size:13px}}.auth-screen{background:linear-gradient(135deg,#eff6ff 0%,#f8fafc 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.auth-brand{background:var(--primary);color:#fff;text-align:center;padding:32px 24px}.auth-brand h1{letter-spacing:-.5px;font-size:28px;font-weight:700}.auth-brand p{opacity:.85;margin-top:4px;font-size:14px}.auth-form{padding:32px 24px}.auth-form h2{color:var(--text);margin-bottom:24px;font-size:20px;font-weight:600}.auth-form .form-group{margin-bottom:16px}.auth-error{color:#dc2626;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:13px}.auth-submit{width:100%;margin-top:8px;padding:12px}.auth-toggle{text-align:center;color:var(--text-muted);margin-top:20px;font-size:14px}.auth-toggle-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600}.auth-toggle-btn:hover{text-decoration:underline}.auth-success{color:#15803d;border-radius:var(--radius-sm);background:#f0fdf4;border:1px solid #bbf7d0;margin-bottom:16px;padding:10px 14px;font-size:13px}.auth-forgot-row{justify-content:flex-end;margin-top:-8px;margin-bottom:8px;display:flex}.password-input-wrap{align-items:center;display:flex;position:relative}.password-input-wrap input{width:100%;padding-right:40px!important}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;right:10px}.password-toggle:hover{color:var(--text-secondary)}.header-user{align-items:center;gap:10px;margin-left:auto;display:flex}.user-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;overflow:hidden}.role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.role-owner{background:var(--primary-light);color:var(--primary)}.role-viewer{color:#15803d;background:#f0fdf4}.viewer-badge{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 14px;font-size:12px;font-weight:600}.unit-detail-modal{max-width:880px}.modal-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px;font-weight:400}.unit-detail-tabs{border-bottom:1px solid var(--border);gap:4px;padding:0 24px;display:flex}.unit-detail-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.unit-detail-tab:hover{color:var(--text);background:var(--surface-hover)}.unit-detail-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{background:var(--primary-light);color:var(--primary);border-radius:20px;margin-left:5px;padding:1px 6px;font-size:11px;font-weight:700;display:inline-block}.notes-tab{flex-direction:column;gap:12px;display:flex}.docs-toolbar{justify-content:flex-end;margin-bottom:16px;display:flex}.docs-list{flex-direction:column;gap:12px;display:flex}.doc-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);padding:16px;transition:box-shadow .2s}.doc-card:hover{box-shadow:var(--shadow)}.doc-card-header{align-items:center;gap:12px;display:flex}.doc-icon-wrap{border-radius:var(--radius-sm);background:var(--primary-light);width:36px;height:36px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.doc-info{flex-direction:column;flex:1;min-width:0;display:flex}.doc-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.doc-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.doc-actions{flex-shrink:0;gap:6px;display:flex}.doc-section-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:700;display:block}.doc-requests,.doc-logs{border-top:1px dashed var(--border);margin-top:14px;padding-top:14px}.request-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:8px 0;font-size:13px;display:flex}.request-row:last-child{border-bottom:none}.requester-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.request-time{color:var(--text-muted);font-size:12px}.request-actions{gap:6px;display:flex}.logs-table{border-collapse:collapse;width:100%;font-size:13px}.logs-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-weight:600}.logs-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:8px 12px}.logs-table tr:last-child td{border-bottom:none}.pill{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.pill-success{background:var(--success-light);color:#059669}.pill-warning{background:var(--warning-light);color:#b45309}.pill-danger{color:#dc2626;background:#fee2e2}.pill-neutral{background:var(--surface-hover);color:var(--text-secondary)}.notif-tab,.notif-list{flex-direction:column;gap:12px;display:flex}.notif-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);padding:14px 16px}.notif-card-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.notif-time{color:var(--text-muted);font-size:12px}.notif-message{color:var(--text);margin-bottom:10px;font-size:14px;line-height:1.5}.notif-recipients{flex-direction:column;gap:6px;display:flex}.recipient-chips{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500}.modal-body textarea{resize:vertical;width:100%;font-family:inherit}.pdf-viewer-overlay{z-index:1100}.pdf-viewer-modal{background:var(--surface);border-radius:var(--radius-lg);width:min(960px,92vw);height:min(86vh,900px);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.pdf-viewer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.pdf-viewer-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.pdf-viewer-actions{align-items:center;gap:8px;display:flex}.pdf-viewer-frame{background:#f8fafc;border:none;flex:1;width:100%}.docs-hint{color:var(--text-secondary);font-size:12px;font-weight:400}.units-table .expiry-soon td{background:#f59e0b0f}.units-table .expiry-critical td{background:#ef444412}.units-table .expiry-expired td{background:#ef444421}.expiry-date{color:var(--text-secondary);font-size:13px}.expiry-badge{align-items:center;gap:5px;font-size:13px;display:inline-flex}.expiry-tag{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:2px 6px;font-size:10px;font-weight:700}.expiry-soon .expiry-tag{background:var(--warning-light);color:#b45309}.expiry-critical .expiry-tag,.expiry-expired .expiry-tag{color:#dc2626;background:#fee2e2}.notes-toolbar{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.notes-compose{resize:vertical;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);min-height:80px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.notes-compose:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.notes-compose-actions{justify-content:flex-end;gap:8px;display:flex}.notes-list{flex-direction:column;gap:10px;display:flex}.note-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;transition:box-shadow .2s}.note-card:hover{box-shadow:var(--shadow-sm)}.note-card-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.note-author{color:var(--primary);font-size:13px;font-weight:600}.note-time{color:var(--text-muted);font-size:12px}.note-content{color:var(--text);white-space:pre-wrap;word-break:break-word;font-size:14px;line-height:1.6}.note-actions{gap:6px;margin-top:10px;display:flex}.note-edit-textarea{resize:vertical;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);min-height:80px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.note-edit-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.note-card-unreplied{border-color:var(--warning);background:#fffbeb}.note-header-right{align-items:center;gap:8px;display:flex}.notes-pending-banner{border:1px solid var(--warning);color:#92400e;border-radius:var(--radius-sm);background:#fffbeb;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.tab-count-warning{color:#92400e;background:#fef3c7}.note-reply{background:var(--surface);border-left:3px solid var(--primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:12px;padding:12px 14px}.note-reply-header{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:6px;display:flex}.note-reply-author{color:var(--primary);font-size:12px;font-weight:600}.note-reply-time{color:var(--text-muted);font-size:11px}.note-reply-content{color:var(--text);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.6}.note-reply-compose{flex-direction:column;gap:8px;margin-top:8px;display:flex}.comment-notif-badge{border:1px solid var(--warning);color:#92400e;border-radius:var(--radius-sm);background:#fef3c7;align-items:center;gap:5px;padding:6px 10px;font-size:12px;font-weight:600;animation:2.5s ease-in-out infinite comment-pulse;display:inline-flex}@keyframes comment-pulse{0%,to{box-shadow:0 0 #f59e0b00}50%{box-shadow:0 0 0 4px #f59e0b33}}.pending-screen{background:linear-gradient(135deg,#eff6ff 0%,#f8fafc 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.pending-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:480px;overflow:hidden}.pending-brand{background:var(--primary);color:#fff;text-align:center;padding:24px}.pending-brand h1{letter-spacing:-.5px;font-size:24px;font-weight:700}.pending-brand p{opacity:.85;margin-top:4px;font-size:13px}.pending-body{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:40px 32px;display:flex}.pending-icon{color:var(--warning);opacity:.85}.pending-title{color:var(--text);margin:0;font-size:20px;font-weight:700}.pending-text{color:var(--text-secondary);max-width:360px;font-size:14px;line-height:1.7}.pending-text strong{color:var(--text)}.pending-phone{color:var(--primary);font-size:16px;font-weight:700;text-decoration:none}.pending-phone:hover{text-decoration:underline}.pending-actions{flex-direction:column;gap:10px;width:100%;margin-top:8px;display:flex}.pending-actions .btn{width:100%}.approval-bell{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);background:0 0;align-items:center;padding:8px 10px;transition:all .2s;display:flex;position:relative}.approval-bell:hover{background:var(--surface-hover);color:var(--text)}.approval-bell.has-pending{border-color:var(--danger);color:var(--danger);animation:2s ease-in-out infinite bell-pulse}@keyframes bell-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 4px #ef444433}}.approval-bell-count{background:var(--danger);color:#fff;border:2px solid var(--surface);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.approval-panel{max-width:680px}.approval-list{flex-direction:column;gap:10px;display:flex}.approval-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;transition:box-shadow .2s;display:flex}.approval-card:hover{box-shadow:var(--shadow-sm)}.approval-card-left{align-items:center;gap:12px;min-width:0;display:flex}.approval-avatar{background:var(--primary-light);width:40px;height:40px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.approval-device-icon{border-radius:var(--radius-sm);background:var(--warning-light);color:#b45309;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.approval-info{flex-direction:column;gap:2px;min-width:0;display:flex}.approval-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.approval-meta{color:var(--text-muted);font-size:12px}.approval-actions{flex-shrink:0;gap:6px;display:flex}.approval-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:40px 16px;font-size:14px;display:flex}.approval-empty svg{color:var(--success);opacity:.7}.form-section-inner{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.form-section-inner h4{color:var(--text);text-transform:uppercase;letter-spacing:.04em;margin:0 0 4px;font-size:13px;font-weight:600}.form-hint{color:var(--text-muted);margin:0 0 12px;font-size:12px}.year-rates-list{flex-direction:column;gap:8px;display:flex}.year-rate-row{grid-template-columns:60px 1fr 140px;align-items:center;gap:10px;display:grid}.year-rate-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:600}.year-rate-input-wrap{align-items:center;display:flex;position:relative}.year-rate-input-wrap input{width:100%;padding-right:52px!important}.year-rate-unit{color:var(--text-muted);pointer-events:none;font-size:12px;position:absolute;right:10px}.year-rate-monthly{color:var(--success);white-space:nowrap;font-size:13px;font-weight:600}.year-rate-empty{color:var(--text-muted);font-style:italic;font-weight:400}.year-indicator{color:var(--text-muted);font-size:11px;font-weight:400}.rate-monthly{color:var(--text-muted);font-size:11px}.input-readonly{cursor:default;background:var(--bg)!important;color:var(--text-muted)!important}.units-overview-header{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;display:flex}.units-overview-header .section-title{white-space:nowrap;margin:0}.building-filter-dropdown select{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:8px;min-width:160px;padding:6px 32px 6px 12px;font-size:13px;font-weight:500}.building-filter-dropdown select:focus{border-color:var(--primary);outline:none}.refreshing-badge{color:var(--primary);background:color-mix(in srgb, var(--primary) 10%, transparent);vertical-align:middle;border-radius:10px;margin-left:10px;padding:2px 8px;font-size:11px;font-weight:500;animation:1s ease-in-out infinite pulse-opacity;display:inline-block}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.4}}.form-readonly input:disabled,.form-readonly select:disabled,.form-readonly textarea:disabled{cursor:default;opacity:1;-webkit-text-fill-color:var(--text);background:var(--bg)!important;color:var(--text)!important;border-color:var(--border)!important}.form-readonly .year-rate-input-wrap input:disabled{opacity:1;-webkit-text-fill-color:var(--text);background:var(--bg)!important;color:var(--text)!important}
