:root{--bg-primary: #0a0e27;--bg-secondary: #151b3d;--bg-tertiary: #1a2247;--accent-cyan: #00fff2;--accent-magenta: #ff00e5;--accent-yellow: #ffed00;--text-primary: #ffffff;--text-secondary: #8892b3;--glass-bg: rgba(21, 27, 61, .6);--glass-border: rgba(0, 255, 242, .2);--shadow-glow: 0 0 20px rgba(0, 255, 242, .3);--shadow-glow-strong: 0 0 30px rgba(0, 255, 242, .6);--clapperboard-camera-row-height: 420px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Courier Prime,monospace;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;min-height:100vh;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(0,255,242,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,242,.1) 1px,transparent 1px);background-size:50px 50px;animation:gridMove 20s linear infinite;pointer-events:none;z-index:0}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.app{position:relative;z-index:1;max-width:1600px;margin:0 auto;padding:2rem}.app-header{text-align:center;margin-bottom:3rem;animation:fadeInDown .8s ease-out}.app-title{font-family:Orbitron,sans-serif;font-size:3rem;font-weight:900;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-magenta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 40px rgba(0,255,242,.5);margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:1rem}.title-icon{font-size:3.5rem;filter:drop-shadow(0 0 10px var(--accent-cyan))}.app-subtitle{font-size:1.1rem;color:var(--text-secondary);font-family:Orbitron,sans-serif;letter-spacing:2px;text-transform:uppercase}.section-title{font-family:Orbitron,sans-serif;font-size:1.8rem;color:var(--accent-cyan);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:3px;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--accent-cyan),transparent);box-shadow:0 0 10px var(--accent-cyan)}.subsection-title{font-family:Orbitron,sans-serif;font-size:1.3rem;color:var(--accent-magenta);margin-bottom:1rem;text-transform:uppercase;letter-spacing:2px}.production-setup{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:15px;padding:2rem;margin-bottom:3rem;box-shadow:var(--shadow-glow);animation:fadeIn 1s ease-out}.setup-section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding-bottom:1rem;margin-bottom:1.5rem;border-bottom:1px solid var(--glass-border);-webkit-user-select:none;user-select:none}.setup-section-header:hover .section-title{color:var(--accent-cyan);text-shadow:0 0 20px rgba(0,255,242,.6)}.setup-section-header .section-title{margin-bottom:0}.setup-section-header .section-title:after{display:none}.setup-collapsible{overflow:hidden;transition:max-height .5s ease,opacity .3s ease}.setup-collapsible.expanded{max-height:3000px;opacity:1}.setup-collapsible.collapsed{max-height:0;opacity:0}.session-form{margin-bottom:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-family:Orbitron,sans-serif;font-size:.9rem;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:1px}.form-input{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:8px;padding:.8rem 1rem;color:var(--text-primary);font-family:Courier Prime,monospace;font-size:.95rem;transition:all .3s ease}.form-input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 15px #00fff266}.form-input::placeholder{color:var(--text-secondary);opacity:.6}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-magenta));border:none;border-radius:8px;padding:1rem 2rem;color:var(--bg-primary);font-family:Orbitron,sans-serif;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00fff24d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-glow-strong)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.collapse-toggle{background:transparent;border:2px solid var(--glass-border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:var(--accent-cyan)}.collapse-toggle:hover{border-color:var(--accent-cyan);box-shadow:0 0 15px #00fff266;transform:scale(1.1)}.toggle-icon{font-size:1rem;transition:transform .3s ease;display:inline-block}.toggle-icon.expanded{transform:rotate(0)}.toggle-icon.collapsed{transform:rotate(-90deg)}.qr-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--glass-border)}.qr-instructions{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.qr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.qr-display{background:var(--bg-secondary);border:2px solid var(--glass-border);border-radius:12px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.qr-display:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,242,.1),transparent);transition:left .5s ease}.qr-display:hover{border-color:var(--accent-cyan);box-shadow:var(--shadow-glow);transform:translateY(-5px)}.qr-display:hover:before{left:100%}.qr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.qr-camera-name{font-family:Orbitron,sans-serif;font-size:1.2rem;color:var(--accent-cyan)}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-family:Orbitron,sans-serif;text-transform:uppercase}.status-badge.waiting{background:#8892b333;color:var(--text-secondary)}.status-badge.connected{background:#00fff233;color:var(--accent-cyan)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.qr-container{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;min-height:250px}.qr-image{width:100%;height:auto;display:block;border-radius:4px}.qr-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--bg-secondary)}.loading-spinner{width:40px;height:40px;border:4px solid rgba(0,255,242,.2);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin 1s linear infinite}.qr-footer{text-align:center}.qr-hint{font-size:.85rem;color:var(--text-secondary);font-style:italic}.clapperboard-section{margin-bottom:3rem;animation:fadeIn 1s ease-out}.clapperboard-section-title{font-family:Orbitron,sans-serif;font-size:1.8rem;font-weight:400;color:var(--accent-cyan);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:2px}.clapperboard{width:100%}.clapperboard-surround{display:flex;flex-direction:column;min-height:calc(var(--clapperboard-camera-row-height) * 2);background:var(--bg-tertiary);border:8px solid #2a2a2a;border-radius:4px;box-shadow:inset 0 0 0 2px #0006,0 4px 12px #00000080,0 0 24px #00fff226;overflow:hidden}.clapperboard-clapper{height:96px;background:#1a1a1a;border-bottom:3px solid #2a2a2a;display:flex;align-items:stretch;overflow:hidden}.clapperboard-clapper-stripes{width:100%;background:repeating-linear-gradient(-45deg,#0a0a0a,#0a0a0a 12px,#e8e8e8 12px,#e8e8e8 24px);opacity:.95}.clapperboard-panel{flex:1;display:flex;align-items:stretch;padding:2rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--glass-border)}.clapperboard-fields{width:100%;max-width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-between}.clapperboard-row-single{width:100%}.clapperboard-row-triple{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;width:100%}.clapperboard-field{display:flex;flex-direction:column;gap:.7rem}.clapperboard-field-label{font-family:Orbitron,sans-serif;font-size:2.8rem;font-weight:400;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:2px}.clapperboard-field-value{font-family:Orbitron,sans-serif;font-size:2.8rem;font-weight:400;color:var(--text-primary);min-height:3em;border-bottom:2px solid var(--glass-border);padding-bottom:.5rem}.clapperboard-field-value-empty{color:var(--text-secondary);opacity:.7}.clapperboard-sticks{display:flex;justify-content:center;gap:1rem;padding:.75rem 1rem;background:#1a1a1a;border-top:3px solid #2a2a2a}.clapperboard-stick{width:10px;height:36px;background:linear-gradient(180deg,#3a3a3a,#2a2a2a);border-radius:2px;box-shadow:inset 0 1px #ffffff1a}.clapperboard-stick-bottom{height:32px;opacity:.9}.clapperboard-hosted{font-family:Orbitron,sans-serif;font-size:1.8rem;color:var(--accent-cyan);letter-spacing:3px;text-transform:uppercase;text-align:center;margin:0;padding:1rem;background:#1a1a1a;border-top:1px solid #2a2a2a}.camera-section{margin-top:3rem;animation:fadeIn 1.2s ease-out}.camera-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;min-height:var(--clapperboard-camera-row-height)}.camera-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid var(--glass-border);border-radius:15px;padding:1.5rem;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.camera-panel.offline{border-color:#8892b34d}.camera-panel.connected{border-color:var(--accent-cyan);box-shadow:0 0 20px #00fff233}.camera-panel.recording{border-color:var(--accent-magenta);box-shadow:0 0 20px #ff00e54d;animation:recordingPulse 2s ease-in-out infinite}@keyframes recordingPulse{0%,to{box-shadow:0 0 20px #ff00e54d}50%{box-shadow:0 0 30px #ff00e599}}.camera-header{display:flex;justify-content:space-between;align-items:center}.camera-info{display:flex;align-items:center;gap:1rem}.camera-title{font-family:Orbitron,sans-serif;font-size:1.4rem;color:var(--text-primary)}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-family:Orbitron,sans-serif;text-transform:uppercase}.status-indicator.offline{color:var(--text-secondary)}.status-indicator.offline .status-dot{background:var(--text-secondary)}.status-indicator.connected{color:var(--accent-cyan)}.status-indicator.connected .status-dot{background:var(--accent-cyan)}.status-indicator.recording{color:var(--accent-magenta)}.status-indicator.recording .status-dot{background:var(--accent-magenta);animation:recordingBlink 1s ease-in-out infinite}@keyframes recordingBlink{0%,to{opacity:1}50%{opacity:.2}}.video-container{background:var(--bg-primary);border-radius:10px;overflow:hidden;aspect-ratio:16 / 9;position:relative}.camera-video{width:100%;height:100%;object-fit:cover;display:block}.video-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.placeholder-icon{font-size:4rem;opacity:.3;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.placeholder-text{font-size:.95rem;text-align:center}.camera-metadata{display:flex;flex-direction:column;gap:.5rem;padding:.8rem;background:#0a0e2780;border-radius:8px;border:1px solid rgba(0,255,242,.1)}.metadata-item{display:flex;gap:.5rem;font-size:.85rem}.metadata-label{color:var(--accent-cyan);font-weight:700;min-width:100px}.metadata-value{color:var(--text-secondary);word-break:break-all}.camera-controls{display:flex;gap:1rem}.btn-control{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.5rem;border:2px solid;border-radius:8px;font-family:Orbitron,sans-serif;font-size:.95rem;font-weight:700;text-transform:uppercase;cursor:pointer;transition:all .3s ease;background:transparent}.btn-record{border-color:var(--accent-cyan);color:var(--accent-cyan)}.btn-record:hover:not(:disabled){background:var(--accent-cyan);color:var(--bg-primary);box-shadow:0 0 20px #00fff280;transform:translateY(-2px)}.btn-stop{border-color:var(--accent-magenta);color:var(--accent-magenta);background:#ff00e51a}.btn-stop:hover:not(:disabled){background:var(--accent-magenta);color:var(--bg-primary);box-shadow:0 0 20px #ff00e580;transform:translateY(-2px)}.btn-control:disabled{opacity:.3;cursor:not-allowed;border-color:var(--text-secondary);color:var(--text-secondary)}.btn-icon{font-size:1.2rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1200px){.camera-grid,.qr-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 968px){.app{padding:1rem}.app-title{font-size:2rem}.title-icon{font-size:2.5rem}.form-row{grid-template-columns:1fr;gap:1rem}.camera-grid,.qr-grid{grid-template-columns:1fr;gap:1.5rem}.section-title{font-size:1.4rem}.subsection-title{font-size:1.1rem}}@media (max-width: 600px){.app-title{font-size:1.5rem;flex-direction:column;gap:.5rem}.app-subtitle{font-size:.85rem}.camera-title{font-size:1.2rem}.btn-control{padding:.6rem 1rem;font-size:.85rem}}.header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.header-title-section{flex:1;min-width:250px}.app-navigation{display:flex;gap:1rem;align-items:center}.nav-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;color:var(--text-secondary);font-family:Orbitron,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.nav-btn.active{background:#00fff21a;border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:var(--shadow-glow)}.nav-icon{font-size:1.2rem}.video-gallery{max-width:1400px;margin:0 auto;padding:2rem}.gallery-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--glass-border)}.gallery-title-section{flex:1;min-width:250px}.gallery-subtitle{color:var(--text-secondary);font-size:.95rem;margin-top:.5rem}.gallery-filters{display:flex;gap:.75rem;flex-wrap:wrap}.filter-btn{padding:.6rem 1.2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:6px;color:var(--text-secondary);font-family:Courier Prime,monospace;font-size:.85rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.filter-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.filter-btn.active{background:#00fff226;border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:0 0 15px #00fff24d}.gallery-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-spinner{width:50px;height:50px;border:3px solid var(--glass-border);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:var(--text-secondary)}.empty-icon{font-size:4rem;opacity:.3}.gallery-empty h3{font-family:Orbitron,sans-serif;font-size:1.5rem;color:var(--text-primary)}.recordings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.recording-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;overflow:hidden;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.recording-card:hover{border-color:var(--accent-cyan);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.recording-thumbnail{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg-secondary);overflow:hidden}.recording-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary))}.placeholder-icon{font-size:3rem;opacity:.3}.thumbnail-overlay{position:absolute;top:0;left:0;right:0;padding:.75rem;display:flex;justify-content:space-between;align-items:flex-start;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent)}.camera-badge{padding:.4rem .8rem;background:#00fff233;border:1px solid var(--accent-cyan);border-radius:4px;font-size:.75rem;font-weight:700;color:var(--accent-cyan);text-transform:uppercase}.recording-status{padding:.4rem .8rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase;border:1px solid}.status-raw{background:#8be9fd33;border-color:#8be9fd;color:#8be9fd}.status-processing{background:#ffed0033;border-color:var(--accent-yellow);color:var(--accent-yellow);animation:pulse 2s ease-in-out infinite}.status-processed{background:#50fa7b33;border-color:#50fa7b;color:#50fa7b}.status-failed{background:#f553;border-color:#f55;color:#f55}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.recording-info{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.recording-meta{display:flex;gap:1rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.meta-icon{font-size:1rem}.recording-date{font-size:.9rem;color:var(--text-secondary);font-style:italic}.recording-guids{display:flex;flex-direction:column;gap:.4rem;padding-top:.75rem;border-top:1px solid var(--glass-border)}.guid-item{display:flex;gap:.5rem;font-size:.75rem}.guid-label{color:var(--accent-cyan);font-weight:700}.guid-value{color:var(--text-secondary);font-family:Courier Prime,monospace}.recording-actions{display:flex;gap:.5rem;padding:1rem;padding-top:0}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .8rem;border:1px solid var(--glass-border);border-radius:6px;background:var(--glass-bg);color:var(--text-secondary);font-family:Courier Prime,monospace;font-size:.8rem;cursor:pointer;transition:all .3s ease;text-decoration:none}.action-btn:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);transform:translateY(-2px);box-shadow:0 4px 12px #00fff233}.btn-process{border-color:var(--accent-magenta);color:var(--accent-magenta)}.btn-process:hover{border-color:var(--accent-magenta);color:var(--accent-magenta);box-shadow:0 4px 12px #ff00e54d}.btn-download{border-color:var(--accent-cyan);color:var(--accent-cyan)}.btn-delete{border-color:#f55;color:#f55}.btn-delete:hover{border-color:#f55;color:#f55;box-shadow:0 4px 12px #ff55554d}.btn-icon{font-size:1rem}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start}.app-navigation{width:100%;flex-direction:column}.nav-btn{width:100%;justify-content:center}.gallery-header{flex-direction:column}.recordings-grid{grid-template-columns:1fr}.recording-actions{flex-wrap:wrap}.action-btn{min-width:calc(50% - .25rem)}}.local-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:.5rem 1rem;background:#00fff233;border:2px solid var(--accent-cyan);border-radius:4px;font-size:.9rem;font-weight:700;color:var(--accent-cyan);letter-spacing:.1em}.status-local{background:#00fff233;border-color:var(--accent-cyan);color:var(--accent-cyan)}.action-info{flex:1;display:flex;align-items:center;gap:.5rem;padding:.6rem .8rem;background:#00fff20d;border:1px solid var(--glass-border);border-radius:6px;font-size:.75rem;color:var(--text-secondary);overflow:hidden}.info-icon{font-size:1rem;flex-shrink:0}.info-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Courier Prime,monospace}.recording-actions{display:flex;gap:.5rem;padding:1rem;padding-top:0;align-items:stretch}.recording-actions .action-btn{flex:0 0 auto;min-width:100px}.zoom-control{padding:1rem;background:#00fff20d;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:.5rem}.zoom-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-primary);font-weight:600;font-family:Orbitron,sans-serif}.zoom-icon{font-size:1.2rem}.zoom-slider{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;position:relative}.zoom-slider::-webkit-slider-track{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent-cyan);border-radius:50%;cursor:pointer;box-shadow:0 0 10px var(--accent-cyan);transition:all .2s ease}.zoom-slider::-moz-range-track{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px}.zoom-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent-cyan);border-radius:50%;cursor:pointer;box-shadow:0 0 10px var(--accent-cyan);transition:all .2s ease;border:none}.zoom-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 20px var(--accent-cyan),0 0 40px #00fff280}.zoom-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 20px var(--accent-cyan),0 0 40px #00fff280}.zoom-slider:disabled{opacity:.3;cursor:not-allowed}.zoom-slider:disabled::-webkit-slider-thumb{background:var(--text-secondary);box-shadow:none;cursor:not-allowed}.zoom-slider:disabled::-moz-range-thumb{background:var(--text-secondary);box-shadow:none;cursor:not-allowed}.video-timeline-empty{margin:2rem auto;padding:2rem;max-width:1400px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 8px 32px #0000004d}.timeline-empty-message{text-align:center;padding:2rem}.timeline-empty-icon{font-size:3rem;display:block;margin-bottom:1rem;opacity:.5}.timeline-empty-text{font-size:1.2rem;color:var(--text-primary);margin-bottom:.5rem;font-family:Orbitron,sans-serif}.timeline-empty-hint{font-size:.9rem;color:var(--text-secondary);font-family:Courier Prime,monospace}.video-timeline{margin:2rem auto;padding:1.5rem;max-width:1400px;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 8px 32px #0000004d;position:relative;overflow:hidden}.video-timeline:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-cyan),var(--accent-magenta),transparent);animation:shimmer 3s infinite}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.timeline-title{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-family:Orbitron,sans-serif;color:var(--accent-cyan);margin:0}.timeline-icon{font-size:1.5rem}.timeline-info{font-size:.9rem;color:var(--text-secondary);font-family:Courier Prime,monospace}.timeline-video-player{display:none}.timeline-bar-container{margin-bottom:1.5rem}.timeline-bar{position:relative;display:flex;height:80px;background:#0000004d;border:1px solid var(--glass-border);border-radius:8px;overflow:hidden}.timeline-segment{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:.5rem;background:#00fff21a;border-right:1px solid var(--glass-border);cursor:pointer;transition:all .2s ease}.timeline-segment:hover{background:#00fff233;transform:translateY(-2px)}.timeline-segment.active{background:#ff00e533;border:2px solid var(--accent-magenta);box-shadow:0 0 20px #ff00e54d}.segment-label{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--text-primary);font-family:Courier Prime,monospace}.segment-camera{font-weight:700;color:var(--accent-cyan)}.segment-duration{color:var(--text-secondary)}.segment-remove{position:absolute;top:.25rem;right:.25rem;width:20px;height:20px;background:#f00c;border:1px solid rgba(255,0,0,1);border-radius:50%;color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease}.timeline-segment:hover .segment-remove{opacity:1}.segment-remove:hover{background:red;transform:scale(1.2)}.timeline-playhead{position:absolute;top:0;bottom:0;width:3px;background:var(--accent-yellow);box-shadow:0 0 10px var(--accent-yellow),0 0 20px #ffed0080;pointer-events:none;z-index:10;transition:left .1s linear}.timeline-playhead:before{content:"▼";position:absolute;top:-18px;left:50%;transform:translate(-50%);color:var(--accent-yellow);font-size:12px}.timeline-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--glass-border)}.timeline-controls-left,.timeline-controls-right{display:flex;align-items:center;gap:1rem}.timeline-btn{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.2rem;background:#00fff21a;border:1px solid var(--accent-cyan);border-radius:8px;color:var(--text-primary);font-family:Orbitron,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.timeline-btn:hover{background:#00fff233;border-color:var(--accent-cyan);box-shadow:0 0 20px #00fff24d;transform:translateY(-2px)}.timeline-btn:active{transform:translateY(0)}.timeline-btn-play{background:#00fff226;border-width:2px}.timeline-btn-play.playing{background:#ff00e526;border-color:var(--accent-magenta)}.timeline-btn-play.playing:hover{background:#ff00e540;box-shadow:0 0 20px #ff00e54d}.timeline-btn-save{border-color:var(--accent-yellow)}.timeline-btn-save:hover{background:#ffed0026;box-shadow:0 0 20px #ffed004d}.timeline-btn-clear{border-color:#ff000080}.timeline-btn-clear:hover{background:#ff00001a;border-color:red;box-shadow:0 0 20px #ff00004d}.timeline-time-display{font-family:Courier Prime,monospace;font-size:1rem;color:var(--text-primary);padding:.5rem 1rem;background:#0000004d;border:1px solid var(--glass-border);border-radius:6px}.btn-timeline{background:#00fff21a;border-color:var(--accent-cyan)}.btn-timeline:hover{background:#00fff233;box-shadow:0 0 15px #00fff24d}@media (max-width: 768px){.video-timeline{margin:1rem;padding:1rem}.timeline-header{flex-direction:column;align-items:flex-start;gap:.5rem}.timeline-bar{height:60px}.timeline-controls{flex-direction:column;gap:.5rem}.timeline-controls-left,.timeline-controls-right{width:100%;justify-content:space-between}.timeline-btn{flex:1;justify-content:center}.btn-text{display:none}}.thumbnail-video-container{position:relative;width:100%;height:100%;background:#000}.thumbnail-video{width:100%;height:100%;object-fit:cover}.thumbnail-play-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0000004d;cursor:pointer;transition:all .3s ease}.thumbnail-play-overlay:hover{background:#00000080}.play-button{width:60px;height:60px;background:#00fff2e6;border:3px solid var(--accent-cyan);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 0 20px #00fff280}.thumbnail-play-overlay:hover .play-button{transform:scale(1.1);background:var(--accent-cyan);box-shadow:0 0 30px #00fff2cc}.play-icon{font-size:24px;color:var(--bg-primary);margin-left:4px}.load-preview-btn{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);padding:.5rem 1rem;background:#00fff233;border:1px solid var(--accent-cyan);border-radius:6px;color:var(--text-primary);font-family:Orbitron,sans-serif;font-size:.8rem;cursor:pointer;transition:all .2s ease}.load-preview-btn:hover{background:#00fff24d;box-shadow:0 0 15px #00fff24d;transform:translate(-50%) translateY(-2px)}.video-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.video-modal-content{position:relative;width:90%;max-width:1200px;background:var(--bg-secondary);border:2px solid var(--accent-cyan);border-radius:12px;padding:1.5rem;box-shadow:0 0 50px #00fff24d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.video-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;background:#f00c;border:2px solid red;border-radius:50%;color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:all .2s ease;z-index:10}.video-modal-close:hover{background:red;transform:rotate(90deg) scale(1.1);box-shadow:0 0 20px #ff000080}.video-modal-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.video-modal-header h3{margin:0;font-family:Orbitron,sans-serif;color:var(--accent-cyan);font-size:1.5rem}.video-modal-date{margin:.5rem 0 0;color:var(--text-secondary);font-family:Courier Prime,monospace;font-size:.9rem}.video-modal-player{width:100%;max-height:70vh;background:#000;border-radius:8px}.video-modal-info{display:flex;gap:2rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--glass-border);font-family:Courier Prime,monospace;color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.video-modal-content{width:95%;padding:1rem}.video-modal-header h3{font-size:1.2rem}.video-modal-info{flex-direction:column;gap:.5rem}.play-button{width:50px;height:50px}.play-icon{font-size:20px}}.setup-storage-btn{margin-left:1rem;padding:.4rem .8rem;background:#ffed001a;border:1px solid var(--accent-yellow);border-radius:6px;color:var(--accent-yellow);font-family:Orbitron,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.setup-storage-btn:hover{background:#ffed0033;box-shadow:0 0 15px #ffed004d;transform:translateY(-2px)}.btn-timeline:disabled{opacity:.5;cursor:not-allowed;background:#6464641a;border-color:#6464644d}.btn-timeline:disabled:hover{background:#6464641a;box-shadow:none;transform:none}.timeline-range-wrapper{position:relative;width:100%}.timeline-range-overlay{position:relative;width:100%;height:28px;margin-bottom:8px}.timeline-range-track{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:6px;background:#0006;border:1px solid var(--glass-border);border-radius:4px;pointer-events:none}.timeline-selection-range{position:absolute;left:0;top:50%;transform:translateY(-50%);height:10px;margin-top:-2px;background:linear-gradient(to right,#00c8dc80,#00fff240 30%,#ff00c840 70%,#dc00b480);border-radius:5px;border:1px solid rgba(0,255,242,.4);box-shadow:0 0 12px #00fff233;pointer-events:none;z-index:2}.range-handle{position:absolute;top:0;width:24px;height:24px;margin-left:-12px;border-radius:50%;cursor:grab;z-index:25;-webkit-user-select:none;user-select:none;transition:transform .15s ease,box-shadow .15s ease;border:2px solid rgba(255,255,255,.9)}.range-handle:active{cursor:grabbing;transform:scale(1.1)}.range-handle:hover{transform:scale(1.15);box-shadow:0 0 20px currentColor}.range-handle-start{background:linear-gradient(135deg,#00d4cc,#00fff2,#00b8b0);box-shadow:0 0 12px #00fff299,inset 0 1px #ffffff4d}.range-handle-start:hover{box-shadow:0 0 18px #00fff2cc,inset 0 1px #fff6}.range-handle-stop{background:linear-gradient(135deg,#c0a,#ff00e5,#b00090);box-shadow:0 0 12px #ff00e599,inset 0 1px #ffffff4d}.range-handle-stop:hover{box-shadow:0 0 18px #ff00e5cc,inset 0 1px #fff6}.timeline-range-info{font-family:Courier Prime,monospace;font-size:.9rem;color:var(--text-secondary);padding:.5rem 1rem;background:#0000004d;border:1px solid var(--glass-border);border-radius:6px}.timeline-btn-play-range{background:#00fff226;border-color:var(--accent-cyan);border-width:2px;font-size:1rem;padding:.8rem 1.5rem}.timeline-btn-play-range:hover{background:#00fff24d;box-shadow:0 0 30px #00fff280}.timeline-btn-play-range:disabled{opacity:.3;cursor:not-allowed}.timeline-btn-play-range:disabled:hover{background:#00fff226;box-shadow:none;transform:none}.timeline-segment{background:linear-gradient(135deg,#00fff21a,#00fff20d)}.timeline-segment:hover{background:linear-gradient(135deg,#00fff233,#00fff21a)}.video-modal-progress{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--glass-border);font-family:Courier Prime,monospace;color:var(--text-secondary);font-size:.9rem;text-align:center}
