:root{--primary-color: #1CB5A3;--primary-hover: #169A8B;--secondary-color: #1769AA;--secondary-hover: #125783;--accent-color: #F5A623;--bg-light: #F9FAFB;--bg-card: #FFFFFF;--bg-table: #E5E7EB;--text-heading: #374151;--text-body: #111827;--success-green: #2ECC71;--error-red: #E63946;--warning-amber: #F5A623;--info-blue: #3498DB;--stale-gray: #95A5A6;--sidebar-bg: #ffffff;--sidebar-text: #64748b;--sidebar-text-active: #1e293b;--sidebar-active: var(--primary-color);--sidebar-hover: #f1f5f9;--sidebar-border: #e2e8f0;--kiosk-title: 4rem;--kiosk-status: 3rem;--kiosk-count: 5rem;--kiosk-label: 2rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-display: "Plus Jakarta Sans", "Public Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Plus Jakarta Sans", "Public Sans", -apple-system, BlinkMacSystemFont, sans-serif;--transition-fast: .15s ease;--transition-normal: .3s ease;--bg-primary: #f8fafc;--bg-secondary: #f8fafc;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--input-bg: #ffffff;--input-border: #cbd5e1;--card-bg: #ffffff;--card-bg-secondary: #f8fafc;--cubicle-occupied-bg: #fee2e2;--cubicle-occupied-border: #fca5a5;--cubicle-vacant-bg: #dcfce7;--cubicle-vacant-border: #86efac}@media(prefers-color-scheme:dark){:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-light: #1e293b;--bg-table: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-heading: #f1f5f9;--text-body: #e2e8f0;--border-color: #334155;--input-bg: #0f172a;--input-border: #475569;--card-bg: #1e293b;--card-bg-secondary: #334155;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4);--sidebar-bg: #1e293b;--sidebar-text: #94a3b8;--sidebar-text-active: #f1f5f9;--sidebar-hover: #334155;--sidebar-border: #334155;--cubicle-occupied-bg: #450a0a;--cubicle-occupied-border: #991b1b;--cubicle-vacant-bg: #052e16;--cubicle-vacant-border: #166534}}:root{--transition-smooth: cubic-bezier(.4, 0, .2, 1);--transition-bounce: cubic-bezier(.68, -.55, .265, 1.55);--transition-elastic: cubic-bezier(.68, -.6, .32, 1.6)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:repeating-linear-gradient(0deg,transparent,transparent 50px,rgba(255,255,255,.03) 50px,rgba(255,255,255,.03) 51px),repeating-linear-gradient(90deg,transparent,transparent 50px,rgba(255,255,255,.03) 50px,rgba(255,255,255,.03) 51px);animation:grid-drift 30s linear infinite;pointer-events:none}@keyframes grid-drift{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-box{background:var(--card-bg, #ffffff);border-radius:16px;border:1px solid var(--border-color, #e2e8f0);box-shadow:var(--shadow-lg);padding:3rem;width:100%;max-width:480px;position:relative;z-index:1;animation:box-entrance .6s var(--transition-smooth) backwards;transform-origin:center center}@keyframes box-entrance{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-title{font-size:28px;font-weight:800;color:var(--text-heading);margin-bottom:.5rem;text-align:center;line-height:1.3;animation:text-entrance .6s var(--transition-smooth) .1s backwards}@keyframes text-entrance{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-subtitle{font-size:15px;color:var(--text-secondary, #6B7280);margin-bottom:2.5rem;text-align:center;font-weight:500;animation:text-entrance .6s var(--transition-smooth) .2s backwards}.login-form{margin-bottom:20px;animation:text-entrance .6s var(--transition-smooth) .3s backwards}.form-group{margin-bottom:1.5rem;transition:transform .2s var(--transition-smooth)}.form-group:focus-within{transform:translateY(-2px)}.form-label{display:block;font-size:14px;font-weight:600;color:var(--text-heading);margin-bottom:8px;transition:all .2s var(--transition-smooth);transform-origin:left center}.form-group:focus-within .form-label{color:var(--primary-color);transform:translate(2px)}.login-box .form-input{width:100%;padding:12px 16px;font-size:15px;border:2px solid #E5E7EB;border-radius:10px;background:#f9fafb;color:#111827;transition:all .25s var(--transition-smooth);outline:none;box-shadow:0 0 #3b82f600}.login-box .form-input:hover{border-color:#d1d5db;background:#fff}.login-box .form-input:focus{border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 4px #3b82f61a,0 1px 3px #0000000d;transform:translateY(-1px)}.login-box .form-input::placeholder{color:#9ca3af;transition:all .2s var(--transition-smooth)}.login-box .form-input:focus::placeholder{opacity:.5;transform:translate(4px)}.form-hint{font-size:12px;color:var(--text-secondary, #6B7280);margin-top:6px;margin-bottom:0;line-height:1.4;opacity:0;transform:translateY(-4px);transition:all .3s var(--transition-smooth);max-height:0;overflow:hidden}.form-group:focus-within .form-hint,.form-group:hover .form-hint{opacity:1;transform:translateY(0);max-height:50px}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:50px}.password-toggle-btn{position:absolute;right:12px;background:transparent;border:none;font-size:20px;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s var(--transition-smooth);z-index:1;transform-origin:center center}.password-toggle-btn:hover{background:#3b82f61a;transform:scale(1.1)}.password-toggle-btn:active{transform:scale(.95)}.login-form .btn-primary{width:100%;margin-top:1.5rem;padding:14px;font-size:16px;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);border:none;border-radius:10px;color:#fff;cursor:pointer;letter-spacing:.3px;text-transform:uppercase;position:relative;overflow:hidden;transition:all .3s var(--transition-smooth);box-shadow:0 4px 12px #3b82f64d,0 0 #3b82f600}.login-form .btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s var(--transition-smooth)}.login-form .btn-primary:hover:before{left:100%}.login-form .btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666,0 0 0 4px #3b82f61a}.login-form .btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #3b82f64d,0 0 0 2px #3b82f61a}.login-form .btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none;animation:button-pulse 1.5s ease-in-out infinite}@keyframes button-pulse{0%,to{opacity:.7}50%{opacity:.85}}.error-alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;margin-bottom:24px;background:#fef2f2;border:2px solid #FCA5A5;border-radius:10px;position:relative;animation:alert-slide-in .4s var(--transition-bounce)}@keyframes alert-slide-in{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.error-icon{flex-shrink:0;width:20px;height:20px;color:#dc2626;margin-top:2px;animation:icon-bounce .6s var(--transition-elastic) .2s backwards}@keyframes icon-bounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.error-content{flex:1}.error-title{font-size:14px;font-weight:700;color:#991b1b;margin-bottom:4px}.error-message{font-size:13px;color:#b91c1c;line-height:1.5}.error-close{flex-shrink:0;width:28px;height:28px;border:none;background:transparent;color:#dc2626;font-size:24px;line-height:1;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s var(--transition-smooth);transform-origin:center center}.error-close:hover{background:#dc26261a;transform:rotate(90deg) scale(1.1)}.error-close:active{transform:rotate(90deg) scale(.9)}@media(prefers-color-scheme:dark){.error-alert{background:#450a0a;border-color:#b91c1c}.error-icon,.error-title,.error-message,.error-close{color:#fca5a5}.login-box .form-input{background:var(--input-bg);border-color:var(--input-border);color:var(--text-primary)}.login-box .form-input:hover{border-color:var(--border-color);background:var(--input-bg)}.login-box .form-input:focus{background:var(--input-bg)}.login-box .form-input::placeholder{color:var(--text-secondary)}}@media(max-width:640px){.login-box{padding:2rem}.login-title{font-size:24px}.login-subtitle{font-size:14px}.form-input{font-size:14px;padding:11px 14px}.login-form .btn-primary{padding:12px;font-size:15px}}.form-input:focus-visible,.password-toggle-btn:focus-visible,.login-form .btn-primary:focus-visible,.error-close:focus-visible{outline:3px solid var(--primary-color);outline-offset:2px}.lobby-card{width:100%;background:#0c1220;border-radius:20px;padding:22px;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center;color:#f8fafc;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;animation:fade-in-up .35s cubic-bezier(.4,0,.2,1) both}.lobby-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #00000073,0 0 0 1px #1cb5a326}.lobby-name{margin:0;font-size:clamp(20px,2vw,24px);font-weight:700;letter-spacing:.5px}.lobby-counts{font-size:13px;color:#94a3b8;font-weight:500;margin-top:-12px}.gender-row{width:100%;display:grid;grid-template-columns:repeat(2,minmax(160px,1fr));gap:18px;justify-items:center;align-items:center}.gender-card{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.gender-label{font-size:15px;letter-spacing:.6px;color:#e5e7eb;text-transform:uppercase}.gender-pill{width:100%;max-width:280px;height:clamp(180px,24vw,220px);border-radius:20px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.1);box-shadow:inset 0 1px #ffffff26,0 4px 12px #00000040}.gender-icon{width:clamp(90px,12vw,140px);height:clamp(90px,12vw,140px);object-fit:contain}.availability-text{font-size:clamp(30px,3.2vw,36px);font-weight:800;color:#f8fafc;font-family:var(--font-display, "Syne", sans-serif);letter-spacing:-.5px}.status-available~.availability-text{color:#4ade80}.status-full~.availability-text{color:#f87171}.status-available{background:linear-gradient(145deg,#22c55e,#16a34a);box-shadow:0 8px 24px #22c55e4d,inset 0 1px #fff3}.status-full{background:linear-gradient(145deg,#ef4444,#dc2626);box-shadow:0 8px 24px #ef44444d,inset 0 1px #ffffff26}.gender-icon{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.lobby-card:hover .gender-icon{transform:scale(1.06)}.gender-pill{transition:box-shadow .25s ease}.status-available .gender-pill:hover{box-shadow:inset 0 1px #ffffff26,0 4px 12px #00000040,0 0 20px #22c55e26}.status-full .gender-pill:hover{box-shadow:inset 0 1px #ffffff26,0 4px 12px #00000040,0 0 20px #ef444426}.lobby-name{animation:fade-in-down .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.1s}@media(max-width:768px){.gender-row{grid-template-columns:repeat(2,minmax(130px,1fr));gap:12px}.gender-pill{height:160px}}.kiosk-page{min-height:100vh;background:#0b0f19;color:#e5e7eb;display:flex;flex-direction:column;padding:24px}.kiosk-header{text-align:center;margin-bottom:16px}.kiosk-title{font-size:clamp(28px,3vw,40px);font-weight:800;letter-spacing:1px;color:#fff}.kiosk-subtitle{margin-top:4px;font-size:clamp(18px,2vw,22px);color:#9ca3af;letter-spacing:.5px}.kiosk-content{flex:1;display:flex;align-items:center;justify-content:center}.lobby-grid{width:100%;max-width:1400px;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.kiosk-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:12px 16px;background:#111827;border:1px solid rgba(255,255,255,.06);border-radius:14px;color:#d1d5db}.last-updated{font-size:16px}.system-status{font-size:16px;font-weight:700;padding:6px 14px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.status-online{background:#10b98126;color:#34d399}.status-offline{background:#ef44442e;color:#f87171}.status-stale{background:#f59e0b2e;color:#fbbf24}.kiosk-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#0b0f19;color:#9ca3af;font-size:20px}.loading-spinner{width:54px;height:54px;border:6px solid rgba(255,255,255,.08);border-top-color:#38bdf8;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.kiosk-page{padding:16px}.kiosk-footer{flex-direction:column;align-items:flex-start;gap:8px}}.topbar{position:fixed;top:0;left:240px;right:0;height:64px;background-color:var(--bg-card);border-bottom:1px solid var(--bg-table);z-index:999;box-shadow:var(--shadow-sm);transition:left .3s ease;animation:fade-in-down .3s cubic-bezier(.4,0,.2,1) both}.topbar.collapsed{left:70px}.topbar-content{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 2rem}.topbar-left{flex:1;display:flex;align-items:center;gap:1rem}.mobile-menu-button{display:none;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-heading);cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-fast)}.mobile-menu-button:hover{background-color:var(--bg-light)}.topbar-title-block{display:flex;flex-direction:column;gap:.15rem}.page-title{margin:0;font-size:20px;font-weight:700;color:var(--text-heading)}.page-subtitle{font-size:12px;color:var(--text-secondary, #94A3B8);font-weight:500}.topbar-right{display:flex;align-items:center;gap:1rem}.topbar-info{padding:.5rem 1rem;font-size:14px;font-weight:500;color:var(--text-secondary);background:var(--bg-light);border-radius:var(--radius-md)}.topbar-status{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;font-size:13px;font-weight:600;border-radius:999px;background:#22c55e1f;color:#22c55e;text-transform:capitalize}.topbar-status.status-offline{background:#ef44441f;color:#ef4444}.topbar-status.status-stale{background:#f59e0b1f;color:#f59e0b}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px #22c55e1f;animation:status-pulse 2.5s ease-in-out infinite}@keyframes status-pulse{0%,to{box-shadow:0 0 0 0 currentColor;opacity:1}50%{box-shadow:0 0 0 5px transparent;opacity:.8}}.topbar-status.status-offline .status-dot,.topbar-status.status-stale .status-dot{animation-name:none}.icon-button{position:relative;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-heading);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.icon-button:hover{background-color:var(--bg-light)}.notification-badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;background-color:var(--error-red);color:#fff;border-radius:9px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.topbar-dropdown-wrapper{position:relative}.tenant-selector-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);color:#3b82f6;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tenant-selector-button:hover{background:#3b82f61f;border-color:#3b82f64d}.tenant-icon{font-size:16px}.tenant-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}.dropdown-arrow{flex-shrink:0;transition:transform .2s ease}.tenant-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--bg-card);border:1px solid var(--bg-table);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.5rem;animation:dropdownFade .2s ease;z-index:1001}.dropdown-item{position:relative;justify-content:flex-start}.dropdown-item.active{background:#3b82f614;color:#3b82f6;font-weight:600}.dropdown-item .checkmark{margin-left:auto;font-size:14px;color:#3b82f6}.empty-notifications{padding:2rem;text-align:center}.empty-icon{font-size:2.5rem;margin-bottom:.5rem;color:var(--success-green)}.empty-text{font-size:16px;font-weight:600;color:var(--text-heading);margin-bottom:.25rem}.empty-subtext{font-size:14px;color:#6b7280}.search-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--bg-card);border:1px solid var(--bg-table);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:1rem;animation:dropdownFade .2s ease;z-index:1000}.search-dropdown form{display:flex;gap:.5rem;margin-bottom:1rem}.search-input{flex:1;padding:.75rem 1rem;border:2px solid var(--bg-table);border-radius:var(--radius-md);font-size:14px;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1cb5a31a}.search-submit-btn{padding:.75rem 1rem;background:var(--primary-color);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.search-submit-btn:hover{background:var(--primary-hover)}.search-suggestions{display:flex;flex-direction:column;gap:.25rem}.suggestion-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-size:14px}.suggestion-item:hover{background:var(--bg-light)}.notifications-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:480px;background:var(--bg-card);border:1px solid var(--bg-table);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:dropdownFade .2s ease;z-index:1000;overflow:hidden}.notifications-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--bg-table)}.notifications-header h3{margin:0;font-size:16px;font-weight:700;color:var(--text-heading)}.mark-read-btn{background:transparent;border:none;color:var(--primary-color);font-size:13px;font-weight:600;cursor:pointer;transition:color var(--transition-fast)}.mark-read-btn:hover{color:var(--primary-hover)}.notifications-list{max-height:320px;overflow-y:auto}.notification-item{display:flex;gap:.75rem;padding:1rem;border-bottom:1px solid var(--bg-table);cursor:pointer;transition:background var(--transition-fast)}.notification-item:hover{background:var(--bg-light)}.notification-item:last-child{border-bottom:none}.notification-icon{font-size:24px;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-size:14px;font-weight:700;color:var(--text-body);margin-bottom:.25rem}.notification-message{font-size:13px;color:#6b7280;margin-bottom:.25rem}.notification-time{font-size:12px;color:#9ca3af}.notifications-footer{padding:.75rem 1rem;border-top:1px solid var(--bg-table)}.view-all-btn{width:100%;padding:.625rem;background:transparent;border:1px solid var(--primary-color);border-radius:var(--radius-sm);color:var(--primary-color);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.view-all-btn:hover{background:var(--primary-color);color:#fff}.user-menu-wrapper{position:relative}.user-button{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--bg-table);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.user-button:hover{background-color:var(--bg-light);border-color:var(--primary-color)}.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:16px}.user-name-sm{font-size:14px;font-weight:600;color:var(--text-heading)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-card);border:1px solid var(--bg-table);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.5rem;animation:dropdownFade .2s ease}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-body);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left}.dropdown-item:hover{background-color:var(--bg-light);color:var(--primary-color)}.dropdown-divider{height:1px;background-color:var(--bg-table);margin:.5rem 0}.logout-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #ef4444;border-radius:var(--radius-md);color:var(--text-primary, #000000);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.logout-button:hover{background:#ef4444;color:#fff;border-color:#dc2626}.logout-button svg{width:18px;height:18px;stroke:currentColor}@media(max-width:1024px)and (min-width:769px){.topbar,.topbar.collapsed{left:70px}}@media(max-width:768px){.topbar,.topbar.collapsed{left:0}.topbar-content{padding:0 1rem}.mobile-menu-button{display:flex}.page-title{font-size:16px}.topbar-right{gap:.5rem}.tenant-selector-button{padding:.5rem .75rem;font-size:13px}.tenant-name{max-width:80px}.logout-button span{display:none}.logout-button{padding:.5rem;min-width:40px;justify-content:center}.user-name-sm{display:none}.notifications-dropdown,.tenant-dropdown{width:calc(100vw - 2rem);right:1rem}}@media(max-width:480px){.page-title{font-size:14px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tenant-selector-button{padding:.4rem .6rem;font-size:12px}.tenant-name{display:none}}.cp-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000;animation:modal-backdrop-in .2s ease both}.cp-modal{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:100%;max-width:420px;margin:1rem;display:flex;flex-direction:column;border:1px solid var(--border-color);animation:modal-slide-in .25s cubic-bezier(.34,1.56,.64,1) both}.cp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem}.cp-modal-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text-heading)}.cp-modal-close{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.cp-modal-close:hover{background:var(--bg-light);color:var(--text-heading)}.cp-modal-body{padding:.75rem 1.5rem 1rem;display:flex;flex-direction:column;gap:1rem}.cp-alert{padding:.625rem .75rem;border-radius:var(--radius-sm);font-size:13px;font-weight:500}.cp-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.cp-alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.cp-form-group{display:flex;flex-direction:column;gap:.35rem}.cp-form-group label{font-size:13px;font-weight:600;color:var(--text-body)}.cp-input{padding:.6rem .75rem;border:1px solid var(--input-border, #cbd5e1);border-radius:.5rem;background:var(--input-bg, white);color:var(--text-primary, #1e293b);font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cp-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1cb5a326}.cp-input:disabled{background:var(--bg-secondary, #f1f5f9);color:var(--text-secondary);cursor:not-allowed}.cp-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--bg-table)}.cp-btn{padding:.55rem 1.1rem;border-radius:.5rem;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-fast)}.cp-btn:disabled{opacity:.5;cursor:not-allowed}.cp-btn-secondary{background:var(--card-bg-secondary, var(--bg-card));color:var(--text-body);border:1px solid var(--input-border, #cbd5e1)}.cp-btn-secondary:hover:not(:disabled){background:var(--bg-secondary, #f1f5f9)}.cp-btn-primary{background:var(--primary-color);color:#fff}.cp-btn-primary:hover:not(:disabled){background:var(--primary-hover)}@media(prefers-color-scheme:dark){.cp-alert-error{background:#3b1a1a;border-color:#7f1d1d;color:#fca5a5}.cp-alert-success{background:#1a3b2a;border-color:#166534;color:#86efac}}.dashboard-layout{display:flex;min-height:100vh;background-color:#0b0d10;color:#e2e8f0;position:relative;overflow-x:hidden;--bg-card: #12151b;--bg-light: #0f1115;--bg-table: #1c2330;--text-heading: #e2e8f0;--text-secondary: #94a3b8;--border-color: rgba(255, 255, 255, .08);--shadow-sm: 0 8px 20px rgba(0, 0, 0, .35);--shadow-lg: 0 14px 30px rgba(0, 0, 0, .4)}.dashboard-layout:before{content:none}.dashboard-main{flex:1;margin-left:260px;width:calc(100% - 260px);min-width:0;position:relative;z-index:1}.dashboard-main.sidebar-collapsed{margin-left:70px;width:calc(100% - 70px);min-width:0}.dashboard-content{width:100%;min-width:0;padding:clamp(16px,2vw,24px) clamp(20px,3vw,32px) clamp(24px,3vw,40px);padding-top:calc(88px + clamp(12px,2vw,24px));max-width:1400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.dashboard-layout .topbar{height:88px;background:transparent;border-bottom:none;box-shadow:none}.dashboard-layout .topbar-content{padding:0 2.5rem}.dashboard-layout .page-title{font-size:28px;font-weight:700;letter-spacing:.02em;color:#fff}.dashboard-layout .page-subtitle{font-size:14px;color:#9ca3af;letter-spacing:.01em}.dashboard-layout .topbar-status{background:#22c55e29;color:#22c55e;box-shadow:0 0 12px #22c55e40}.dashboard-layout .topbar-status.status-offline{background:#ef44442e;color:#ef4444;box-shadow:0 0 12px #ef44444d}.dashboard-layout .topbar-status .status-dot{box-shadow:0 0 8px currentColor,0 0 16px currentColor}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;width:100%;max-width:1400px;justify-content:center}.dashboard-grid>.lobby-card:nth-child(1){animation-delay:0ms}.dashboard-grid>.lobby-card:nth-child(2){animation-delay:60ms}.dashboard-grid>.lobby-card:nth-child(3){animation-delay:.12s}.dashboard-grid>.lobby-card:nth-child(4){animation-delay:.18s}.dashboard-grid>.lobby-card:nth-child(5){animation-delay:.24s}.dashboard-grid>.lobby-card:nth-child(6){animation-delay:.3s}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:5rem 2rem;color:var(--text-secondary, #94a3b8);animation:fade-in-up .3s ease both}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:5rem 2rem;text-align:center;color:var(--text-secondary, #94a3b8);animation:fade-in-up .3s ease both}.loading-spinner{width:40px;height:40px;border:3px solid rgba(28,181,163,.2);border-top-color:var(--primary-color, #1CB5A3);border-radius:50%;animation:spin .75s linear infinite}@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media(max-width:1024px){.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media(max-width:768px){.dashboard-main{margin-left:0;width:100%}.dashboard-content{padding:1rem 1.25rem 2rem;padding-top:calc(88px + 1rem)}.dashboard-grid{grid-template-columns:1fr}}.lobby-card{position:relative;overflow:hidden}.lobby-card:after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);pointer-events:none;opacity:0;transition:opacity .2s}.lobby-card:hover:after{opacity:1;animation:shine-sweep .7s cubic-bezier(.4,0,.2,1)}.availability-text{animation:count-pop .45s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.3s}.status-full .gender-pill{animation:breathe 3s cubic-bezier(.4,0,.2,1) infinite}.loading-spinner{filter:drop-shadow(0 0 8px rgba(28,181,163,.3))}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--hm-cell-size: clamp(6px, .55vw, 12px)}.heatmap-page{display:flex;flex-direction:column;gap:16px;animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:50ms}.hm-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;justify-content:space-between}.hm-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}.hm-label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;color:var(--text-secondary)}.hm-input{padding:6px 10px!important;font-size:13px!important;border-radius:8px!important;min-width:130px}.hm-kpis{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.hm-kpi{padding:6px 12px;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);font-size:13px;color:var(--text-secondary);white-space:nowrap}.hm-kpi-muted{font-size:12px;opacity:.7}.hm-legend{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.hm-legend-scale{display:flex;flex-direction:column;gap:4px;flex:1 1 280px;min-width:200px;max-width:400px}.hm-legend-bar{width:100%;height:10px;border-radius:999px;border:1px solid var(--border-color);background:linear-gradient(90deg,#22c358,#eeee2b,#e84f30)}.hm-legend-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}.hm-hint{font-size:12px;color:var(--text-secondary)}.hm-error{padding:10px 14px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:13px}.hm-empty{padding:24px;border-radius:12px;border:1px dashed var(--border-color);color:var(--text-secondary);background:var(--bg-secondary);font-size:13px;text-align:center}.hm-grid-wrap{border:1px solid var(--border-color);border-radius:12px;overflow:auto;max-height:min(560px,calc(100vh - 300px));min-height:200px;background:#fff;scrollbar-width:none;-ms-overflow-style:none}.hm-grid-wrap::-webkit-scrollbar{display:none}.hm-time-header{position:sticky;top:0;z-index:4;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.hm-time-inner{display:grid;align-items:stretch;width:max-content;min-width:100%}.hm-corner{position:sticky;left:0;background:var(--bg-secondary);border-right:1px solid var(--border-color);font-size:12px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;height:34px;z-index:5}.hm-tick{height:34px;border-right:1px solid #f1f5f9;display:flex;align-items:center;justify-content:center;font-size:10px;color:#94a3b8}.hm-tick-hour{border-right:1px solid #cbd5e1;color:#475569;font-weight:600}.hm-rows{background:#fff}.hm-row{display:grid;width:max-content;min-width:100%;border-bottom:1px solid #f1f5f9}.hm-row-label{position:sticky;left:0;z-index:3;padding:8px 10px;font-size:13px;color:var(--text-primary);background:#fff;border-right:1px solid var(--border-color);display:flex;align-items:center;gap:6px;white-space:nowrap}.hm-badge{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary)}.hm-cell{width:var(--hm-cell-size);height:28px;border-right:1px solid rgba(0,0,0,.04);cursor:default}.hm-cell-hour{border-right:1px solid rgba(0,0,0,.12)}.hm-cell:hover{outline:2px solid var(--primary-color, #1CB5A3);outline-offset:-1px}.hm-cell-future{background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px)!important;cursor:not-allowed;opacity:.45}.hm-cell-future:hover{outline:none}.hm-tick-future{opacity:.3}.hm-tooltip{position:fixed;pointer-events:none;z-index:50;background:#0f172aeb;border:1px solid rgba(255,255,255,.15);color:#f8fafc;padding:8px 12px;border-radius:10px;font-size:12px;transform:translate(12px,12px);display:none;max-width:280px;line-height:1.5}.hm-tooltip-visible{display:block}.hm-tooltip-muted{color:#94a3b8}.hm-insights{margin-top:4px}.hm-insights h3{margin:0 0 12px;font-size:1rem;font-weight:600;color:var(--text-primary)}.hm-insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.hm-insight-card{background:var(--card-bg, #fff);border:1px solid var(--border-color);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:6px;transition:transform .18s ease,box-shadow .18s ease;animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both}.hm-insight-card:nth-child(1){animation-delay:.1s}.hm-insight-card:nth-child(2){animation-delay:.17s}.hm-insight-card:nth-child(3){animation-delay:.24s}.hm-insight-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.hm-insight-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.hm-insight-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.hm-insight-detail{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.hm-duration{margin-top:4px}.hm-duration h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--text-primary)}.hm-duration-sub{margin:0 0 16px;font-size:13px;color:var(--text-secondary)}.hm-actions{display:flex;gap:8px;flex-wrap:wrap}.hm-btn-export{padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg, #fff);color:var(--text-primary);cursor:pointer;transition:background .15s ease,border-color .15s ease}.hm-btn-export:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.hm-raw{margin-top:4px}.hm-raw h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--text-primary)}.hm-raw-table-wrap{overflow-x:auto;border:1px solid var(--border-color);border-radius:8px}.hm-raw-table{width:100%;border-collapse:collapse;font-size:13px}.hm-raw-table thead th{background:var(--bg-secondary, #f8fafc);padding:8px 12px;text-align:left;font-weight:600;color:var(--text-secondary);white-space:nowrap;border-bottom:1px solid var(--border-color)}.hm-raw-table tbody td{padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.hm-raw-table tbody tr:last-child td{border-bottom:none}.hm-raw-table tbody tr:hover td{background:#1cb5a30a}.hm-raw-cubicles{font-family:monospace;font-size:12px;color:var(--text-secondary);max-width:280px;word-break:break-all}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(prefers-color-scheme:dark){.hm-error{background:#451a1a;border-color:#7f1d1d;color:#fca5a5}.hm-grid-wrap,.hm-rows,.hm-row-label{background:var(--card-bg)}.hm-row{border-bottom-color:var(--border-color)}.hm-cell{border-right-color:#ffffff0a}.hm-cell-hour{border-right-color:#ffffff1f}.hm-tick{border-right-color:var(--border-color);color:var(--text-secondary)}.hm-tick-hour{border-right-color:var(--border-color);color:var(--text-primary)}}@media(max-width:768px){.hm-controls{flex-direction:column}.hm-insights-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.heatmap-page *,.heatmap-page *:before,.heatmap-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.hm-section-label{font-size:11px;font-weight:600;letter-spacing:.07em;color:var(--text-secondary);text-transform:uppercase;margin-top:4px}.hm-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.hm-kpi-card{background:var(--bg-secondary, #f8fafc);border:1px solid var(--border-color);border-radius:10px;padding:14px 16px}.hm-kpi-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.hm-kpi-val{font-size:22px;font-weight:600;font-family:var(--font-display, "Syne", sans-serif);color:var(--text-primary);line-height:1.15}.hm-kpi-val.warn{color:#c04828}.hm-kpi-val.ok{color:#0f6e56}.hm-kpi-sub{font-size:11px;color:var(--text-secondary);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hm-rag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.hm-rag-card{border:1px solid var(--border-color);border-radius:10px;padding:10px 12px;background:var(--card-bg, #fff)}.hm-rag-title{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hm-rag-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.hm-rag-row:last-child{margin-bottom:0}.hm-rag-gender{font-size:11px;color:var(--text-secondary)}.hm-rag-right{display:flex;align-items:center;gap:5px}.hm-rag-pct{font-size:11px;font-weight:600}.hm-rag-pct-green{color:#0f6e56}.hm-rag-pct-amber{color:#854f0b}.hm-rag-pct-red{color:#a32d2d}.hm-rag-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hm-rag-dot-green{background:#1d9e75}.hm-rag-dot-amber{background:#ba7517}.hm-rag-dot-red{background:#c04828}.hm-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color)}.hm-tab{font-size:13px;font-weight:500;padding:8px 16px;cursor:pointer;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;-webkit-user-select:none;user-select:none;transition:color .15s,border-color .15s}.hm-tab:hover{color:var(--text-primary)}.hm-tab.active{color:var(--primary-color, #1CB5A3);font-weight:600;border-bottom-color:var(--primary-color, #1CB5A3)}.hm-tab-panel{display:flex;flex-direction:column;gap:12px;padding-top:4px}@media(prefers-color-scheme:dark){.hm-kpi-card{background:var(--card-bg)}.hm-kpi-val.warn{color:#f87171}.hm-kpi-val.ok{color:#34d399}.hm-rag-card{background:var(--card-bg)}.hm-rag-pct-green{color:#34d399}.hm-rag-pct-amber{color:#fbbf24}.hm-rag-pct-red{color:#f87171}.hm-rag-dot-green{background:#34d399}.hm-rag-dot-amber{background:#fbbf24}.hm-rag-dot-red{background:#f87171}}.hm-kpi-card{animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;transition:transform .18s ease,box-shadow .18s ease}.hm-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.hm-kpi-grid .hm-kpi-card:nth-child(1){animation-delay:80ms}.hm-kpi-grid .hm-kpi-card:nth-child(2){animation-delay:.14s}.hm-kpi-grid .hm-kpi-card:nth-child(3){animation-delay:.2s}.hm-kpi-grid .hm-kpi-card:nth-child(4){animation-delay:.26s}.hm-kpi-val{animation:count-pop .4s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.2s}.hm-rag-card{animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;transition:transform .15s ease,box-shadow .15s ease}.hm-rag-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.hm-rag-grid .hm-rag-card:nth-child(1){animation-delay:60ms}.hm-rag-grid .hm-rag-card:nth-child(2){animation-delay:.1s}.hm-rag-grid .hm-rag-card:nth-child(3){animation-delay:.14s}.hm-rag-grid .hm-rag-card:nth-child(4){animation-delay:.18s}.hm-rag-grid .hm-rag-card:nth-child(5){animation-delay:.22s}.hm-rag-grid .hm-rag-card:nth-child(6){animation-delay:.26s}.hm-rag-grid .hm-rag-card:nth-child(n+7){animation-delay:.3s}.hm-rag-dot-red{animation:breathe 2s cubic-bezier(.4,0,.2,1) infinite}.hm-tab.active{animation:elastic-snap .3s cubic-bezier(.34,1.56,.64,1)}.hm-duration{animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.15s}.hm-raw{animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.2s}.hm-legend-bar{position:relative;overflow:hidden}.hm-legend-bar:after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shine-sweep 1.2s cubic-bezier(.4,0,.2,1) .5s both;pointer-events:none}.hm-btn-export{position:relative;overflow:hidden}.hm-btn-export:after{content:"";position:absolute;top:50%;left:50%;width:100%;aspect-ratio:1;border-radius:50%;background:#1cb5a326;transform:translate(-50%,-50%) scale(0);opacity:0;pointer-events:none}.hm-btn-export:active:after{animation:ripple-expand .4s cubic-bezier(.4,0,.2,1)}@media(max-width:900px){.hm-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.hm-kpi-grid,.hm-rag-grid{grid-template-columns:repeat(2,1fr)}.hm-tab{font-size:12px;padding:8px 10px}}.tenants-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.tenants-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary, #1e293b);margin:0}.search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:.5rem;transition:all .2s;background:#fff}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1rem}.error-banner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;margin-bottom:1.5rem;background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:.5rem;color:#991b1b;font-size:.875rem}.error-banner button{background:none;border:none;color:#991b1b;font-size:1.5rem;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s}.error-banner button:hover{background:#0000000d}.tenants-table-container{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.tenants-table{width:100%;border-collapse:collapse}.tenants-table thead{background:var(--bg-secondary, #f1f5f9)}.tenants-table th{padding:1rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #64748b);white-space:nowrap}.tenants-table td{padding:1rem;border-top:1px solid #e2e8f0;font-size:.875rem}.tenants-table tbody tr{transition:background .15s}.tenants-table tbody tr:hover{background:#f8fafc}.tenant-name{font-weight:500;color:var(--text-primary, #1e293b)}.tenant-slug{font-family:Monaco,Menlo,Courier New,monospace;font-size:.75rem;color:#6366f1;background:#eef2ff;padding:.25rem .5rem;border-radius:.25rem;display:inline-block}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:capitalize}.status-badge:before{content:"";display:inline-block;width:.5rem;height:.5rem;border-radius:50%}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.active:before{background:#22c55e}.empty-state{padding:4rem 2rem;text-align:center;color:var(--text-secondary, #64748b)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.empty-state h3{font-size:1.125rem;font-weight:500;margin:0 0 .5rem;color:var(--text-primary, #1e293b)}.empty-state p{margin:0;font-size:.875rem}.btn{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.btn-secondary{background:#fff;color:var(--text-primary, #1e293b);border:1px solid #cbd5e1}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.btn-sm{padding:.375rem .875rem;font-size:.75rem}.btn-danger{background:#fff;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5}.btn-success{background:#fff;color:#16a34a;border:1px solid #bbf7d0}.btn-success:hover:not(:disabled){background:#f0fdf4;border-color:#86efac}.btn-warning{background:#fff;color:#eab308;border:1px solid #fde047}.btn-warning:hover:not(:disabled){background:#fefce8;border-color:#facc15}.action-buttons{display:flex;gap:.5rem;align-items:center}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;animation:slideUp .2s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary, #1e293b);margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary, #64748b);cursor:pointer;padding:.25rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:var(--text-primary, #1e293b)}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary, #1e293b);margin-bottom:.5rem}.form-group small{display:block;font-size:.75rem;color:var(--text-secondary, #64748b);margin-top:.375rem}.form-input{width:100%;padding:.75rem 1rem;font-size:.875rem;border:1px solid #cbd5e1;border-radius:.5rem;transition:all .2s;background:#fff;font-family:inherit}.form-input:disabled{background:#f1f5f9;cursor:not-allowed}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e2e8f0}.tenant-details{display:flex;flex-direction:column;gap:1rem}.detail-row{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 0;border-bottom:1px solid #f1f5f9}.detail-row:last-child{border-bottom:none}.detail-row label{min-width:120px;font-weight:600;color:var(--text-secondary, #64748b);font-size:.875rem}.detail-row span,.detail-row code{flex:1;font-size:.875rem;color:var(--text-primary, #1e293b)}.detail-row code{font-family:Monaco,Menlo,Courier New,monospace;background:#f1f5f9;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;word-break:break-all}.admin-count{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.25rem .5rem;background:#eff6ff;color:#1e40af;border-radius:.375rem;font-weight:600;font-size:.875rem}.success-banner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;margin-bottom:1.5rem;background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #22c55e;border-radius:.5rem;color:#166534;font-size:.875rem}.success-banner button{background:none;border:none;color:#166534;font-size:1.5rem;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s}.success-banner button:hover{background:#0000000d}@media(max-width:768px){.admin-main{margin-left:0}.admin-content{padding:1rem;padding-top:calc(64px + 1rem)}.tenants-header{flex-direction:column;align-items:stretch}.search-container{max-width:100%;order:-1}.tenants-table{font-size:.8125rem}.tenants-table th,.tenants-table td{padding:.75rem .5rem}.modal-content{width:95%}}@media(prefers-color-scheme:dark){.search-input{background:var(--input-bg);border-color:var(--input-border);color:var(--text-primary)}.tenants-table-container{background:var(--bg-card);box-shadow:0 1px 3px #0000004d}.tenants-table td{border-color:var(--border-color)}.tenants-table tbody tr:hover{background:var(--bg-secondary)}.tenant-slug{background:#1e1b4b;color:#a5b4fc}.status-badge.active{background:#052e16;color:#86efac}.status-badge.active:before{background:#16a34a}.status-badge.inactive{background:#450a0a;color:#fca5a5}.status-badge.inactive:before{background:#ef4444}.error-banner{background:#450a0a;border-color:#b91c1c;color:#fca5a5}.error-banner button{color:#fca5a5}.success-banner{background:#052e16;border-color:#15803d;color:#86efac}.success-banner button{color:#86efac}.modal-content{background:var(--bg-card)}.modal-header{border-color:var(--border-color)}.modal-close:hover{background:var(--bg-secondary)}.modal-footer{border-color:var(--border-color)}.form-input{background:var(--input-bg);border-color:var(--input-border);color:var(--text-primary)}.form-input:disabled{background:var(--bg-secondary)}.btn-secondary{background:var(--card-bg-secondary);border-color:var(--input-border);color:var(--text-primary)}.btn-danger{background:#450a0a;color:#fca5a5;border-color:#b91c1c}.btn-success{background:#052e16;color:#86efac;border-color:#15803d}.btn-warning{background:#451a03;color:#fcd34d;border-color:#b45309}.detail-row{border-color:var(--border-color)}.detail-row code{background:var(--bg-secondary);color:var(--text-primary)}.admin-count{background:#1e3a5f;color:#93c5fd}}.admin-content{flex:1;padding:2rem;padding-top:calc(64px + 2rem);max-width:1400px}.users-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.users-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1e293b)}.search-container{flex:1;max-width:400px;position:relative}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none}.search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;border:1px solid var(--border-color, #e2e8f0);border-radius:.5rem;font-size:.875rem;color:var(--text-primary, #1e293b);background:var(--bg-primary, #fff);transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:var(--text-secondary, #64748b)}.success-banner,.error-banner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;margin-bottom:1.5rem;border-radius:.5rem;font-size:.875rem}.success-banner{background:#f0fdf4;border:1px solid #bbf7d0;border-left:4px solid #22c55e;color:#166534}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #ef4444;color:#991b1b}.success-banner button,.error-banner button{background:none;border:none;font-size:1.25rem;color:inherit;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s ease}.success-banner button:hover{background:#22c55e1a}.error-banner button:hover{background:#ef44441a}.loading-state{display:flex;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary, #64748b);font-size:1rem}.empty-state{text-align:center;padding:4rem 2rem}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary, #1e293b)}.empty-state p{margin:0;font-size:.875rem;color:var(--text-secondary, #64748b)}.users-table-container{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:var(--bg-secondary, #f8fafc)}.users-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color, #e2e8f0)}.users-table td{padding:1rem;font-size:.875rem;color:var(--text-primary, #1e293b);border-bottom:1px solid var(--border-color, #e2e8f0)}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover{background:var(--bg-secondary, #f8fafc)}.user-email{font-weight:500;color:var(--text-primary, #1e293b)}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.role-superadmin{background:#fef3c7;color:#92400e}.role-admin{background:#dbeafe;color:#1e40af}.role-management{background:#e0e7ff;color:#3730a3}.role-viewer{background:#d1fae5;color:#065f46}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.active:before{background:#10b981}.status-badge.inactive{background:#fee2e2;color:#991b1b}.status-badge.inactive:before{background:#ef4444}.user-id{font-family:Courier New,monospace;font-size:.75rem;color:var(--text-secondary, #64748b);background:var(--bg-secondary, #f8fafc);padding:.25rem .5rem;border-radius:.25rem}.action-buttons{display:flex;gap:.5rem}.btn-action{padding:.375rem .75rem;border:1px solid var(--border-color, #e2e8f0);border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:var(--bg-primary, #fff)}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-edit{color:#3b82f6;border-color:#3b82f6}.btn-edit:hover:not(:disabled){background:#eff6ff}.btn-reset{color:#f59e0b;border-color:#f59e0b}.btn-reset:hover:not(:disabled){background:#fffbeb}.btn-delete{color:#ef4444;border-color:#ef4444}.btn-delete:hover:not(:disabled){background:#fef2f2}.btn-reset-password{padding:.5rem 1rem;border:1px solid var(--border-color, #e2e8f0);border-radius:.375rem;font-size:.875rem;background:var(--bg-primary, #fff);color:var(--text-primary, #1e293b);cursor:pointer;transition:all .2s ease}.btn-reset-password:hover{background:var(--bg-secondary, #f8fafc);border-color:var(--primary-color, #3b82f6)}.tenant-name{font-size:.875rem;color:var(--text-primary, #1e293b)}.tenant-name.system-admin{font-style:italic;color:var(--text-secondary, #64748b)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg-card, #fff);border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary, #1e293b)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary, #64748b);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem;transition:all .2s ease}.modal-close:hover{background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #1e293b)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-color, #e2e8f0)}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary, #1e293b)}.form-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color, #e2e8f0);border-radius:.5rem;font-size:.875rem;color:var(--text-primary, #1e293b);background:var(--bg-primary, #fff);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background:var(--bg-secondary, #f8fafc);cursor:not-allowed}.form-group small{display:block;margin-top:.375rem;font-size:.75rem;color:var(--text-secondary, #64748b)}.btn{padding:.625rem 1.25rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary-color, #3b82f6);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover, #2563eb)}.btn-secondary{background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary, #e2e8f0)}@media(max-width:768px){.admin-main{margin-left:0}.admin-content{padding:1rem}.users-table{font-size:.875rem}.users-table th,.users-table td{padding:.75rem .5rem}}@media(prefers-color-scheme:dark){.success-banner{background:#052e16;border-color:#15803d;color:#86efac}.success-banner button{color:#86efac}.error-banner{background:#450a0a;border-color:#b91c1c;color:#fca5a5}.error-banner button{color:#fca5a5}.role-superadmin{background:#451a03;color:#fcd34d}.role-admin{background:#1e3a5f;color:#93c5fd}.role-management{background:#1e1b4b;color:#a5b4fc}.role-viewer,.status-badge.active{background:#052e16;color:#86efac}.status-badge.active:before{background:#10b981}.status-badge.inactive{background:#450a0a;color:#fca5a5}.status-badge.inactive:before{background:#ef4444}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .25s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@keyframes fadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}@keyframes slideIn{0%{transform:translateY(-30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes slideDown{0%{max-height:0;opacity:0;transform:translateY(-10px)}to{max-height:500px;opacity:1;transform:translateY(0)}}@keyframes fadeInText{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.modal-dialog{background:var(--card-bg, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideIn .35s cubic-bezier(.4,0,.2,1);transition:box-shadow .3s ease}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-heading)}.modal-close-btn{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.modal-close-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#0000001a;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.modal-close-btn:hover:before{width:100%;height:100%}.modal-close-btn:hover{background-color:var(--border-color);color:var(--text-heading);transform:scale(1.1) rotate(90deg)}.modal-close-btn:active{transform:scale(.95) rotate(90deg)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color, #e5e7eb);display:flex;justify-content:flex-end;gap:.75rem;background-color:var(--card-bg, #ffffff)}.modal-body .form-group{margin-bottom:1rem}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{display:block;font-size:13px;font-weight:600;margin-bottom:.5rem;color:var(--text-heading)}.modal-body input[type=text],.modal-body input[type=email],.modal-body input[type=password],.modal-body input[type=number],.modal-body select,.modal-body textarea{width:100%;padding:.75rem;border:2px solid var(--border-color, #e5e7eb);border-radius:var(--radius-md, 8px);font-size:14px;font-family:inherit;background-color:var(--input-bg, #ffffff);color:var(--text-primary, #1f2937);transition:all .25s cubic-bezier(.4,0,.2,1)}.modal-body input[type=text]:hover,.modal-body input[type=email]:hover,.modal-body input[type=password]:hover,.modal-body input[type=number]:hover,.modal-body select:hover,.modal-body textarea:hover{border-color:#a0a0a0}.modal-body input[type=text]:focus,.modal-body input[type=email]:focus,.modal-body input[type=password]:focus,.modal-body input[type=number]:focus,.modal-body select:focus,.modal-body textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #3b82f626;transform:translateY(-1px)}.modal-body textarea{resize:vertical;min-height:100px}.password-strength-meter{height:6px;background-color:var(--border-color);border-radius:3px;margin-top:.5rem;overflow:hidden}.password-strength-bar{height:100%;border-radius:3px;transition:all .3s ease}.password-strength-bar.weak{width:33%;background-color:#dc2626}.password-strength-bar.fair{width:66%;background-color:#f59e0b}.password-strength-bar.strong{width:100%;background-color:#16a34a}.password-strength-text{font-size:12px;margin-top:.25rem;color:var(--text-secondary)}.modal-message{padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:13px;animation:slideInMessage .3s cubic-bezier(.4,0,.2,1);transform-origin:left center}@keyframes slideInMessage{0%{opacity:0;transform:translate(-20px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.modal-message.success{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.modal-message.error{background-color:#fee2e2;color:#7f1d1d;border:1px solid #fca5a5}.modal-message.warning{background-color:#fef3c7;color:#78350f;border:1px solid #fde68a}.modal-message.info{background-color:#dbeafe;color:#1e3a8a;border:1px solid #93c5fd}.modal-footer button{padding:.6rem 1.5rem;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.modal-footer button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .5s ease,height .5s ease}.modal-footer button:active:before{width:300px;height:300px}.modal-footer .btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f640}.modal-footer .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.modal-footer .btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.modal-footer .btn-primary:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;opacity:.6;box-shadow:none}.modal-footer .btn-secondary{background-color:var(--card-bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.modal-footer .btn-secondary:hover:not(:disabled){background-color:var(--border-color);border-color:#888;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.modal-footer .btn-secondary:active:not(:disabled){transform:translateY(0)}.modal-footer .btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 2px 8px #dc262640}.modal-footer .btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-2px);box-shadow:0 6px 20px #dc262666}.modal-footer .btn-danger:active:not(:disabled){transform:translateY(0)}@media(max-width:640px){.modal-dialog{max-width:95vw;max-height:95vh;width:95vw}.modal-header,.modal-body{padding:1rem}.modal-footer{padding:.75rem 1rem;flex-direction:column}.modal-footer button{width:100%}}.modal-dialog.scrollable{max-height:85vh;display:flex;flex-direction:column}.modal-dialog.scrollable .modal-body{flex:1;overflow-y:auto}.info-box-neutral{padding:.75rem 1rem;border-radius:6px;background-color:#f3f4f6;color:#374151}.info-box-blue{padding:.75rem;border-radius:6px;background-color:#f0f9ff;border:1px solid #bae6fd;color:#0369a1}.info-box-warning{padding:.75rem;border-radius:6px;background-color:#fff7ed;border:1px solid #ffedd5;color:#92400e}@media(prefers-color-scheme:dark){.modal-overlay{background-color:#000000b3}.modal-message.success{background-color:#052e16;color:#86efac;border-color:#15803d}.modal-message.error{background-color:#450a0a;color:#fca5a5;border-color:#b91c1c}.modal-message.warning{background-color:#451a03;color:#fcd34d;border-color:#b45309}.modal-message.info{background-color:#0c4a6e;color:#7dd3fc;border-color:#0369a1}.info-box-neutral{background-color:#374151;color:#e5e7eb}.info-box-blue{background-color:#0c4a6e;border-color:#1e40af;color:#7dd3fc}.info-box-warning{background-color:#451a03;border-color:#b45309;color:#fcd34d}}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary, #f8fafc)}.admin-main{flex:1;display:flex;flex-direction:column;margin-left:240px}.admin-content{flex:1;padding:2rem;padding-top:calc(64px + 2rem);max-width:1400px;animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:50ms}.section-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary, #1e293b)}.page-header .section-title{margin:0;flex-shrink:0}.content-meta{font-size:12px;color:var(--text-secondary, #94a3b8);text-align:right;margin:-1rem 0 .5rem}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;animation:fade-in-down .25s cubic-bezier(.4,0,.2,1) both}.page-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1e293b)}.page-header p{margin:.25rem 0 0;color:var(--text-secondary, #64748b);font-size:.875rem}.header-actions{display:flex;gap:.75rem;align-items:center;flex:1;justify-content:flex-end}.search-container{flex:1;max-width:360px;position:relative}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);font-size:1rem;color:#94a3b8}.search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;border:1px solid var(--border-color, #e2e8f0);border-radius:.5rem;font-size:.875rem;background:var(--input-bg, #ffffff);color:var(--text-primary, #1e293b);transition:all .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.table-container{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-sm);animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-secondary, #f8fafc)}.data-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color, #e2e8f0)}.data-table td{padding:1rem;font-size:.875rem;color:var(--text-primary, #1e293b);border-bottom:1px solid var(--border-color, #e2e8f0)}.data-table small{display:block;margin-top:.2rem;color:var(--text-secondary, #64748b);font-size:.75rem}.data-table tbody tr:last-child td{border-bottom:none}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.data-table tbody tr{transition:background-color .12s ease}.data-table tbody tr:hover{background:#1cb5a30a}.table-actions{display:flex;gap:.5rem}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .65rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-online{background:#dcfce7;color:#166534}.badge-offline{background:#fee2e2;color:#991b1b}.badge-stale{background:#fef3c7;color:#92400e}.badge-info{background:#e0f2fe;color:#075985}.badge-warning{background:#fef3c7;color:#92400e}.badge-critical{background:#fee2e2;color:#991b1b}.pill{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:9999px;font-size:.75rem;font-weight:600}.pill-mqtt{background:#e0f2fe;color:#075985}.pill-callback{background:#ede9fe;color:#5b21b6}.btn{padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;border-radius:.5rem;border:1px solid transparent;cursor:pointer;transition:all .2s ease;display:inline-block}.btn-primary{background:var(--primary-color, #1CB5A3);color:#fff;transition:background-color .15s ease,transform .1s ease,box-shadow .15s ease}.btn-primary:hover:not(:disabled){background:var(--primary-hover, #169A8B);box-shadow:0 4px 12px #1cb5a359;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:none}.btn-danger{background:#ef4444;color:#fff;transition:background-color .15s ease,transform .1s ease}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-danger:active:not(:disabled){transform:translateY(0)}.btn-sm{padding:.35rem .75rem;font-size:13px;border-radius:6px}.btn-action{padding:.35rem .75rem;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s;font-weight:500;border:none}.btn-action.btn-edit{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.btn-action.btn-edit:hover:not(:disabled){background:#fde68a;border-color:#f59e0b}.btn-action.btn-delete{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.btn-action.btn-delete:hover:not(:disabled){background:#fecaca;border-color:#f87171}.btn-action.btn-view{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.btn-action.btn-view:hover:not(:disabled){background:#a7f3d0;border-color:#34d399}.btn-action.btn-reset{background:#e9d5ff;color:#6b21a8;border:1px solid #c084fc}.btn-action.btn-reset:hover:not(:disabled){background:#ddd6fe;border-color:#a855f7}.btn-action.btn-info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.btn-action.btn-info:hover:not(:disabled){background:#bfdbfe;border-color:#60a5fa}.btn-text{padding:.35rem .5rem;background:transparent;border:none;color:var(--text-primary, #1e293b);cursor:pointer;font-size:.8rem;border-radius:.375rem}.btn-text:hover{background:#0f172a14}.btn-text.danger{color:#b91c1c}.btn-text.danger:hover{background:#ef44441f}.empty-state{text-align:center;padding:3.5rem 2rem;color:var(--text-secondary, #64748b);animation:fade-in-up .35s cubic-bezier(.4,0,.2,1) both;animation-delay:.1s}.empty-state h3{margin:0 0 .5rem;color:var(--text-primary, #1e293b)}.modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;z-index:2000;animation:modal-backdrop-in .2s ease both}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card-bg, #ffffff);border-radius:.75rem;width:100%;max-width:560px;max-height:calc(100vh - 4rem);box-shadow:0 20px 45px #0f172a33;margin:auto;display:flex;flex-direction:column;overflow:hidden;animation:modal-slide-in .25s cubic-bezier(.34,1.56,.64,1) both}@keyframes modal-slide-in{0%{opacity:0;transform:scale(.94) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem .75rem;flex-shrink:0}.modal-header h3{margin:0;font-size:1.25rem;color:var(--text-primary, #1e293b)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b}.modal-body{padding:1.5rem 1.75rem;overflow-y:auto;flex:1 1 auto}.modal-footer{padding:1rem 1.75rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem;border-top:1px solid var(--border-color, #e2e8f0);background:var(--card-bg, #ffffff);flex-shrink:0}.form-grid{display:grid;gap:1rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary, #1e293b)}.form-group input,.form-group select,.form-group textarea{padding:.6rem .75rem;border-radius:.5rem;border:1px solid var(--input-border, #cbd5e1);font-size:.875rem;background:var(--input-bg, #ffffff);color:var(--text-primary, #1e293b)}.form-group textarea{resize:vertical;min-height:90px}.form-group small{font-size:.75rem;color:var(--text-secondary, #64748b)}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:var(--primary-color, #1CB5A3);flex-shrink:0}.checkbox-grid{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.checkbox-item{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary, #f8fafc);padding:.5rem .6rem;border-radius:.5rem}.checkbox-item input{margin:0}.sensor-id-link{font-family:monospace;font-size:13px;font-weight:600;color:#3b82f6;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:opacity .2s}.sensor-id-link:hover{opacity:.7}@media(prefers-color-scheme:dark){.btn-action.btn-edit{background:#451a03;color:#fcd34d;border-color:#b45309}.btn-action.btn-edit:hover:not(:disabled){background:#78350f;border-color:#f59e0b}.btn-action.btn-delete{background:#450a0a;color:#fca5a5;border-color:#b91c1c}.btn-action.btn-delete:hover:not(:disabled){background:#7f1d1d;border-color:#dc2626}.btn-action.btn-view{background:#052e16;color:#6ee7b7;border-color:#15803d}.btn-action.btn-view:hover:not(:disabled){background:#14532d;border-color:#16a34a}.btn-action.btn-reset{background:#2e1065;color:#c4b5fd;border-color:#7c3aed}.btn-action.btn-reset:hover:not(:disabled){background:#4c1d95;border-color:#a78bfa}.btn-action.btn-info{background:#172554;color:#93c5fd;border-color:#1e40af}.btn-action.btn-info:hover:not(:disabled){background:#1e3a5f;border-color:#3b82f6}.badge-online{background:#052e16;color:#86efac}.badge-offline{background:#450a0a;color:#fca5a5}.badge-stale{background:#451a03;color:#fcd34d}.badge-info{background:#0c4a6e;color:#7dd3fc}.badge-warning{background:#451a03;color:#fcd34d}.badge-critical{background:#450a0a;color:#fca5a5}.pill-mqtt{background:#0c4a6e;color:#7dd3fc}.pill-callback{background:#2e1065;color:#c4b5fd}.modal-overlay{background:#0009}.btn-text{color:var(--text-primary)}.btn-text:hover{background:#f1f5f914}.btn-text.danger{color:#fca5a5}.btn-text.danger:hover{background:#ef444426}.sensor-id-link{color:#60a5fa}}.data-table tbody tr{animation:row-slide-in .25s cubic-bezier(.4,0,.2,1) both}.data-table tbody tr:nth-child(1){animation-delay:0ms}.data-table tbody tr:nth-child(2){animation-delay:30ms}.data-table tbody tr:nth-child(3){animation-delay:60ms}.data-table tbody tr:nth-child(4){animation-delay:90ms}.data-table tbody tr:nth-child(5){animation-delay:.12s}.data-table tbody tr:nth-child(6){animation-delay:.15s}.data-table tbody tr:nth-child(7){animation-delay:.18s}.data-table tbody tr:nth-child(8){animation-delay:.21s}.data-table tbody tr:nth-child(9){animation-delay:.24s}.data-table tbody tr:nth-child(10){animation-delay:.27s}.data-table tbody tr:nth-child(n+11){animation-delay:.3s}.badge{animation:count-pop .35s cubic-bezier(.34,1.56,.64,1) both}.search-input:focus{border-color:var(--primary-color, #1CB5A3);box-shadow:0 0 0 3px #1cb5a31f;animation:focus-ring-expand .25s cubic-bezier(.4,0,.2,1) forwards}.btn-action{position:relative;overflow:hidden}.btn-action:after{content:"";position:absolute;top:50%;left:50%;width:100%;aspect-ratio:1;border-radius:50%;background:#ffffff40;transform:translate(-50%,-50%) scale(0);opacity:0;pointer-events:none}.btn-action:active:after{animation:ripple-expand .4s cubic-bezier(.4,0,.2,1)}.form-grid .form-group:nth-child(1){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:50ms}.form-grid .form-group:nth-child(2){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.1s}.form-grid .form-group:nth-child(3){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.15s}.form-grid .form-group:nth-child(4){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.2s}.form-grid .form-group:nth-child(5){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.25s}.form-grid .form-group:nth-child(n+6){animation:fade-in-up .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.3s}.empty-state h3{animation:fade-in-down .35s cubic-bezier(.4,0,.2,1) both;animation-delay:.15s}.modal-footer .btn{animation:fade-in-up .2s cubic-bezier(.4,0,.2,1) both}.modal-footer .btn:first-child{animation-delay:.1s}.modal-footer .btn:last-child{animation-delay:.15s}@media(max-width:768px){.admin-main{margin-left:0}.admin-content{padding:1.25rem;padding-top:calc(64px + 1.25rem)}.header-actions{width:100%;justify-content:space-between;flex-wrap:wrap}.search-container{max-width:none;width:100%}.modal-content{max-width:100%}}.sensor-detail-container{flex:1;padding:2rem;padding-top:calc(64px + 2rem);max-width:1200px;animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:50ms}.back-btn{display:inline-flex;align-items:center;padding:.5rem 1rem;margin-bottom:1rem;background:var(--card-bg-secondary, #f8fafc);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:.5rem;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.back-btn:hover{border-color:var(--primary-color, #1CB5A3);color:var(--primary-color, #1CB5A3);transform:translate(-2px)}.sensor-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;margin-bottom:1rem;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem;box-shadow:0 1px 3px #0000000f;animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.1s}.sensor-header-info{display:flex;flex-direction:column;gap:.15rem}.sensor-header-id{font-family:monospace;font-size:15px;font-weight:700;color:var(--text-primary, #1e293b);letter-spacing:.5px}.sensor-header-name{font-size:14px;color:var(--text-secondary, #64748b)}.sensor-header-meta{font-size:13px;color:var(--text-secondary, #64748b)}.time-period-tabs{display:flex;gap:.375rem;margin-bottom:1rem;padding:.375rem;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:.625rem;width:fit-content}.tab-btn{padding:.4rem .875rem;background:transparent;color:var(--text-secondary, #64748b);border:none;border-radius:.375rem;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.tab-btn:hover{background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #1e293b)}.tab-btn.active{background:#3b82f6;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}.stat-card{padding:.875rem 1rem;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem}.stat-label{font-size:11px;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.375rem}.stat-value{font-size:20px;font-weight:700;color:var(--text-primary, #1e293b)}.stat-value.occupied{color:#991b1b}.stat-value.vacant{color:#065f46}.stat-value.last-reading{font-size:13px;font-weight:600}.charts-section{background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:.75rem;padding:1.25rem}.charts-title{margin:0 0 1rem;font-size:13px;font-weight:700;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.5px}.chart-container{width:100%}.chart-empty{text-align:center;padding:4rem 2rem;color:var(--text-secondary, #64748b);font-size:14px}@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.sensor-detail-container{padding:1.25rem;padding-top:calc(64px + 1.25rem)}.time-period-tabs{width:100%;justify-content:center}}.stat-card{animation:count-pop .35s cubic-bezier(.34,1.56,.64,1) both;transition:transform .18s ease,box-shadow .18s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(0, 0, 0, .1))}.stats-grid .stat-card:nth-child(1){animation-delay:.12s}.stats-grid .stat-card:nth-child(2){animation-delay:.18s}.stats-grid .stat-card:nth-child(3){animation-delay:.24s}.stats-grid .stat-card:nth-child(4){animation-delay:.3s}.stat-value{animation:slot-drop .4s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.25s}.charts-section{animation:fade-in-up .35s cubic-bezier(.4,0,.2,1) both;animation-delay:.2s}.tab-btn.active{animation:elastic-snap .3s cubic-bezier(.34,1.56,.64,1)}.time-period-tabs{animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.15s}@media(prefers-color-scheme:dark){.back-btn:hover{border-color:#60a5fa;color:#60a5fa}.sensor-header{box-shadow:0 1px 3px #0003}.tab-btn.active{background:#2563eb}.stat-value.occupied{color:#fca5a5}.stat-value.vacant{color:#86efac}}.dashboard-container{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary, #f8fafc)}.dashboard-content{display:flex;flex:1}.main-content{flex:1;margin-left:240px;padding:2rem;padding-top:calc(64px + 2rem)}.settings-page{max-width:800px}.settings-header{margin-bottom:2rem}.settings-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary, #1e293b);margin:0 0 .5rem}.settings-header p{color:var(--text-secondary, #64748b);margin:0}.settings-card{background:var(--card-bg, #ffffff);border-radius:.75rem;box-shadow:var(--shadow-sm);padding:2rem;border:1px solid var(--border-color, #e2e8f0)}.settings-card+.settings-card{margin-top:1.5rem}.settings-card h2{font-size:1.25rem;font-weight:600;color:var(--text-primary, #1e293b);margin:0 0 .5rem}.card-description{color:var(--text-secondary, #64748b);margin:0 0 1.5rem;font-size:.875rem}.alert{display:flex;gap:.75rem;padding:1rem;margin-bottom:1.5rem;border-radius:.5rem;font-size:.875rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.alert span:first-child{font-size:1.25rem}.password-form{display:flex;flex-direction:column;gap:1.5rem}.timezone-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary, #1e293b)}.form-group small{color:var(--text-secondary, #64748b);font-size:.75rem}.form-input{padding:.625rem .875rem;font-size:.875rem;border:1px solid var(--input-border, #cbd5e1);border-radius:.5rem;transition:all .2s;background:var(--input-bg, #ffffff);color:var(--text-primary, #1e293b)}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background:var(--bg-secondary, #f1f5f9);color:var(--text-secondary, #64748b);cursor:not-allowed}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}.btn{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--card-bg-secondary, #f8fafc);color:var(--text-primary, #1e293b);border:1px solid var(--input-border, #cbd5e1)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary, #f8fafc)}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.logo-variants-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:640px){.logo-variants-grid{grid-template-columns:1fr}}.logo-variant-card{display:flex;flex-direction:column;gap:.75rem}.logo-variant-label{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.logo-variant-preview{display:flex;align-items:center;justify-content:center;border-radius:.75rem;min-height:80px;padding:1rem}.logo-variant-preview img{height:56px;max-width:100%;object-fit:contain}.logo-variant-empty{font-size:.8rem;color:var(--text-secondary)}.logo-bg-light{background:#fff;border:1px solid #e2e8f0}.logo-bg-dark{background:#1e293b;border:1px solid #334155}.logo-bg-dark .logo-variant-empty{color:#94a3b8}.logo-variant-actions{display:flex;gap:.5rem}.logo-variant-msg{font-size:.8rem;padding:.25rem 0}.logo-variant-msg.success{color:var(--success-green, #2ecc71)}.logo-variant-msg.error{color:var(--error-red, #e63946)}.btn-sm{padding:.4rem .875rem;font-size:.8rem}@media(prefers-color-scheme:dark){.alert-error{background:#450a0a;border-color:#b91c1c;color:#fca5a5}.alert-success{background:#052e16;border-color:#15803d;color:#86efac}.form-input option{background:var(--input-bg);color:var(--text-primary)}.settings-page .form-input::selection{background:#3b82f6;color:#fff;-webkit-text-fill-color:#ffffff}.settings-page .form-input:focus{box-shadow:0 0 0 3px #3b82f640}}@media(max-width:768px){.main-content{margin-left:0;padding:1rem;padding-top:calc(64px + 1rem)}.settings-card{padding:1.5rem}.form-actions{flex-direction:column-reverse}.btn{width:100%}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;background-color:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;z-index:1000;box-shadow:none}@media(min-width:769px){.sidebar{transition:none}}@media(max-width:768px){.sidebar{transition:transform .3s ease}}.sidebar.collapsed{width:70px}.sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar.collapsed .sidebar-header{flex-direction:column;padding:1rem .5rem;gap:.75rem}.collapse-toggle{background:var(--sidebar-hover);border:none;color:var(--sidebar-text);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;transition:background .2s ease;flex-shrink:0}.collapse-toggle:hover{background:var(--sidebar-hover)}.sidebar-logo{display:flex;align-items:center;gap:.5rem}.sidebar.collapsed .sidebar-logo{justify-content:center}.logo-icon{font-size:28px;display:flex;align-items:center;justify-content:center}.logo-text{font-family:Syne,sans-serif;font-size:18px;font-weight:800;color:var(--sidebar-text-active);letter-spacing:3px;text-transform:uppercase}.logo-image{height:56px;width:100%;max-width:210px;object-fit:contain}.logo-light-only{display:block}.logo-dark-only,.logo-dark-fallback{display:none}.logo-light-fallback{display:block}@media(prefers-color-scheme:dark){.logo-light-only{display:none}.logo-dark-only,.logo-dark-fallback{display:block}.logo-light-fallback{display:none}}.sidebar-nav{flex:1;overflow-y:auto;padding:.5rem .625rem}.menu-list{list-style:none;padding:0;margin:0}.menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:8px;color:var(--sidebar-text);cursor:pointer;transition:background-color .15s ease,color .15s ease;font-size:14.5px;text-align:left;white-space:nowrap}.menu-item.no-animate{transition:none}.sidebar.collapsed .menu-item{justify-content:center;padding:.75rem 0}.menu-item:hover{background-color:var(--sidebar-hover);color:var(--sidebar-text-active)}.menu-item.active{background:#1cb5a31f;color:var(--primary-color);box-shadow:inset 0 0 0 1px #1cb5a333}.menu-item.active .menu-icon{color:var(--primary-color)}.menu-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-label{font-weight:500}.sidebar-footer{padding:1rem;border-top:1px solid var(--sidebar-border);position:relative;display:flex;flex-direction:column;gap:.75rem}.user-info-wrapper{position:relative}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);background:transparent;border:none;width:100%;text-align:left;color:inherit}.user-info:hover{background-color:var(--sidebar-hover)}.user-menu{position:absolute;bottom:100%;left:0;right:0;margin-bottom:.5rem;background:var(--card-bg);border:1px solid var(--sidebar-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;width:100%;background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);font-size:14px;text-align:left}.user-menu-item:hover{background:var(--sidebar-hover)}.user-menu-item.logout{color:var(--danger-color);border-top:1px solid var(--sidebar-border)}.user-menu-item.logout:hover{background:#ef44441a}.menu-item-icon{font-size:16px;width:20px;display:flex;align-items:center;justify-content:center}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.user-details{flex:1;min-width:0}.user-name{font-size:14px;font-weight:600;color:var(--sidebar-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;width:100%;padding:.65rem .75rem;background:transparent;border:none;border-radius:var(--radius-md);color:var(--danger-color);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.sidebar-logout:hover{background:#ef44441f}.menu-list .menu-item:nth-child(1){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:60ms}.menu-list .menu-item:nth-child(2){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.1s}.menu-list .menu-item:nth-child(3){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.14s}.menu-list .menu-item:nth-child(4){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.18s}.menu-list .menu-item:nth-child(5){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.22s}.menu-list .menu-item:nth-child(6){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.26s}.menu-list .menu-item:nth-child(7){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.3s}.menu-list .menu-item:nth-child(8){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.34s}.menu-list .menu-item:nth-child(n+9){animation:fade-in-left .25s cubic-bezier(.4,0,.2,1) both;animation-delay:.38s}.menu-list .menu-item.no-animate{animation:none}.menu-item:hover .menu-icon{transform:scale(1.1);transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.menu-item.active .menu-icon{animation:count-pop .3s cubic-bezier(.34,1.56,.64,1) both}.sidebar-header{animation:fade-in-down .3s cubic-bezier(.4,0,.2,1) both}.sidebar-footer{animation:fade-in-up .3s cubic-bezier(.4,0,.2,1) both;animation-delay:.4s}.user-avatar{transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.user-info:hover .user-avatar{transform:scale(1.08)}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--sidebar-text)}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1024px)and (min-width:769px){.sidebar,.sidebar.collapsed{width:70px}.menu-item{justify-content:center;padding:.75rem 0}.logo-text,.menu-label,.user-details{display:none}}@media(max-width:768px){.sidebar{width:240px;transform:translate(-100%)}.sidebar:not(.collapsed){transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.sidebar:not(.collapsed) .logo-text,.sidebar:not(.collapsed) .menu-label,.sidebar:not(.collapsed) .user-details{display:block}.collapse-toggle{display:none}}.app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body, "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary, #f5f5f5);color:var(--text-primary, #333)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display, "Syne", sans-serif)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.form-group{margin-bottom:1.5rem}.form-label,.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary, #333);font-size:14px}.form-input,.form-group input{width:100%;padding:12px 16px;font-size:15px;border:2px solid var(--input-border, #e0e0e0);border-radius:6px;background-color:var(--input-bg, #fafafa);color:var(--text-primary, #333);transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;font-family:inherit}.form-input:focus,.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder,.form-group input::placeholder{color:#999}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease,transform .1s ease;display:inline-block;text-align:center;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-online{background-color:#d4edda;color:#155724}.status-offline{background-color:#f8d7da;color:#721c24}.status-stale{background-color:#e2e3e5;color:#383d41}.error-message{padding:12px 16px;background:#fee;border:1px solid #fcc;color:#c33;border-radius:6px;margin-bottom:1rem;font-size:14px}.success-message{padding:12px 16px;background:#d4edda;border:1px solid #c3e6cb;color:#155724;border-radius:6px;margin-bottom:1rem;font-size:14px}.loading{text-align:center;padding:40px;color:#666;font-size:16px}@media(prefers-color-scheme:dark){.form-input:focus,.form-group input:focus{background-color:var(--input-bg)}.status-online{background-color:#052e16;color:#86efac}.status-offline{background-color:#450a0a;color:#fca5a5}.status-stale{background-color:#451a03;color:#fcd34d}.error-message{background:#450a0a;border-color:#b91c1c;color:#fca5a5}.success-message{background:#052e16;border-color:#15803d;color:#86efac}.loading{color:var(--text-secondary)}}:root{--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-elastic: cubic-bezier(.68, -.6, .32, 1.6);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out-circ: cubic-bezier(.85, 0, .15, 1);--duration-instant: .1s;--duration-fast: .2s;--duration-normal: .3s;--duration-slow: .5s;--duration-slower: .7s}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes scale-in-modal{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes bounce-in{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes fade-out-down{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}@keyframes scale-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes progress-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes bounce-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 8px #3b82f600}}.animate-fade-in-up{animation:fade-in-up var(--duration-normal) var(--ease-smooth)}.animate-fade-in-down{animation:fade-in-down var(--duration-normal) var(--ease-smooth)}.animate-fade-in-left{animation:fade-in-left var(--duration-normal) var(--ease-smooth)}.animate-fade-in-right{animation:fade-in-right var(--duration-normal) var(--ease-smooth)}.animate-scale-in{animation:scale-in var(--duration-normal) var(--ease-smooth)}.animate-bounce-in{animation:bounce-in var(--duration-slow) var(--ease-elastic)}.animate-delay-100{animation-delay:.1s}.animate-delay-200{animation-delay:.2s}.animate-delay-300{animation-delay:.3s}.animate-delay-400{animation-delay:.4s}.animate-delay-500{animation-delay:.5s}.animate-backwards{animation-fill-mode:backwards}.animate-forwards{animation-fill-mode:forwards}.animate-both{animation-fill-mode:both}.hover-lift{transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth)}.hover-lift:hover{transform:translateY(-2px)}.hover-lift-strong{transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth)}.hover-lift-strong:hover{transform:translateY(-4px)}.hover-scale{transition:transform var(--duration-fast) var(--ease-smooth)}.hover-scale:hover{transform:scale(1.05)}.hover-scale-sm{transition:transform var(--duration-fast) var(--ease-smooth)}.hover-scale-sm:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--duration-fast) var(--ease-smooth)}.hover-glow:hover{box-shadow:0 0 20px #3b82f64d}.active-press:active{transform:scale(.98)}.skeleton{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:shimmer 2s infinite linear;border-radius:4px}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-button{height:40px;border-radius:8px}.transition-all{transition:all var(--duration-normal) var(--ease-smooth)}.transition-colors{transition:color var(--duration-fast) var(--ease-smooth),background-color var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth)}.transition-transform{transition:transform var(--duration-fast) var(--ease-smooth)}.transition-opacity{transition:opacity var(--duration-fast) var(--ease-smooth)}.transition-shadow{transition:box-shadow var(--duration-fast) var(--ease-smooth)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.hover-lift:hover,.hover-lift-strong:hover,.hover-scale:hover,.hover-scale-sm:hover{transform:none}}.focus-ring:focus-visible{outline:3px solid var(--primary-color);outline-offset:2px}.focus-ring-inset:focus-visible{outline:3px solid var(--primary-color);outline-offset:-3px}.card-enter{animation:fade-in-up var(--duration-normal) var(--ease-smooth) backwards}.card-hover{transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth)}.card-hover:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.button-hover{position:relative;overflow:hidden;transition:all var(--duration-fast) var(--ease-smooth)}.button-hover:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left var(--duration-slow) var(--ease-smooth)}.button-hover:hover:before{left:100%}.button-hover:hover{transform:translateY(-2px)}.button-hover:active{transform:translateY(0)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes breathe{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.97)}}@keyframes reveal-up{0%{opacity:0;clip-path:inset(100% 0 0 0);transform:translateY(12px)}to{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}}@keyframes reveal-left{0%{opacity:0;clip-path:inset(0 100% 0 0);transform:translate(-8px)}to{opacity:1;clip-path:inset(0 0 0 0);transform:translate(0)}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes ripple-expand{0%{transform:scale(0);opacity:.4}to{transform:scale(2.5);opacity:0}}@keyframes border-trace{0%{background-size:0 2px,2px 0,0 2px,2px 0}25%{background-size:100% 2px,2px 0,0 2px,2px 0}50%{background-size:100% 2px,2px 100%,0 2px,2px 0}75%{background-size:100% 2px,2px 100%,100% 2px,2px 0}to{background-size:100% 2px,2px 100%,100% 2px,2px 100%}}@keyframes count-pop{0%{opacity:0;transform:scale(.5) translateY(8px)}60%{opacity:1;transform:scale(1.08) translateY(-2px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes row-slide-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes wiggle{0%,to{transform:rotate(0)}20%{transform:rotate(-2deg)}40%{transform:rotate(2deg)}60%{transform:rotate(-1deg)}80%{transform:rotate(1deg)}}@keyframes dot-ping{0%{transform:scale(1);opacity:1}75%,to{transform:scale(2.2);opacity:0}}@keyframes elastic-snap{0%{transform:scaleX(.85)}40%{transform:scaleX(1.06)}70%{transform:scaleX(.97)}to{transform:scaleX(1)}}.animate-float{animation:float 4s var(--ease-smooth) infinite}.animate-breathe{animation:breathe 3s var(--ease-smooth) infinite}.animate-reveal-up{animation:reveal-up var(--duration-normal) var(--ease-smooth) both}.animate-count-pop{animation:count-pop var(--duration-slow) var(--ease-out-back) both}.animate-row-slide{animation:row-slide-in var(--duration-fast) var(--ease-smooth) both}.animate-gradient-bg{background-size:200% 200%;animation:gradient-shift 8s ease infinite}.hover-teal-glow{transition:box-shadow var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth)}.hover-teal-glow:hover{box-shadow:0 0 0 3px #1cb5a326,0 4px 16px #1cb5a31f;border-color:#1cb5a366}.hover-border-trace{position:relative;background-image:linear-gradient(var(--primary-color),var(--primary-color)),linear-gradient(var(--primary-color),var(--primary-color)),linear-gradient(var(--primary-color),var(--primary-color)),linear-gradient(var(--primary-color),var(--primary-color));background-position:top left,top right,bottom right,bottom left;background-repeat:no-repeat;background-size:0 2px,2px 0,0 2px,2px 0;transition:background-size .4s var(--ease-smooth)}.hover-border-trace:hover{background-size:100% 2px,2px 100%,100% 2px,2px 100%}.ripple-container{position:relative;overflow:hidden}.ripple-container:after{content:"";position:absolute;top:50%;left:50%;width:100%;aspect-ratio:1;border-radius:50%;background:#1cb5a333;transform:translate(-50%,-50%) scale(0);opacity:0;pointer-events:none}.ripple-container:active:after{animation:ripple-expand .5s var(--ease-smooth)}.dot-ping-wrapper{position:relative;display:inline-flex}.dot-ping-wrapper:before{content:"";position:absolute;inset:0;border-radius:50%;background:inherit;animation:dot-ping 1.5s var(--ease-smooth) infinite}.animate-delay-50{animation-delay:50ms}.animate-delay-75{animation-delay:75ms}.animate-delay-150{animation-delay:.15s}.animate-delay-600{animation-delay:.6s}.animate-delay-700{animation-delay:.7s}.animate-delay-800{animation-delay:.8s}@keyframes focus-ring-expand{0%{box-shadow:0 0 #1cb5a366}to{box-shadow:0 0 0 4px #1cb5a31f}}.focus-ring-animate:focus{animation:focus-ring-expand .25s var(--ease-smooth) forwards;outline:none;border-color:var(--primary-color)}.tab-slide-indicator{position:relative}.tab-slide-indicator:after{content:"";position:absolute;bottom:-1px;left:50%;width:0;height:2px;background:var(--primary-color);border-radius:1px;transition:width var(--duration-fast) var(--ease-out-back),left var(--duration-fast) var(--ease-out-back)}.tab-slide-indicator:hover:after,.tab-slide-indicator.active:after{width:100%;left:0}@keyframes shine-sweep{0%{left:-75%}to{left:125%}}.hover-shine{position:relative;overflow:hidden}.hover-shine:after{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);pointer-events:none;opacity:0;transition:opacity .2s}.hover-shine:hover:after{opacity:1;animation:shine-sweep .6s var(--ease-smooth)}@keyframes slot-drop{0%{opacity:0;transform:translateY(-100%);filter:blur(2px)}70%{opacity:1;transform:translateY(6%);filter:blur(0)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.animate-slot-drop{animation:slot-drop .45s var(--ease-out-back) both}@keyframes tooltip-pop{0%{opacity:0;transform:translateY(4px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-tooltip-pop{animation:tooltip-pop .15s var(--ease-out-back) both}
