.header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:#0d1220;border-bottom:1px solid rgba(0,212,255,.25);min-height:50px;gap:var(--spacing-md);box-shadow:0 2px 20px #00d4ff1a;color:#fff}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header .back-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#1f2937!important;border:1px solid #374151!important;border-radius:var(--radius-sm);color:#fff!important;font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.header .back-btn:hover{background:#111827!important;border-color:#60a5fa!important;transform:translate(-2px)}.header .back-btn svg{width:18px;height:18px}.logo{height:50px;margin:-8px 0;display:flex;align-items:center;justify-content:center}.logo-icon{height:100%;width:auto;object-fit:contain}.header-title{font-size:1.25rem;font-weight:600;color:#fff;letter-spacing:.5px;white-space:nowrap}.header-center{display:flex;align-items:center;gap:var(--spacing-lg)}.status-group{display:flex;gap:var(--spacing-md)}.status-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:var(--status-online);box-shadow:0 0 6px var(--status-online)}.status-dot.offline{background:var(--status-offline);box-shadow:0 0 6px var(--status-offline)}.status-label{color:#ffffffb3}.status-value{color:#fff;font-weight:600}.system-info{display:flex;gap:var(--spacing-md)}.info-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.7rem;padding:2px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.info-item:hover{background:#ffffff1a}.info-item.network{color:#00bcd4;background:#00bcd41a}.info-item.system{color:var(--text-secondary);background:#ffffff0d}.info-icon{width:14px;height:14px}.add-camera-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:6px 12px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:var(--radius-sm);color:#fff!important;font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 4px #10b9814d}.add-camera-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.datetime{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.time{font-size:1.1rem;font-weight:600;color:#fff;font-variant-numeric:tabular-nums}.date{font-size:.7rem;color:#ffffffb3}.menu-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff1a;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.menu-btn:hover{background:#fff3}.menu-btn svg{width:16px;height:16px}.user-section{display:flex;align-items:center;gap:var(--spacing-sm);padding-left:var(--spacing-md);border-left:1px solid var(--border-light)}.user-name{color:var(--text-secondary);font-size:.85rem;font-weight:500}.admin-link{padding:4px 12px;background:#8b5cf633;border:1px solid var(--accent-purple);border-radius:var(--radius-sm);color:var(--accent-purple);font-size:.75rem;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.admin-link:hover{background:#8b5cf666;color:var(--text-primary)}.logout-btn{display:flex;align-items:center;gap:4px;padding:4px 12px;background:#ef44441a;border:1px solid var(--status-offline);border-radius:var(--radius-sm);color:var(--status-offline);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:#ef44444d;color:var(--text-primary)}.logout-btn svg{width:14px;height:14px}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#1f2937!important;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff!important;cursor:pointer;transition:all var(--transition-fast)}.user-menu-trigger:hover,.user-menu-trigger.active{background:#111827;border-color:#60a5fa}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#60a5fa,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff}.user-avatar.large{width:40px;height:40px;font-size:16px}.user-menu .user-name{font-size:.85rem;font-weight:500;color:#fff!important}.dropdown-arrow{width:18px;height:18px;color:#d1d5db;transition:transform var(--transition-fast)}.user-menu-trigger.active .dropdown-arrow{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:#141928fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0009;z-index:1000;animation:dropdownSlide .2s ease;overflow:hidden}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-header{display:flex;align-items:center;gap:12px;padding:16px;background:#0f1423f2}.user-info{display:flex;flex-direction:column;gap:2px}.user-fullname{font-size:.95rem;font-weight:600;color:var(--text-primary)}.user-email{font-size:.75rem;color:#9ca3af}.menu-divider{height:1px;background:#ffffff14}.menu-items{padding:8px 0}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;background:transparent;border:none;color:#d1d5db;font-size:.9rem;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.menu-item:hover{background:#ffffff14;color:#fff!important}.menu-item svg{width:20px;height:20px;flex-shrink:0}.menu-item.logout{padding:12px 16px;color:var(--status-offline)}.menu-item.logout:hover{background:#ef44441a}.sidebar{width:240px;background:linear-gradient(180deg,#0d1525,#080d18);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-right:1px solid rgba(0,212,255,.15);display:flex;flex-direction:column;transition:width var(--transition-normal);position:relative;z-index:10;box-shadow:2px 0 30px #000c}.sidebar.collapsed{width:50px}.sidebar.collapsed .sidebar-content{display:none}.sidebar-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1);background:#0000004d}.sidebar-title{font-size:14px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.header-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.add-project-btn{background:var(--accent-blue);border:none;color:var(--bg-primary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.add-project-btn:hover{background:#00a5bb;transform:scale(1.05)}.add-project-btn svg{width:16px;height:16px}.toggle-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.toggle-btn:hover{background:var(--border-light);color:var(--text-primary)}.toggle-btn svg{width:20px;height:20px}.project-list{overflow-y:auto;padding:var(--spacing-sm) 0;flex:1}.project-item{display:flex;align-items:center;gap:10px;width:calc(100% - 16px);margin:4px 8px;padding:10px 12px;background:#000f1e99;border:1px solid rgba(0,212,255,.12);border-radius:8px;cursor:pointer;transition:all .2s ease;overflow:hidden}.project-item:hover{background:#00d4ff14;border-color:#00d4ff80;box-shadow:0 0 14px #00d4ff33}.project-item.active{background:#00d4ff1a;border-color:#00d4ffcc;box-shadow:0 0 20px #00d4ff4d}.project-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);border-radius:6px;color:#4a7a9b;transition:all .2s}.project-item:hover .project-icon{color:#00d4ff;border-color:#00d4ff80;background:#00d4ff26}.project-item.active .project-icon{color:#00d4ff;border-color:#00d4ffb3;background:#00d4ff33}.project-icon svg{width:18px;height:18px}.project-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-name-text{font-size:13px;font-weight:600;color:#7a9bb5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}.project-item:hover .project-name-text,.project-item.active .project-name-text{color:#00d4ff}.project-selected-label{font-size:10px;font-weight:700;color:#00d4ff;letter-spacing:1px}.project-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.project-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity var(--transition-fast);margin-right:var(--spacing-xs);flex-shrink:0}.project-item:hover .project-actions{opacity:1}.edit-project-btn,.delete-project-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.edit-project-btn:hover{background:#00bcd41a;color:var(--accent-blue)}.delete-project-btn:hover{background:#ff52521a;color:var(--status-offline)}.edit-project-btn svg,.delete-project-btn svg{width:14px;height:14px}.no-projects{font-size:12px;color:var(--text-muted);text-align:center;padding:var(--spacing-md);font-style:italic}.project-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.project-name-text{display:inline-block;white-space:nowrap}.project-item:hover .project-name{text-overflow:clip}.project-item:hover .project-name-text{animation:marquee 4s linear infinite}@keyframes marquee{0%{transform:translate(0)}10%{transform:translate(0)}90%{transform:translate(calc(-100% + 80px))}to{transform:translate(calc(-100% + 80px))}}.camera-count{font-size:10px;font-weight:500;color:#4a7a9b;white-space:nowrap;transition:color .2s}.project-item:hover .camera-count,.project-item.active .camera-count{color:#00d4ff}.expand-arrow{width:20px;height:20px;display:flex;align-items:center;justify-content:center;margin-right:4px;transition:transform .2s ease;flex-shrink:0}.expand-arrow svg{width:16px;height:16px;color:var(--text-muted)}.expand-arrow.expanded{transform:rotate(90deg)}.project-item:hover .expand-arrow svg{color:var(--text-primary)}.project-item.active .expand-arrow svg{color:var(--accent-blue)}.project-node{margin-bottom:2px}.project-node>.camera-list{background:#0003;padding:var(--spacing-xs) 0;margin-left:12px;border-left:1px solid rgba(255,255,255,.1)}.project-node>.camera-list .camera-item{padding:8px 12px 8px 20px;cursor:pointer;display:flex;align-items:center;gap:8px}.project-node>.camera-list .camera-item:hover{background:#00bcd41a}.project-node>.camera-list .camera-icon{width:16px;height:16px;color:var(--accent-blue);flex-shrink:0}.project-node>.camera-list .camera-name{font-size:12px;color:var(--text-secondary)}.project-node>.camera-list .camera-item:hover .camera-name{color:var(--accent-blue)}.project-node>.camera-list .no-cameras{font-size:11px;color:var(--text-muted);padding:8px 20px;font-style:italic}.project-node>.camera-list .camera-loading{display:flex;align-items:center;gap:8px;padding:8px 20px;font-size:11px;color:var(--text-muted)}.mini-spinner{width:12px;height:12px;border:2px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.camera-management{flex:1;display:flex;flex-direction:column;border-top:1px solid var(--border-color);overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-header)}.section-header .selector-title{margin-bottom:0}.add-camera-btn{background:var(--accent-blue);border:none;color:var(--bg-primary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.add-camera-btn:hover{background:#00a5bb;transform:scale(1.05)}.add-camera-btn svg{width:18px;height:18px}.camera-list{flex:1;overflow-y:auto;padding:var(--spacing-xs) 0}.camera-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-md);transition:background var(--transition-fast)}.camera-item:hover{background:var(--border-light)}.camera-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.camera-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-location{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.camera-item:hover .camera-actions{opacity:1}.edit-camera-btn,.delete-camera-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.edit-camera-btn:hover{background:#00bcd41a;color:var(--accent-blue)}.delete-camera-btn:hover{background:#ff52521a;color:var(--status-offline)}.edit-camera-btn svg,.delete-camera-btn svg{width:16px;height:16px}.no-cameras{font-size:12px;color:var(--text-muted);text-align:center;padding:var(--spacing-md);font-style:italic}.grid-selector{padding:var(--spacing-md);border-top:1px solid var(--border-color);background:var(--bg-primary)}.selector-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;margin-bottom:var(--spacing-sm);letter-spacing:.5px}.grid-options{display:flex;gap:var(--spacing-sm)}.grid-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.grid-option:hover{border-color:var(--text-muted)}.grid-option.active{border-color:var(--accent-blue);background:#00bcd41a}.grid-preview{display:grid;gap:2px;width:36px;height:36px}.grid-option.active .grid-cell{background:var(--accent-blue)}.grid-label{font-size:11px;color:var(--text-secondary);font-weight:500}.grid-option.active .grid-label{color:var(--accent-blue)}.sidebar-collapsed-content{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;padding-top:var(--spacing-md)}.expand-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.expand-btn:hover{background:var(--border-light);color:var(--accent-blue)}.expand-btn svg{width:24px;height:24px}@media (max-width: 768px){.sidebar{position:absolute;left:0;top:0;height:100%;z-index:100;box-shadow:var(--shadow-lg)}.sidebar.collapsed{width:40px}}.camera-frame{position:relative;background:#050a12;overflow:hidden;border:2px solid rgba(0,212,255,.6);box-shadow:0 0 18px #00d4ff40,0 0 4px #00d4ff66 inset;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.camera-frame.aspect-16-9{aspect-ratio:16 / 9}.camera-frame.aspect-4-3{aspect-ratio:4 / 3}.camera-frame.aspect-1-1{aspect-ratio:1 / 1}.camera-frame:not(.fullscreen):hover{transform:scale(1.01);border-color:#00d4ff;box-shadow:0 0 30px #00d4ff99,0 0 80px #00d4ff26;z-index:5}.camera-frame.offline{opacity:.85}.camera-frame.fullscreen{border:none}.camera-stream{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#050d18,#020810);position:relative}.stream-video{width:100%;height:100%;object-fit:contain;position:absolute;top:0;left:0;background:#000}.stream-video.hidden{opacity:0}.stream-video.visible{opacity:1;z-index:1}.stream-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#050d18,#020810)}.no-signal{color:var(--text-muted);font-size:.9rem;text-align:center;padding:var(--spacing-md)}.no-signal-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);text-align:center}.no-signal-icon{width:48px;height:48px;color:var(--text-muted);opacity:.6}.no-signal-text{color:var(--text-secondary);font-size:.95rem;font-weight:500}.no-signal-playback-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#00bcd426;border:1px solid var(--accent-blue);border-radius:var(--radius-sm);color:var(--accent-blue);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.no-signal-playback-btn:hover{background:#00bcd44d;transform:scale(1.02)}.no-signal-playback-btn svg{width:16px;height:16px}.camera-frame.fullscreen .no-signal-icon{width:64px;height:64px}.camera-frame.fullscreen .no-signal-text{font-size:1.2rem}.camera-frame.fullscreen .no-signal-playback-btn{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.camera-frame.fullscreen .no-signal-playback-btn svg{width:20px;height:20px}.stream-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#252540e6;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.85rem;z-index:2}.playback-container{width:100%;height:100%;position:relative}.playback-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#252540e6;gap:var(--spacing-sm);color:var(--text-secondary);font-size:.85rem;z-index:2}.playback-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#dc3545e6;color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.85rem;z-index:3}.click-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:#000000b3;border-radius:var(--radius-md);color:var(--text-primary);font-size:.8rem;opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:15}.click-hint svg{width:32px;height:32px;color:var(--accent-blue)}.camera-frame:not(.fullscreen):hover .click-hint{opacity:1}.camera-overlay-top{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(180deg,rgba(0,0,0,.7) 0%,transparent 100%);pointer-events:none}.camera-info-left{display:flex;align-items:center;gap:var(--spacing-sm)}.camera-name{font-size:1rem;font-weight:600;color:var(--text-primary);text-shadow:0 1px 3px rgba(0,0,0,.5)}.camera-frame.fullscreen .camera-name{font-size:1.4rem}.camera-frame.fullscreen .camera-location{font-size:1.2rem}.status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:background .3s ease,box-shadow .3s ease}.camera-frame.fullscreen .status-indicator{width:14px;height:14px}.status-indicator.online{background:var(--status-online);box-shadow:0 0 8px var(--status-online);animation:pulse 2s ease-in-out infinite}.status-indicator.offline{background:var(--status-offline);box-shadow:0 0 8px var(--status-offline)}.camera-info-right{display:flex;align-items:center;gap:12px}.camera-location{font-size:.9rem;font-weight:500;color:var(--text-primary);text-shadow:0 1px 3px rgba(0,0,0,.5)}.camera-action-buttons{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .2s ease;pointer-events:auto}.camera-frame:hover .camera-action-buttons{opacity:1}.camera-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#00000080;color:var(--text-secondary)}.camera-action-btn:hover{transform:scale(1.1)}.camera-action-btn svg{width:16px;height:16px}.camera-action-btn.edit-btn:hover{background:#00bcd4cc;color:#fff}.camera-action-btn.delete-btn:hover{background:#ef4444cc;color:#fff}.camera-frame.fullscreen .camera-action-btn{width:36px;height:36px}.camera-frame.fullscreen .camera-action-btn svg{width:20px;height:20px}.camera-overlay-bottom{position:absolute;bottom:0;left:0;right:0;z-index:10;display:flex;justify-content:space-between;align-items:flex-end;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(0deg,rgba(0,0,0,.7) 0%,transparent 100%)}.camera-icons{display:flex;gap:var(--spacing-xs)}.icon-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);pointer-events:auto}.camera-frame.fullscreen .icon-btn{width:32px;height:32px}.camera-frame.fullscreen .icon-btn svg{width:22px;height:22px}.icon-btn:hover{color:var(--text-primary)}.icon-btn svg{width:16px;height:16px}.icon-btn.wifi{color:var(--status-offline);transition:color .3s ease}.icon-btn.wifi.active{color:var(--status-online)}.camera-status{display:flex;align-items:center;gap:var(--spacing-sm)}.rec-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;font-weight:600;color:var(--status-recording);text-shadow:0 1px 3px rgba(0,0,0,.5)}.camera-frame.fullscreen .rec-indicator{font-size:1rem}.rec-dot{width:8px;height:8px;border-radius:50%;background:var(--status-recording);animation:blink 1s ease-in-out infinite}.camera-frame.fullscreen .rec-dot{width:12px;height:12px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.95)}}.record-btn{background:#ffffff1a!important;border:1px solid rgba(255,255,255,.2)!important;cursor:pointer;transition:all .2s ease}.record-btn:hover{background:#ef44444d!important;border-color:#ef4444!important}.record-btn svg{width:14px;height:14px;color:#ef4444}.record-btn.recording{background:linear-gradient(135deg,#ef4444,#dc2626)!important;border-color:#ef4444!important;animation:pulse-record 1.5s infinite}.record-btn.recording svg{color:#fff}@keyframes pulse-record{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 6px #ef444400}}.playback-btn{background:#ffffff1a!important;border:1px solid rgba(255,255,255,.2)!important;cursor:pointer;transition:all .2s ease}.playback-btn:hover{background:#00bcd44d!important;border-color:var(--accent-blue)!important}.playback-btn svg{width:14px;height:14px;color:var(--accent-blue)}.rec-indicator.recording-active{background:#ef444433;padding:4px 8px;border-radius:4px;border:1px solid rgba(239,68,68,.5)}.rec-indicator.playback-active{background:#00bcd433;padding:4px 8px;border-radius:4px;border:1px solid rgba(0,188,212,.5);color:var(--accent-blue);display:flex;align-items:center}.live-btn{background:#4caf5033!important;border:1px solid rgba(76,175,80,.5)!important;cursor:pointer;transition:all .2s ease;padding:4px 8px!important;width:auto!important;border-radius:4px;color:#4caf50!important;font-weight:600}.live-btn:hover{background:#4caf5066!important;border-color:#4caf50!important}.live-btn svg{width:14px;height:14px;color:#4caf50}.playback-video{z-index:5}.playback-video::-webkit-media-controls{z-index:20}.stream-inactive{cursor:pointer;transition:all .3s ease}.stream-inactive:hover{background:#00bcd41a}.click-to-view{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary);padding:20px}.click-to-view svg{width:48px;height:48px;color:var(--accent-blue);opacity:.7;transition:all .3s ease}.stream-inactive:hover .click-to-view svg{opacity:1;transform:scale(1.1)}.click-to-view span{font-size:14px;font-weight:500}.upload-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.upload-modal{background:#1a1a2e;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid #333;box-shadow:0 20px 60px #00000080}.upload-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#16213e;border-bottom:1px solid #333}.upload-modal-header h2{margin:0;font-size:1.25rem;color:#00d4ff}.upload-close-btn{background:none;border:none;color:#888;font-size:1.5rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.upload-close-btn:hover{color:#fff}.upload-modal-body{padding:20px;overflow-y:auto;flex:1}.upload-selects{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.upload-select-group{display:flex;flex-direction:column;gap:6px}.upload-select-group label{font-size:.85rem;color:#888}.upload-select-group select{padding:10px 12px;background:#0f0f23;border:1px solid #333;border-radius:6px;color:#fff;font-size:.95rem;cursor:pointer;transition:border-color .2s}.upload-select-group select:focus{outline:none;border-color:#00d4ff}.upload-select-group select:disabled{opacity:.5;cursor:not-allowed}.upload-info{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;background:#0f0f23;border-radius:8px;padding:16px;border:1px solid #333}.upload-info-item{display:flex;flex-direction:column;gap:4px}.upload-info-item label{font-size:.8rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.upload-info-value{font-size:1rem;color:#00d4ff;font-weight:500}.upload-dropzone{border:2px dashed #444;border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s;background:#00d4ff05}.upload-dropzone:hover:not(.disabled){border-color:#00d4ff;background:#00d4ff0d}.upload-dropzone.dragging{border-color:#00d4ff;background:#00d4ff1a;transform:scale(1.01)}.upload-dropzone.disabled{opacity:.5;cursor:not-allowed}.upload-dropzone-content{pointer-events:none}.upload-icon{font-size:3rem;display:block;margin-bottom:12px}.upload-dropzone p{margin:4px 0;color:#ccc}.upload-hint{font-size:.85rem;color:#888!important}.upload-formats{font-size:.8rem;color:#666!important;margin-top:8px!important}.upload-chunk-info{font-size:.75rem;color:#00d4ff!important;margin-top:4px!important;opacity:.8}.upload-jobs{margin-top:24px}.upload-jobs h3{font-size:.95rem;color:#888;margin-bottom:12px}.upload-job{background:#0f0f23;border-radius:8px;padding:12px 16px;margin-bottom:10px;border:1px solid #333}.upload-job-info{display:flex;align-items:center;gap:12px;margin-bottom:10px}.upload-job-icon{font-size:1.25rem}.upload-job-details{flex:1;min-width:0}.upload-job-name{display:block;color:#fff;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-job-size{font-size:.8rem;color:#666}.upload-job-status{display:flex;align-items:center;gap:12px}.upload-progress-bar{flex:1;height:6px;background:#333;border-radius:3px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#00d4ff,#0f8);border-radius:3px;transition:width .3s ease}.upload-progress-text{font-size:.8rem;color:#888;white-space:nowrap;min-width:120px}.upload-status-text{font-size:.85rem}.upload-status-text.success{color:#0f8}.upload-status-text.error{color:#ff6b6b}.upload-cancel-btn,.upload-remove-btn{padding:4px 12px;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s}.upload-cancel-btn{background:#ff6b6b;color:#fff}.upload-cancel-btn:hover{background:#ff5252}.upload-remove-btn{background:#333;color:#888}.upload-remove-btn:hover{background:#444;color:#fff}.upload-modal-footer{padding:16px 20px;background:#16213e;border-top:1px solid #333;display:flex;justify-content:flex-end}.upload-done-btn{padding:10px 24px;background:#00d4ff;color:#000;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.upload-done-btn:hover{background:#00b8e6}@media (max-width: 500px){.upload-selects{grid-template-columns:1fr}.upload-modal{width:95%;max-height:95vh}}.recordings-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.recordings-panel{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:600px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;animation:slideIn .3s ease;border:1px solid var(--border-color);overflow:hidden}.recordings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:#0003}.recordings-title-wrapper{display:flex;align-items:center;gap:var(--spacing-md)}.recordings-icon{width:32px;height:32px;color:var(--accent-blue)}.recordings-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.recordings-subtitle{font-size:13px;color:var(--text-secondary);margin:2px 0 0}.recordings-header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.upload-video-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#00d4ff,#00b8e6);border:none;border-radius:var(--radius-sm);color:#000;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.upload-video-btn:hover{background:linear-gradient(135deg,#00b8e6,#009dd1);transform:translateY(-1px)}.upload-video-btn svg{width:16px;height:16px}.recordings-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.recordings-close:hover{background:var(--border-light);color:var(--status-offline)}.recordings-close svg{width:20px;height:20px}.recordings-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.recordings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;color:var(--text-secondary);gap:var(--spacing-md)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}.recordings-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;color:var(--status-offline);gap:var(--spacing-sm)}.recordings-error svg{width:48px;height:48px}.recordings-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;color:var(--text-secondary);text-align:center}.recordings-empty svg{width:64px;height:64px;color:var(--text-muted);margin-bottom:var(--spacing-md)}.recordings-empty p{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.recordings-empty span{font-size:13px;color:var(--text-muted)}.recordings-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recording-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#ffffff0d;border-radius:var(--radius-md);border:1px solid var(--border-color);transition:all var(--transition-fast);cursor:pointer;pointer-events:auto}.recording-item:hover{background:#ffffff1a;border-color:var(--accent-blue)}.recording-thumbnail{width:80px;height:50px;background:#0006;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.recording-thumbnail:hover{background:#00bcd44d}.recording-thumbnail svg{width:24px;height:24px;color:var(--text-primary)}.recording-info{flex:1;min-width:0;cursor:pointer}.recording-name{font-size:14px;font-weight:500;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recording-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:12px;color:var(--text-secondary)}.recording-meta span{display:flex;align-items:center;gap:4px}.recording-meta svg{width:14px;height:14px;color:var(--text-muted)}.recording-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.action-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.action-btn svg{width:16px;height:16px}.action-btn.play-btn:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.action-btn.download-btn:hover{background:var(--status-online);border-color:var(--status-online);color:#fff}.action-btn.delete-btn:hover{background:var(--status-offline);border-color:var(--status-offline);color:#fff}@media (max-width: 600px){.recordings-panel{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}.recording-item{flex-wrap:wrap}.recording-thumbnail{width:60px;height:40px}.recording-info{flex-basis:calc(100% - 80px)}.recording-actions{width:100%;justify-content:flex-end;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.recording-meta{gap:var(--spacing-sm)}}.camera-grid-container{position:relative;width:100%;height:100%}.camera-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:3px;width:100%;height:100%;background:#020608;overflow:hidden}.floating-add-camera-btn{position:absolute;top:16px;right:16px;z-index:20;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#00bcd44d;border:1px solid rgba(0,188,212,.5);border-radius:8px;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;opacity:.6;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.floating-add-camera-btn:hover{opacity:1;background:#00bcd499;box-shadow:0 4px 20px #00bcd466;transform:translateY(-2px)}.floating-add-camera-btn svg{width:20px;height:20px}.no-cameras-message{grid-column:1 / -1;grid-row:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted);background:linear-gradient(135deg,#353550,#252540)}.no-cameras-message svg{width:64px;height:64px;opacity:.5}.no-cameras-message p{font-size:1.1rem;margin:0}.add-first-camera-btn{padding:12px 24px;background:var(--accent-blue);border:none;border-radius:8px;color:var(--bg-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.add-first-camera-btn:hover{background:#00a5bb;transform:scale(1.05)}.camera-grid.fullscreen,.camera-grid.grid-1x1{grid-template-columns:1fr;grid-template-rows:1fr}.camera-grid.grid-2x2{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.camera-grid.grid-3x3{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.camera-grid.grid-4x4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}.camera-grid.grid-5x5{grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr)}.camera-grid.grid-6x6{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr)}@media (max-width: 768px){.camera-grid{grid-template-columns:1fr;grid-template-rows:repeat(4,1fr)}.camera-grid.grid-3x3,.camera-grid.grid-4x4,.camera-grid.grid-5x5,.camera-grid.grid-6x6{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}}.footer{display:flex;align-items:center;justify-content:space-between;padding:4px 12px;background:#1a202cf2;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-top:1px solid rgba(255,255,255,.05);min-height:32px;position:relative;box-shadow:0 -2px 20px #0006}.footer-left{display:flex;align-items:center}.live-indicator{display:flex;align-items:center;gap:4px;padding:2px 8px;background:#ff17441a;border-radius:4px}.live-indicator.playback{background:#3b82f626}.live-indicator.playback .live-text{color:#60a5fa}.live-text{font-size:.7rem;font-weight:700;color:var(--text-primary);letter-spacing:1px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--status-offline)}.live-dot.active{background:var(--status-live);box-shadow:0 0 8px var(--status-live);animation:blink 1s ease-in-out infinite}.footer-center{flex:1}.footer-right{display:flex;align-items:center}.grid-selector-inline{display:flex;align-items:center;gap:3px;padding:2px;background:#ffffff0d;border-radius:6px;border:1px solid var(--border-light)}.grid-option-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease;color:var(--text-secondary);font-size:.6rem;font-weight:500}.grid-option-btn:hover{background:#ffffff1a;color:var(--text-primary)}.grid-option-btn.active{background:linear-gradient(135deg,#8a2be24d,#00bcd44d);border-color:var(--accent-blue);color:var(--accent-blue)}.grid-option-btn:active{transform:scale(.95)}.grid-preview{display:grid;gap:1px;width:16px;height:16px}.grid-preview-1{grid-template-columns:1fr;grid-template-rows:1fr}.grid-preview-2{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.grid-preview-3{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.grid-preview-4{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}.grid-cell{background:var(--text-muted);border-radius:1px}.grid-option-btn.active .grid-cell{background:var(--accent-blue)}.aspect-selector{position:relative;margin-left:8px}.aspect-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff0d;border:1px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .15s ease;color:var(--text-secondary);font-size:.65rem;font-weight:500}.aspect-btn svg{width:14px;height:14px}.aspect-btn:hover{background:#ffffff1a;color:var(--text-primary)}.aspect-btn.active{background:#00bcd426;border-color:var(--accent-blue);color:var(--accent-blue)}.aspect-menu{position:absolute;bottom:calc(100% + 6px);right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 20px #0006;overflow:hidden;z-index:100;animation:slideUp .15s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.aspect-menu-item{display:block;width:100%;padding:6px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:.7rem;font-weight:500;text-align:left;cursor:pointer;transition:all .1s ease}.aspect-menu-item:hover{background:#ffffff14;color:var(--text-primary)}.aspect-menu-item.active{background:#00bcd426;color:var(--accent-blue)}@media (max-width: 768px){.footer{padding:3px 8px}.grid-option-btn{padding:3px 6px}.grid-preview{width:14px;height:14px}.grid-option-btn span{display:none}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .3s ease;border:1px solid var(--border-color)}.modal-small{width:400px;max-width:90vw}.modal-medium{width:500px;max-width:90vw}.modal-large{width:700px;max-width:90vw}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-header)}.modal-title-wrapper{display:flex;align-items:center;gap:var(--spacing-sm)}.modal-title-icon{width:24px;height:24px;color:var(--accent-blue)}.modal-title{font-size:18px;font-weight:700;color:#000;margin:0}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal-close:hover{background:var(--border-light);color:var(--status-offline)}.modal-close svg{width:20px;height:20px}.modal-body{padding:var(--spacing-lg);overflow-y:auto}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #00bcd433}.form-input::placeholder{color:var(--text-muted)}.form-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-checkbox input{width:16px;height:16px;accent-color:var(--accent-blue)}.form-checkbox span{font-size:13px;color:var(--text-secondary)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;display:inline-flex;align-items:center;gap:var(--spacing-xs)}.btn-primary{background:var(--accent-blue);color:var(--bg-primary)}.btn-primary:hover{background:#00a5bb}.btn-secondary{background:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--text-muted)}.btn-danger{background:var(--status-offline);color:#fff}.btn-danger:hover{background:#f33}.btn svg{width:16px;height:16px}.confirm-message{font-size:14px;color:var(--text-secondary);line-height:1.6;text-align:center;padding:var(--spacing-md) 0}.confirm-message strong{color:var(--text-primary)}.confirm-icon{display:flex;justify-content:center;margin-bottom:var(--spacing-md)}.confirm-icon svg{width:48px;height:48px;color:var(--status-offline)}.aspect-ratio-options{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.aspect-ratio-option{display:flex;align-items:center;cursor:pointer}.aspect-ratio-option input[type=radio]{display:none}.aspect-ratio-label{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary);transition:all var(--transition-fast)}.aspect-ratio-option input[type=radio]:checked+.aspect-ratio-label{background:#00bcd426;border-color:var(--accent-blue);color:var(--accent-blue)}.aspect-ratio-option:hover .aspect-ratio-label{border-color:var(--text-muted);color:var(--text-primary)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-blue);cursor:pointer}.checkbox-text{font-size:14px;color:var(--text-primary);font-weight:500}.form-hint{font-size:12px;color:var(--text-muted);margin-top:var(--spacing-xs);line-height:1.4}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#0d1e35,#070d18);padding:20px}.auth-form{background:#0f192df2;padding:40px;border-radius:16px;box-shadow:0 0 40px #00d4ff1f,0 8px 32px #0009;width:100%;max-width:400px;border:1px solid rgba(0,212,255,.3)}.auth-form h1{color:var(--text-primary);text-align:center;margin-bottom:30px;font-size:1.8rem}.auth-error{background:#ef44441a;border:1px solid var(--status-offline);color:var(--status-offline);padding:12px;border-radius:8px;margin-bottom:20px;text-align:center;font-size:.9rem}.form-group{margin-bottom:20px}.form-group label{display:block;color:#00d4ff;margin-bottom:8px;font-size:.85rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.form-group input{width:100%;padding:12px 16px;background:#ffffff0f;border:1px solid rgba(0,212,255,.25);border-radius:8px;color:#e0f0ff;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ffff1a}.form-group input::placeholder{color:var(--text-muted)}.auth-form button[type=submit]{width:100%;padding:14px;background:linear-gradient(135deg,#00bcd4,#00acc1);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #00bcd466}.auth-form button[type=submit]:hover:not(:disabled){background:linear-gradient(135deg,#00acc1,#0097a7);box-shadow:0 6px 20px #00bcd480;transform:translateY(-2px)}.auth-form button[type=submit]:active:not(:disabled){transform:scale(.98)}.auth-form button[type=submit]:disabled{opacity:.7;cursor:not-allowed}.auth-form p{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:.9rem}.auth-form a{color:var(--accent-primary);text-decoration:none;font-weight:500}.auth-form a:hover{text-decoration:underline}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);color:var(--text-primary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.admin-page{padding:24px 40px;width:100%;max-width:100%;height:100vh;overflow-y:auto;box-sizing:border-box}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-header h1{color:var(--text-primary);font-size:1.5rem}.back-link{color:var(--accent-primary);text-decoration:none;display:flex;align-items:center;gap:8px}.back-link:hover{text-decoration:underline}.admin-section{background:var(--bg-secondary);border-radius:12px;padding:20px;margin-bottom:20px;border:1px solid var(--border-color);overflow-x:auto}.admin-section h2{color:var(--text-primary);font-size:1.2rem;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.users-table{width:100%;min-width:700px;border-collapse:collapse}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{color:var(--text-secondary);font-weight:500;font-size:.85rem;text-transform:uppercase}.users-table td{color:var(--text-primary)}.users-table td:last-child{white-space:nowrap;text-align:left;padding-left:24px}.users-table th:last-child{text-align:left;padding-left:24px}.users-table th:nth-child(1),.users-table td:nth-child(1){width:5%}.users-table th:nth-child(2),.users-table td:nth-child(2){width:12%}.users-table th:nth-child(3),.users-table td:nth-child(3){width:20%}.users-table th:nth-child(4),.users-table td:nth-child(4){width:10%;text-align:center;vertical-align:middle}.users-table th:nth-child(5),.users-table td:nth-child(5){width:10%;text-align:center}.users-table th:nth-child(6),.users-table td:nth-child(6){width:13%}.users-table th:nth-child(7),.users-table td:nth-child(7){width:30%}.role-badge{display:inline-block;padding:4px 0;width:80px;text-align:center;border-radius:6px;font-size:.8rem;font-weight:600;letter-spacing:.5px}.role-badge.admin{background:#8b5cf633;color:var(--accent-secondary)}.role-badge.user{background:#00ffff1a;color:var(--accent-primary)}.action-btn{display:inline-block;padding:7px 20px;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;margin-right:8px;transition:all .15s;white-space:nowrap;overflow:visible;min-width:fit-content;line-height:1.5;vertical-align:middle;box-sizing:content-box}.action-btn:hover{opacity:.85}.action-btn.role{background:transparent;border-color:#7c4dff;color:#7c4dff}.action-btn.role:hover{background:#7c4dff;color:#fff}.action-btn.delete{background:transparent;border-color:var(--status-offline);color:var(--status-offline)}.action-btn.delete:hover{background:var(--status-offline);color:#fff}.action-btn.perm{background:transparent;border-color:#00bcd4;color:#00bcd4}.action-btn.perm:hover{background:#00bcd4;color:#fff}.action-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.admin-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border-color)}.admin-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-1px}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:#00bcd4;border-bottom-color:#00bcd4}.project-select-row{display:flex;align-items:center;gap:12px;margin-bottom:24px;color:var(--text-secondary);font-size:.9rem}.project-select{padding:8px 16px;background:linear-gradient(135deg,#0097a7,#00bcd4);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:500;min-width:220px;cursor:pointer;box-shadow:0 2px 6px #00bcd466}.project-select option{background:#1f2937;color:#fff}.project-select:focus{outline:none;box-shadow:0 0 0 3px #00bcd44d}.members-section{margin-bottom:28px}.members-section h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}.members-count{color:var(--text-secondary);font-weight:400;font-size:.85rem}.members-loading,.members-empty{color:var(--text-secondary);font-size:.9rem;padding:16px 0}.perm-modal-body{padding:4px 0}.perm-modal-desc{color:var(--text-secondary);font-size:.9rem;margin-bottom:16px;line-height:1.5}.perm-modal-desc strong{color:var(--text-primary)}.perm-project-list{list-style:none;display:flex;flex-direction:column;gap:8px}.perm-project-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ffffff0a;border:1px solid var(--border-color);border-radius:8px;transition:background .15s}.perm-project-item.granted{background:#00bcd414;border-color:#00bcd44d}.perm-project-name{color:var(--text-primary);font-size:.9rem}.settings-page{height:100vh;overflow-y:auto;background:var(--bg-primary);color:var(--text-primary)}.settings-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(90deg,#1a1a2e,#16213e,#1a1a2e);border-bottom:1px solid var(--border-light)}.back-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#ffffff1a;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.back-btn:hover{background:#ffffff26;border-color:var(--accent-blue)}.back-btn svg{width:20px;height:20px}.settings-title{font-size:24px;font-weight:700;margin:0;letter-spacing:1px}.settings-content{display:flex;height:calc(100vh - 80px)}.settings-sidebar{width:200px;background:var(--bg-secondary);border-right:1px solid var(--border-color);padding:var(--spacing-md)}.settings-nav{display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left}.nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.nav-item.active{background:#00bcd426;color:var(--accent-blue);border-left:3px solid var(--accent-blue)}.nav-icon{font-size:20px}.nav-label{flex:1}.settings-main{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.settings-section-header{margin-bottom:var(--spacing-lg)}.settings-section-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.settings-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.setting-item:hover{border-color:var(--accent-blue);background:#00bcd40d}.setting-icon{font-size:32px;display:flex;align-items:center;justify-content:center;width:50px;height:50px;background:#ffffff0d;border-radius:var(--radius-md)}.setting-content{flex:1}.setting-label{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.setting-description{font-size:13px;color:var(--text-muted)}.setting-action{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.setting-action:hover{background:#00bcd433;color:var(--accent-blue)}.setting-action svg{width:20px;height:20px}@media (max-width: 768px){.settings-content{flex-direction:column}.settings-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color)}.settings-nav{flex-direction:row;overflow-x:auto}.nav-item{flex-direction:column;min-width:80px;text-align:center}}.support-page{height:100vh;overflow-y:auto;background:var(--bg-primary);color:var(--text-primary)}.support-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(90deg,#1a1a2e,#16213e,#1a1a2e);border-bottom:1px solid var(--border-light)}.support-title{font-size:24px;font-weight:700;margin:0;letter-spacing:1px}.support-content{display:flex;min-height:calc(100vh - 80px)}.support-sidebar{width:250px;background:var(--bg-secondary);border-right:1px solid var(--border-color);padding:var(--spacing-md)}.support-nav{display:flex;flex-direction:column;gap:var(--spacing-xs)}.support-main{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-lg) 0}.guide-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.guide-main-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-xl, 28px) var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-top:4px solid var(--card-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.guide-main-card:hover{border-color:var(--card-color);box-shadow:0 6px 20px #0000004d;transform:translateY(-3px)}.guide-main-card-icon{font-size:36px}.guide-main-card-label{font-size:15px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.5px}.guide-main-card-desc{font-size:13px;color:var(--text-muted);margin:0;flex:1}.guide-main-card-count{font-size:12px;font-weight:600;color:var(--card-color);background:#ffffff0f;padding:3px 10px;border-radius:12px;border:1px solid var(--card-color)}.guide-sub-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.guide-back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);width:fit-content}.guide-back-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.guide-sub-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.5px}.guide-empty{padding:var(--spacing-xl, 28px);text-align:center;color:var(--text-muted);font-size:14px;background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-md)}.doc-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.doc-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.doc-item:hover{border-color:var(--accent-blue)}.doc-item-icon{font-size:28px;flex-shrink:0}.doc-item-info{flex:1;display:flex;flex-direction:column;gap:4px}.doc-item-info strong{font-size:14px;color:var(--text-primary)}.doc-item-info span{font-size:12px;color:var(--text-muted)}.doc-item-actions{display:flex;gap:var(--spacing-sm)}.doc-action-btn{padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--accent-blue);border-radius:var(--radius-sm);background:none;color:var(--accent-blue);cursor:pointer;text-decoration:none;transition:all var(--transition-fast)}.doc-action-btn:hover{background:var(--accent-blue);color:#000}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.video-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-fast)}.video-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.video-thumb{position:relative;width:100%;aspect-ratio:16/9;background:#111;overflow:hidden}.video-thumb img{width:100%;height:100%;object-fit:cover}.video-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff3;background:#1a1a2e}.video-duration{position:absolute;bottom:6px;right:8px;font-size:11px;font-weight:600;background:#000c;color:#fff;padding:2px 6px;border-radius:3px}.video-card-info{padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:4px}.video-card-info strong{font-size:13px;color:var(--text-primary)}.video-card-info span{font-size:12px;color:var(--text-muted)}.faq-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.faq-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast)}.faq-item.open{border-color:var(--accent-blue)}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.faq-question:hover{background:#ffffff08}.faq-chevron{font-size:10px;color:var(--text-muted);flex-shrink:0}.faq-answer{padding:0 var(--spacing-lg) var(--spacing-md);border-top:1px solid var(--border-color)}.faq-answer p{margin:var(--spacing-md) 0 0;font-size:14px;color:var(--text-secondary);line-height:1.6}.pdf-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.pdf-viewer-container{width:90%;max-width:900px;height:85vh;background:var(--bg-secondary);border-radius:var(--radius-md);display:flex;flex-direction:column;overflow:hidden}.video-player-container{width:90%;max-width:800px;background:#000;border-radius:var(--radius-md);display:flex;flex-direction:column;overflow:hidden}.pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border-bottom:1px solid var(--border-color);font-size:14px;font-weight:500;color:var(--text-primary)}.pdf-viewer-header button{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px}.pdf-viewer-header button:hover{color:var(--text-primary);background:#ffffff1a}.pdf-iframe{flex:1;width:100%;border:none}.video-player{width:100%;max-height:70vh;background:#000}@media (max-width: 768px){.guide-cards-grid{grid-template-columns:1fr}}.create-ticket-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-lg)}.create-ticket-btn:hover{background:#00a5bb;transform:translateY(-2px);box-shadow:0 4px 12px #00bcd44d}.create-ticket-btn svg{width:18px;height:18px}.tickets-list{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg)}.tickets-header{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.ticket-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:var(--spacing-sm);transition:all var(--transition-fast)}.ticket-item:hover{border-color:var(--accent-blue)}.ticket-info{flex:1}.ticket-title{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.ticket-date{font-size:12px;color:var(--text-muted)}.ticket-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-pending{background:#ffc10733;color:#ffc107}.status-processing{background:#2196f333;color:#2196f3}.status-resolved{background:#4caf5033;color:#4caf50}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.contact-card{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.contact-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.contact-icon{font-size:36px}.contact-content{flex:1}.contact-type{font-size:12px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}.contact-value{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.contact-description{font-size:13px;color:var(--text-secondary)}.contact-form-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg)}.contact-form-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.contact-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-input,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #00bcd433}.form-textarea{resize:vertical;min-height:120px;font-family:inherit}.submit-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:var(--bg-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);align-self:flex-start}.submit-btn:hover{background:#00a5bb;transform:translateY(-2px)}.submit-btn svg{width:18px;height:18px}@media (max-width: 768px){.support-content{flex-direction:column}.support-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color)}.support-nav{flex-direction:row;overflow-x:auto}.nav-item{min-width:100px}.form-row,.contact-grid{grid-template-columns:1fr}}.profile-page{height:100vh;overflow-y:auto;background:var(--bg-primary);padding:var(--spacing-xl) var(--spacing-md)}.profile-container{max-width:800px;margin:0 auto}.back-button{position:fixed;top:var(--spacing-lg);left:var(--spacing-lg);display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#1e293bf2;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);z-index:100}.back-button:hover{background:#334155;border-color:var(--accent-blue);transform:translate(-4px)}.back-button svg{width:20px;height:20px}.profile-header{text-align:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.profile-avatar{width:120px;height:120px;margin:0 auto var(--spacing-md);background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-cyan) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #00bcd44d}.profile-avatar svg{width:60px;height:60px;color:#fff}.profile-header h1{font-size:2rem;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.role-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin{background:#00bcd426;color:var(--accent-blue);border:1px solid var(--accent-blue)}.role-badge.user{background:#9ca3af26;color:var(--text-secondary);border:1px solid var(--border-color)}.profile-message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-weight:500}.profile-message.success{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.3)}.profile-message.error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.profile-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.section-header h2{font-size:1.5rem;color:var(--text-primary);margin:0}.btn-edit{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#00bcd41a;color:var(--accent-blue);border:1px solid var(--accent-blue);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.btn-edit:hover{background:#00bcd433;transform:translateY(-2px)}.btn-edit svg{width:16px;height:16px}.profile-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.info-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.info-label{font-weight:600;color:var(--text-secondary)}.info-value{color:var(--text-primary);font-weight:500}.security-note{display:block;margin-top:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem;font-style:italic}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:all var(--transition-normal)}.form-group input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #00bcd41a}.form-group input:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}.form-group small{color:var(--text-secondary);font-size:.75rem}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.btn-primary,.btn-secondary{flex:1;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);border:none}.btn-primary{background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-cyan) 100%);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00bcd44d}.btn-secondary{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--text-secondary)}@media (max-width: 768px){.profile-page{padding:var(--spacing-md)}.profile-header{padding:var(--spacing-lg)}.profile-header h1{font-size:1.5rem}.profile-avatar{width:100px;height:100px}.profile-avatar svg{width:50px;height:50px}.profile-section{padding:var(--spacing-lg)}.section-header{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.info-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.form-actions{flex-direction:column}}.app{display:flex;flex-direction:column;height:100%;width:100%;background:transparent}.app-body{flex:1;display:flex;overflow:hidden}.main-content{flex:1;padding:var(--spacing-sm);overflow:hidden;display:flex}.main-content.scrollable{overflow-y:auto}:root{--bg-primary: #0a0e1a;--bg-secondary: rgba(10, 16, 30, .97);--bg-header: #0d1220;--bg-footer: rgba(10, 16, 30, .97);--bg-camera: rgba(0, 0, 0, .6);--bg-camera-frame: rgba(0, 20, 40, .8);--text-primary: #e0f0ff;--text-secondary: #7a9bb5;--text-muted: #3a5570;--status-online: #00e676;--status-offline: #ff5252;--status-recording: #ff1744;--status-live: #ff1744;--accent-primary: #00d4ff;--accent-blue: #00d4ff;--accent-purple: #7c4dff;--accent-secondary: #7c4dff;--border-color: rgba(0, 180, 220, .2);--border-light: rgba(0, 180, 220, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .4);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .3s ease;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-family);background:#0a0e1a;background-attachment:fixed;color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;width:100%;display:flex;flex-direction:column}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.pulse{animation:pulse 2s ease-in-out infinite}.blink{animation:blink 1s ease-in-out infinite}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
