@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--color-bg-primary:#0a0e17;--color-bg-secondary:#111827;--color-bg-tertiary:#1a2235;--color-bg-card:#111827d9;--color-bg-glass:#11182799;--color-accent:#00d4ff;--color-accent-hover:#3df;--color-accent-glow:#00d4ff4d;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-danger-glow:#ef44444d;--color-live:#ef4444;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-border:#94a3b81f;--color-border-active:#00d4ff66;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px var(--color-accent-glow);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-smooth:.4s cubic-bezier(.16, 1, .3, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);width:100vw;height:100vh;line-height:1.5;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.app-layout{grid-template-rows:56px 1fr auto;grid-template-columns:1fr 360px;gap:0;width:100vw;height:100vh;display:grid}.top-bar{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);z-index:100;grid-column:1/-1;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.top-bar__brand{align-items:center;gap:12px;display:flex}.top-bar__logo{background:linear-gradient(135deg, var(--color-accent), #7c3aed);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.top-bar__divider{background:var(--color-border);width:1px;height:24px}.top-bar__status{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.top-bar__controls{align-items:center;gap:8px;display:flex}.status-dot{background:var(--color-success);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot}.status-dot--live{background:var(--color-live);animation:1s ease-in-out infinite pulse-dot-live}.status-dot--offline{background:var(--color-text-muted);animation:none}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #10b98166}50%{opacity:.8;box-shadow:0 0 0 6px #10b98100}}@keyframes pulse-dot-live{0%,to{opacity:1;box-shadow:0 0 #ef444480}50%{opacity:.7;box-shadow:0 0 0 8px #ef444400}}.live-badge{letter-spacing:1px;text-transform:uppercase;color:var(--color-live);background:#ef444426;border:1px solid #ef44444d;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:700;display:flex}.replay-badge{letter-spacing:1px;text-transform:uppercase;color:var(--color-accent);background:#00d4ff26;border:1px solid #00d4ff4d;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:700;display:flex}.video-area{background:#000;flex-direction:column;grid-area:2/1/-1;min-height:0;display:flex;position:relative;overflow:hidden}.video-container{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.video-element,.replay-image{object-fit:cover;width:100%;height:100%}.camera-all{transform-origin:50%;transform:scale(1)}.camera-1{transform-origin:0 0;transform:scale(2)}.camera-2{transform-origin:100% 0;transform:scale(2)}.camera-3{transform-origin:0 100%;transform:scale(2)}.camera-4{transform-origin:100% 100%;transform:scale(2)}.camera-bar{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);gap:6px;padding:10px 16px;display:flex}.camera-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;display:flex}.camera-btn:hover{border-color:var(--color-border-active);color:var(--color-text-primary);background:#00d4ff14}.camera-btn--active{border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 0 12px var(--color-accent-glow);background:#00d4ff1f}.canvas-overlay{z-index:10;cursor:crosshair;width:100%;height:100%;position:absolute;top:0;left:0}.premiere-timeline{-webkit-user-select:none;user-select:none;background:#1a1d24;border-top:1px solid #ffffff0f;padding:0}.premiere-transport{background:#12141a;border-bottom:1px solid #ffffff0a;align-items:center;gap:6px;padding:6px 12px;display:flex}.premiere-transport__group{align-items:center;gap:2px;display:flex}.premiere-btn{color:#8a8f98;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:3px;justify-content:center;align-items:center;width:30px;height:28px;font-size:13px;transition:all .12s;display:flex}.premiere-btn:hover{color:#e0e4ea;background:#ffffff0f}.premiere-btn--exit{color:#ef4444;margin-right:6px}.premiere-btn--exit:hover{background:#ef444426}.premiere-btn--play{color:#c0c4cc;background:#ffffff0a;border:1px solid #ffffff14;border-radius:4px;width:34px;height:34px;margin:0 2px}.premiere-btn--play:hover{color:var(--color-accent);background:#00d4ff1a;border-color:#00d4ff4d}.premiere-btn--playing{color:var(--color-accent);background:#00d4ff1f;border-color:#00d4ff4d}.premiere-timecode{background:#0a0c10;border:1px solid #ffffff0f;border-radius:3px;align-items:center;gap:4px;margin-left:8px;padding:3px 10px;display:flex}.premiere-timecode__current{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.5px;font-size:13px;font-weight:700}.premiere-timecode__sep{color:#3a3f48;font-size:11px}.premiere-timecode__total{font-family:var(--font-mono);color:#5a5f68;letter-spacing:.5px;font-size:12px}.premiere-speed{margin-left:4px;position:relative}.premiere-btn--speed{width:auto;font-family:var(--font-mono);align-items:center;gap:4px;padding:0 8px;font-size:11px;font-weight:700;display:flex}.premiere-speed__menu{z-index:20;background:#1a1d24;border:1px solid #ffffff1a;border-radius:4px;min-width:90px;position:absolute;bottom:calc(100% + 6px);left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 24px #00000080}.premiere-speed__option{color:#8a8f98;width:100%;font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;padding:6px 12px;font-size:12px;font-weight:600;transition:all .1s;display:flex}.premiere-speed__option:last-child{border-bottom:none}.premiere-speed__option:hover{color:#e0e4ea;background:#00d4ff14}.premiere-speed__option--active{color:var(--color-accent);background:#00d4ff0f}.premiere-speed__hint{color:#4a4f58;letter-spacing:1px;font-size:9px}.premiere-fps{font-family:var(--font-mono);color:#4a4f58;margin-left:auto;font-size:11px}.premiere-ruler-wrap{scrollbar-width:thin;scrollbar-color:#00d4ff33 transparent;padding:0 12px 8px;overflow:auto hidden}.premiere-ruler-wrap::-webkit-scrollbar{height:4px}.premiere-ruler-wrap::-webkit-scrollbar-thumb{background:#00d4ff40;border-radius:2px}.premiere-ruler{cursor:pointer;background:#0f1115;border:1px solid #ffffff0a;border-radius:2px;min-width:100%;height:40px;position:relative;overflow:visible}.premiere-zoom{align-items:center;gap:4px;margin-left:4px;display:flex}.premiere-zoom__label{font-family:var(--font-mono);color:var(--color-text-muted);text-align:center;min-width:36px;font-size:10px}.premiere-tick{pointer-events:none;background:#ffffff1a;width:1px;height:8px;position:absolute;top:0}.premiere-tick--major{background:#fff3;height:14px}.premiere-tick__label{font-family:var(--font-mono);color:#4a4f58;white-space:nowrap;font-size:9px;position:absolute;top:16px;left:50%;transform:translate(-50%)}.premiere-tick--second{background:#ffffff26;height:11px}.premiere-tick__label--minor{color:#3a3f48;font-size:8px}.premiere-progress{pointer-events:none;background:#00d4ff0a;border-right:none;height:100%;position:absolute;top:0;left:0}.premiere-playhead{z-index:5;pointer-events:none;height:100%;position:absolute;top:0;transform:translate(-50%)}.premiere-playhead__head{border-left:6px solid #0000;border-right:6px solid #0000;border-top:8px solid var(--color-accent);filter:drop-shadow(0 0 4px #00d4ff66);width:0;height:0;margin:0 auto}.premiere-playhead__line{background:var(--color-accent);width:2px;height:calc(100% - 8px);margin:0 auto;box-shadow:0 0 6px #00d4ff4d}.sidebar-container{background:var(--color-bg-secondary);border-left:1px solid var(--color-border);flex-direction:column;grid-area:2/2/-1;display:flex;overflow:hidden}.sidebar{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.sidebar__title{letter-spacing:.5px;text-transform:uppercase;color:var(--color-text-primary);font-size:14px;font-weight:700}.sidebar__count{color:var(--color-accent);background:#00d4ff1f;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600}.add-marker-form{border-bottom:1px solid var(--color-border);gap:8px;padding:12px 16px;display:flex}.add-marker-input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-mono);transition:border-color var(--transition-fast);-moz-appearance:textfield;outline:none;flex:1;padding:10px 14px;font-size:14px}.add-marker-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.add-marker-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.add-marker-input::placeholder{color:var(--color-text-muted)}.add-marker-input:focus{border-color:var(--color-accent)}.add-marker-btn{background:var(--color-accent);border-radius:var(--radius-sm);color:var(--color-bg-primary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;padding:10px 16px;font-size:13px;font-weight:700}.add-marker-btn:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-glow)}.add-marker-btn:disabled{opacity:.5;cursor:not-allowed}.markers-list{flex:1;padding:8px 0;overflow-y:auto}.marker-item{cursor:pointer;transition:all var(--transition-fast);border-left:3px solid #0000;align-items:center;gap:12px;padding:12px 16px;display:flex}.marker-item:hover{border-left-color:var(--color-accent);background:#00d4ff0a}.marker-item--active{background:#e74c3c1f;border-left-color:#e74c3c;box-shadow:inset 0 0 0 1px #e74c3c26}.marker-item--active .marker-number{color:#e74c3c;background:linear-gradient(135deg,#e74c3c40,#e74c3c26);border-color:#e74c3c66}.marker-item--cooling{opacity:.5}.marker-cooldown{color:#fff6;font-size:11px;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.marker-cooldown-spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.marker-number{border-radius:var(--radius-md);width:40px;height:40px;font-family:var(--font-mono);color:var(--color-accent);background:linear-gradient(135deg,#00d4ff26,#7c3aed26);border:1px solid #00d4ff33;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.marker-info{flex:1;min-width:0}.marker-type{color:var(--color-text-primary);font-size:13px;font-weight:600}.marker-time{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);margin-top:2px}.marker-actions{flex-shrink:0;align-items:center;gap:6px;margin-left:8px;display:flex}.marker-action{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-accent);cursor:pointer;transition:all var(--transition-fast);background:#00d4ff14;border:1px solid #00d4ff26;justify-content:center;align-items:center;font-size:14px;display:flex}.marker-action:hover{border-color:var(--color-accent);background:#00d4ff33}.marker-action--delete{color:var(--color-text-muted);background:#ef44440f;border-color:#ef44441f}.marker-action--delete:hover{color:var(--color-danger);background:#ef444433;border-color:#ef444480}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;display:flex}.empty-state__icon{opacity:.3;font-size:40px}.empty-state__text{color:var(--color-text-muted);font-size:13px;line-height:1.6}.drawing-toolbar{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:20;gap:4px;padding:6px;display:flex;position:absolute;top:12px;left:12px}.drawing-tool-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:16px;display:flex}.drawing-tool-btn:hover{color:var(--color-text-primary);background:#ffffff0f}.drawing-tool-btn--active{color:var(--color-danger);background:#ef444426;border-color:#ef44444d}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s ease-out fadeIn}.slide-up{animation:.4s cubic-bezier(.16,1,.3,1) slideUp}.kbd{background:var(--color-bg-tertiary);border:1px solid var(--color-border);min-width:22px;height:22px;font-family:var(--font-mono);color:var(--color-text-muted);border-radius:4px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;display:inline-flex}.top-bar__srt-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;display:flex}.top-bar__srt-btn:hover{border-color:var(--color-border-active);color:var(--color-accent);background:#00d4ff14}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-lg), 0 0 60px #00000080;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-header__title{color:var(--color-text-primary);align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.modal-header__icon{color:var(--color-accent)}.modal-close-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{border-color:var(--color-border);color:var(--color-text-primary);background:#ffffff0f}.modal-body{padding:20px 24px 24px}.srt-config-grid{border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:0;margin-bottom:20px;display:flex;overflow:hidden}.srt-config-row{background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.srt-config-row:last-child{border-bottom:none}.srt-config-label{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.srt-config-value{color:var(--color-text-primary);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.srt-config-value--mono{font-family:var(--font-mono);color:var(--color-accent);font-size:14px}.srt-config-hint{color:var(--color-text-muted);font-size:11px;font-weight:400}.srt-mode-badge{color:var(--color-success);text-transform:uppercase;letter-spacing:.5px;background:#10b9811f;border:1px solid #10b98140;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700}.srt-url-block{margin-bottom:20px}.srt-url-label{text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);margin-bottom:8px;font-size:11px;font-weight:600}.srt-url-row{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:8px;padding:12px 16px;display:flex}.srt-url-value{font-family:var(--font-mono);color:var(--color-accent);word-break:break-all;flex:1;font-size:13px}.srt-copy-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;display:flex}.srt-copy-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#00d4ff1a}.srt-copy-btn--copied{color:var(--color-success);background:#10b9811f;border-color:#10b9814d}.srt-info-notice{border-radius:var(--radius-md);color:var(--color-text-secondary);background:#00d4ff0a;border:1px solid #00d4ff1f;gap:12px;padding:14px 16px;font-size:12px;line-height:1.6;display:flex}.srt-info-notice strong{color:var(--color-text-primary);font-weight:600}.srt-info-icon{color:var(--color-accent);flex-shrink:0;margin-top:1px}.sidebar__title-row{color:var(--color-text-primary);align-items:center;gap:8px;display:flex}.camera-btn__pos{font-family:var(--font-mono);color:var(--color-text-muted);letter-spacing:.5px;background:#ffffff0f;border-radius:3px;padding:1px 5px;font-size:10px;font-weight:600}.empty-state__icon{color:var(--color-text-muted);opacity:.3}.marker-time{align-items:center;gap:4px;display:flex}.marker-time__sep{color:var(--color-text-muted);opacity:.4}.add-marker-btn{align-items:center;gap:4px;display:flex}.gst-status-bar{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 16px;display:flex}.gst-status-left{align-items:center;gap:8px;display:flex}.gst-status-label{color:var(--color-text-muted);font-size:12px;font-weight:500}.gst-status-value{text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.gst-status-uptime{font-family:var(--font-mono);color:var(--color-text-muted);background:#ffffff0a;border-radius:4px;padding:1px 8px;font-size:11px}.gst-status-right{align-items:center;gap:10px;display:flex}.gst-port-indicator{align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.gst-restart-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:30px;height:30px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.gst-restart-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#00d4ff14}.gst-restart-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes gst-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gst-spin{animation:1s linear infinite gst-spin}.modal-content--sm{max-width:380px}.confirm-title{color:var(--color-text-primary);margin:0 0 8px;font-size:16px;font-weight:700}.confirm-text{color:var(--color-text-secondary);margin:0 0 24px;font-size:13px;line-height:1.5}.confirm-actions{justify-content:center;align-items:center;gap:10px;display:flex}.confirm-btn{border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:1px solid;align-items:center;gap:6px;padding:8px 20px;font-size:13px;font-weight:600;display:flex}.confirm-btn--cancel{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-secondary)}.confirm-btn--cancel:hover{border-color:var(--color-text-muted);color:var(--color-text-primary);background:#ffffff0f}.confirm-btn--danger{color:var(--color-danger);background:#ef444426;border-color:#ef44444d}.confirm-btn--danger:hover{border-color:var(--color-danger);background:#ef444440}.quality-selector{z-index:10;position:absolute;top:12px;right:12px}.quality-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);background:#0009;border:1px solid #ffffff1f;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.quality-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#000c}.quality-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);background:#0f141ef2;animation:.15s ease-out slideUp;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.quality-option{border:none;border-bottom:1px solid var(--color-border);width:100%;color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;display:flex}.quality-option:last-child{border-bottom:none}.quality-option:hover{color:var(--color-text-primary);background:#00d4ff0f}.quality-option--active{color:var(--color-accent);background:#00d4ff1a}.quality-option__label{font-weight:700;font-family:var(--font-mono)}.quality-option__bitrate{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono)}.timeline-btn--play{border-radius:50%;width:40px;height:40px}.timeline-btn--play.timeline-btn--active{border-color:var(--color-accent);color:var(--color-accent);background:#00d4ff26;box-shadow:0 0 12px #00d4ff33}.speed-selector{position:relative}.speed-btn{gap:4px}.speed-label{font-family:var(--font-mono);font-size:11px;font-weight:700}.speed-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:100px;box-shadow:var(--shadow-lg);background:#0f141ef2;animation:.15s ease-out slideUp;position:absolute;bottom:calc(100% + 8px);left:50%;overflow:hidden;transform:translate(-50%)}.speed-option{border:none;border-bottom:1px solid var(--color-border);width:100%;color:var(--color-text-secondary);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:space-between;align-items:center;padding:8px 14px;font-size:13px;font-weight:600;display:flex}.speed-option:last-child{border-bottom:none}.speed-option:hover{color:var(--color-text-primary);background:#00d4ff0f}.speed-option--active{color:var(--color-accent);background:#00d4ff1a}.speed-hint{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:400}.split-half{background:#000;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;overflow:hidden}.split-half--left{border-right:1px solid #fff3;left:0;right:50%}.split-half--right{left:50%;right:0}.split-clip-wrapper{aspect-ratio:16/9;border-radius:2px;width:100%;position:relative;overflow:hidden}.split-clip-wrapper .replay-image,.split-clip-wrapper .video-element{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.split-half-label{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;letter-spacing:.5px;background:#000000a6;border-radius:4px;padding:3px 10px;font-size:12px;font-weight:600;position:absolute;top:8px;left:8px}.camera-btn--compare-active{color:#fff!important;background:#e74c3c26!important;border-color:#e74c3c!important}.camera-btn__vs-badge{color:#fff;letter-spacing:.5px;cursor:pointer;background:#e74c3c99;border-radius:4px;margin-left:auto;padding:3px 8px;font-size:10px;font-weight:700;line-height:1;transition:all .15s}.camera-btn__vs-badge:hover{background:#e74c3ce6;transform:scale(1.05)}.camera-btn__vs-badge--active{background:#e74c3c}.comparison-overlay{z-index:1000;background:var(--color-bg,#0a0a0f);flex-direction:column;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.comparison-header{background:#ffffff08;border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex}.comparison-title{color:var(--color-text,#f0f0f0);white-space:nowrap;margin:0;font-size:13px;font-weight:600}.comparison-cam-selector{flex:1;justify-content:center;gap:6px;display:flex}.comparison-cam-btn{color:#ffffff80;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex;position:relative}.comparison-cam-btn:hover{color:#fffc;border-color:#fff3}.comparison-cam-btn--active{border-color:var(--color-accent,#e74c3c);color:#fff;background:#e74c3c26}.comparison-cam-pos{opacity:.5;font-size:10px}.comparison-cam-ready{color:#2ecc71;font-size:8px;position:absolute;top:3px;right:4px}.comparison-close{color:#fff9;cursor:pointer;background:#ffffff0f;border:none;border-radius:6px;padding:6px;transition:all .15s}.comparison-close:hover{color:#fff;background:#e74c3c4d}.comparison-grid{flex:1;gap:2px;min-height:0;padding:2px;display:grid}.comparison-grid--single{grid-template-rows:1fr;grid-template-columns:1fr}.comparison-grid--dual{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.comparison-grid--triple{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.comparison-grid--triple .comparison-cell:nth-child(3){grid-column:1/-1}.comparison-grid--quad{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.comparison-cell{background:#000;border-radius:4px;position:relative;overflow:hidden}.comparison-cell-label{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;letter-spacing:.5px;background:#0009;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;left:8px}.comparison-video{object-fit:contain;width:100%;height:100%}.comparison-controls{background:#ffffff08;border-top:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex}.comparison-transport{align-items:center;gap:4px;display:flex}.comp-ctrl-btn{color:#ffffffb3;cursor:pointer;background:#ffffff0f;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.comp-ctrl-btn:hover{color:#fff;background:#ffffff1f}.comp-ctrl-btn--play{background:var(--color-accent,#e74c3c);color:#fff;border-radius:50%;width:40px;height:40px}.comp-ctrl-btn--play:hover{background:#c0392b;transform:scale(1.05)}.comparison-time{color:#fff9;min-width:90px;font-family:JetBrains Mono,monospace;font-size:12px}.comparison-time-sep{opacity:.4;margin:0 3px}.comparison-progress{cursor:pointer;background:#ffffff1a;border-radius:3px;flex:1;height:6px;transition:height .15s;position:relative}.comparison-progress:hover{height:10px}.comparison-progress-fill{background:var(--color-accent,#e74c3c);border-radius:3px;height:100%;transition:width .1s linear}.comparison-progress-marker{pointer-events:none;background:#f1c40f;border-radius:1px;width:2px;height:calc(100% + 8px);position:absolute;top:-4px}.comparison-speed{position:relative}.comp-speed-btn{color:#ffffffb3;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;display:flex}.comp-speed-btn:hover{border-color:#fff3}.comp-speed-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#14141ef2;border:1px solid #ffffff1a;border-radius:8px;flex-direction:column;gap:2px;min-width:70px;margin-bottom:4px;padding:4px;display:flex;position:absolute;bottom:100%;right:0}.comp-speed-option{color:#ffffffb3;cursor:pointer;text-align:center;background:0 0;border:none;border-radius:4px;padding:6px 10px;font-size:12px}.comp-speed-option:hover{background:#ffffff14}.comp-speed-option--active{color:#fff;background:#e74c3c33;font-weight:600}.login-screen{font-family:var(--font-primary);z-index:9999;background:linear-gradient(135deg,#0a0a12 0%,#121225 40%,#0d1117 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-screen:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 80%,#6366f114 0%,#0000 50%),radial-gradient(circle at 80% 20%,#dc26260f 0%,#0000 50%);position:absolute;inset:0}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;width:380px;padding:40px 32px;animation:.5s ease-out loginFadeIn;position:relative}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.login-card__header{text-align:center;margin-bottom:32px}.login-card__icon{color:#ef4444;background:linear-gradient(135deg,#dc262626,#6366f126);border:1px solid #dc262640;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex}.login-card__title{color:#f1f5f9;letter-spacing:-.02em;margin:0 0 4px;font-size:24px;font-weight:700}.login-card__subtitle{color:#64748b;margin:0;font-size:13px;font-weight:400}.login-card__form{flex-direction:column;gap:16px;display:flex}.login-card__error{color:#fca5a5;background:#dc26261a;border:1px solid #dc262633;border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;animation:.3s ease-out loginFadeIn;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field__label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.login-field__input{color:#f1f5f9;width:100%;font-size:14px;font-family:var(--font-primary);box-sizing:border-box;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;outline:none;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.login-field__input::placeholder{color:#475569}.login-field__input:focus{border-color:#6366f180;box-shadow:0 0 0 3px #6366f11a}.login-field__password-wrap{position:relative}.login-field__password-wrap .login-field__input{padding-right:40px}.login-field__eye{color:#64748b;cursor:pointer;background:0 0;border:none;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.login-field__eye:hover{color:#94a3b8}.login-card__submit{color:#fff;font-size:14px;font-weight:600;font-family:var(--font-primary);cursor:pointer;background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:12px 20px;transition:opacity .2s,transform .1s;display:flex}.login-card__submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-card__submit:active:not(:disabled){transform:translateY(0)}.login-card__submit:disabled{opacity:.5;cursor:not-allowed}.login-card__footer{text-align:center;border-top:1px solid #ffffff0f;margin-top:24px;padding-top:20px}.login-card__footer span{color:#475569;font-size:11px}.spin{animation:1s linear infinite spin}.top-bar__user{color:#94a3b8;align-items:center;gap:6px;padding:0 8px;font-size:12px;font-weight:500;display:flex}.top-bar__logout{color:#64748b;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.top-bar__logout:hover{color:#ef4444;background:#dc26261a;border-color:#dc26264d}.dashboard{min-height:100vh;font-family:var(--font-primary);background:linear-gradient(135deg,#0a0a12 0%,#121225 40%,#0d1117 100%);padding:0 24px 40px}.dashboard__header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px 0;display:flex}.dashboard__brand{align-items:center;gap:14px;display:flex}.dashboard__logo-icon{color:#ef4444;background:linear-gradient(135deg,#dc262626,#6366f126);border:1px solid #dc262640;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.dashboard__title{color:#f1f5f9;letter-spacing:-.02em;margin:0;font-size:20px;font-weight:700}.dashboard__subtitle{color:#64748b;margin:2px 0 0;font-size:12px}.dashboard__header-right{align-items:center;gap:12px;display:flex}.dashboard__user{color:#94a3b8;font-size:13px;font-weight:500}.dashboard__logout{color:#64748b;font-size:12px;font-family:var(--font-primary);cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:6px 14px;transition:all .2s}.dashboard__logout:hover{color:#ef4444;background:#dc26261a;border-color:#dc26264d}.dashboard__stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.stat-card{text-align:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:10px;padding:16px;position:relative}.stat-card--live{background:#ef44440a;border-color:#ef444433}.stat-card__value{color:#f1f5f9;font-size:28px;font-weight:700;line-height:1;display:block}.stat-card__label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-top:6px;font-size:11px;display:block}.stat-card__pulse{background:#ef4444;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse;position:absolute;top:12px;right:12px}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #ef444466}50%{opacity:.8;box-shadow:0 0 0 6px #ef444400}}.dashboard__actions{align-items:center;gap:8px;margin-top:16px;margin-bottom:16px;display:flex}.dashboard__new-btn{color:#fff;font-size:13px;font-weight:600;font-family:var(--font-primary);cursor:pointer;background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;transition:opacity .2s;display:flex}.dashboard__new-btn:hover{opacity:.9}.dashboard__refresh-btn{color:#64748b;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.dashboard__refresh-btn:hover{color:#94a3b8;border-color:#ffffff26}.dashboard__new-form{gap:8px;margin-bottom:16px;animation:.3s ease-out loginFadeIn;display:flex}.dashboard__new-input{color:#f1f5f9;font-size:13px;font-family:var(--font-primary);background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;outline:none;flex:1;padding:10px 14px}.dashboard__new-input:focus{border-color:#6366f180}.dashboard__new-input::placeholder{color:#475569}.dashboard__new-submit{color:#fff;font-size:13px;font-weight:600;font-family:var(--font-primary);cursor:pointer;background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:8px;padding:10px 20px}.dashboard__new-submit:disabled{opacity:.5;cursor:not-allowed}.dashboard__new-cancel{color:#64748b;font-size:13px;font-family:var(--font-primary);cursor:pointer;background:0 0;border:1px solid #ffffff14;border-radius:8px;padding:10px 16px}.dashboard__list{flex-direction:column;gap:8px;display:flex}.dashboard__empty{color:#475569;flex-direction:column;align-items:center;gap:8px;padding:60px 20px;font-size:14px;display:flex}.dashboard__empty-hint{color:#334155;font-size:12px}.session-card{background:#ffffff05;border:1px solid #ffffff0f;border-radius:10px;justify-content:space-between;align-items:center;padding:16px 20px;transition:all .2s;display:flex}.session-card:hover{background:#ffffff0a;border-color:#ffffff1a}.session-card__left{flex-direction:column;gap:6px;display:flex}.session-card__status-badge{text-transform:uppercase;letter-spacing:.03em;border:1px solid;border-radius:20px;align-items:center;gap:6px;width:fit-content;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.session-card__name{color:#f1f5f9;margin:0;font-size:16px;font-weight:600}.session-card__meta{color:#475569;align-items:center;gap:5px;font-size:12px;display:flex}.session-card__actions{align-items:center;gap:6px;display:flex}.session-card__btn{font-size:12px;font-weight:500;font-family:var(--font-primary);cursor:pointer;color:#94a3b8;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;transition:all .2s;display:flex}.session-card__btn--live{color:#ef4444;background:#ef44441a;border-color:#ef444440}.session-card__btn--live:hover{background:#ef444433}.session-card__btn--enter{color:#818cf8;background:#6366f11a;border-color:#6366f140}.session-card__btn--enter:hover{background:#6366f133}.session-card__btn--stop{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b40;padding:7px 10px}.session-card__btn--stop:hover{background:#f59e0b33}.session-card__btn--delete{color:#475569;background:0 0;border-color:#0000;padding:7px 8px}.session-card__btn--delete:hover{color:#ef4444;background:#ef44441a}.top-bar__back{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.top-bar__back:hover{color:#f1f5f9;background:#ffffff14}.top-bar__session-name{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:13px;font-weight:600;overflow:hidden}.server-status{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin:0;padding:14px 18px}.server-status--loading,.server-status--offline{color:var(--color-text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.server-status__title{text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:12px;font-size:11px;font-weight:700;display:flex}.server-status__grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.server-metric{flex-direction:column;gap:6px;display:flex}.server-metric__header{align-items:center;gap:6px;font-size:12px;display:flex}.server-metric__label{color:var(--color-text-secondary);font-weight:500}.server-metric__value{font-family:var(--font-mono);margin-left:auto;font-size:12px;font-weight:700}.server-metric__bar-bg{background:#ffffff0f;border-radius:2px;height:4px;overflow:hidden}.server-metric__bar-fill{border-radius:2px;height:100%;transition:width .6s,background .3s}.server-metric__detail{color:var(--color-text-muted);font-size:10px;font-family:var(--font-mono)}.session-card__srt{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);align-items:center;gap:6px;margin-top:6px;display:flex}.session-card__srt code{color:var(--color-accent);cursor:pointer;background:#00d4ff14;border:1px solid #00d4ff26;border-radius:4px;padding:2px 6px;font-size:10px;transition:all .2s}.session-card__srt code:hover{background:#00d4ff26;border-color:#00d4ff4d}.server-status__latency{font-family:var(--font-mono);margin-left:auto;font-size:11px;font-weight:700}.server-status__badge{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.server-info-grid{border-bottom:1px solid var(--color-border);grid-template-columns:1fr 1fr;gap:4px 16px;margin-bottom:14px;padding-bottom:12px;display:grid}.server-info-row{align-items:center;gap:6px;min-width:0;padding:3px 0;font-size:11px;display:flex}.server-info-row__label{color:var(--color-text-muted);white-space:nowrap}.server-info-row__value{color:var(--color-text-secondary);font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.server-status__metrics-title{text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);margin-bottom:10px;font-size:10px;font-weight:700}.server-compact{border-bottom:1px solid var(--color-border);background:#0003;flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex}.server-compact-metric{align-items:center;gap:4px;font-size:10px;display:flex}.server-compact-metric__label{color:var(--color-text-muted);text-transform:uppercase;font-size:9px;font-weight:600}.server-compact-metric__value{font-family:var(--font-mono);font-size:10px;font-weight:700}.server-compact-metric__bar{background:#ffffff0f;border-radius:2px;width:30px;height:3px;overflow:hidden}.server-compact-metric__bar>div{border-radius:2px;height:100%;transition:width .6s}.srt-indicator{background:var(--color-text-muted);border-radius:50%;flex-shrink:0;width:6px;height:6px}.srt-indicator--active{background:var(--color-success);animation:1.5s ease-in-out infinite srt-pulse-green}.srt-indicator--waiting{background:#f59e0b;animation:1.5s ease-in-out infinite srt-pulse-yellow}@keyframes srt-pulse-green{0%,to{opacity:1;box-shadow:0 0 #10b98180}50%{opacity:.7;box-shadow:0 0 0 4px #10b98100}}@keyframes srt-pulse-yellow{0%,to{opacity:1;box-shadow:0 0 #f59e0b80}50%{opacity:.7;box-shadow:0 0 0 4px #f59e0b00}}.top-bar__srt-btn--live{color:var(--color-success)!important;border-color:#10b9814d!important}.top-bar__srt-btn--waiting{color:#f59e0b!important;border-color:#f59e0b4d!important}
