@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);:root{--bg-primary:#fafafa;--bg-card:#fff;--bg-hover:#f5f5f7;--bg-input:#f5f5f7;--border-color:#e8e8e8;--border-hover:#d2d2d7;--text-primary:#1d1d1f;--text-secondary:#86868b;--text-muted:#aeaeb2;--accent:#0071e3;--accent-hover:#0077ed;--success:#34c759;--warning:#f5a623;--danger:#ff3b30;--purple:#af52de;--cyan:#00acc1;--pink:#ec407a}.dark-mode{--bg-primary:#0d0d0d;--bg-card:#1a1a1a;--bg-hover:#252525;--bg-input:#252525;--border-color:#2d2d2d;--border-hover:#3d3d3d;--text-primary:#f5f5f7;--text-secondary:#98989d;--text-muted:#636366;--accent:#0a84ff;--accent-hover:#409cff}#root,body,html{-webkit-font-smoothing:antialiased;background-color:#fafafa;background-color:var(--bg-primary);color:#1d1d1f;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100%;line-height:1.5;margin:0;padding:0;transition:background-color .3s ease,color .3s ease}.btn-primary{align-items:center;background:#0071e3;background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-primary:hover{background:#0077ed;background:var(--accent-hover);box-shadow:0 4px 12px #0071e34d;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-primary svg{height:16px;width:16px}.btn-secondary{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e8e8e8;border:1px solid var(--border-color);border-radius:10px;color:#1d1d1f;color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-secondary:hover{background:#f5f5f7;background:var(--bg-hover);border-color:#d2d2d7;border-color:var(--border-hover)}.btn-secondary svg{height:16px;width:16px}.btn-danger{align-items:center;background:#ff3b30;background:var(--danger);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-danger:hover{background:#e62e26;transform:translateY(-1px)}.search-input{background:#f5f5f7;background:var(--bg-input);border:1px solid #e8e8e8;color:#1d1d1f;flex:1 1;outline:none;padding:12px 16px}.search-input:focus{border-color:#0071e3}.search-input::placeholder{color:#aeaeb2}.filter-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.filter-tab{background:#f5f5f7;background:var(--bg-input);border:1px solid #e8e8e8;border:1px solid var(--border-color);border-radius:8px;color:#86868b;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;padding:8px 16px;transition:all .2s ease}.filter-tab:hover{background:#f5f5f7;background:var(--bg-hover);color:#1d1d1f;color:var(--text-primary)}.filter-tab.active{background:#0071e3;background:var(--accent);border-color:#0071e3;border-color:var(--accent);color:#fff}.section-card{background:#fff;background:var(--bg-card);border:1px solid #e8e8e8;border:1px solid var(--border-color);border-radius:14px;margin-bottom:24px;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.section-header{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:18px 22px}.section-title{color:#1d1d1f;color:var(--text-primary);font-size:15px;font-weight:600;margin:0}.section-link{color:#0071e3;color:var(--accent);cursor:pointer;font-size:13px;font-weight:500;text-decoration:none}.section-link:hover{color:#0077ed;color:var(--accent-hover)}.list-item{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:14px;padding:14px 22px;transition:background .2s ease}.list-item:last-child{border-bottom:none}.list-item:hover{background:#f5f5f7;background:var(--bg-hover)}.list-icon{align-items:center;background:#f5f5f7;background:var(--bg-input);border-radius:8px;color:#86868b;color:var(--text-secondary);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.list-icon svg{height:18px;width:18px}.list-info{flex:1 1;min-width:0}.list-name{color:#1d1d1f;color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:2px}.list-meta{color:#86868b;color:var(--text-secondary);font-size:12px}.status-badge{border-radius:16px;flex-shrink:0;font-size:11px;font-weight:500;padding:5px 10px}.status-badge.pending{background:#fff3e0;color:#e65100}.status-badge.completed{background:#e8f5e9;color:#2e7d32}.status-badge.sent{background:#e3f2fd;color:#1565c0}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.in-progress{background:#fff3e0;color:#e65100}.dark-mode .status-badge.pending{background:#f5a62333;color:#ffb74d}.dark-mode .status-badge.completed{background:#34c75933;color:#81c784}.dark-mode .status-badge.sent{background:#0a84ff33;color:#64b5f6}.dark-mode .status-badge.active{background:#34c75933;color:#81c784}.dark-mode .status-badge.in-progress{background:#f5a62333;color:#ffb74d}.card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:20px}.pagination{border-top:1px solid #e8e8e8;border-top:1px solid var(--border-color);gap:8px;padding:16px 0}.pagination button{background:#f5f5f7;background:var(--bg-input);border:1px solid #e8e8e8;border:1px solid var(--border-color);border-radius:8px;color:#86868b;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;padding:8px 14px;transition:all .2s ease}.pagination button:hover{background:#f5f5f7;background:var(--bg-hover);color:#1d1d1f;color:var(--text-primary)}.pagination button.active{background:#0071e3;background:var(--accent);border-color:#0071e3;border-color:var(--accent);color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination span{color:#86868b;color:var(--text-secondary);font-size:13px}.empty-state{color:#86868b}.empty-state svg{color:#0071e3}.empty-state p{color:#86868b;font-size:15px;margin:0}input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{background:#f5f5f7;background:var(--bg-input);border:1px solid #e8e8e8;border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:#1d1d1f;color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:12px 16px;transition:all .2s ease;width:100%}input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=text]:focus,select:focus,textarea:focus{border-color:#0071e3;border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a}input::placeholder,textarea::placeholder{color:#aeaeb2;color:var(--text-muted)}@media screen and (max-width:768px){input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{font-size:16px;padding:14px 16px}button{min-height:44px;min-width:44px}}.app-container{display:flex;min-height:100dvh}.app-container:has(.map-container){height:100vh;overflow:hidden}.sidebar{background:var(--bg-card);border-right:1px solid var(--border-color);box-sizing:border-box;display:flex;flex-direction:column;height:100dvh;overflow-y:auto;padding:24px 0 12px;position:fixed;transition:background-color .3s ease,border-color .3s ease,transform .3s ease;width:240px;z-index:100}.logo{margin-bottom:32px;padding:0 24px}.logo h1{color:var(--text-primary);font-size:22px;font-weight:700;letter-spacing:-.5px;margin:0}.beta-badge,.logo span{color:var(--accent)}.beta-badge{font-size:10px;font-weight:600;letter-spacing:.5px;margin-left:2px;vertical-align:super}.nav-menu{display:flex;flex:1 1;flex-direction:column}.nav-item{align-items:center;border-left:3px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:400;gap:12px;padding:12px 24px;text-decoration:none;transition:all .2s ease}.nav-item.active,.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{border-left-color:var(--accent);font-weight:500}.nav-item svg{flex-shrink:0;height:18px;width:18px}.nav-section{border-top:1px solid var(--border-color);margin-top:24px;padding-top:24px}.theme-toggle{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:12px;margin-top:auto;padding:12px 24px;transition:all .2s ease}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.theme-toggle svg{flex-shrink:0;height:18px;width:18px}.theme-label{flex:1 1}.toggle-switch{background:var(--bg-input);border:1px solid var(--border-color);border-radius:12px;height:24px;position:relative;transition:background-color .3s ease;width:44px}.toggle-switch.active{background:var(--accent);border-color:var(--accent)}.toggle-knob{background:var(--bg-card);border-radius:50%;box-shadow:0 1px 3px #0003;height:18px;left:2px;position:absolute;top:2px;transition:transform .3s ease;width:18px}.toggle-switch.active .toggle-knob{transform:translateX(20px)}.user-profile{border-top:1px solid var(--border-color);gap:10px;margin-top:16px;padding:16px 24px}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{flex:1 1;min-width:0}.user-profile .user-name{color:var(--text-primary);font-size:13px;font-weight:500}.user-profile .user-email,.user-profile .user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-profile .user-email{color:var(--text-secondary);font-size:11px}.logout-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.logout-btn:hover{background:var(--bg-hover);color:var(--danger)}.logout-btn svg{height:16px;width:16px}.main-content{background:var(--bg-primary);box-sizing:border-box;flex:1 1;margin-left:240px;padding:32px 40px;transition:margin-left .3s ease,padding .3s ease}.main-content:has(.map-container){height:100vh;overflow:hidden}.main-content.full-width{margin-left:0}.mobile-menu-btn{align-items:center;background:var(--bg-card);border:none;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:var(--text-primary);cursor:pointer;display:none;height:44px;justify-content:center;left:16px;position:fixed;top:16px;transition:all .2s ease;width:44px;z-index:101}.mobile-menu-btn:hover{background:var(--bg-hover)}.mobile-menu-btn svg{height:20px;width:20px}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:99}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:32px}.page-title{color:var(--text-primary);font-size:26px;font-weight:600;letter-spacing:-.5px;margin:0}.page-subtitle{color:var(--text-secondary);font-size:14px;margin-top:4px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease}.stat-card:hover{border-color:var(--border-hover);box-shadow:0 2px 12px #0000000a}.dark-mode .stat-card:hover{box-shadow:0 2px 12px #0003}.stat-header{gap:10px;margin-bottom:12px}.stat-header,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:8px;height:32px;justify-content:center;width:32px}.stat-icon svg{height:16px;width:16px}.stat-icon.pending{background:#fff3e0;color:var(--warning)}.stat-icon.completed{background:#e8f5e9;color:var(--success)}.stat-icon.primary{background:#e3f2fd;color:var(--accent)}.stat-icon.purple{background:#f3e5f5;color:var(--purple)}.stat-icon.cyan{background:#e0f7fa;color:var(--cyan)}.stat-icon.pink{background:#fce4ec;color:var(--pink)}.dark-mode .stat-icon.pending{background:#f5a62326}.dark-mode .stat-icon.completed{background:#34c75926}.dark-mode .stat-icon.primary{background:#0a84ff26}.dark-mode .stat-icon.purple{background:#af52de26}.dark-mode .stat-icon.cyan{background:#00acc126}.dark-mode .stat-icon.pink{background:#ec407a26}.stat-label{color:var(--text-secondary);font-size:12px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.stat-value{color:var(--text-primary);font-size:28px;font-weight:600;letter-spacing:-.5px;line-height:1.2}.stat-trend{color:var(--success);font-size:12px;margin-top:4px}.search-bar{align-items:center;display:flex;gap:12px;margin-bottom:24px}.upload-zone{border:2px dashed var(--border-hover);border-radius:12px;cursor:pointer;margin:20px;padding:32px;text-align:center;transition:all .2s ease}.upload-zone:hover{background:#0071e30a;border-color:var(--accent)}.dark-mode .upload-zone:hover{background:#0a84ff14}.upload-zone svg{color:var(--text-secondary);height:40px;margin-bottom:12px;width:40px}.upload-zone:hover svg{color:var(--accent)}.upload-zone h4{color:var(--text-primary);font-size:15px;font-weight:500;margin:0 0 4px}.upload-zone p{color:var(--text-secondary);font-size:13px;margin:0}.upload-zone span{color:var(--accent);font-weight:500}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.content-grid{grid-template-columns:1fr}}@media (max-width:768px){.mobile-menu-btn{display:flex}.sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.visible,.sidebar.open+.sidebar-overlay,.sidebar.open~.sidebar-overlay{opacity:1;pointer-events:auto}.sidebar{box-shadow:2px 0 12px #00000026;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar.open .logo{padding-left:60px}.main-content{margin-left:0;padding:80px 20px 20px;transform:none;will-change:auto}.page-header{align-items:flex-start;flex-direction:column}.page-title{font-size:22px}.stats-grid{grid-template-columns:1fr}.stat-card{padding:16px}.stat-value{font-size:24px}}.map-container{position:relative}.app-container .main-content .map-container,.map-container{height:100vh;margin:-32px -40px;overflow:hidden;width:calc(100% + 80px)}@media (max-width:768px){.map-container{bottom:0;height:100%;height:100dvh;left:0;margin:0;padding:0;position:fixed;right:0;top:0;width:100%;width:100vw;z-index:1}.main-content:has(.map-container){height:100dvh;margin:0;overflow:hidden;padding:0}}.map-wrapper{bottom:0;height:100%;left:0;position:absolute;right:0;top:0;width:100%}@media (max-width:768px){.map-wrapper{height:100dvh;left:0;position:fixed;top:0;width:100vw}}.app-container:has(.sidebar.open) .sidebar-overlay{display:block;opacity:1;pointer-events:auto}.mapboxgl-popup-content{background:#0000!important;border-radius:0!important;box-shadow:none!important;padding:0!important}.mapboxgl-popup-tip{border-top-color:#808080cc!important}.dark-mode .mapboxgl-popup-tip{border-top-color:#2d2d2de6!important}.photo-upload-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:max(20px,env(safe-area-inset-top)) 20px max(20px,env(safe-area-inset-bottom));position:fixed;right:0;top:0;z-index:2000}.photo-upload-modal{animation:slideUp .3s ease;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:90dvh;max-width:500px;padding:28px;position:relative;width:100%}.photo-upload-modal h2{color:var(--text-primary);font-size:22px;font-weight:600;margin:0 0 8px}.property-address{color:var(--text-secondary);font-size:14px;margin:0 0 24px}.close-button{align-items:center;background:var(--bg-input);border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px}.close-button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.close-button:disabled{cursor:not-allowed;opacity:.5}.photo-capture-section{background:var(--bg-primary);border:2px dashed var(--border-color);border-radius:12px;flex:1 1;margin:24px 0;min-height:0;overflow:hidden;transition:border-color .2s ease}.photo-capture-section:hover{border-color:var(--accent)}.photo-placeholder{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:50px 20px}.photo-placeholder p{font-size:15px;margin:0}.take-photo-button{align-items:center;background-color:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease}.take-photo-button:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px)}.take-photo-button:disabled{cursor:not-allowed;opacity:.5}.photo-preview-container{align-items:center;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:16px;position:relative}.photo-preview{border-radius:8px;max-height:100%;max-width:100%;object-fit:contain}.remove-photo-button{align-items:center;background-color:#ff3b301a;border:none;border-radius:8px;color:var(--danger);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:6px;margin-top:12px;padding:8px 16px;transition:all .2s ease}.remove-photo-button:hover:not(:disabled){background-color:var(--danger);color:#fff}.remove-photo-button:disabled{cursor:not-allowed;opacity:.5}.note-input-section{margin:24px 0}.note-input-section label{color:var(--text-primary);display:block;font-size:14px;font-weight:500;margin-bottom:8px}.note-input-section textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;min-height:80px;padding:12px 14px;resize:vertical;transition:all .2s ease;width:100%}.note-input-section textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.note-input-section textarea::placeholder{color:var(--text-muted)}.note-input-section textarea:disabled{background-color:var(--bg-primary);cursor:not-allowed}.upload-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.upload-complete-button,.upload-incomplete-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:500;gap:8px;justify-content:center;padding:14px 20px;transition:all .2s ease}.upload-complete-button{background-color:var(--accent);color:#fff}.upload-complete-button:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px)}.upload-incomplete-button{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.upload-incomplete-button:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-hover)}.upload-complete-button:disabled,.upload-incomplete-button:disabled{cursor:not-allowed;opacity:.5}.uploading-indicator{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:30px}.uploading-indicator .spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent);height:40px;width:40px}.uploading-indicator p{color:var(--text-secondary);font-size:15px;margin:0}@media (max-width:600px){.photo-upload-overlay{align-items:center;padding:16px}.photo-upload-modal{border-radius:14px;margin-top:0;max-height:85dvh;padding:16px}.photo-upload-modal h2{font-size:18px;margin-bottom:4px}.property-address{font-size:13px;margin-bottom:12px}.photo-capture-section{margin:12px 0}.photo-preview-container{padding:8px}.remove-photo-button{margin-top:8px}.note-input-section{margin:12px 0}.note-input-section textarea{min-height:60px;padding:10px 12px}.upload-actions{gap:8px;margin-top:12px}.upload-complete-button,.upload-incomplete-button{font-size:14px;padding:12px 16px}}.bottom-sheet-backdrop{animation:fadeIn .2s ease;background:#0000004d;top:0;z-index:1500}.bottom-sheet,.bottom-sheet-backdrop{bottom:0;left:0;position:fixed;right:0}.bottom-sheet{animation:slideUp .25s ease;background:var(--bg-card);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;margin:0 auto;max-height:50dvh;max-width:500px;overflow-y:auto;padding:12px 16px calc(16px + env(safe-area-inset-bottom));width:calc(100% - 24px);z-index:1501}.bottom-sheet-close{align-items:center;background:var(--bg-input);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;position:absolute;right:16px;top:12px;transition:background .2s ease;width:32px}.bottom-sheet-close:hover{background:var(--bg-hover);color:var(--text-primary)}.bottom-sheet-title{color:var(--text-primary);font-size:17px;font-weight:600;margin:0 0 8px;padding-right:40px}.bottom-sheet-completed-badge{background:#34c75926;border-radius:12px;color:var(--success);display:inline-block;font-size:11px;font-weight:500;margin-bottom:10px;padding:3px 10px}.bottom-sheet-details{margin-bottom:16px}.bottom-sheet-attr{color:var(--text-secondary);font-size:13px;margin:4px 0}.bottom-sheet-attr strong{color:var(--text-primary);font-weight:500}.bottom-sheet-distance-icon{color:var(--text-muted);height:12px;vertical-align:-1px;width:12px}.bottom-sheet-actions{display:flex;gap:10px}.bottom-sheet-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:opacity .2s ease}.bottom-sheet-btn.note-btn{background:var(--accent);color:#fff}.bottom-sheet-btn.photo-btn{background:var(--success);color:#fff}.bottom-sheet-btn.photo-btn.disabled{cursor:not-allowed;opacity:.4}.bottom-sheet-btn svg{height:16px;width:16px}.progress-modal{bottom:20px;font-family:inherit;position:fixed;right:20px;z-index:1000}.progress-modal.expanded{animation:slideUp .2s ease-out;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px #0000001f;display:flex;flex-direction:column;max-height:33vh;width:380px}.progress-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.progress-modal-title{color:var(--text-primary);font-size:13px;font-weight:600}.progress-modal-header-actions{align-items:center;display:flex;gap:8px}.progress-header-btn{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:4px 8px;transition:background-color .15s ease,color .15s ease}.progress-header-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.progress-header-btn.icon{align-items:center;display:flex;justify-content:center;padding:4px}.progress-operation-list{flex:1 1;overflow-y:auto;padding:8px}.progress-operation-item{animation:itemSlideIn .2s ease-out;background:var(--bg-input);border-radius:8px;margin-bottom:6px;padding:10px 12px;transition:background-color .15s ease}.progress-operation-item:last-child{margin-bottom:0}@keyframes itemSlideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.progress-operation-item.completed{background:#34c7591a}.progress-operation-item.error{background:#ff3b301a;border:none;padding:10px 12px}.progress-operation-header{align-items:flex-start;display:flex;gap:10px}.progress-operation-icon{align-items:center;border-radius:50%;color:var(--accent);display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.progress-operation-icon.completed{background:#34c75926;color:var(--success)}.progress-operation-icon.error{background:#ff3b3026;border:none;color:var(--danger);padding:0}.progress-operation-content{flex:1 1;min-width:0}.progress-operation-label{color:var(--text-primary);font-size:12.5px;font-weight:500;line-height:1.3;text-align:left;word-break:break-word}.progress-operation-message{color:var(--text-secondary);font-size:12px;margin-top:2px}.progress-operation-error{color:var(--danger);font-size:12px;margin-top:2px}.progress-operation-actions{align-items:center;display:flex;flex-shrink:0;gap:4px}.progress-action-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:24px;justify-content:center;transition:background-color .15s ease,color .15s ease;width:24px}.progress-action-btn:hover{background:var(--bg-hover)}.progress-action-btn.retry:hover{color:var(--accent)}.progress-action-btn.close:hover{color:var(--danger)}.progress-text-action-btn{background:none;border:1px solid var(--border-color);border-radius:6px;color:var(--accent);cursor:pointer;font-size:11px;font-weight:600;padding:3px 10px;transition:background-color .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap}.progress-text-action-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.progress-text-action-btn.danger{border-color:#ff3b304d;color:var(--danger)}.progress-text-action-btn.danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.progress-bar-container{background:var(--border-color);border-radius:2px;height:4px;margin-top:10px;overflow:hidden}.progress-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s ease}.progress-bar-fill.indeterminate{animation:indeterminateProgress 1.5s ease-in-out infinite;width:30%}@keyframes indeterminateProgress{0%{transform:translateX(-100%)}50%{transform:translateX(200%)}to{transform:translateX(-100%)}}.progress-spinner{animation:spin 1s linear infinite}.progress-minimized-indicator{align-items:center;animation:slideUp .2s ease-out;background:var(--bg-card);border:1px solid var(--border-color);border-radius:28px;box-shadow:0 2px 12px #0000001a;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 14px;transition:box-shadow .15s ease,border-color .15s ease,opacity .15s ease}.progress-minimized-indicator:hover{border-color:var(--border-hover);box-shadow:0 4px 20px #0000001f}.progress-minimized-indicator svg{color:var(--accent)}.progress-minimized-count{color:var(--text-secondary)}.progress-minimized-indicator.idle{opacity:.7}.progress-minimized-indicator.idle:hover{opacity:1}.progress-minimized-indicator.idle svg{color:var(--success)}.progress-minimized-error-dot{background:var(--danger);border-radius:50%;height:8px;width:8px}.progress-minimized-indicator.empty{box-shadow:0 1px 4px #0000000f;font-size:12px;opacity:.5;padding:6px 12px}.progress-minimized-indicator.empty:hover{opacity:.8}.progress-empty-state,.progress-minimized-indicator.empty svg{color:var(--text-secondary)}.progress-empty-state{font-size:13px;padding:24px 16px;text-align:center}@media (max-width:768px){.progress-modal.expanded{border-bottom:none;border-left:none;border-radius:12px 12px 0 0;border-right:none;bottom:0;left:0;max-height:50vh;right:0;width:100%}}.loading-spinner-fullscreen{background:var(--bg-primary);bottom:0;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-spinner-fullscreen,.loading-spinner-inline{align-items:center;display:flex;justify-content:center}.loading-spinner-inline{min-height:200px;padding:40px 20px}.loading-spinner-content{align-items:center;display:flex;flex-direction:column;gap:20px;text-align:center}.spinner{border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent);display:inline-block;position:relative}.spinner,.spinner-ring{animation:spin 1s linear infinite}.spinner-ring{border:3px solid #0000;border-radius:50%;border-top:3px solid var(--accent);position:absolute}.loading-spinner-content.small .spinner,.loading-spinner-content.small .spinner-ring{border-width:2px;height:30px;width:30px}.loading-spinner-content.medium .spinner{height:50px;width:50px}.loading-spinner-content.medium .spinner-ring{border-width:3px;height:50px;width:50px}.loading-spinner-content.large .spinner,.loading-spinner-content.large .spinner-ring{border-width:4px;height:70px;width:70px}.spinner-ring:first-child{animation-delay:0s;opacity:1}.spinner-ring:nth-child(2){animation-delay:-.3s;opacity:.6}.spinner-ring:nth-child(3){animation-delay:-.6s;opacity:.3}.loading-message{color:var(--text-secondary);font-size:14px;font-weight:500;margin:0}.loading-spinner-fullscreen .loading-spinner-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #0000001a;padding:40px 50px}.dark-mode .loading-spinner-fullscreen .loading-spinner-content{box-shadow:0 4px 24px #0000004d}.loading-spinner-inline .loading-message{color:var(--text-secondary)}@media (max-width:768px){.loading-spinner-fullscreen .loading-spinner-content{margin:20px;padding:32px 40px}.loading-message{font-size:13px}.loading-spinner-content.large .spinner{height:60px;width:60px}.loading-spinner-content.large .spinner-ring{border-width:3px;height:60px;width:60px}}@media (max-width:480px){.loading-spinner-fullscreen .loading-spinner-content{margin:15px;padding:24px 32px}.loading-message{font-size:12px}.loading-spinner-content.medium .spinner{height:40px;width:40px}.loading-spinner-content.medium .spinner-ring{border-width:2px;height:40px;width:40px}.loading-spinner-content.large .spinner{height:50px;width:50px}.loading-spinner-content.large .spinner-ring{border-width:3px;height:50px;width:50px}}@media (prefers-reduced-motion:reduce){.spinner-ring{animation:spin 3s linear infinite}}.property-owners-container{max-width:1000px}.property-owners-container .tab-navigation{display:flex;gap:8px;margin-bottom:24px}.property-owners-container .tab-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease}.property-owners-container .tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.property-owners-container .tab-btn.active{background:var(--bg-card);border-color:var(--text-primary);color:var(--text-primary);font-weight:600}.header-controls{flex-wrap:wrap;gap:12px;margin-bottom:24px}.header-controls,.search-box{align-items:center;display:flex}.search-box{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;flex:1 1;gap:8px;height:36px;max-width:350px;padding:0 12px;transition:all .2s ease}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a}.property-owners-container .search-box .search-icon{color:var(--text-muted);flex-shrink:0;font-size:14px}.search-box input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:14px;height:100%;min-width:0;outline:none;padding:0}.clear-search,.search-box input::placeholder{color:var(--text-muted)}.clear-search{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .2s ease}.clear-search:hover{background:var(--bg-hover);color:var(--text-secondary)}.sort-control{align-items:center;display:flex;gap:8px}.sort-control label{color:var(--text-secondary);font-size:13px;white-space:nowrap}.sort-control select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-size:14px;outline:none;padding:10px 14px;transition:all .2s ease}.sort-control select:focus{border-color:var(--accent)}.results-info{color:var(--text-secondary);font-size:13px;padding:14px 0 0}.pagination{justify-content:center;padding:24px 0 8px}.status-section{margin-bottom:24px}.property-owners-list{display:flex;flex-direction:column;gap:16px}.company-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:all .2s ease}.company-item:hover{border-color:var(--border-hover);box-shadow:0 4px 16px #00000014}.dark-mode .company-item:hover{box-shadow:0 4px 16px #0000004d}.company-item.expanded{border-color:var(--accent)}.company-item.sent-yesterday{border-left:4px solid var(--success)}.company-item.has-notes{border-left:4px solid var(--accent)}.company-item.no-notes{border-left:4px solid var(--text-muted)}.company-item-header{align-items:center;cursor:pointer;display:flex;gap:14px;padding:16px 20px;transition:background-color .2s}.company-item-header:hover{background:var(--bg-hover)}.company-icon{flex-shrink:0;font-size:20px}.sent-yesterday .company-icon{color:var(--success)}.has-notes .company-icon{color:var(--accent)}.no-notes .company-icon{color:var(--text-muted)}.company-info{flex:1 1;min-width:0}.company-info h3{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 4px}.company-meta{color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:12px;gap:12px}.property-count{font-weight:500}.notes-count{color:var(--accent);font-weight:600}.company-item.expanded .expand-icon{transform:rotate(180deg)}.company-item-details{animation:slideDown .2s ease;border-top:1px solid var(--border-color);padding:0 20px 20px}.detail-field{align-items:flex-start;display:flex;gap:12px;margin:16px 0}.detail-field label{color:var(--text-secondary);font-size:12px;font-weight:500;letter-spacing:.3px;min-width:80px;padding-top:8px;text-transform:uppercase}.field-display,.field-edit{align-items:center;display:flex;flex:1 1;gap:10px}.field-display span{border-radius:8px}.field-display span,.field-edit input{background:var(--bg-input);color:var(--text-primary);flex:1 1;font-size:14px;padding:10px 12px}.field-edit input{border:1px solid var(--border-color);border-radius:8px;font-family:inherit;transition:all .2s ease}.field-edit input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.cancel-btn,.edit-btn,.save-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;justify-content:center;min-height:32px;min-width:32px;padding:8px;transition:all .2s ease}.edit-btn{background:#0071e31a;color:var(--accent)}.edit-btn:hover{background:var(--accent);color:#fff}.save-btn{background:#34c7591a;color:var(--success)}.save-btn:hover{background:var(--success);color:#fff}.cancel-btn{background:#ff3b301a;color:var(--danger)}.cancel-btn:hover{background:var(--danger);color:#fff}.company-notes-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.notes-header{margin-bottom:12px}.notes-header h4{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.notes-list-inline{display:flex;flex-direction:column;gap:10px;max-height:350px;overflow-y:auto}.note-item-inline{background:var(--bg-input);border-left:3px solid var(--accent);border-radius:8px;padding:12px}.note-header-inline{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.note-header-inline h5{color:var(--accent);font-size:13px;font-weight:600;margin:0}.edit-note-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--accent);cursor:pointer;display:flex;font-size:13px;justify-content:center;padding:6px;transition:all .2s ease}.edit-note-btn:hover{background:#0071e31a}.note-content-inline{color:var(--text-primary);font-size:13px;line-height:1.5;white-space:pre-wrap}.note-edit-inline{display:flex;flex-direction:column;gap:10px}.note-edit-inline textarea{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:13px;line-height:1.5;min-height:80px;padding:12px;resize:vertical;transition:all .2s ease;width:100%}.note-edit-inline textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.note-actions{display:flex;gap:10px;justify-content:flex-end}.cancel-note-btn,.save-note-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.save-note-btn{background:var(--success);color:#fff}.save-note-btn:hover{background:#2e9e4e}.cancel-note-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.cancel-note-btn:hover{background:var(--bg-hover)}.company-actions{align-items:center;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;padding-top:16px}.send-email-btn{align-items:center;background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 18px;transition:all .2s ease}.send-email-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.invite-owner-btn{align-items:center;background:var(--purple);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 18px;transition:all .2s ease}.invite-owner-btn:hover:not(:disabled){background:#9c27b0;transform:translateY(-1px)}.invite-owner-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.action-hint{color:var(--warning);font-size:12px;font-style:italic;margin:0}.invite-tokens-section{padding:0}.invite-tokens-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.invite-tokens-header span{color:var(--text-secondary);font-size:13px}.create-invite-btn{align-items:center;background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease}.create-invite-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.invite-tokens-list{display:flex;flex-direction:column;gap:12px}.invite-token-card{background:var(--bg-card);border:1px solid var(--border-color);border-left:4px solid var(--text-muted);border-radius:10px;padding:16px}.invite-token-card.status-active{border-left-color:var(--success)}.invite-token-card.status-expired{border-left-color:var(--warning)}.invite-token-card.status-used{border-left-color:var(--accent)}.invite-token-card.status-revoked{border-left-color:var(--danger)}.token-main{justify-content:space-between;margin-bottom:12px}.token-email,.token-main{align-items:center;display:flex}.token-email{color:var(--text-primary);font-weight:500;gap:8px}.token-icon{color:var(--text-secondary)}.token-status{border-radius:16px;font-size:11px}.token-status.status-active{background:#34c75926;color:var(--success)}.token-status.status-expired{background:#f5a62326;color:var(--warning)}.token-status.status-used{background:#0071e326;color:var(--accent)}.token-status.status-revoked{background:#ff3b3026;color:var(--danger)}.token-details{color:var(--text-secondary);flex-wrap:wrap;font-size:12px;gap:16px;margin-bottom:12px}.token-actions{flex-wrap:wrap;gap:8px}.token-action-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;gap:6px;padding:8px 14px;transition:all .2s ease}.token-action-btn:hover{background:var(--bg-hover)}.token-action-btn.copy{border-color:var(--accent);color:var(--accent)}.token-action-btn.resend{border-color:var(--success);color:var(--success)}.token-action-btn.revoke{border-color:var(--warning);color:var(--warning)}.token-action-btn.delete{border-color:var(--danger);color:var(--danger)}.modal-content .form-group{margin-bottom:18px}.modal-content .form-group label{color:var(--text-primary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.modal-content .form-group input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px;transition:all .2s ease;width:100%}.modal-content .form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.modal-actions{gap:12px;margin-top:24px}.modal-actions .cancel-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;padding:12px 20px;transition:all .2s ease}.modal-actions .cancel-btn:hover{background:var(--bg-hover)}.modal-actions .submit-btn{align-items:center;background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.modal-actions .submit-btn:hover{background:var(--accent-hover)}@media (max-width:768px){.header-controls{align-items:stretch;flex-direction:column;gap:12px}.search-box{max-width:none}.sort-control{width:100%}.sort-control select{flex:1 1}.results-info{text-align:center}.company-item-header{padding:14px 16px}.company-item-details{padding:0 16px 16px}.company-info h3{font-size:14px}.company-meta{flex-direction:column;gap:4px}.detail-field{align-items:flex-start;flex-direction:column}.detail-field label{margin-bottom:4px;padding-top:0}.field-display,.field-edit{width:100%}.tab-navigation{flex-direction:column}.tab-btn{justify-content:center;width:100%}.invite-tokens-header{align-items:stretch;flex-direction:column;gap:12px}.token-main{align-items:flex-start;flex-direction:column;gap:8px}.token-details{flex-direction:column;gap:4px}.token-actions{width:100%}.token-action-btn{flex:1 1;justify-content:center}.modal-content{padding:20px}.modal-actions{flex-direction:column}.modal-actions button{justify-content:center;width:100%}.cancel-btn,.edit-btn,.edit-note-btn,.save-btn{min-height:44px;min-width:44px}.field-edit input,.note-edit-inline textarea,.search-box input{font-size:16px}}@media (max-width:480px){.company-info h3{font-size:14px}.pagination{flex-direction:column;gap:12px}.pagination-btn{justify-content:center;width:100%}}.company-tokens-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.company-tokens-section h4{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:12px}.tokens-list-inline{display:flex;flex-direction:column;gap:8px}.token-item-inline{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:10px 12px}.token-item-inline .token-info{align-items:center;display:flex;flex:1 1;gap:12px;min-width:200px}.token-item-inline .token-email{color:var(--text-primary);font-size:13px;font-weight:500}.token-item-inline .token-status{align-items:center;border-radius:4px;display:flex;font-size:11px;font-weight:500;gap:4px;padding:3px 8px}.token-item-inline .token-status.status-active{background:#34c75926;color:#34c759}.token-item-inline .token-status.status-expired{background:#ff950026;color:#ff9500}.token-item-inline .token-status.status-used{background:#007aff26;color:#007aff}.token-item-inline .token-status.status-revoked{background:#ff3b3026;color:#ff3b30}.token-item-inline .token-meta{color:var(--text-muted);font-size:12px}.token-actions-inline{display:flex;gap:6px}.token-actions-inline button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:12px;justify-content:center;padding:6px 8px;transition:all .2s ease}.token-actions-inline .copy-link-btn{background:var(--accent);color:#fff}.token-actions-inline .copy-link-btn:hover{background:var(--accent-hover)}.token-actions-inline .revoke-btn{background:#ff950026;color:#ff9500}.token-actions-inline .revoke-btn:hover{background:#ff950040}.token-actions-inline .delete-btn{background:#ff3b3026;color:#ff3b30}.token-actions-inline .delete-btn:hover{background:#ff3b3040}.company-users-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.company-users-section h4{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:12px}.users-list-inline{display:flex;flex-direction:column;gap:8px}.user-item-inline{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:10px 12px}.user-item-inline .user-info{display:flex;flex-direction:column;gap:2px}.user-item-inline .user-name{color:var(--text-primary);font-size:14px;font-weight:500}.user-item-inline .user-email{color:var(--text-muted);font-size:12px}.user-item-inline .user-status{align-items:center;border-radius:12px;display:flex;font-size:12px;gap:4px;padding:4px 8px}.user-item-inline .user-status.status-active{background:#34c75926;color:#34c759}.company-invites-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.company-invites-section h4{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:12px}.invites-list-inline{display:flex;flex-direction:column;gap:8px}.invite-item-inline{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:10px 12px}.invite-item-inline .invite-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.invite-item-inline .invite-email{color:var(--text-primary);font-size:14px;font-weight:500;word-break:break-word}.invite-item-inline .invite-date{align-items:center;color:var(--text-muted);display:flex;font-size:12px;gap:4px}.invite-item-inline .invite-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.invite-item-inline .invite-status{align-items:center;border-radius:12px;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 8px}.invite-item-inline .invite-status.status-active{background:#34c75926;color:#34c759}.invite-item-inline .invite-status.status-expired{background:#ff950026;color:#ff9500}.invite-item-inline .invite-status.status-used{background:#0071e326;color:var(--accent)}.invite-item-inline .invite-status.status-revoked{background:#ff3b3026;color:#ff3b30}.invite-item-inline .copy-link-btn{align-items:center;background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.invite-item-inline .copy-link-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}@media (max-width:480px){.invite-item-inline{align-items:flex-start;flex-direction:column;gap:10px}.invite-item-inline .invite-actions{justify-content:space-between;width:100%}.invite-item-inline .copy-link-btn{flex:1 1;justify-content:center}}.invites-tab-content{margin-top:0}.invites-list{display:flex;flex-direction:column;gap:12px}.invite-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:16px;transition:all .2s ease}.invite-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000d}.invite-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.invite-company{align-items:center;color:var(--text-primary);display:flex;font-size:15px;font-weight:600;gap:8px}.invite-company .company-icon{color:var(--accent);font-size:16px}.invite-card .invite-status{align-items:center;border-radius:12px;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px}.invite-card .invite-status.status-active{background:#34c75926;color:#34c759}.invite-card .invite-status.status-expired{background:#ff950026;color:#ff9500}.invite-card .invite-status.status-used{background:#0071e326;color:var(--accent)}.invite-card .invite-status.status-revoked{background:#ff3b3026;color:#ff3b30}.invite-card-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.invite-detail{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:8px}.invite-detail .detail-icon{color:var(--text-muted);font-size:14px;width:16px}.invite-card-actions{border-top:1px solid var(--border-color);padding-top:12px}.invite-card-actions .copy-link-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s ease;width:100%}.invite-card-actions .copy-link-btn:hover{background:var(--bg-hover);border-color:var(--text-secondary)}.users-tab-content{margin-top:0}.users-list{display:flex;flex-direction:column;gap:12px}.user-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:16px;transition:all .2s ease}.user-card:hover{border-color:var(--text-muted)}.user-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.user-card-info{align-items:center;display:flex;gap:12px}.user-card-info .user-icon{color:var(--text-muted);font-size:20px}.user-card-info .user-details{display:flex;flex-direction:column;gap:2px}.user-card-info .user-name{color:var(--text-primary);font-size:15px;font-weight:600}.user-card-info .user-email{color:var(--text-secondary);font-size:13px}.user-card .user-status{align-items:center;background:#34c75926;border-radius:12px;color:#34c759;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px}.user-card-body{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.user-detail{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:8px}.user-detail .detail-icon{color:var(--text-muted);font-size:14px;width:16px}.user-card-actions{border-top:1px solid var(--border-color);padding-top:12px}.user-card-actions .delete-user-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:#ff3b30;color:var(--danger,#ff3b30);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s ease;width:100%}.user-card-actions .delete-user-btn:hover{background:#ff3b301a;border-color:#ff3b30;border-color:var(--danger,#ff3b30)}@media (max-width:480px){.property-owners-container .tab-navigation{flex-direction:column}.property-owners-container .tab-btn{justify-content:center}.invite-card-header,.user-card-header{align-items:flex-start;flex-direction:column;gap:8px}}.team-container{max-width:1200px}.team-header{margin-bottom:28px}.team-header h1{align-items:center;color:var(--text-primary);display:flex;font-size:20px;font-weight:600;gap:10px;margin:0 0 6px}.team-header h1 svg{color:var(--accent)}.team-header .subtitle{color:var(--text-secondary);font-size:14px;margin:0}.team-container .section-header{border-bottom:none;margin-bottom:24px;padding-bottom:0}.team-container .section-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:18px;font-weight:600;gap:10px;margin:0}.team-container .section-header h2 svg{color:var(--accent)}.tab-navigation{display:flex;gap:8px;margin-bottom:24px}.tab-btn{align-items:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease}.tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.members-list{display:flex;flex-direction:column;gap:0}.member-item{background:var(--bg-card);border:1px solid var(--border-color);border-bottom:none;transition:all .2s ease}.member-item:first-child{border-radius:12px 12px 0 0}.member-item:last-child{border-bottom:1px solid var(--border-color);border-radius:0 0 12px 12px}.member-item:only-child{border-bottom:1px solid var(--border-color);border-radius:12px}.member-item:hover{background:var(--bg-hover)}.member-item.expanded{border-color:var(--accent);border-bottom:1px solid var(--accent)}.member-item.expanded+.member-item{border-top-color:var(--accent)}.member-row{cursor:pointer;gap:14px;padding:16px 20px;transition:background-color .2s}.member-avatar,.member-row{align-items:center;display:flex}.member-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;height:44px;justify-content:center;width:44px}.avatar-icon{color:#fff;font-size:18px}.avatar-icon.owner{color:gold}.member-info{flex:1 1;min-width:0}.member-info h3{color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 4px}.member-email,.member-info h3{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-email{color:var(--text-secondary);font-size:12px;margin:0 0 8px}.role-badge{border-radius:16px;font-size:11px}.role-badge.owner{background:#34c75926;color:var(--success)}.role-badge.employee{background:#0071e326;color:var(--accent)}.dark-mode .role-badge.owner{background:#34c75933}.dark-mode .role-badge.employee{background:#0a84ff33}.expand-indicator{align-items:center;background:var(--bg-input);border-radius:50%;color:var(--text-secondary);display:flex;flex-shrink:0;font-size:18px;height:28px;justify-content:center;transition:all .2s ease;width:28px}.member-card.expanded .expand-indicator{transform:rotate(180deg)}.member-details{animation:slideDown .2s ease;border-top:1px solid var(--border-color);padding:0 16px 16px}.detail-group{margin:16px 0}.detail-group label{color:var(--text-secondary);display:block;font-size:11px;font-weight:500;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.display-field,.edit-field{align-items:center;display:flex;gap:10px}.display-field span{border-radius:8px}.display-field span,.edit-field input{background:var(--bg-input);color:var(--text-primary);flex:1 1;font-size:13px;padding:10px 12px}.edit-field input{border:1px solid var(--border-color);border-radius:8px;font-family:inherit;transition:all .2s ease}.edit-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.icon-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:13px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.icon-btn.edit{background:#0071e31a;color:var(--accent)}.icon-btn.edit:hover{background:var(--accent);color:#fff}.icon-btn.save{background:#34c7591a;color:var(--success)}.icon-btn.save:hover{background:var(--success);color:#fff}.role-change-btn{border:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;padding:8px 14px;transition:all .2s ease}.role-change-btn.owner{background:#ff3b301a;color:var(--danger)}.role-change-btn.owner:hover{background:var(--danger);color:#fff}.role-change-btn.employee{background:#0071e31a;color:var(--accent)}.role-change-btn.employee:hover{background:var(--accent);color:#fff}.member-actions{border-top:1px solid var(--border-color);display:flex;gap:10px;margin-top:16px;padding-top:16px}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:10px;transition:all .2s ease}.action-btn.secondary{background:#0071e31a;color:var(--accent)}.action-btn.secondary:hover{background:var(--accent);color:#fff}.action-btn.danger{background:#ff3b301a;color:var(--danger)}.action-btn.danger:hover{background:var(--danger);color:#fff}.action-btn:disabled{cursor:not-allowed;opacity:.5}.shifts-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.shifts-section h4{color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 12px}.shifts-list{display:flex;flex-direction:column;gap:10px;max-height:250px;overflow-y:auto}.shift-item{background:var(--bg-input);border-left:3px solid var(--accent);border-radius:8px;justify-content:space-between;padding:12px}.shift-info{color:var(--text-secondary);display:flex;flex-direction:column;gap:4px}.shift-info,.shift-properties{font-size:12px}.shift-duration{color:var(--accent);font-size:13px;font-weight:600}.modal-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;padding:20px}.modal-content{animation:slideUp .3s ease;background:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 10px 40px #0003;max-height:90vh;max-width:450px;overflow-y:auto;width:100%}.modal-content h3{margin:0 0 24px}.form-field{display:flex;flex-direction:column}.form-field label{color:var(--text-primary);font-size:13px;font-weight:500;margin-bottom:6px}.required{color:var(--danger)}.form-field input,.form-field select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px;transition:all .2s ease}.form-field input:focus,.form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.form-field small{color:var(--text-secondary);font-size:11px;line-height:1.4;margin-top:6px}.create-btn,.invite-btn{align-items:center;background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.create-btn:hover,.invite-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #0071e34d;transform:translateY(-1px)}.empty-state{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:50px 30px;text-align:center}.empty-state svg{color:var(--accent);margin-bottom:16px;opacity:.4}.empty-state p{color:var(--text-secondary);font-size:14px;margin:8px 0 20px}.access-denied,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px;text-align:center}.access-denied svg{color:var(--danger);margin-bottom:20px}.access-denied h2{color:var(--text-primary);font-size:20px;margin:0 0 8px}.access-denied p{font-size:14px}.access-denied p,.no-data{color:var(--text-secondary);margin:0}.no-data{font-size:13px;font-style:italic}@media (max-width:768px){.tab-navigation{flex-direction:column}.tab-btn{justify-content:center}.member-row{padding:14px 16px}.member-actions{flex-direction:column}.team-container .section-header{align-items:stretch;flex-direction:column;gap:12px}.create-btn,.invite-btn{justify-content:center;width:100%}.modal-content{border-radius:0;margin:0;max-height:100dvh;min-height:100dvh;padding:20px}.form-actions{flex-direction:column}.form-actions button{justify-content:center;width:100%}.shift-item{align-items:flex-start;flex-direction:column;gap:10px}.shift-stats{justify-content:space-between;width:100%}}.invite-management{display:flex;flex-direction:column;margin:0;max-width:100%;overflow-y:auto;padding:0}.invite-management .page-header{border-bottom:1px solid var(--border-color);flex-shrink:0;margin:0;padding:0 0 24px}.page-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;width:100%}.header-content h1{align-items:center;color:var(--text-primary);display:flex;font-size:26px;font-weight:600;gap:12px;margin:0 0 6px}.header-content h1 svg{color:var(--accent)}.subtitle{color:var(--text-secondary);font-size:14px;margin:0}.create-token-btn{align-items:center;background-color:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.create-token-btn:hover{background-color:var(--accent-hover);box-shadow:0 4px 12px #0071e34d;transform:translateY(-1px)}.create-token-btn:active{transform:translateY(0)}.form-modal{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-container{animation:slideUp .3s ease;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:600px;overflow-y:auto;padding:28px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-container h3{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 24px}.form-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1fr;margin-bottom:24px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:14px}.form-group input,.form-group select{padding:12px 14px}.form-group input:focus,.form-group select:focus{outline:none}.form-hint{color:var(--text-muted);font-size:12px;line-height:1.4;margin-top:6px}.form-actions{display:flex;gap:12px;justify-content:flex-end}.invite-management .btn-primary,.invite-management .btn-secondary{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease}.invite-management .btn-primary{background:var(--accent);color:#fff}.invite-management .btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.invite-management .btn-secondary{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.invite-management .btn-secondary:hover{background:var(--bg-hover)}.tokens-list{display:flex;flex:1 1;flex-direction:column;gap:16px;margin:0 auto;max-width:1200px;padding:24px 0;width:100%}.token-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease}.token-card:hover{border-color:var(--border-hover);box-shadow:0 4px 16px #00000014}.dark-mode .token-card:hover{box-shadow:0 4px 16px #0000004d}.token-card.active{border-left:4px solid var(--success)}.token-card.expired{border-left:4px solid var(--warning)}.token-card.used{border-left:4px solid var(--text-muted)}.token-card.revoked{border-left:4px solid var(--danger)}.token-card-header{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.token-info{display:flex;flex-direction:column;gap:8px}.token-role{align-items:center;color:var(--text-primary);display:flex;font-size:15px;font-weight:600;gap:8px}.token-role svg{color:var(--accent)}.token-status{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:500;gap:6px;padding:5px 12px;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.token-status.active{background:#34c75926;color:var(--success)}.token-status.expired{background:#ffc10726;color:var(--warning)}.token-status.used{background:var(--bg-input);color:var(--text-muted)}.token-status.revoked{background:#ff3b3026;color:var(--danger)}.dark-mode .token-status.active{background:#34c75933}.dark-mode .token-status.expired{background:#ffc10733}.dark-mode .token-status.revoked{background:#ff3b3033}.token-actions{display:flex;gap:6px}.btn-icon{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-icon:hover{background:var(--bg-hover);transform:scale(1.05)}.btn-icon.email{color:var(--accent)}.btn-icon.email:hover{background:#0071e31a}.btn-icon.copy{color:var(--accent)}.btn-icon.copy:hover{background:#0071e31a}.btn-icon.revoke{color:var(--warning)}.btn-icon.revoke:hover{background:#ffc1071a}.btn-icon.delete{color:var(--danger)}.btn-icon.delete:hover{background:#ff3b301a}.token-details{display:flex;flex-direction:column;gap:12px}.detail-row{align-items:flex-start;color:var(--text-secondary);display:flex;font-size:14px;gap:12px}.detail-label{color:var(--text-primary);flex-shrink:0;font-weight:500;min-width:80px}.token-value{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-family:SF Mono,Courier New,monospace;font-size:12px;padding:8px 12px;word-break:break-all}.invite-management .empty-state{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:80px 20px;text-align:center}.invite-management .empty-state svg{color:var(--accent);margin-bottom:20px;opacity:.4}.invite-management .empty-state p{color:var(--text-primary);font-size:16px;margin:8px 0}.empty-subtitle{color:var(--text-secondary)!important;font-size:14px!important}.invite-management .access-denied{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:100px 20px;text-align:center}.invite-management .access-denied svg{color:var(--danger);margin-bottom:24px}.invite-management .access-denied h2{color:var(--text-primary);margin-bottom:12px}.invite-management .access-denied p{color:var(--text-secondary);font-size:15px}.invite-management .loading{align-items:center;display:flex;flex-direction:column;gap:20px;height:300px;justify-content:center;padding:20px}.invite-management .loading-spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent);height:44px;width:44px}.invite-management .loading p{color:var(--text-secondary);font-size:15px;margin:0}@media (max-width:768px){.invite-management .page-header{padding:0 0 20px}.page-header-content{align-items:flex-start;flex-direction:column;gap:16px;max-width:none}.header-content h1{font-size:22px}.tokens-list{max-width:none;padding:20px 0}.create-token-btn{justify-content:center;padding:14px 20px;width:100%}.form-container{padding:20px}.token-card{padding:16px}.token-card-header{flex-direction:column;gap:12px}.token-actions{justify-content:flex-end;width:100%}.detail-label{min-width:70px}}@media (max-width:480px){.header-content h1{font-size:20px}.token-role{font-size:14px}}.invite-management.embedded{height:auto;overflow:visible;padding:0}.invite-management.embedded .tokens-list{margin:0;padding:0}.embedded-header{display:flex;justify-content:flex-end;margin-bottom:20px}.address-autocomplete{min-width:500px;position:relative}.address-autocomplete .edit-input{max-width:none;min-width:500px;width:100%}.address-suggestions{background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 12px #00000026;left:0;list-style:none;margin-top:2px;max-height:200px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:1000}.address-suggestion{border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:8px 10px}.address-suggestion:last-child{border-bottom:none}.address-suggestion.active,.address-suggestion:hover{background:var(--bg-hover)}.suggestion-main{color:var(--text-primary);font-size:14px;font-weight:500}.suggestion-secondary{color:var(--text-secondary);font-size:12px}.property-data-container{display:flex;flex-direction:column;margin:0 auto;max-width:100%;padding:0}.property-data-header{display:flex;flex-direction:column;flex-shrink:0;gap:20px;margin-bottom:24px}.property-data-header h1{color:var(--text-primary);font-size:26px;font-weight:600;margin:0}.controls{flex-wrap:wrap;gap:15px}.controls,.search-container{align-items:center;display:flex}.search-container{max-width:300px}.search-icon{color:var(--text-muted);font-size:14px;left:14px;pointer-events:none;position:absolute;z-index:1}.property-data-container .search-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;padding:10px 14px 10px 40px;transition:all .2s ease;width:100%}.property-data-container .search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.property-data-container .search-input::placeholder{color:var(--text-muted)}.action-buttons{align-items:center;display:flex;gap:10px}.add-property-button,.update-map-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.update-map-button{background-color:var(--success);color:#fff}.update-map-button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.update-map-button:disabled{background-color:var(--bg-hover);color:var(--text-muted);cursor:not-allowed}.add-property-button{background-color:var(--accent);color:#fff}.add-property-button:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.table-container{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.table-info{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0;padding:16px 20px}.table-info p{color:var(--text-secondary);font-size:14px;margin:0}.table-wrapper{flex:1 1;overflow:auto;padding-bottom:40px}.property-data-table{border-collapse:collapse;font-size:14px;table-layout:fixed;width:100%}.property-data-table thead{background-color:var(--bg-card);position:-webkit-sticky;position:sticky;top:0;z-index:10}.sortable-header{background-color:var(--accent);border-bottom:2px solid var(--accent-hover);color:#fff;cursor:pointer;font-weight:500;padding:14px 12px;position:relative;text-align:left;transition:background-color .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-header:hover{background-color:var(--accent-hover)}.header-content{align-items:center;display:flex;gap:8px;justify-content:space-between}.sort-icon{color:#fff9;flex-shrink:0;font-size:12px}.sort-icon.active{color:#fff}.property-cell{border-bottom:1px solid var(--border-color);color:var(--text-primary);overflow:visible;padding:0;position:relative;vertical-align:top}.cell-content{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:10px 12px;position:relative}.cell-content.editable{cursor:pointer;transition:background-color .15s ease}.cell-content.editable:hover{background-color:var(--bg-hover)}.cell-value{cursor:default;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-value:hover{word-wrap:break-word;background:var(--bg-card);border-radius:6px;box-shadow:0 4px 12px #0003;box-sizing:border-box;left:0;max-width:300px;min-width:100%;overflow:visible;padding:8px 12px;position:absolute;top:0;white-space:normal;z-index:100}.cell-value.has-notes{background-color:#ffc10726;border-left:3px solid var(--warning);border-radius:8px;padding:6px 10px}.dark-mode .cell-value.has-notes{background-color:#ffc1071a}.edit-cell-btn{background:none;border:none;border-radius:6px;color:var(--accent);cursor:pointer;flex-shrink:0;opacity:0;padding:6px;transition:all .2s ease}.property-cell:hover .edit-cell-btn{opacity:1}.edit-cell-btn:hover{background-color:#0071e31a}.edit-cell{background:var(--bg-card);border-radius:6px;box-shadow:0 4px 12px #0003;box-sizing:border-box;display:flex;flex-direction:column;gap:6px;left:0;padding:8px;position:absolute;top:0;z-index:100}.add-input,.edit-input,.edit-textarea{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;line-height:1.4;overflow:hidden;padding:8px 10px;resize:none;transition:border-color .2s ease}.edit-input{max-width:300px;min-width:120px;width:auto}.edit-input:focus,.edit-textarea:focus{border-color:var(--border-hover);outline:none}.edit-textarea{min-height:60px;resize:vertical}.add-input{background-color:var(--bg-input);border-color:var(--border-color);min-width:0;width:100%}.add-input:focus{border-color:var(--accent);outline:none}.add-row .property-cell{overflow:hidden;padding:8px}.add-actions,.edit-actions{display:flex;gap:8px;justify-content:flex-end}.cancel-add-btn,.cancel-btn,.save-add-btn,.save-btn{align-items:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:11px;font-weight:500;justify-content:center;padding:4px 8px;transition:all .15s ease}.cancel-add-btn:hover,.cancel-btn:hover,.save-add-btn:hover,.save-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.actions-header{cursor:default;padding-right:12px;width:100px}.actions-header:hover{background-color:var(--accent)}.actions-cell{border-bottom:1px solid var(--border-color);padding:10px 8px}.property-actions{flex-wrap:nowrap;gap:4px;justify-content:center}.completion-status{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:5px 10px;white-space:nowrap}.completion-status.completed{background-color:#34c75926;color:var(--success)}.completion-status.pending{background-color:#ffc10726;color:var(--warning)}.dark-mode .completion-status.completed{background-color:#34c75933}.dark-mode .completion-status.pending{background-color:#ffc10733}.view-on-map-btn{background-color:#0071e31a;border-radius:6px;color:var(--accent);font-size:12px;padding:6px}.view-on-map-btn:hover{background-color:var(--accent);color:#fff}.duplicate-btn{align-items:center;background-color:#af52de1a;border:none;border-radius:6px;color:var(--purple);cursor:pointer;display:flex;font-family:inherit;font-size:12px;justify-content:center;padding:6px;transition:all .2s ease}.duplicate-btn:hover{background-color:var(--purple);color:#fff}.delete-btn{align-items:center;background-color:#ff3b301a;border:none;border-radius:6px;color:var(--danger);cursor:pointer;display:flex;font-family:inherit;font-size:12px;justify-content:center;padding:6px;transition:all .2s ease}.delete-btn:hover{background-color:var(--danger);color:#fff}.add-row{background-color:#34c7590d;border-left:3px solid var(--success)}.dark-mode .add-row{background-color:#34c75914}.loading-container{height:300px}.no-data-message{background-color:var(--bg-primary);font-size:14px;margin-top:20px;padding:50px 30px}.filter-bar{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-shrink:0;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:10px 16px}.filter-bar,.filter-group{align-items:center;display:flex}.filter-group{gap:6px}.filter-group label{color:var(--text-primary);font-size:13px;font-weight:500;white-space:nowrap}.filter-group select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:13px;min-width:110px;padding:6px 10px;transition:all .2s ease}.filter-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.days-filter .day-checkboxes{display:flex;flex-wrap:wrap;gap:4px}.day-checkbox{align-items:center;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 8px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.day-checkbox input{display:none}.day-checkbox.active,.day-checkbox:has(input:checked){background-color:var(--accent);border-color:var(--accent);color:#fff}.day-checkbox:hover:not(.active){border-color:var(--accent)}.status-filter .status-checkboxes{display:flex;gap:14px}.status-checkbox{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px}.status-checkbox input{accent-color:var(--accent);cursor:pointer;height:18px;width:18px}.status-label.completed{color:var(--success);font-weight:500}.status-label.pending{color:var(--warning);font-weight:500}.clear-filters-btn{align-items:center;background-color:#ff3b301a;border:none;border-radius:8px;color:var(--danger);cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:500;gap:4px;margin-left:auto;padding:6px 12px;transition:all .2s ease}.clear-filters-btn:hover{background-color:var(--danger);color:#fff}.pagination-container{background-color:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;justify-content:center;padding:16px 20px}.pagination{align-items:center;display:flex;gap:12px}.pagination-btn{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);gap:8px;padding:10px 16px}.pagination-btn:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--accent)}.pagination-btn:disabled{opacity:.5}.pagination-info{white-space:nowrap}@media (max-width:1200px){.property-data-table{font-size:13px}.cell-content,.sortable-header{padding:12px 8px}.controls{gap:10px}.search-container{max-width:250px;min-width:150px}.filter-bar{gap:10px}.filter-group select{min-width:100px}}@media (max-width:768px){.property-data-container{padding:0}.controls{align-items:stretch;flex-direction:column;gap:15px}.search-container{max-width:none;min-width:auto}.action-buttons{flex-direction:column;gap:8px}.add-property-button,.update-map-button{justify-content:center;width:100%}.property-data-table{font-size:12px}.sortable-header{min-width:80px;padding:10px 6px}.header-content{flex-direction:column;gap:4px}.cell-content{align-items:stretch;flex-direction:column;padding:10px 6px}.edit-cell-btn{align-self:flex-start;opacity:1}.table-wrapper{overflow-x:auto}.property-actions{flex-direction:row;gap:6px}.duplicate-btn,.view-on-map-btn{justify-content:center}.filter-bar{align-items:stretch;flex-direction:column}.filter-group{flex-wrap:wrap}.days-filter{align-items:flex-start;flex-direction:column}.days-filter .day-checkboxes{width:100%}.status-filter{align-items:flex-start;flex-direction:column}.clear-filters-btn{justify-content:center;margin-left:0;width:100%}.table-info{align-items:stretch;flex-direction:column;text-align:center}.pagination{justify-content:center}}.duplicate-row{background-color:#ffc1071a;border-left:4px solid var(--warning)}.duplicate-row td:first-child{position:relative}.duplicate-row .property-cell{background-color:#ffc1070d}.dark-mode .duplicate-row{background-color:#ffc10726}.dark-mode .duplicate-row .property-cell{background-color:#ffc1071a}.bulk-edited-row{animation:bulk-edit-fade 3s ease-out forwards;background-color:#34c7591a;border-left:4px solid var(--success)}.bulk-edited-row .property-cell{background-color:#34c7590d}.dark-mode .bulk-edited-row{background-color:#34c75926}.dark-mode .bulk-edited-row .property-cell{background-color:#34c7591a}@keyframes bulk-edit-fade{0%{opacity:1}70%{opacity:1}to{opacity:.4}}.days-dropdown{background:var(--bg-card);border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;min-width:160px;padding:12px;position:absolute;top:0;z-index:100}.days-dropdown-options{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.days-dropdown-option{align-items:center;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.days-dropdown-option input{display:none}.days-dropdown-option.selected{background-color:var(--accent);border-color:var(--accent);color:#fff}.days-dropdown-option:hover:not(.selected){background-color:var(--bg-hover);border-color:var(--accent)}.service-badge{align-items:center;border-radius:12px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px;transition:all .2s ease}.service-badge.service-yes{background-color:#34c75926;color:var(--success)}.service-badge.service-no{background-color:#8e8e9326;color:var(--text-muted)}.service-badge:hover{transform:scale(1.05)}.dark-mode .service-badge.service-yes{background-color:#34c75933}.dark-mode .service-badge.service-no{background-color:#8e8e9333}.service-badge.service-pending{background-color:#ffc10726;color:#f0ad4e;color:var(--warning,#f0ad4e);font-size:10px;gap:3px;padding:3px 7px;white-space:nowrap}.dark-mode .service-badge.service-pending{background-color:#ffc10733}.service-badge.billing-weekly{background-color:#007aff1f;color:#007aff;color:var(--accent,#007aff)}.service-badge.billing-monthly{background-color:#af52de1f;color:#af52de}.dark-mode .service-badge.billing-weekly{background-color:#007aff33}.dark-mode .service-badge.billing-monthly{background-color:#af52de33}.undo-button{align-items:center;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.undo-button:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--accent)}.undo-button:disabled{cursor:not-allowed;opacity:.4}.toolbar-toggle-btn{align-items:center;background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.toolbar-toggle-btn:hover{background-color:var(--bg-hover);border-color:var(--accent)}.toolbar-toggle-btn.active{background-color:var(--accent);border-color:var(--accent);color:#fff}.toolbar-toggle-btn.has-active:not(.active){border-color:var(--accent);color:var(--accent)}.tools-menu-container{position:relative}.tools-menu-backdrop{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.tools-menu-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #00000026;display:flex;flex-direction:column;gap:2px;margin-top:4px;min-width:200px;padding:6px;position:absolute;right:0;top:100%;z-index:100}.tools-menu-dropdown button{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:10px;padding:10px 14px;text-align:left;transition:background-color .15s ease;width:100%}.tools-menu-dropdown button:hover:not(:disabled){background-color:var(--bg-hover)}.tools-menu-dropdown button:disabled{cursor:not-allowed;opacity:.4}.tools-menu-section{align-items:center;display:flex;gap:10px;padding:8px 14px}.tools-menu-label{color:var(--text-secondary);font-size:13px;font-weight:600;white-space:nowrap}.tools-menu-select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;flex:1 1;font-family:inherit;font-size:13px;min-width:0;padding:6px 10px}.tools-menu-select:focus{border-color:var(--accent);outline:none}.tools-menu-divider{background-color:var(--border-color);height:1px;margin:4px 8px}.checkbox-cell,.checkbox-header{max-width:40px;min-width:40px;padding:10px 8px;text-align:center;width:40px}.checkbox-header{background-color:var(--accent);border-bottom:2px solid var(--accent-hover)}.checkbox-cell{border-bottom:1px solid var(--border-color)}.row-checkbox{accent-color:var(--accent);cursor:pointer;height:16px;width:16px}.selected-row{background-color:#0071e314}.dark-mode .selected-row{background-color:#0071e326}.column-picker-container{display:flex;justify-content:flex-end;position:relative}.column-picker-backdrop{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.column-picker-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #00000026;margin-top:4px;min-width:180px;padding:8px;position:absolute;right:0;top:100%;z-index:100}.column-picker-option{align-items:center;border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;gap:8px;padding:6px 10px;transition:background-color .15s ease}.column-picker-option:hover{background-color:var(--bg-hover)}.column-picker-option input[type=checkbox]{accent-color:var(--accent);cursor:pointer;height:14px;width:14px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:var(--bg-card);border-radius:14px;box-shadow:0 20px 60px #0000004d;max-width:440px;padding:28px;width:90%}.modal-content h3{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 20px}.modal-body{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.modal-field{align-items:center;display:flex;gap:12px}.modal-field label{color:var(--text-secondary);font-size:14px;font-weight:500;min-width:100px}.modal-value{font-weight:600}.modal-date-input,.modal-value{color:var(--text-primary);font-size:14px}.modal-date-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;flex:1 1;font-family:inherit;padding:10px 14px}.modal-date-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.modal-warning{background-color:#ffc1071a;border-radius:8px;color:var(--warning);font-size:13px;margin:0;padding:10px 14px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-cancel-btn{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.modal-cancel-btn:hover:not(:disabled){background-color:var(--bg-hover)}.modal-confirm-btn{background-color:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.modal-confirm-btn:hover:not(:disabled){background-color:var(--accent-hover)}.modal-confirm-btn:disabled{cursor:not-allowed;opacity:.5}.view-on-map-btn:disabled{cursor:not-allowed;opacity:.3}.view-on-map-btn:disabled:hover{background-color:#0071e31a;color:var(--accent)}@media (max-width:768px){.toolbar-toggle-btn,.undo-button{justify-content:center;width:100%}.tools-menu-dropdown{left:0;min-width:100%;right:auto}.checkbox-cell,.checkbox-header{max-width:32px;min-width:32px;padding:8px 4px;width:32px}.row-checkbox{height:14px;width:14px}}.upload-modal{max-width:480px}.upload-zone-inline{background:var(--bg-card);border:2px dashed var(--border-hover);border-radius:12px;padding:32px 24px;text-align:center;transition:border-color .2s}.upload-zone-inline:hover{border-color:var(--accent)}.upload-zone-icon{color:var(--accent);height:40px;margin-bottom:12px;width:40px}.upload-zone-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 8px}.upload-zone-desc{color:var(--text-secondary);font-size:13px;font-weight:500;margin:0}.upload-zone-optional{color:var(--text-muted);font-size:12px;margin:4px 0 16px}.upload-file-label{align-items:center;cursor:pointer;display:inline-flex;gap:8px}.upload-progress-inline{display:flex;flex-direction:column;gap:14px}.upload-progress-info{align-items:center;display:flex;gap:12px}.upload-progress-file-icon{background:var(--bg-hover);border-radius:8px;color:var(--accent);flex-shrink:0;height:32px;padding:6px;width:32px}.upload-progress-filename{color:var(--text-primary);font-size:14px;font-weight:500}.upload-progress-status{color:var(--text-secondary);font-size:12px}.upload-progress-bar-row{align-items:center;display:flex;gap:12px}.upload-progress-track{background:var(--bg-input);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.upload-progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:4px;height:100%;transition:width .3s ease}.upload-progress-fill.complete{background:linear-gradient(90deg,var(--success),#2ea043)}.upload-progress-fill.cancelled{background:linear-gradient(90deg,var(--danger),#e62e26)}.upload-progress-pct{color:var(--text-primary);font-size:13px;font-weight:600;min-width:40px;text-align:right}.upload-status-inline{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 14px}.upload-status-inline.in-progress{background:#0071e31a;color:var(--accent)}.upload-status-inline.complete{background:#34c7591a;color:var(--success)}.upload-status-inline.cancelled{background:#ff3b301a;color:var(--danger)}.dark-mode .upload-status-inline.in-progress{background:#0a84ff26}.dark-mode .upload-status-inline.complete{background:#34c75926}.dark-mode .upload-status-inline.cancelled{background:#ff3b3026}.upload-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:initial;height:16px;width:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.employee-property-header,.header-row{margin-bottom:8px}.header-row{align-items:center;display:flex;gap:12px}.employee-property-header h1{color:var(--text-primary);font-size:18px;font-weight:600;margin:0;white-space:nowrap}.filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.filter-select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;flex:0 0 auto;font-family:inherit;font-size:15px;padding:10px 14px;transition:all .2s ease;width:auto}.filter-select:focus{border-color:var(--accent);outline:none}.employee-property-container .search-container{align-items:center;display:flex;flex:1 1;max-width:180px;min-width:120px;position:relative}.employee-property-container .search-icon{color:var(--text-muted);font-size:12px;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.employee-property-container .search-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:13px;padding:8px 10px 8px 30px;transition:all .2s ease;width:100%}.employee-property-container .search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #0071e31a;outline:none}.employee-property-container .search-input::placeholder{color:var(--text-muted)}.filter-checkbox{background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;font-size:12px;gap:6px;padding:6px 10px;white-space:nowrap}.filter-checkbox input[type=checkbox]{height:14px;margin:0;width:14px}.regions-container{display:flex;flex-direction:column;gap:24px}.region-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;overflow:hidden;transition:all .3s ease}.region-header{align-items:center;background:#0071e314;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.dark-mode .region-header{background:#0a84ff1a}.region-title{align-items:center;display:flex;gap:10px}.region-icon{color:var(--accent);font-size:18px}.region-title h2{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.region-stats{gap:16px}.region-stats,.stat{align-items:center;display:flex}.stat{font-size:13px;font-weight:500;gap:6px}.stat.completed{color:var(--success)}.stat.pending{color:var(--warning)}.completion-percentage{background:var(--bg-card);border-radius:16px;color:var(--text-secondary);font-size:13px;font-weight:600;padding:5px 14px}.progress-bar{background:var(--border-color);height:4px;position:relative}.progress-fill{background:linear-gradient(90deg,var(--success),#2e9e4e);height:100%;transition:width .3s ease}.property-item{background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:10px 20px;transition:background-color .2s}.property-item:last-child{border-bottom:none}.property-item:hover{background:var(--bg-hover)}.property-item.completed{border-left:4px solid var(--success)}.property-item.pending{border-left:4px solid var(--warning)}.property-main{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:4px}.property-address{flex:1 1}.address{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:4px}.property-name{color:var(--text-secondary);font-size:12px;font-style:italic}.property-info{align-items:flex-end;display:flex;flex-direction:column;gap:4px;text-align:right}.service-days{background:#0071e31a;border-radius:10px;color:var(--accent);font-size:11px;font-weight:500;padding:3px 10px}.dark-mode .service-days{background:#0a84ff26}.property-status{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.completion-info,.pending-info{align-items:center;display:flex;gap:10px}.status-icon{font-size:16px}.status-icon.completed{color:var(--success)}.status-icon.pending{color:var(--warning)}.completion-details{display:flex;flex-direction:column;gap:2px}.status-text{color:var(--text-primary);font-size:13px;font-weight:600}.completion-time{color:var(--text-secondary);font-size:11px}.completed-by{color:var(--text-muted);font-size:10px;font-style:italic}.view-on-map-btn{background:var(--accent);font-size:14px;height:36px;justify-content:center;min-width:36px;padding:8px 10px}.view-on-map-btn:hover{background:var(--accent-hover)}.property-notes{background:#0071e30d;border-left:3px solid var(--accent);border-radius:6px;color:var(--text-primary);font-size:12px;line-height:1.5;margin-top:8px;padding:10px 12px}.property-notes strong{color:var(--accent)}.expand-icon{margin-left:10px;transition:transform .2s}.property-item.expanded .expand-icon{transform:rotate(180deg)}.property-details-expanded{animation:slideDown .2s ease;border-top:1px solid var(--border-color);margin-top:12px;padding:16px 0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.property-details-expanded h4{color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 16px}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.photo-item{background:var(--bg-card)}.photo-thumbnail{align-items:center;background:var(--bg-input);display:flex;height:180px;justify-content:center;width:100%}.photo-thumbnail img{cursor:pointer;transition:transform .2s}.photo-thumbnail img:hover{transform:scale(1.05)}.photo-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.photo-status{border-radius:12px;display:inline-block;font-weight:500;padding:4px 10px}.photo-status.complete{background:#34c75926}.photo-status.incomplete{background:#f5a62326}.photo-date{color:var(--text-secondary);font-size:11px}.photo-uploader{color:var(--text-muted);font-size:10px;font-style:italic}.photo-note{background:var(--bg-input);border-left:3px solid var(--warning);border-radius:4px;color:var(--text-primary);font-size:11px;margin-bottom:8px;margin-top:8px;padding:8px}.photo-note strong{color:var(--warning)}.download-photo-btn{align-items:center;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:12px;gap:6px;justify-content:center;padding:8px 14px;transition:all .2s ease;width:100%}.download-photo-btn:hover{background:var(--accent-hover)}.loading-photos{gap:16px;padding:40px}.loading-photos .spinner{height:36px;width:36px}.loading-photos p{color:var(--text-secondary);font-size:13px;margin:0}.no-photos{gap:12px}.no-photos p{font-size:13px}.photo-modal-overlay{background:#000000e6;z-index:3000}.photo-modal-content{align-items:center;display:flex;justify-content:center}.photo-modal-close{background:#fff;border-radius:50%;color:var(--text-primary);font-size:20px;height:36px;top:-44px;transition:all .2s ease;width:36px}.photo-modal-close:hover{background:var(--danger);color:#fff}.loading-container{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:300px;padding:40px}.loading-container p{color:var(--text-secondary);font-size:14px;margin:0}.no-data-message{background:var(--bg-input);border-radius:12px;color:var(--text-secondary);font-style:italic;padding:40px;text-align:center}@media (max-width:768px){.header-row{flex-wrap:wrap;gap:8px}.employee-property-container .search-container{flex:1 1;max-width:none;min-width:100px}.filters-row{gap:6px}.filter-select{-webkit-appearance:menulist;appearance:menulist;flex:0 0 auto;font-size:15px;padding:10px 12px;width:auto}.filter-checkbox{font-size:14px;padding:10px 12px}.region-header{align-items:stretch;flex-direction:column;gap:12px;padding:16px}.region-stats,.region-title{justify-content:center}.region-stats{display:flex;flex-wrap:wrap;gap:8px}.stat{background:var(--bg-card);border-radius:20px;flex:0 0 auto;font-size:12px;padding:6px 12px}.completion-percentage{margin-top:4px;text-align:center;width:100%}.property-item{display:flex;flex-direction:column;gap:12px;padding:16px}.property-main{align-items:flex-start;flex-direction:row;gap:12px}.property-address{flex:1 1;min-width:0}.address{word-wrap:break-word;overflow-wrap:break-word}.property-info{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:6px;text-align:left}.expand-icon{flex-shrink:0;margin:-8px -8px -8px 0;padding:8px}.property-status{align-items:center;border-top:1px solid var(--border-color);flex-direction:row;gap:12px;justify-content:space-between;padding-top:12px}.completion-info,.pending-info{align-items:center;flex-direction:row;gap:10px}.completion-details{align-items:center;flex-direction:row;flex-wrap:wrap;gap:8px}.view-on-map-btn{flex-shrink:0;height:44px;min-width:44px;width:44px}.photos-grid{grid-template-columns:1fr}.photo-modal-close{right:10px;top:10px}.filter-select,.search-input{font-size:16px}}@media (max-width:480px){.header-row{align-items:stretch;flex-direction:column;gap:6px}.employee-property-header h1{font-size:16px;text-align:left}.employee-property-container .search-container{max-width:none}.filters-row{gap:4px}.filter-select{flex:0 0 auto;font-size:15px;padding:10px 12px;width:auto}.filter-checkbox{font-size:14px;gap:6px;padding:10px 12px}.filter-checkbox input[type=checkbox]{height:18px;width:18px}.region-title h2{font-size:15px}.region-icon{font-size:16px}.property-item,.region-header{padding:14px}.address{font-size:14px;line-height:1.3}.property-name{font-size:11px;margin-top:2px}.service-days{font-size:10px;padding:2px 8px}.status-text{font-size:12px}.completed-by,.completion-time{font-size:10px}.stat{font-size:11px;padding:5px 10px}.completion-percentage{font-size:12px;padding:6px 12px}.filter-select,.search-input{font-size:16px}}.property-portal-container{background-color:var(--bg-primary);box-sizing:border-box;margin:0;max-width:100%;overflow-y:auto;padding:24px;width:100%}.property-portal-container .page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.property-portal-container .page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 4px}.property-portal-container .page-subtitle{color:var(--text-secondary);font-size:15px;margin:0}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}.search-container{flex:1 1;max-width:400px;min-width:200px;position:relative}.search-input{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px;transition:all .2s ease;width:100%}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.search-input::placeholder{color:var(--text-muted)}.filter-checkboxes{display:flex;gap:16px}.filter-checkbox{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px}.filter-checkbox input[type=checkbox]{accent-color:var(--accent);cursor:pointer;height:18px;width:18px}.property-portal-container .section-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.properties-section{overflow:visible}.properties-list{padding:0}.property-list-item{border-bottom:1px solid var(--border-color);transition:all .2s ease}.property-list-item:last-child{border-bottom:none}.property-list-item:hover{background-color:var(--bg-hover)}.property-list-item.expanded{background-color:var(--bg-input)}.property-row{align-items:center;cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:14px 20px}.property-main-info{flex:1 1;min-width:0}.property-address{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 4px}.property-schedule{display:flex;flex-wrap:wrap;gap:14px}.property-schedule .schedule-item{align-items:center;color:var(--text-secondary);display:flex;font-size:13px;gap:5px}.property-schedule .schedule-icon{font-size:11px}.property-schedule .schedule-icon.trash{color:var(--text-muted)}.property-schedule .schedule-icon.recycle{color:var(--success)}.property-actions{align-items:center;display:flex;flex-shrink:0;gap:12px}.status-icon-only{align-items:center;display:flex;font-size:18px;justify-content:center}.status-icon-only .status-completed{color:var(--success)}.status-icon-only .status-pending{color:var(--text-muted)}.view-on-map-btn{align-items:center;background-color:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s ease;white-space:nowrap}.view-on-map-btn:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.view-on-map-btn:active{transform:translateY(0)}.expand-icon{color:var(--text-muted);flex-shrink:0;font-size:14px;transition:transform .2s ease}.expand-icon.rotated{transform:rotate(180deg)}.today-completion-info{color:var(--success);font-size:13px;padding:0 20px 12px}.property-notes-inline{align-items:flex-start;color:var(--text-secondary);display:flex;font-size:13px;gap:8px;padding:0 20px 12px}.property-notes-inline svg{color:var(--accent);flex-shrink:0;margin-top:2px}.property-expanded-section{background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:20px}.photos-section{margin-bottom:24px}.history-section h4,.photos-section h4{color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 14px}.loading-photos{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;padding:30px}.loading-photos .spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent);height:32px;margin-bottom:10px;width:32px}.photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-item{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.photo-thumbnail{aspect-ratio:4/3;cursor:pointer;overflow:hidden}.photo-thumbnail img{height:100%;object-fit:cover;transition:transform .2s ease;width:100%}.photo-thumbnail:hover img{transform:scale(1.05)}.photo-info{display:flex;flex-direction:column;gap:6px;padding:12px}.photo-status{border-radius:4px;font-size:11px;font-weight:600;padding:4px 8px;text-transform:uppercase;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.photo-status.complete{background-color:#34c75926;color:var(--success)}.photo-status.incomplete{background-color:#ffc10726;color:var(--warning)}.photo-date{color:var(--text-muted);font-size:12px}.photo-note{line-height:1.4}.download-btn,.photo-note{color:var(--text-secondary);font-size:12px}.download-btn{align-items:center;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;font-family:inherit;gap:6px;margin-top:4px;padding:8px 12px;transition:all .2s ease}.download-btn:hover{background-color:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.no-photos{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-muted);display:flex;flex-direction:column;padding:40px}.no-photos svg{margin-bottom:10px;opacity:.5}.no-photos p{font-size:14px;margin:0}.history-section{margin-top:0}.no-history{color:var(--text-muted);font-size:13px;font-style:italic}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{align-items:flex-start;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;display:flex;gap:14px;padding:12px}.history-date{align-items:center;color:var(--accent);display:flex;flex-shrink:0;font-size:13px;font-weight:600;gap:6px;min-width:100px}.history-details{color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:13px;gap:8px 16px}.history-time{color:var(--text-primary)}.history-worker{color:var(--text-secondary)}.history-notes{align-items:center;color:var(--text-muted);display:flex;gap:4px;width:100%}.history-notes svg{color:var(--accent);font-size:11px}.pagination-controls{align-items:center;background-color:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;gap:16px;justify-content:center;padding:20px}.pagination-btn{align-items:center;background-color:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:var(--accent-hover)}.pagination-btn:disabled{background-color:var(--bg-input);color:var(--text-muted);cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:14px;font-weight:500}.no-properties{color:var(--text-secondary);padding:50px 25px;text-align:center}.no-properties p{font-size:15px;margin:10px 0}.photo-modal-overlay{align-items:center;background-color:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.photo-modal-content{max-height:90vh;max-width:90vw;position:relative}.photo-modal-content img{border-radius:8px;max-height:90vh;max-width:100%;object-fit:contain}.photo-modal-close{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:32px;height:40px;justify-content:center;padding:0;position:absolute;right:0;top:-40px;width:40px}.photo-modal-close:hover{opacity:.8}.service-pill{align-items:center;border:none;border-radius:20px;cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:600;gap:6px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.service-pill.active{background-color:#34c75926;color:var(--success)}.service-pill.active:hover{background-color:#34c75940}.service-pill.inactive{background-color:#8e8e9326;color:var(--text-muted)}.service-pill.inactive:hover{background-color:#8e8e9340}.service-pill.pending-deactivation{background-color:#ffc10726;color:#f0ad4e;color:var(--warning,#f0ad4e)}.service-pill.pending-deactivation:hover{background-color:#ffc10740}.service-pill.pending-activation{background-color:#34c75926;color:#34c759;color:var(--success,#34c759)}.service-pill.pending-activation:hover{background-color:#34c75940}.service-pill:disabled{cursor:not-allowed;opacity:.6}.pill-spinner{animation:spin .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;display:inline-block;height:14px;width:14px}.confirm-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9998}.confirm-dialog{background-color:var(--bg-card);border-radius:14px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:24px;width:100%}.confirm-dialog h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 12px}.confirm-dialog p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 20px}.dont-ask-again{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;gap:8px;margin-bottom:16px}.dont-ask-again input{cursor:pointer}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.btn-cancel-dialog{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-cancel-dialog:hover{background-color:var(--bg-hover)}.btn-confirm-dialog{background-color:#ff3b30;background-color:var(--danger,#ff3b30);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-confirm-dialog:hover{opacity:.9}.btn-confirm-dialog.secondary{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.btn-confirm-dialog.secondary:hover{background-color:var(--bg-hover);opacity:1}.period-selector-actions{display:flex;gap:10px;margin-bottom:12px}.period-selector-actions .btn-confirm-dialog{background-color:#007aff;background-color:var(--accent,#007aff);color:#fff;flex:1 1}.period-selector-actions .btn-confirm-dialog.secondary{background-color:var(--bg-input);border:2px solid #007aff;border:2px solid var(--accent,#007aff);color:var(--text-primary)}.property-portal-container .loading-container{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:60px 20px}@media (max-width:768px){.property-portal-container{padding:16px}.property-portal-container .page-title{font-size:24px}.filters-bar{align-items:stretch;flex-direction:column}.search-container{max-width:none}.filter-checkboxes{justify-content:flex-start}.property-row{align-items:flex-start;flex-direction:column;gap:12px;padding:14px 16px}.property-actions{justify-content:space-between;width:100%}.view-on-map-btn span{display:none}.view-on-map-btn{padding:8px 10px}.property-schedule{flex-direction:column;gap:4px}.property-expanded-section{padding:16px}.photos-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.history-item{flex-direction:column;gap:8px}.history-date{min-width:auto}.pagination-controls{gap:12px;padding:16px}.pagination-btn{font-size:13px;padding:8px 14px}.property-notes-inline,.today-completion-info{padding:0 16px 12px}}@media (max-width:480px){.property-portal-container{padding:12px}.property-portal-container .page-title{font-size:20px}.property-row{padding:12px}.property-address{font-size:14px}.property-expanded-section{padding:12px}.photos-grid{gap:10px;grid-template-columns:1fr 1fr}.pagination-controls{flex-wrap:wrap}}.property-owner-dashboard{background-color:var(--bg-primary);box-sizing:border-box;margin:0;max-width:100%;overflow-y:auto;padding:24px;width:100%}.property-owner-dashboard .page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.property-owner-dashboard .page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 4px}.property-owner-dashboard .page-subtitle{color:var(--text-secondary);font-size:15px;margin:0}.property-owner-dashboard .stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.property-owner-dashboard .stat-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease}.property-owner-dashboard .stat-card:hover{border-color:var(--border-hover);box-shadow:0 4px 12px #00000014}.dark-mode .property-owner-dashboard .stat-card:hover{box-shadow:0 4px 12px #0000004d}.property-owner-dashboard .stat-header{align-items:center;display:flex;gap:10px;margin-bottom:12px}.property-owner-dashboard .stat-icon{align-items:center;border-radius:10px;display:flex;font-size:16px;height:36px;justify-content:center;width:36px}.property-owner-dashboard .stat-icon.primary{background-color:#0071e31f;color:var(--accent)}.property-owner-dashboard .stat-icon.completed{background-color:#34c7591f;color:var(--success)}.property-owner-dashboard .stat-icon.pending{background-color:#8e8e931f;color:var(--text-muted)}.property-owner-dashboard .stat-label{color:var(--text-secondary);font-size:13px;font-weight:500}.property-owner-dashboard .stat-value{color:var(--text-primary);font-size:32px;font-weight:700}.property-owner-dashboard .stat-note{color:#f0ad4e;color:var(--warning,#f0ad4e);font-size:12px;font-weight:500;margin-top:4px}.property-owner-dashboard .content-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.property-owner-dashboard .section-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.property-owner-dashboard .section-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.property-owner-dashboard .section-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.weekly-schedule{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);padding:20px}.schedule-day{align-items:center;background-color:var(--bg-primary);border-radius:10px;display:flex;flex-direction:column;padding:12px 8px;transition:all .2s ease}.schedule-day.today{background-color:#0071e31a;border:2px solid var(--accent)}.schedule-day.past{opacity:.6}.schedule-day.completed .day-icons{opacity:.5}.day-label{color:var(--text-secondary);font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.schedule-day.today .day-label{color:var(--accent)}.day-icons{align-items:center;display:flex;gap:4px;margin-bottom:6px;min-height:20px}.service-icon{font-size:14px}.service-icon.trash{color:var(--text-muted)}.service-icon.recycling{color:var(--success)}.no-service{color:var(--text-muted);font-size:14px}.day-count{color:var(--text-primary);font-size:13px;font-weight:600;min-height:18px}.completed-check{color:var(--success);font-size:14px}.quick-actions{padding:16px}.action-card{background-color:var(--bg-primary);border-radius:10px;padding:16px}.action-card:hover{background-color:var(--bg-hover);border-color:var(--accent)}.action-icon{font-size:18px}.action-icon.primary{background-color:#0071e31f}.action-icon.completed{background-color:#34c7591f}.action-title{font-size:15px;font-weight:600}.action-desc{font-size:13px}.action-arrow{font-size:14px}.property-owner-dashboard .loading-container{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:60px 20px}@media (max-width:900px){.property-owner-dashboard .content-grid{grid-template-columns:1fr}}@media (max-width:768px){.property-owner-dashboard{padding:16px}.property-owner-dashboard .page-title{font-size:24px}.property-owner-dashboard .stats-grid{gap:12px;grid-template-columns:repeat(3,1fr)}.property-owner-dashboard .stat-card{padding:14px}.property-owner-dashboard .stat-value{font-size:24px}.property-owner-dashboard .stat-icon{font-size:14px;height:32px;width:32px}.weekly-schedule{gap:4px;padding:16px}.schedule-day{padding:10px 4px}.day-label{font-size:10px}.service-icon{font-size:12px}.day-count{font-size:11px}}@media (max-width:480px){.property-owner-dashboard{padding:12px}.property-owner-dashboard .page-title{font-size:20px}.property-owner-dashboard .stats-grid{gap:8px;grid-template-columns:1fr 1fr 1fr}.property-owner-dashboard .stat-card{padding:12px}.property-owner-dashboard .stat-value{font-size:20px}.property-owner-dashboard .stat-label{font-size:11px}.weekly-schedule{gap:2px;padding:12px}.schedule-day{border-radius:8px;padding:8px 2px}.day-label{font-size:9px;margin-bottom:4px}.day-count,.service-icon{font-size:10px}.action-card{padding:12px}.action-icon{font-size:16px;height:36px;width:36px}.action-title{font-size:14px}.action-desc{font-size:12px}}.dashboard-page{display:flex;flex-direction:column}.shift-banner{align-items:center;background:linear-gradient(135deg,#34c7591a,#34c7590d);border:1px solid #34c75933;border-radius:12px;color:var(--success);display:flex;font-size:14px;gap:10px;margin-bottom:24px;padding:14px 20px}.shift-banner svg{animation:pulse 2s ease-in-out infinite;height:18px;width:18px}.content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.quick-actions-mobile{display:none}.quick-actions-section{align-self:start;margin-bottom:0}.quick-actions{display:flex;flex-direction:column;gap:12px}.action-card{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;font-family:inherit;gap:14px;padding:20px;text-align:left;transition:all .2s ease;width:100%}.action-card:hover{background:var(--bg-hover);border-color:var(--border-hover)}.action-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.action-icon svg{height:18px;width:18px}.action-icon.primary{background:#e3f2fd;color:var(--accent)}.action-icon.completed{background:#e8f5e9;color:var(--success)}.dark-mode .action-icon.primary{background:#0a84ff26}.dark-mode .action-icon.completed{background:#34c75926}.action-info{flex:1 1}.action-title{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:2px}.action-desc{color:var(--text-secondary);font-size:12px}.action-arrow{color:var(--text-muted);height:14px;transition:transform .2s ease;width:14px}.action-card:hover .action-arrow{color:var(--accent);transform:translateX(4px)}.filters-section{border-top:1px solid var(--border-color);padding:16px}.filters-title{color:var(--text-secondary);font-size:13px;font-weight:500;letter-spacing:.3px;margin:0 0 12px;text-transform:uppercase}.filters-section .filter-controls{background:none;padding:0}.filters-section .filter-controls h3{display:none}.filters-section .filter-control{display:inline-flex;margin-bottom:8px;margin-right:16px}.filters-section .checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px}.filters-section .filter-label{color:var(--text-secondary);font-size:13px}.list-content{padding:0}.dashboard-page .btn-primary.btn-danger{background:var(--danger)}.dashboard-page .btn-primary.btn-danger:hover{background:#e62e26}@media (max-width:768px){.shift-banner{font-size:13px;padding:12px 16px}.quick-actions{flex-direction:column}.content-grid{grid-template-columns:1fr}.quick-actions-mobile{align-self:stretch;display:block;margin-bottom:24px;width:100%}.quick-actions-mobile .quick-actions{padding:0}.content-grid .quick-actions-section{display:none}.action-card{padding:20px}.action-icon{border-radius:12px;height:44px;width:44px}.action-icon svg{height:20px;width:20px}.action-title{font-size:16px;font-weight:600}.action-desc{font-size:13px}.filters-section{padding:12px}}.shifts-page{max-width:1200px}.back-button{align-items:center;background:none;border:none;color:var(--accent);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:500;gap:8px;margin-bottom:12px;padding:0;transition:color .2s ease}.back-button:hover{color:var(--accent-hover)}.back-button svg{height:14px;width:14px}.shifts-page .shift-banner{align-items:center;background:linear-gradient(135deg,#34c7591a,#34c7590d);border:1px solid #34c75933;border-radius:12px;color:var(--success);display:flex;font-size:14px;gap:10px;margin-bottom:24px;padding:14px 20px}.shifts-page .shift-banner svg{animation:pulse 2s ease-in-out infinite;height:18px;width:18px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stats-grid-4{grid-template-columns:repeat(4,1fr)}.shifts-page .section-card{flex:1 1}.shifts-list{min-height:50vh;padding:0}.shift-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:16px;padding:18px 22px;transition:background .2s ease}.shift-item:last-child{border-bottom:none}.shift-item:hover{background:var(--bg-hover)}.shift-item.active-shift{background:linear-gradient(135deg,#34c7590d,#34c75905)}.shift-icon{align-items:center;background:var(--bg-input);border-radius:10px;color:var(--text-secondary);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.shift-icon svg{height:20px;width:20px}.shift-item.active-shift .shift-icon{background:#34c75926;color:var(--success)}.shift-info{flex:1 1;min-width:0}.shift-date{color:var(--text-primary);font-size:15px;font-weight:500;margin-bottom:4px}.shift-time{color:var(--text-secondary);font-size:13px}.shift-stats{flex-shrink:0;gap:16px}.shift-properties,.shift-stats{align-items:center;display:flex}.shift-properties{color:var(--text-secondary);font-size:13px;gap:6px}.shift-properties svg{color:var(--success);height:14px;width:14px}.shifts-page .btn-primary.btn-danger{background:var(--danger)}.shifts-page .btn-primary.btn-danger:hover{background:#e62e26}.empty-hint{color:var(--text-muted);font-size:13px;margin-top:8px!important}@media (max-width:1200px){.stats-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.shifts-page .shift-banner{font-size:13px;padding:12px 16px}.stats-grid-4{grid-template-columns:1fr}.shift-item{flex-wrap:wrap;padding:16px}.shift-info{flex-basis:calc(100% - 60px);flex-grow:1;flex-shrink:1}.shift-stats{border-top:1px solid var(--border-color);justify-content:space-between;margin-top:12px;padding-top:12px;width:100%}}.invoice-history-container{background-color:var(--bg-primary);box-sizing:border-box;margin:0;max-width:100%;overflow-y:auto;padding:24px;width:100%}.invoice-history-container .page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.invoice-history-container .page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 4px}.invoice-history-container .page-subtitle{color:var(--text-secondary);font-size:15px;margin:0}.invoice-filters{margin-bottom:20px}.invoice-filters .search-container{max-width:400px;position:relative}.invoice-filters .search-icon{color:var(--text-muted);font-size:14px;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.invoice-filters .search-input{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px 12px 40px;transition:all .2s ease;width:100%}.invoice-filters .search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.invoice-filters .search-input::placeholder{color:var(--text-muted)}.invoice-filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.invoice-filters-row+.invoice-filters-row{margin-top:12px}.invoice-filter-select{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;min-width:180px;padding:12px 14px;transition:all .2s ease}.invoice-filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a;outline:none}.invoice-status-chips{display:flex;gap:6px}.invoice-status-chip{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s ease}.invoice-status-chip:hover{border-color:var(--text-muted)}.invoice-status-chip.active{background-color:var(--accent);border-color:var(--accent);color:#fff}.period-dates{display:block;font-size:11px;font-weight:400;margin-top:1px;opacity:.85}.invoice-clear-filters{align-items:center;background-color:#ff3b301a;border:none;border-radius:8px;color:#ff3b30;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:5px;padding:6px 12px;transition:all .2s ease}.invoice-clear-filters:hover{background-color:#ff3b3033}.invoices-section{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.invoices-list{padding:0}.invoice-card{border-bottom:1px solid var(--border-color);transition:all .2s ease}.invoice-card:last-child{border-bottom:none}.invoice-card:hover{background-color:var(--bg-hover)}.invoice-card.expanded{background-color:var(--bg-input)}.invoice-row{align-items:center;cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.invoice-main-info{flex:1 1;min-width:0}.invoice-header-line{align-items:center;display:flex;gap:10px;margin-bottom:4px}.invoice-number{color:var(--text-primary);font-size:15px;font-weight:600}.invoice-status-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;text-transform:uppercase}.invoice-status-badge.generated{background-color:#8e8e9326;color:var(--text-muted)}.invoice-status-badge.sent{background-color:#34c75926;color:var(--success)}.invoice-status-badge.viewed{background-color:#0071e326;color:var(--accent)}.invoice-status-badge.paid{background-color:#34c75926;color:var(--success)}.invoice-meta{color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:13px;gap:14px}.invoice-company{font-weight:500}.invoice-actions{align-items:center;display:flex;flex-shrink:0;gap:12px}.invoice-total{color:var(--text-primary);font-size:16px;font-weight:700}.mark-paid-btn{align-items:center;background-color:initial;border:1px solid var(--success);border-radius:8px;color:var(--success);cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:600;gap:5px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.mark-paid-btn:hover{background-color:var(--success);color:#fff;transform:translateY(-1px)}.pdf-btn{align-items:center;background-color:#ff3b301a;border-radius:8px;color:#ff3b30;display:flex;height:36px;justify-content:center;text-decoration:none;transition:all .2s ease;width:36px}.pdf-btn:hover{background-color:#ff3b3033;transform:translateY(-1px)}.invoice-card .expand-icon{color:var(--text-muted);flex-shrink:0;font-size:14px;transition:transform .2s ease}.invoice-card .expand-icon.rotated{transform:rotate(180deg)}.invoice-expanded{background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:16px 20px 20px}.line-items-table{border-collapse:collapse;font-size:13px;margin-bottom:16px;width:100%}.line-items-table th{background-color:var(--bg-card);border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-size:12px;font-weight:600;padding:8px 12px;text-align:left;text-transform:uppercase}.line-items-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:10px 12px}.line-items-table tfoot td{border-bottom:none;border-top:2px solid var(--border-color);padding-top:12px}.download-pdf-btn{align-items:center;background-color:var(--accent);border:none;border-radius:8px;color:#fff;display:inline-flex;font-size:13px;font-weight:500;gap:8px;padding:10px 18px;text-decoration:none;transition:all .2s ease}.download-pdf-btn:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.no-invoices{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;padding:60px 25px}.no-invoices svg{margin-bottom:14px;opacity:.4}.no-invoices p{font-size:15px;margin:0}.invoice-history-container .pagination-controls{align-items:center;border-top:1px solid var(--border-color);display:flex;gap:16px;justify-content:center;padding:20px}.invoice-history-container .pagination-btn{align-items:center;background-color:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s ease}.invoice-history-container .pagination-btn:hover:not(:disabled){background-color:var(--accent-hover)}.invoice-history-container .pagination-btn:disabled{background-color:var(--bg-input);color:var(--text-muted);cursor:not-allowed}.invoice-history-container .pagination-info{color:var(--text-secondary);font-size:14px;font-weight:500}.invoice-history-container .loading-container{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:60px 20px}@media (max-width:768px){.invoice-history-container{padding:16px}.invoice-history-container .page-title{font-size:24px}.invoice-filters .search-container{max-width:none}.invoice-filters-row{align-items:stretch;flex-direction:column}.invoice-filter-select{min-width:0;min-width:auto;width:100%}.invoice-status-chips{-webkit-overflow-scrolling:touch;overflow-x:auto;padding-bottom:2px}.invoice-row{align-items:flex-start;flex-direction:column;gap:10px;padding:14px 16px}.invoice-actions{justify-content:space-between;width:100%}.invoice-meta{flex-direction:column;gap:4px}.line-items-table{font-size:12px}.line-items-table td,.line-items-table th{padding:8px 6px}}@media (max-width:480px){.invoice-history-container{padding:12px}.invoice-history-container .page-title{font-size:20px}.invoice-row{padding:12px}}.settings-page{max-width:800px}.settings-content{padding:0}.settings-row{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 22px}.settings-row:last-child{border-bottom:none}.settings-row.clickable{cursor:pointer;transition:background-color .2s ease}.settings-row.clickable:hover{background:var(--bg-hover)}.settings-label{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:2px}.settings-description{color:var(--text-secondary);font-size:12px}.settings-value{color:var(--text-secondary);font-size:14px;text-align:right}.role-badge{background:var(--bg-input);border-radius:6px;color:var(--text-primary);display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;text-transform:capitalize}.settings-toggle{background:var(--bg-input);border:1px solid var(--border-color);border-radius:12px;flex-shrink:0;height:24px;position:relative;transition:background-color .3s ease;width:44px}.settings-toggle.active{background:var(--accent);border-color:var(--accent)}.settings-toggle .toggle-knob{background:var(--bg-card);border-radius:50%;box-shadow:0 1px 3px #0003;height:18px;left:2px;position:absolute;top:2px;transition:transform .3s ease;width:18px}.settings-toggle.active .toggle-knob{transform:translateX(20px)}.theme-options{display:flex;gap:8px}.theme-option{align-items:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;gap:6px;padding:8px 14px;transition:all .2s ease}.theme-option:hover{background:var(--bg-hover);color:var(--text-primary)}.theme-option.active{background:var(--accent);border-color:var(--accent);color:#fff}.theme-option svg{height:14px;width:14px}.danger-card{border-color:#ff3b3033}.danger-card .settings-label{color:var(--danger)}@media (max-width:768px){.settings-row{align-items:flex-start;flex-direction:column;gap:12px}.settings-value{text-align:left}.settings-row button{justify-content:center;width:100%}.theme-options{width:100%}.theme-option{flex:1 1;justify-content:center}}.auth-form-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100dvh;padding:20px}.auth-form-wrapper{animation:slideIn .3s ease-out;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 24px #00000014;max-width:400px;padding:40px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.dark-mode .auth-form-wrapper{box-shadow:0 4px 24px #0000004d}.auth-form-wrapper h2{color:var(--text-primary);font-size:24px;font-weight:600;margin:0 0 8px;text-align:center}.auth-form-wrapper .subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:32px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary);display:block;font-size:13px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31a}.form-group input::placeholder{color:var(--text-muted)}.error{background:#ff3b301a;border:1px solid #ff3b3033;border-radius:10px;color:var(--danger)}.error,.success{font-size:13px;margin-bottom:20px;padding:12px 16px;text-align:center}.success{background:#34c7591a;border:1px solid #34c75933;border-radius:10px;color:var(--success)}.invite-notice{background:#0071e31a;border:1px solid #0071e333;border-radius:10px;color:var(--accent);font-size:13px;margin-bottom:20px;padding:12px 16px;text-align:center}.invite-notice strong{display:block;margin-bottom:4px}.auth-form-wrapper .btn-primary{margin-bottom:0;margin-top:8px}.auth-form-wrapper .btn-primary,.auth-form-wrapper .btn-secondary{font-size:15px;justify-content:center;padding:14px 20px;width:100%}.auth-form-wrapper .btn-secondary{margin-top:12px}.forgot-password-link{margin-top:16px;text-align:center}.link-button{background:none;border:none;color:var(--accent);cursor:pointer;font-family:inherit;font-size:13px;padding:0;text-decoration:none;transition:color .2s ease}.link-button:hover{color:var(--accent-hover);text-decoration:underline}.signup-link{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;margin-top:24px;padding-top:24px;text-align:center}.signup-link a{color:var(--accent);font-weight:500;text-decoration:none}.signup-link a:hover{color:var(--accent-hover);text-decoration:underline}.role-selection{margin-bottom:20px}.role-buttons{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:10px}.role-button{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:14px;text-align:center;transition:all .2s ease}.role-button.selected{background:#0071e31a;border-color:var(--accent);color:var(--accent)}.dark-mode .role-button.selected{background:#0a84ff26}.role-button:hover{border-color:var(--border-hover)}.role-description{color:var(--text-secondary);font-size:12px;margin-top:8px;text-align:center}.auth-logo{margin-bottom:32px;text-align:center}.auth-logo h1{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0}.auth-logo span{color:var(--accent)}@media (max-width:480px){.auth-form-wrapper{border:none;border-radius:0;box-shadow:none;display:flex;flex-direction:column;justify-content:center;max-width:none;min-height:100dvh;padding:32px 24px}.auth-form-container{padding:0}.form-group input{font-size:16px}.role-buttons{grid-template-columns:1fr}}