:root{--bg-primary:#f0f4f8;--bg-secondary:#fff;--bg-card:#ffffffd9;--bg-sidebar:#ffffffb3;--bg-input:#f8fafc;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--border-color:#94a3b840;--border-strong:#94a3b866;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#3b82f61a;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--danger-bg:#ef44441a;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 30px #0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--transition:.2s ease;--sidebar-width:220px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,sans-serif}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-card:#1e293bd9;--bg-sidebar:#0f172ad9;--bg-input:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#94a3b826;--border-strong:#94a3b84d;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-light:#60a5fa26;--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 30px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}select{appearance:none;border-radius:var(--radius-sm);border:1px solid var(--border-color);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;background-color:var(--bg-input);color:var(--text-primary);font-size:13px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition);outline:none;padding:8px 30px 8px 12px}select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;max-width:100%;margin-left:60px;padding:32px 40px;transition:margin-left .25s;overflow-x:hidden}.sidebar-expanded~.main-content{margin-left:220px}.sidebar{background:var(--bg-sidebar);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-collapsed{width:60px}.sidebar-expanded{width:220px;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border-color);white-space:nowrap;align-items:center;gap:10px;min-height:56px;padding:16px;display:flex}.brand-icon{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;font-weight:800;display:flex}.brand-text{color:var(--text-primary);opacity:1;font-size:15px;font-weight:700;transition:opacity .15s}.sidebar-collapsed .brand-text{opacity:0;pointer-events:none}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:8px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13px;font-weight:500;text-decoration:none;display:flex;overflow:hidden}.nav-link:hover{background:var(--accent-light);color:var(--accent);text-decoration:none}.nav-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}.back-link{color:var(--text-muted);font-size:12px}.back-link:hover{color:var(--accent)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-label{text-overflow:ellipsis;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border-color);padding:12px 8px}.sidebar-user{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:10px;padding:8px;font-size:12px;display:flex;overflow:hidden}.user-avatar{background:var(--accent-light);width:28px;height:28px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.sidebar-action{padding:6px}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;display:flex}.logout-btn:hover{color:var(--danger);background:var(--danger-bg)}.sidebar-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap;padding:14px 12px 4px;font-size:10px;font-weight:600}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.card-header{margin-bottom:20px}.card-header h1,.card-header h2{margin-bottom:4px;font-size:20px;font-weight:700}.card-header p{color:var(--text-secondary);font-size:14px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:600;font-family:var(--font-family);border:1px solid #0000;align-items:center;gap:8px;padding:10px 20px;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);text-decoration:none;box-shadow:0 4px 12px #3b82f64d}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--accent-light);border-color:var(--accent)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{color:var(--accent);background:var(--accent-light)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#dc2626}.btn-sm{padding:6px 14px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-input,.form-select,.form-textarea{border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-input);width:100%;color:var(--text-primary);font-size:14px;font-family:var(--font-family);transition:border-color var(--transition);outline:none;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.data-table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;background:var(--bg-secondary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px 16px;font-size:12px;font-weight:600}.data-table th:hover{color:var(--accent)}.data-table td{border-bottom:1px solid var(--border-color);white-space:nowrap;padding:10px 16px}.data-table tr:hover{background:var(--accent-light)}.data-table tr:last-child td{border-bottom:none}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-tag{background:var(--accent-light);color:var(--accent)}.badge-plan{color:#8b5cf6;background:#8b5cf61a}.badge-stage{border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600}.filter-bar{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);z-index:50;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:20px;padding:16px 20px;display:flex;position:relative}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px;font-weight:600}.filter-group select,.filter-group input[type=text]{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:13px;font-family:var(--font-family);outline:none;min-width:140px;padding:8px 12px}.filter-group select:focus,.filter-group input[type=text]:focus{border-color:var(--accent)}.filter-count{color:var(--text-muted);margin-left:auto;font-size:13px;font-weight:500}.multi-select-trigger,.custom-select-trigger{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:13px;font-family:var(--font-family);cursor:pointer;white-space:nowrap;min-width:140px;transition:border-color var(--transition);align-items:center;gap:8px;padding:8px 12px;display:flex}.multi-select-trigger:hover,.multi-select-trigger:focus,.custom-select-trigger:hover,.custom-select-trigger:focus{border-color:var(--accent);outline:none}.multi-select-dropdown,.custom-select-dropdown{border:1px solid var(--border-color);border-radius:var(--radius-md);z-index:100;background:#fff;min-width:180px;max-width:220px;max-height:480px;margin-top:4px;padding:4px;animation:.12s fadeIn;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014}[data-theme=dark] .multi-select-dropdown,[data-theme=dark] .custom-select-dropdown{background:#1e293b;box-shadow:0 8px 24px #0006,0 2px 8px #0000004d}.multi-select-option,.custom-select-option{color:var(--text-primary);cursor:pointer;transition:background var(--transition);text-transform:none;letter-spacing:0;white-space:nowrap;text-overflow:ellipsis;border-radius:6px;align-items:center;gap:6px;margin-bottom:0;padding:6px 8px;font-size:13px;font-weight:500;display:flex;overflow:hidden}.multi-select-option:hover,.custom-select-option:hover{background:var(--accent-light)}.custom-select-option.selected{background:var(--accent-light);color:var(--accent);font-weight:600}.multi-select-option input[type=checkbox]{appearance:none;border:2px solid var(--border-strong);background:var(--bg-input);cursor:pointer;width:16px;height:16px;transition:all var(--transition);border-radius:4px;flex-shrink:0;position:relative}.multi-select-option input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.multi-select-option input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:2px;left:5px;transform:rotate(45deg)}.multi-select-swatch{border-radius:50%;flex-shrink:0;width:10px;height:10px}.custom-select-chevron{opacity:.4;margin-left:auto;font-size:10px}.map-container{position:relative}.map-container.map-fullscreen{z-index:9999;background:var(--bg-primary);flex-direction:column;display:flex;position:fixed;inset:0}.map-container.map-fullscreen .filter-bar{border-top:none;border-left:none;border-right:none;border-radius:0;flex-shrink:0;margin-bottom:0}.map-container.map-fullscreen .map-body{flex:1;min-height:0;position:relative}.map-container.map-fullscreen .map-frame{border:none!important;border-radius:0!important;height:auto!important;min-height:0!important;position:absolute!important;inset:0!important}.map-body{position:relative}.map-frame{isolation:isolate}.map-controls{z-index:1000;flex-direction:column;gap:6px;display:flex;position:absolute;top:10px;right:10px}.map-ctrl-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;width:34px;height:34px;color:var(--text-secondary);transition:all var(--transition);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex}.map-ctrl-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.map-ctrl-btn.map-ctrl-active{background:var(--accent);color:#fff;border-color:var(--accent)}.map-layer-picker{z-index:1001;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(12px);white-space:nowrap;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:0;right:calc(100% + 8px)}.map-layer-option{color:var(--text-secondary);font-size:13px;font-family:var(--font-family);text-align:left;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;padding:6px 14px 6px 10px}.map-layer-option:hover{background:var(--accent-light);color:var(--text-primary)}.map-layer-option.active{background:var(--accent);color:#fff}.map-container.map-tv-mode,.map-container:fullscreen{background:#0a0a0f;position:relative;width:100vw!important;height:100vh!important}.map-container.map-tv-mode .map-body,.map-container:fullscreen .map-body{position:absolute!important;inset:0!important}.map-container.map-tv-mode .map-frame,.map-container:fullscreen .map-frame{border:none!important;border-radius:0!important;height:100%!important;min-height:0!important;position:absolute!important;inset:0!important}.map-container.map-tv-mode .map-controls,.map-container:fullscreen .map-controls{opacity:.05;transition:opacity .3s}.map-container.map-tv-mode .map-controls:hover,.map-container:fullscreen .map-controls:hover{opacity:1}.map-container.map-tv-mode .timelapse-overlay,.map-container:fullscreen .timelapse-overlay{padding:14px 22px;bottom:24px;right:24px}.map-container.map-tv-mode .timelapse-date,.map-container:fullscreen .timelapse-date{font-size:26px}.map-container.map-tv-mode .timelapse-count,.map-container:fullscreen .timelapse-count{font-size:14px}.timelapse-overlay{z-index:1000;-webkit-backdrop-filter:blur(12px);color:#f1f5f9;border-radius:var(--radius-md);text-align:right;pointer-events:none;background:#0f172ad9;padding:10px 16px;font-family:Inter,sans-serif;position:absolute;bottom:16px;right:16px;box-shadow:0 4px 20px #0000004d}.timelapse-date{letter-spacing:-.02em;font-size:18px;font-weight:700;line-height:1.2}.timelapse-count{color:#94a3b8;margin-top:2px;font-size:12px;font-weight:500}@keyframes markerPop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.timelapse-slider-wrap{z-index:1000;border-radius:0 0 var(--radius-md)var(--radius-md);opacity:.35;background:linear-gradient(#0000,#0f172a40);padding:16px 12px 10px;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.timelapse-slider-wrap:hover{opacity:1}.timelapse-slider{appearance:none;cursor:pointer;background:#fff3;border-radius:3px;outline:none;width:100%;height:6px;transition:height .2s}.timelapse-slider-wrap:hover .timelapse-slider{border-radius:4px;height:8px}.timelapse-slider::-webkit-slider-thumb{appearance:none;background:var(--accent,#3b82f6);cursor:grab;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px #0000004d}.timelapse-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 12px #0006}.timelapse-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.1)}.timelapse-slider::-moz-range-thumb{background:var(--accent,#3b82f6);cursor:grab;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px #0000004d}.timelapse-slider::-moz-range-thumb:hover{transform:scale(1.2)}.timelapse-slider::-moz-range-track{background:#fff3;border-radius:3px;height:6px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{font-size:24px;font-weight:800}.page-header p{color:var(--text-secondary);margin-top:2px;font-size:14px}.page-header-actions{align-items:center;gap:10px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:90%;max-width:560px;max-height:85vh;box-shadow:var(--shadow-lg);padding:28px;animation:.2s slideUp;overflow-y:auto}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:20px}.modal-close:hover{background:var(--danger-bg);color:var(--danger)}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:400px;box-shadow:var(--shadow-lg);padding:40px}.login-brand{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 16px;display:flex}.login-card h1{text-align:center;margin-bottom:4px;font-size:22px;font-weight:800}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:28px;font-size:14px}.login-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.login-card .btn-primary{justify-content:center;width:100%;margin-top:8px;padding:12px;font-size:15px}.login-success{color:#16a34a;border-radius:var(--radius-sm);background:#dcfce7;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-toggle{text-align:center;color:var(--text-muted);margin-top:16px;font-size:13px}.login-toggle-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.login-toggle-btn:hover{text-decoration:underline}.launcher-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.launcher-container{width:100%;max-width:680px}.launcher-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:48px;padding-bottom:24px;display:flex}.launcher-brand{align-items:center;gap:16px;display:flex}.launcher-logo{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border-radius:2px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.launcher-header h1{letter-spacing:-.02em;font-size:22px;font-weight:800}.launcher-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px;font-weight:400}.launcher-grid{background:var(--border-color);border:1px solid var(--border-color);gap:1px;display:grid}.app-card{background:var(--bg-card);box-shadow:none;color:inherit;cursor:pointer;border:none;border-left:3px solid #0000;border-radius:0;align-items:center;gap:16px;padding:20px 24px;text-decoration:none;transition:all .15s;display:flex}.app-card:hover{border-left-color:var(--accent);background:var(--bg-secondary);text-decoration:none}.app-card-icon{color:#fff;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:800;display:flex}.app-card-body{flex:1;min-width:0}.app-card-body h3{letter-spacing:-.01em;margin-bottom:2px;font-size:15px;font-weight:700}.app-card-body p{color:var(--text-secondary);font-size:12px;line-height:1.4}.app-card-arrow{color:var(--text-muted);opacity:0;flex-shrink:0;transition:all .15s}.app-card:hover .app-card-arrow{opacity:1;color:var(--accent);transform:translate(2px)}.launcher-footer{text-align:center;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-top:48px;font-size:11px;font-weight:600}.theme-toggle{border:1px solid var(--border-color);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:14px;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.toast{background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:2000;padding:12px 20px;font-size:14px;font-weight:500;animation:.3s slideUp;position:fixed;bottom:24px;right:24px}.activity-feed{flex-direction:column;gap:12px;display:flex}.activity-item{border-radius:var(--radius-sm);border:1px solid var(--border-color);gap:12px;padding:10px;font-size:13px;display:flex}.activity-icon{background:var(--accent-light);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.activity-content{flex:1}.activity-time{color:var(--text-muted);font-size:12px}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state-icon{margin-bottom:16px;font-size:48px}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:18px}.stats-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px}.stat-card .stat-value{color:var(--text-primary);font-size:28px;font-weight:800}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding:16px}.filter-bar{flex-direction:column;align-items:stretch}.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:12px}}.status-badge{font-size:11px;font-weight:600;font-family:var(--font-family);transition:all var(--transition);border:none;border-radius:20px;align-items:center;padding:3px 10px;display:inline-flex}.status-active{color:#16a34a;background:#22c55e1f}.status-inactive{background:var(--bg-secondary);color:var(--text-muted)}.status-deactivated{color:#dc2626;background:#ef44441f}.status-badge:not(:disabled):hover{filter:brightness(.9);transform:scale(1.02)}[data-theme=dark] .status-active{color:#4ade80;background:#22c55e2e}[data-theme=dark] .status-deactivated{color:#f87171;background:#ef44442e}.perm-matrix td,.perm-matrix th{vertical-align:middle;padding:8px 12px}.perm-dot{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:inline-flex}.perm-granted{color:#16a34a;background:#22c55e1f}.perm-denied{color:#dc2626;background:#ef444414}[data-theme=dark] .perm-granted{color:#4ade80;background:#22c55e2e}[data-theme=dark] .perm-denied{color:#f87171;background:#ef444426}.toggle-switch{cursor:pointer;width:36px;height:20px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;bottom:2px;left:2px;box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px)}.activity-feed{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);max-height:500px;overflow-y:auto}.activity-item{border-bottom:1px solid var(--border-color);align-items:flex-start;gap:10px;padding:10px 14px;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{flex-shrink:0;margin-top:1px;font-size:14px}.activity-content{flex:1;min-width:0}.activity-time{color:var(--text-muted);margin-top:2px;font-size:11px}.form-select{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-family);cursor:pointer;outline:none;padding:8px 12px}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.modal-backdrop{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;max-width:420px;padding:24px;animation:.15s fadeIn;box-shadow:0 20px 60px #0003}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:18px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:4px;font-size:18px}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.form-group{margin-bottom:14px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.form-input{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-family);outline:none;padding:8px 12px}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.user-config-panel{background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-direction:column;gap:20px;padding:20px 24px;animation:.15s fadeIn;display:flex}.config-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px}.config-section-title{color:var(--text-primary);margin-bottom:12px;font-size:13px;font-weight:700}.config-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px;display:grid}.config-toggle-row{border-radius:var(--radius-sm);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.config-toggle-row:hover{background:var(--bg-hover)}.perm-tabs{border-bottom:2px solid var(--border-color);gap:0;margin-bottom:24px;display:flex}.perm-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .15s}.perm-tab:hover{color:var(--text-primary)}.perm-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.perm-matrix td,.perm-matrix th{padding:8px 12px}.perm-checkbox{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.perm-checkbox input{opacity:0;width:0;height:0;position:absolute}.perm-check-mark{border:2px solid var(--border-color);background:var(--bg-card);border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .15s;display:flex}.perm-checkbox input:checked+.perm-check-mark{background:var(--accent);border-color:var(--accent)}.perm-checkbox input:checked+.perm-check-mark:after{content:"✓";color:#fff;font-size:13px;font-weight:700}.perm-check-mark.perm-modified{box-shadow:0 0 0 2px var(--accent-light)}.perm-checkbox:hover .perm-check-mark{border-color:var(--accent)}.perm-save-bar{border-top:1px solid var(--border-color);justify-content:flex-end;align-items:center;gap:12px;margin-top:8px;padding:16px 0;display:flex}.user-list{flex-direction:column;gap:4px;display:flex}.user-list-item{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:flex}.user-list-item:hover{border-color:var(--accent);background:var(--bg-secondary)}.user-list-avatar{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.user-detail-header{border-bottom:1px solid var(--border-color);margin-bottom:24px;padding-bottom:16px}.override-badge{color:var(--accent);background:var(--accent-light);text-transform:uppercase;letter-spacing:.3px;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}
