@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdBookCn.OTF) format("opentype");font-weight:400;font-style:normal}@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdBookCnIt.OTF) format("opentype");font-weight:400;font-style:italic}@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdMediumCn.OTF) format("opentype");font-weight:500;font-style:normal}@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdMediumCnIt.OTF) format("opentype");font-weight:500;font-style:italic}@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdBoldCn.OTF) format("opentype");font-weight:700;font-style:normal}@font-face{font-family:Benguiat;src:url(/fonts/ITCBenguiatStdBoldCnIt.OTF) format("opentype");font-weight:700;font-style:italic}.tl2-page{display:grid;grid-template-rows:52px 1fr minmax(200px,300px);height:100vh;overflow:hidden;touch-action:pan-x pan-y}.tl2-topbar{height:52px;padding:0 20px;display:flex;align-items:center;gap:12px;background:#0d0d16;border-bottom:1px solid rgba(255,255,255,.06)}.tl2-body{display:flex;overflow:hidden;min-height:0}.tl2-body>*{min-width:0}.tl2-left-panel{flex:0 0 250px;background:#0c0c14;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;overflow:hidden}.tl2-center{flex:1 1 0;display:flex;flex-direction:column;overflow:hidden;background:#08080e;min-height:0;min-width:0;position:relative}.tl2-crop-format-bar{display:flex;align-items:center;gap:2px;padding:3px 12px;background:#0a0a12;border-bottom:1px solid rgba(255,255,255,.04);flex-shrink:0}.tl2-crop-format-btn{background:none;border:1px solid transparent;color:#666;font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .15s;letter-spacing:.04em}.tl2-crop-format-btn:hover{color:#aaa;border-color:#ffffff1a}.tl2-crop-format-btn.active{color:#00b4d8;border-color:#00b4d8;background:#00b4d81a}.tl2-center .tl2-preview-container{flex:1;background:#000;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:0;min-width:0;max-height:42vh;border-radius:0}.tl2-crop-frame{position:relative;overflow:hidden;max-width:100%;min-width:0}.tl2-crop-frame.active{border:1px solid rgba(0,180,216,.4)}.tl2-center .tl2-preview-video{max-width:100%;max-height:100%;object-fit:contain;display:block;margin:0 auto}.tl2-center .tl2-preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#333;font-size:.85rem;font-weight:600;letter-spacing:.06em;background:#000}.tl2-center .tl2-preview-info{position:absolute;bottom:8px;left:12px;font-size:.65rem;color:#ffffff73;background:#000000a6;padding:3px 8px;border-radius:4px;pointer-events:none}.tl2-center .tl2-coach-panel{border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;max-height:260px}.tl2-right-panel{background:#0c0c14;border-left:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;overflow:hidden;position:relative;flex-shrink:0}.tl2-inspector-resize-handle{position:absolute;left:-4px;top:0;bottom:0;width:8px;cursor:col-resize;z-index:20;background:transparent;transition:background .15s}.tl2-inspector-resize-handle:hover,.tl2-inspector-resize-handle:active{background:#7c3aed80}.tl2-inspector-header{height:40px;display:flex;align-items:center;padding:0 16px;font-size:.72rem;font-weight:800;letter-spacing:.14em;color:#555;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.tl2-inspector-scroll{flex:1;overflow-y:auto;min-height:0;padding:4px 0}.tl2-inspector-empty{flex:1;display:flex;align-items:center;justify-content:center;color:#333;font-size:.82rem;font-weight:500;text-align:center;padding:40px 30px;line-height:1.6}.tl2-insp-section{padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.04)}.tl2-insp-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;color:#555;text-transform:uppercase;margin-bottom:4px}.tl2-insp-value{font-size:.82rem;color:#ccc;font-weight:500}.tl2-insp-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tl2-insp-source{font-size:.72rem;color:#666;font-family:SF Mono,Fira Code,monospace;word-break:break-all}.tl2-insp-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;color:#fff}.tl2-insp-volume-row{display:flex;align-items:center;gap:10px}.tl2-insp-volume-row input[type=range]{flex:1;accent-color:#7c3aed}.tl2-insp-volume-val{font-size:.78rem;font-weight:700;color:#a78bfa;min-width:40px;text-align:right}.tl2-bottom{display:flex;flex-direction:column;background:#09090f;border-top:1px solid rgba(255,255,255,.06);overflow:hidden;min-height:0}.tl2-bottom .tl2-canvas{flex:1;display:flex;overflow:auto;position:relative;background:#0a0a12;min-height:0}.tl2-bottom .tl2-tracks-wrap{position:relative;min-height:100%;flex-shrink:0}.tl2-bottom-header{height:32px;display:flex;align-items:center;padding:0 16px;background:#0c0c16;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;gap:12px}.tl2-bottom-header-title{font-size:.68rem;font-weight:800;letter-spacing:.12em;color:#555;text-transform:uppercase}.tl2-bottom-header-info{font-size:.68rem;color:#444;font-family:SF Mono,Fira Code,monospace}.tl2-bottom .tl2-transport,.tl2-bottom .tl2-gap-bar{flex-shrink:0}.tl2-bottom .tl2-ai-assist-bar{flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}.tl2-kf-diamond-btn{position:absolute;bottom:8px;right:50px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#0009;border:1px solid rgba(167,139,250,.3);border-radius:6px;cursor:pointer;padding:0;z-index:6;transition:background .15s,border-color .15s}.tl2-kf-diamond-btn:hover{background:#7c3aed40;border-color:#a78bfa}.tl2-kf-diamond-btn.active{background:#7c3aed59;border-color:#7c3aed}.tl2-kf-marker{position:absolute;top:0;width:20px;height:20px;background:transparent;border:none;transform:translate(-10px);z-index:6;pointer-events:auto;cursor:ew-resize}.tl2-kf-marker:after{content:"";position:absolute;top:2px;left:4px;width:12px;height:12px;background:#7c3aed;border:1.5px solid #a78bfa;border-radius:1px;transform:rotate(45deg);transition:background .12s,box-shadow .12s,transform .12s}.tl2-kf-marker:hover:after{background:#a855f7;box-shadow:0 0 8px #a855f7b3;transform:rotate(45deg) scale(1.2)}.tl2-kf-marker.dragging:after{background:#c084fc;box-shadow:0 0 12px #c084fce6;transform:rotate(45deg) scale(1.3)}@media (max-width: 1200px){.tl2-left-panel{flex:0 0 220px}}@media (max-width: 960px){.tl2-left-panel{flex:0 0 200px}.tl2-right-panel{display:none}}.tl2-beat{pointer-events:auto;cursor:pointer;padding:0 5px;margin-left:-5px;background-clip:content-box}.tl2-text-inspector-right{display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.tl2-text-inspector-right .tl2-tinsp-body{padding:8px;overflow-x:hidden}.tl2-text-inspector-right .tl2-tinsp-presets-row{flex-wrap:wrap}.tl2-txt-handle-l,.tl2-txt-handle-r{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize;z-index:3;transition:background .1s}.tl2-txt-handle-l{left:0;border-radius:4px 0 0 4px}.tl2-txt-handle-r{right:0;border-radius:0 4px 4px 0}.tl2-txt-handle-l:hover,.tl2-txt-handle-r:hover{background:#a855f799}.tl2-text-inspector-float{position:absolute;bottom:48px;left:50%;transform:translate(-50%);width:380px;max-height:420px;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:12px;z-index:50;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0009}.tl2-tinsp-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.tl2-tinsp-text-input{flex:1;background:#252530;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:6px 10px;color:#e0e0e0;font-size:13px;font-weight:600;outline:none}.tl2-tinsp-text-input:focus{border-color:#00b4d8}.tl2-tinsp-close{background:none;border:none;color:#888;font-size:14px;cursor:pointer;padding:4px;border-radius:4px}.tl2-tinsp-close:hover{color:#fff;background:#ffffff1a}.tl2-tinsp-tabs{display:flex;gap:0;padding:0 12px;border-bottom:1px solid rgba(255,255,255,.08)}.tl2-tinsp-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:#777;font-size:12px;font-weight:500;padding:8px 0;cursor:pointer;transition:all .15s}.tl2-tinsp-tab:hover{color:#bbb}.tl2-tinsp-tab.active{color:#00b4d8;border-bottom-color:#00b4d8;font-weight:600}.tl2-tinsp-body{padding:8px 12px;overflow-y:auto;flex:1;min-height:0}.tl2-tinsp-presets-row{display:flex;gap:6px;padding:6px 0 10px;overflow-x:auto;scrollbar-width:none}.tl2-tinsp-presets-row::-webkit-scrollbar{display:none}.tl2-tinsp-preset{min-width:36px;height:36px;border-radius:50%;border:2px solid #333;background:#222;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s;flex-shrink:0}.tl2-tinsp-preset:hover{border-color:#555}.tl2-tinsp-preset.active{border-color:#00b4d8;box-shadow:0 0 0 2px #00b4d84d}.tl2-tinsp-preset-reset{font-size:18px;color:#666;line-height:1}.tl2-tinsp-subnav{display:flex;gap:4px;padding:4px 0 8px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:8px}.tl2-tinsp-subnav::-webkit-scrollbar{display:none}.tl2-tinsp-subnav-item{background:none;border:none;color:#666;font-size:11px;padding:4px 8px;cursor:pointer;white-space:nowrap;border-radius:4px;transition:all .15s}.tl2-tinsp-subnav-item:hover{color:#aaa;background:#ffffff0d}.tl2-tinsp-subnav-item.active{color:#fff;font-weight:600}.tl2-tinsp-spacing{display:flex;flex-direction:column;gap:10px}.tl2-tinsp-row{display:flex;gap:12px}.tl2-tinsp-align-group{display:flex;gap:2px;background:#252530;border-radius:8px;padding:2px}.tl2-tinsp-align-btn{width:34px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:2px solid transparent;border-radius:6px;color:#777;cursor:pointer;transition:all .15s}.tl2-tinsp-align-btn:hover{color:#ccc;background:#ffffff0d}.tl2-tinsp-align-btn.active{color:#fff;border-color:#fff9;background:#ffffff14}.tl2-tinsp-slider-row{display:flex;align-items:center;gap:8px}.tl2-tinsp-slider-label{font-size:11px;color:#888;min-width:60px;text-align:right}.tl2-tinsp-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#333;border-radius:2px;outline:none;cursor:pointer}.tl2-tinsp-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid #555;cursor:pointer;box-shadow:0 1px 4px #0006}.tl2-tinsp-slider.accent::-webkit-slider-thumb{background:#00b4d8;border-color:#00b4d8}.tl2-tinsp-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid #555;cursor:pointer}.tl2-tinsp-slider.accent::-moz-range-thumb{background:#00b4d8;border-color:#00b4d8}.tl2-tinsp-slider-val{font-size:11px;color:#aaa;min-width:40px;text-align:left;font-variant-numeric:tabular-nums}.tl2-tinsp-slider-wrap{flex:1;position:relative}.tl2-tinsp-value-badge{position:absolute;top:-16px;left:50%;transform:translate(-50%);background:#00b4d8;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;pointer-events:none}.tl2-tinsp-color-input{width:32px;height:24px;border:none;cursor:pointer;background:transparent;border-radius:4px}.tl2-tinsp-delete-btn{width:100%;background:#dc262626;border:1px solid rgba(220,38,38,.3);color:#f87171;font-size:11px;padding:6px;border-radius:6px;cursor:pointer;transition:all .15s;margin-top:4px}.tl2-tinsp-delete-btn:hover{background:#dc262640}.tl2-tinsp-placeholder{padding:20px;text-align:center;color:#555;font-size:12px}.tl2-tinsp-anim-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;height:56px;gap:2px;padding:2px;background:#252530;border:2px solid transparent;border-radius:6px;color:#ccc;cursor:pointer;transition:all .15s;overflow:hidden}.tl2-tinsp-anim-cell:hover{border-color:#444;background:#2a2a3a}.tl2-tinsp-anim-cell.active{border-color:#00b4d8;background:#00b4d81a}.tl2-text-preview-selected{outline:2px solid rgba(255,255,255,.8);outline-offset:6px}.tl2-text-preview-close{position:absolute;top:-18px;left:-8px;font-size:10px;color:#fff;background:#000000b3;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;line-height:1}.tl2-text-preview-close:hover{background:#dc2626}@keyframes txt-fade-in{0%,80%{opacity:0}90%{opacity:1}to{opacity:0}}@keyframes txt-slide-up{0%,70%{transform:translateY(10px);opacity:0}85%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-slide-down{0%,70%{transform:translateY(-10px);opacity:0}85%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-slide-left{0%,70%{transform:translate(12px);opacity:0}85%{transform:translate(0);opacity:1}to{opacity:0}}@keyframes txt-slide-right{0%,70%{transform:translate(-12px);opacity:0}85%{transform:translate(0);opacity:1}to{opacity:0}}@keyframes txt-scale-up{0%,70%{transform:scale(0);opacity:0}85%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes txt-typewriter{0%,70%{clip-path:inset(0 100% 0 0)}90%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 0 0 0);opacity:0}}@keyframes txt-bounce-in{0%,70%{transform:scale(0)}80%{transform:scale(1.2)}85%{transform:scale(1)}to{opacity:0}}@keyframes txt-blur-in{0%,70%{filter:blur(6px);opacity:0}85%{filter:blur(0);opacity:1}to{opacity:0}}@keyframes txt-drop-in{0%,70%{transform:translateY(-16px);opacity:0}85%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-rise-up{0%,70%{transform:translateY(8px) scale(.8);opacity:0}85%{transform:translateY(0) scale(1);opacity:1}to{opacity:0}}@keyframes txt-pop{0%,70%{transform:scale(.5);opacity:0}82%{transform:scale(1.15)}88%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes txt-pop-fast{0%,80%{transform:scale(.3);opacity:0}90%{transform:scale(1.1)}95%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes txt-zoom-in{0%,70%{transform:scale(0);opacity:0}85%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes txt-wipe-left{0%,70%{clip-path:inset(0 100% 0 0)}85%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 0 0 0);opacity:0}}@keyframes txt-flip-x{0%,70%{transform:scaleX(0);opacity:0}85%{transform:scaleX(1);opacity:1}to{opacity:0}}@keyframes txt-flip-y{0%,70%{transform:scaleY(0);opacity:0}85%{transform:scaleY(1);opacity:1}to{opacity:0}}@keyframes txt-rotate-in{0%,70%{transform:rotate(-180deg);opacity:0}85%{transform:rotate(0);opacity:1}to{opacity:0}}@keyframes txt-spring{0%,65%{transform:scale(0)}75%{transform:scale(1.3)}80%{transform:scale(.9)}85%{transform:scale(1.05)}90%{transform:scale(1)}to{opacity:0}}@keyframes txt-elastic{0%,65%{transform:scale(0)}75%{transform:scale(1.4)}80%{transform:scale(.85)}85%{transform:scale(1.1)}90%{transform:scale(1)}to{opacity:0}}@keyframes txt-slam{0%,70%{transform:scale(3);opacity:0}82%{transform:scale(.9)}88%{transform:scale(1);opacity:1}to{opacity:0}}@keyframes txt-expand{0%,70%{transform:scaleX(0);opacity:0}85%{transform:scaleX(1);opacity:1}to{opacity:0}}@keyframes txt-drop{0%,70%{transform:translateY(-16px);opacity:0}82%{transform:translateY(3px)}88%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-rise{0%,70%{transform:translateY(10px);opacity:0}85%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-bounce{0%,70%{transform:translateY(-16px);opacity:0}80%{transform:translateY(4px)}85%{transform:translateY(-2px)}90%{transform:translateY(0);opacity:1}to{opacity:0}}@keyframes txt-fade-out{0%{opacity:1}70%{opacity:1}90%{opacity:0}to{opacity:0}}@keyframes txt-slide-up-out{0%{opacity:1}70%{transform:translateY(0);opacity:1}90%{transform:translateY(-10px);opacity:0}to{opacity:0}}@keyframes txt-slide-down-out{0%{opacity:1}70%{transform:translateY(0);opacity:1}90%{transform:translateY(10px);opacity:0}to{opacity:0}}@keyframes txt-slide-left-out{0%{opacity:1}70%{transform:translate(0);opacity:1}90%{transform:translate(-12px);opacity:0}to{opacity:0}}@keyframes txt-slide-right-out{0%{opacity:1}70%{transform:translate(0);opacity:1}90%{transform:translate(12px);opacity:0}to{opacity:0}}@keyframes txt-scale-down{0%{opacity:1}70%{transform:scale(1);opacity:1}90%{transform:scale(0);opacity:0}to{opacity:0}}@keyframes txt-blur-out{0%{opacity:1}70%{filter:blur(0);opacity:1}90%{filter:blur(6px);opacity:0}to{opacity:0}}@keyframes txt-zoom-out{0%{opacity:1}70%{transform:scale(1);opacity:1}90%{transform:scale(0);opacity:0}to{opacity:0}}@keyframes txt-shrink{0%{opacity:1}70%{transform:scale(1);opacity:1}90%{transform:scale(.3);opacity:0}to{opacity:0}}@keyframes txt-dissolve{0%{opacity:1}60%{opacity:1}to{opacity:0}}@keyframes txt-rotate-out{0%{opacity:1}70%{transform:rotate(0);opacity:1}90%{transform:rotate(180deg);opacity:0}to{opacity:0}}@keyframes txt-pop-out{0%{opacity:1}70%{transform:scale(1)}85%{transform:scale(1.5);opacity:0}to{opacity:0}}@keyframes txt-drop-out{0%{opacity:1}70%{transform:translateY(0);opacity:1}90%{transform:translateY(16px);opacity:0}to{opacity:0}}@keyframes txt-slam-out{0%{opacity:1}70%{transform:scale(1)}80%{transform:scale(1.1)}90%{transform:scale(0);opacity:0}to{opacity:0}}@keyframes txt-elastic-out{0%{opacity:1}70%{transform:scale(1)}78%{transform:scale(1.2)}84%{transform:scale(.8)}90%{transform:scale(0);opacity:0}to{opacity:0}}@keyframes txt-pulse{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}@keyframes txt-glow{0%{filter:brightness(1)}50%{filter:brightness(1.4)}to{filter:brightness(1)}}@keyframes txt-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes txt-bounce-loop{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes txt-wave{0%,to{transform:rotate(0)}25%{transform:rotate(3deg)}75%{transform:rotate(-3deg)}}@keyframes txt-flicker{0%,to{opacity:1}50%{opacity:.5}}@keyframes txt-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes txt-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes txt-wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes txt-heartbeat{0%,to{transform:scale(1)}15%{transform:scale(1.15)}30%{transform:scale(1)}45%{transform:scale(1.08)}60%{transform:scale(1)}}@keyframes txt-swing{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes txt-rock{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}@keyframes txt-vibrate{0%,to{transform:translate(0)}10%{transform:translate(-1px)}20%{transform:translate(1px)}30%{transform:translate(-1px)}40%{transform:translate(1px)}}@keyframes txt-levitate{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes txt-spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes txt-sway{0%,to{transform:translate(0)}50%{transform:translate(8px)}}@keyframes txt-bob{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes txt-rubber{0%,to{transform:scale(1)}25%{transform:scale(.9,1.1)}50%{transform:scale(1.1,.9)}75%{transform:scale(.95,1.05)}}@keyframes txt-nod{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes txt-jitter{0%,to{transform:translate(0)}25%{transform:translate(-2px,1px)}50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,-1px)}}@keyframes txt-scale-breathe{0%,to{transform:scale(.95)}50%{transform:scale(1.05)}}@keyframes txt-zoom-breathe{0%,to{transform:scale(.9)}50%{transform:scale(1.1)}}@keyframes txt-tilt{0%,to{transform:rotate(0)}50%{transform:rotate(2deg)}}@keyframes txt-shake-subtle{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}@keyframes txt-shake-strong{0%,to{transform:translate(0)}10%{transform:translate(-5px)}30%{transform:translate(5px)}50%{transform:translate(-5px)}70%{transform:translate(5px)}90%{transform:translate(-3px)}}@keyframes txt-glow-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}@keyframes txt-flicker-fast{0%,to{opacity:1}33%{opacity:.3}66%{opacity:.8}}@keyframes txt-bounce-gentle{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes txt-color-cycle{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.tl2-anim-fade-in{animation:txt-fade-in 2s ease infinite}.tl2-anim-pop{animation:txt-pop 2s ease infinite}.tl2-anim-pop-fast{animation:txt-pop-fast 2s ease infinite}.tl2-anim-slide-up{animation:txt-slide-up 2s ease infinite}.tl2-anim-slide-down{animation:txt-slide-down 2s ease infinite}.tl2-anim-slide-left{animation:txt-slide-left 2s ease infinite}.tl2-anim-slide-right{animation:txt-slide-right 2s ease infinite}.tl2-anim-slide-up-fast{animation:txt-slide-up 1.5s ease infinite}.tl2-anim-slide-down-fast{animation:txt-slide-down 1.5s ease infinite}.tl2-anim-slide-left-fast{animation:txt-slide-left 1.5s ease infinite}.tl2-anim-slide-right-fast{animation:txt-slide-right 1.5s ease infinite}.tl2-anim-bounce{animation:txt-bounce 2s ease infinite}.tl2-anim-bounce-in{animation:txt-bounce-in 2s ease infinite}.tl2-anim-zoom-in{animation:txt-zoom-in 2s ease infinite}.tl2-anim-zoom-in-slow{animation:txt-zoom-in 3s ease infinite}.tl2-anim-blur-in{animation:txt-blur-in 2s ease infinite}.tl2-anim-blur-in-fast{animation:txt-blur-in 1.5s ease infinite}.tl2-anim-wipe-left{animation:txt-wipe-left 2s ease infinite}.tl2-anim-wipe-right{animation:txt-wipe-left 2s ease-in-out infinite reverse}.tl2-anim-wipe-up{animation:txt-slide-up 2s ease infinite}.tl2-anim-wipe-down{animation:txt-slide-down 2s ease infinite}.tl2-anim-drop{animation:txt-drop 2s ease infinite}.tl2-anim-drop-in{animation:txt-drop-in 2s ease infinite}.tl2-anim-rise{animation:txt-rise 2s ease infinite}.tl2-anim-rise-up{animation:txt-rise-up 2s ease infinite}.tl2-anim-flip-x{animation:txt-flip-x 2s ease infinite}.tl2-anim-flip-y{animation:txt-flip-y 2s ease infinite}.tl2-anim-rotate-in{animation:txt-rotate-in 2s ease infinite}.tl2-anim-rotate-in-cw{animation:txt-rotate-in 2s ease infinite reverse}.tl2-anim-spring{animation:txt-spring 2s ease infinite}.tl2-anim-elastic{animation:txt-elastic 2s ease infinite}.tl2-anim-scale-up{animation:txt-scale-up 2s ease infinite}.tl2-anim-scale-up-big{animation:txt-scale-up 2.5s ease infinite}.tl2-anim-scale-down-in{animation:txt-slam 2s ease infinite}.tl2-anim-typewriter{animation:txt-typewriter 2s steps(3) infinite}.tl2-anim-letter-by-letter{animation:txt-typewriter 3s steps(5) infinite}.tl2-anim-word-by-word{animation:txt-typewriter 2s steps(2) infinite}.tl2-anim-fade-up{animation:txt-rise-up 2s ease infinite}.tl2-anim-fade-down{animation:txt-slide-down 2s ease infinite}.tl2-anim-slam{animation:txt-slam 2s ease infinite}.tl2-anim-expand{animation:txt-expand 2s ease infinite}.tl2-anim-fade-out{animation:txt-fade-out 2s ease infinite}.tl2-anim-slide-up-out{animation:txt-slide-up-out 2s ease infinite}.tl2-anim-slide-down-out{animation:txt-slide-down-out 2s ease infinite}.tl2-anim-slide-left-out{animation:txt-slide-left-out 2s ease infinite}.tl2-anim-slide-right-out{animation:txt-slide-right-out 2s ease infinite}.tl2-anim-slide-up-fast-out{animation:txt-slide-up-out 1.5s ease infinite}.tl2-anim-slide-down-fast-out{animation:txt-slide-down-out 1.5s ease infinite}.tl2-anim-zoom-out{animation:txt-zoom-out 2s ease infinite}.tl2-anim-zoom-out-slow{animation:txt-zoom-out 3s ease infinite}.tl2-anim-blur-out{animation:txt-blur-out 2s ease infinite}.tl2-anim-blur-out-fast{animation:txt-blur-out 1.5s ease infinite}.tl2-anim-wipe-left-out{animation:txt-slide-left-out 2s ease infinite}.tl2-anim-wipe-right-out{animation:txt-slide-right-out 2s ease infinite}.tl2-anim-wipe-up-out{animation:txt-slide-up-out 2s ease infinite}.tl2-anim-wipe-down-out{animation:txt-slide-down-out 2s ease infinite}.tl2-anim-shrink{animation:txt-shrink 2s ease infinite}.tl2-anim-flip-x-out{animation:txt-flip-x 2s ease infinite reverse}.tl2-anim-flip-y-out{animation:txt-flip-y 2s ease infinite reverse}.tl2-anim-rotate-out{animation:txt-rotate-out 2s ease infinite}.tl2-anim-dissolve{animation:txt-dissolve 2s ease infinite}.tl2-anim-scale-down{animation:txt-scale-down 2s ease infinite}.tl2-anim-fade-up-out{animation:txt-slide-up-out 2s ease infinite}.tl2-anim-fade-down-out{animation:txt-slide-down-out 2s ease infinite}.tl2-anim-pop-out{animation:txt-pop-out 2s ease infinite}.tl2-anim-contract{animation:txt-shrink 2s ease infinite}.tl2-anim-drop-out{animation:txt-drop-out 2s ease infinite}.tl2-anim-rise-out{animation:txt-slide-up-out 2s ease infinite}.tl2-anim-slam-out{animation:txt-slam-out 2s ease infinite}.tl2-anim-elastic-out{animation:txt-elastic-out 2s ease infinite}.tl2-anim-pulse{animation:txt-pulse 1s ease-in-out infinite}.tl2-anim-float{animation:txt-float 2s ease-in-out infinite}.tl2-anim-wobble{animation:txt-wobble .8s ease-in-out infinite}.tl2-anim-shake-subtle{animation:txt-shake-subtle .3s ease-in-out infinite}.tl2-anim-shake-strong{animation:txt-shake-strong .2s ease-in-out infinite}.tl2-anim-glow-pulse{animation:txt-glow-pulse 1.5s ease-in-out infinite}.tl2-anim-flicker{animation:txt-flicker .3s ease-in-out infinite}.tl2-anim-flicker-fast{animation:txt-flicker-fast .2s ease-in-out infinite}.tl2-anim-breathe{animation:txt-breathe 2s ease-in-out infinite}.tl2-anim-swing{animation:txt-swing 1.2s ease-in-out infinite}.tl2-anim-rock{animation:txt-rock 1s ease-in-out infinite}.tl2-anim-vibrate{animation:txt-vibrate .1s linear infinite}.tl2-anim-heartbeat{animation:txt-heartbeat 1.2s ease-in-out infinite}.tl2-anim-jitter{animation:txt-jitter .08s linear infinite}.tl2-anim-bounce-gentle{animation:txt-bounce-gentle .8s ease-in-out infinite}.tl2-anim-wave{animation:txt-wave 1s ease-in-out infinite}.tl2-anim-spin-slow{animation:txt-spin-slow 4s linear infinite}.tl2-anim-color-cycle{animation:txt-color-cycle 3s linear infinite}.tl2-anim-scale-breathe{animation:txt-scale-breathe 1.5s ease-in-out infinite}.tl2-anim-nod{animation:txt-nod .6s ease-in-out infinite}.tl2-anim-sway{animation:txt-sway 1.5s ease-in-out infinite}.tl2-anim-glow{animation:txt-glow 1.5s ease-in-out infinite}.tl2-anim-shake{animation:txt-shake .4s ease-in-out infinite}.tl2-anim-bounce-loop,.tl2-anim-bounce:not(.tl2-anim-bounce-in):not(.tl2-anim-bounce-gentle){animation:txt-bounce-loop .8s ease-in-out infinite}.tl2-anim-zoom-breathe{animation:txt-zoom-breathe 2s ease-in-out infinite}.tl2-anim-tilt{animation:txt-tilt 1s ease-in-out infinite}.tl2-anim-bob{animation:txt-bob .8s ease-in-out infinite}.tl2-anim-rubber{animation:txt-rubber .8s ease-in-out infinite}.tl2-anim-levitate{animation:txt-levitate 3s ease-in-out infinite}.tl2-tinsp-cat-chip{font-size:9px;padding:2px 6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#888;cursor:pointer;transition:all .15s;text-transform:capitalize;white-space:nowrap}.tl2-tinsp-cat-chip:hover{background:#ffffff1a;color:#bbb}.tl2-tinsp-cat-chip.active{background:#00b4d826;border-color:#00b4d8;color:#00b4d8}.tl2-caption-word{display:inline;transition:color .05s ease,background-color .1s ease,text-shadow .1s ease,text-decoration-color .1s ease;word-spacing:.15em}.tl2-fx-block[draggable=true]{cursor:grab}.tl2-fx-block[draggable=true]:active{cursor:grabbing;opacity:.6}.tl2-track-fx.drag-over{background:#00b4d81a}.tl2-fx-lane-add{margin-left:auto;background:none;border:1px solid #444;color:#888;width:18px;height:18px;border-radius:4px;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center}.tl2-fx-lane-add:hover{border-color:#00b4d8;color:#00b4d8}.tl2-source-video-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:grab;border-radius:6px;transition:background .15s}.tl2-source-video-item:hover{background:#ffffff0f}.tl2-source-video-item:active{cursor:grabbing;opacity:.7}.tl2-lyrics-btn{margin-left:auto;padding:3px 10px;font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3);border-radius:4px;cursor:pointer;transition:background .15s,border-color .15s}.tl2-lyrics-btn:hover:not(:disabled){background:#10b98140;border-color:#10b981}.tl2-lyrics-btn:disabled{opacity:.5;cursor:not-allowed}.tl2-track-lyrics{height:48px;position:relative;border-bottom:1px solid rgba(255,255,255,.04)}.tl2-track-lyrics .tl2-track-body{position:relative;height:100%}.tl2-lyrics-word{position:absolute;top:4px;height:28px;background:#10b9812e;border:1px solid rgba(16,185,129,.4);border-radius:4px;display:flex;align-items:center;cursor:grab;-webkit-user-select:none;user-select:none;overflow:hidden;transition:box-shadow .1s}.tl2-lyrics-word:active{cursor:grabbing}.tl2-lyrics-word.selected{border-color:#10b981;box-shadow:0 0 0 1px #10b981,0 0 8px #10b9814d}.tl2-lyrics-word-text{font-size:9px;font-weight:600;color:#a7f3d0;padding:0 3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;pointer-events:none}.tl2-lyrics-handle-l,.tl2-lyrics-handle-r{width:5px;height:100%;cursor:ew-resize;flex-shrink:0;transition:background .1s}.tl2-lyrics-handle-l:hover,.tl2-lyrics-handle-r:hover{background:#10b98166}.tl2-lyrics-block{position:absolute;top:4px;height:40px;background:#10b98126;border:1px solid rgba(16,185,129,.35);border-radius:5px;display:flex;align-items:center;cursor:grab;-webkit-user-select:none;user-select:none;overflow:hidden;transition:box-shadow .12s,border-color .12s}.tl2-lyrics-block:hover{border-color:#10b98199}.tl2-lyrics-block:active{cursor:grabbing}.tl2-lyrics-block.selected{border-color:#10b981;background:#10b98140;box-shadow:0 0 0 1px #10b981,0 0 8px #10b98140}.tl2-lyrics-block.split-cursor{cursor:crosshair}.tl2-lyrics-block-text{font-size:13px;font-weight:600;color:#a7f3d0;padding:2px 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;pointer-events:none;line-height:1.3}.tl2-lyrics-block-edit{font-size:13px;font-weight:600;color:#fff;padding:2px 8px;flex:1}.tl2-lyrics-words-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.tl2-lyrics-subword{position:absolute;top:2px;bottom:2px;background:#10b98133;border:1px solid rgba(16,185,129,.5);border-radius:3px;display:flex;align-items:center;justify-content:center;pointer-events:auto;cursor:grab;overflow:hidden}.tl2-lyrics-subword:hover{background:#10b98159}.tl2-lyrics-subword.selected{border-color:#34d399;background:#34d3994d;box-shadow:0 0 4px #34d39966}.tl2-lyrics-select-rect{position:absolute;top:0;height:100%;background:#10b98126;border:1px solid rgba(16,185,129,.5);border-radius:2px;pointer-events:none;z-index:3}.tl2-multitrack-lane{position:relative}.tl2-track-header{position:absolute;left:0;top:0;bottom:0;width:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;z-index:10;background:#0c0c16f2;border-right:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tl2-track-header-label{font-size:.62rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.tl2-track-header-btn{background:none;border:none;cursor:pointer;font-size:.65rem;padding:1px 3px;border-radius:3px;opacity:.6;transition:opacity .15s,background .15s}.tl2-track-header-btn:hover{opacity:1;background:#ffffff14}.tl2-track-header-btn.active{opacity:1;background:#ef444433}.tl2-track-delete-btn{color:#ef4444;font-size:.6rem;font-weight:700;opacity:.4}.tl2-track-delete-btn:hover{opacity:1;background:#ef444440!important}.tl2-track-add-btn{color:#22c55e;font-size:.75rem;font-weight:700;opacity:.5}.tl2-track-add-btn:hover{opacity:1;background:#22c55e40!important}.tl2-add-track-btn{height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#ffffff05;border-bottom:1px solid #151520;transition:background .15s}.tl2-add-track-btn:hover{background:#ffffff0f}.tl2-add-track-btn span{font-size:.62rem;font-weight:700;color:#555;letter-spacing:.08em}.tl2-overlay-controls{display:flex;flex-direction:column;gap:6px;padding:8px 10px;background:#ffffff08;border-radius:6px;border:1px solid rgba(255,255,255,.06)}.tl2-overlay-controls label{font-size:.68rem;font-weight:700;color:#888;letter-spacing:.06em;text-transform:uppercase}.tl2-overlay-controls input[type=range]{width:100%;accent-color:#a855f7}.tl2-overlay-controls select{background:#1a1a2e;border:1px solid rgba(255,255,255,.1);color:#ccc;font-size:.72rem;padding:3px 6px;border-radius:4px}.tl2-crop-frame [style*="pointer-events: auto"]{cursor:grab}.tl2-crop-frame [style*="pointer-events: auto"]:active{cursor:grabbing}.tl2-segment.is-slot{border-width:2px}.tl2-slot-badge{position:absolute;top:2px;left:4px;background:#a855f7;color:#fff;font-size:.55rem;font-weight:800;padding:0 4px;border-radius:3px;letter-spacing:.06em;line-height:1.4;z-index:2;pointer-events:none}.tl2-slot-type-badge{background:#a855f759!important;color:#d8b4fe!important;font-size:.55rem!important;text-transform:uppercase}.tl2-preflight-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:9999;display:flex;align-items:center;justify-content:center}.tl2-preflight-modal{background:#1a1a2e;border:1px solid rgba(168,85,247,.3);border-radius:12px;padding:24px;min-width:440px;max-width:560px;max-height:80vh;overflow-y:auto;color:#eee}.tl2-preflight-modal h3{margin:0 0 12px;font-size:1rem;color:#a855f7;text-transform:uppercase;letter-spacing:.04em}.tl2-preflight-summary{display:flex;gap:12px;font-size:.82rem;margin-bottom:16px;color:#ccc}.tl2-preflight-slot-row{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:6px;background:#ffffff08;margin-bottom:6px;font-size:.78rem}.tl2-preflight-slot-row .slot-idx{color:#888;min-width:24px;font-weight:700}.tl2-preflight-slot-row .slot-type{background:#a855f733;color:#c084fc;padding:1px 6px;border-radius:3px;font-size:.68rem;text-transform:uppercase;font-weight:700}.tl2-preflight-slot-row .slot-dur{color:#aaa;min-width:40px;text-align:right}.tl2-preflight-error{color:#f87171;font-size:.78rem;margin:4px 0}.tl2-preflight-warning{color:#fbbf24;font-size:.78rem;margin:4px 0}.tl2-preflight-status{font-weight:700;font-size:.85rem;margin:12px 0;padding:8px 12px;border-radius:6px}.tl2-preflight-status.ok{background:#22c55e1a;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.tl2-preflight-status.error{background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.2)}.tl2-preflight-status.warning{background:#eab3081a;color:#fbbf24;border:1px solid rgba(234,179,8,.2)}.tl2-preflight-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.tl2-ai-panel{position:fixed;top:0;right:0;width:360px;height:100vh;background:#0c0c16;border-left:1px solid rgba(168,85,247,.25);display:flex;flex-direction:column;z-index:1000;box-shadow:-4px 0 24px #00000080}.tl2-ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.tl2-ai-panel-title{font-size:.75rem;font-weight:800;letter-spacing:.12em;color:#a855f7}.tl2-ai-panel-close{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:2px 6px}.tl2-ai-panel-close:hover{color:#fff}.tl2-ai-panel-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.06)}.tl2-ai-panel-tab{flex:1;background:none;border:none;color:#555;font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:10px 0;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tl2-ai-panel-tab:hover{color:#aaa}.tl2-ai-panel-tab.active{color:#a855f7;border-bottom-color:#a855f7}.tl2-ai-panel-body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:12px;gap:10px}.tl2-ai-quick-actions{display:flex;flex-wrap:wrap;gap:6px}.tl2-ai-quick-chip{background:#ffffff08;border:1px solid;border-radius:14px;padding:4px 12px;font-size:.68rem;font-weight:600;cursor:pointer;transition:background .15s}.tl2-ai-quick-chip:hover:not(:disabled){background:#ffffff14}.tl2-ai-quick-chip:disabled{opacity:.4;cursor:not-allowed}.tl2-ai-panel-input-wrap{display:flex;gap:6px}.tl2-ai-panel-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e5e5e5;padding:8px 10px;font-size:.78rem;outline:none}.tl2-ai-panel-input:focus{border-color:#a855f780}.tl2-ai-panel-go{background:#7c3aed;border:none;color:#fff;padding:8px 14px;border-radius:6px;font-size:.75rem;font-weight:700;cursor:pointer}.tl2-ai-panel-go:disabled{opacity:.4;cursor:not-allowed}.tl2-ai-panel-msg{font-size:.72rem;color:#a78bfa;padding:6px 8px;background:#a855f714;border-radius:6px;line-height:1.4}.tl2-ai-panel-body .tl2-coach-messages{flex:1;overflow-y:auto;max-height:none}.tl2-ai-panel-body .tl2-coach-input-wrap{flex-shrink:0}.tl2-btn-active{background:#a855f726!important;border-color:#a855f799!important}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0f;--bg-card: #14141f;--bg-sidebar: #0e0e18;--bg-input: #1a1a2e;--border: #2a2a3e;--text: #e0e0e8;--text-dim: #8888a0;--accent: #6c5ce7;--accent-hover: #7f70f0;--accent-glow: rgba(108, 92, 231, .3);--success: #00d68f;--danger: #ff4757;--warning: #ffa502}body{font-family:SF Mono,Fira Code,Consolas,monospace;background:var(--bg);color:var(--text);min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh}.sidebar-brand{padding:1.5rem 1rem;font-size:1.1rem;font-weight:700;letter-spacing:2px;color:var(--accent);border-bottom:1px solid var(--border)}.sidebar nav{flex:1;display:flex;flex-direction:column;padding:.5rem 0}.nav-link{display:block;padding:.8rem 1rem;color:var(--text-dim);text-decoration:none;font-size:.85rem;border-left:3px solid transparent;transition:all .15s}.nav-link:hover{color:var(--text);background:#6c5ce714}.nav-link.active{color:var(--accent);border-left-color:var(--accent);background:#6c5ce71f}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);min-height:50px}.status-loading{color:var(--warning);font-size:.8rem;animation:pulse 1.2s infinite}.pipeline-monitor{position:fixed;bottom:0;left:240px;right:0;height:220px;background:#0c0c14;border-top:2px solid var(--accent);display:flex;flex-direction:column;z-index:100}.monitor-header{display:flex;align-items:center;gap:1rem;padding:.5rem 1.2rem;font-size:.85rem;font-weight:700;letter-spacing:2px;color:var(--accent);background:#6c5ce714;border-bottom:1px solid var(--border);flex-shrink:0}.monitor-live{color:var(--success);animation:pulse 1s infinite;font-size:.75rem;letter-spacing:3px;background:#00d68f26;padding:.15rem .6rem;border-radius:3px}.monitor-count{margin-left:auto;color:var(--text-dim);font-size:.75rem;font-weight:400;letter-spacing:0}.monitor-logs{flex:1;overflow-y:auto;padding:.5rem 0}.monitor-logs::-webkit-scrollbar{width:6px}.monitor-logs::-webkit-scrollbar-track{background:transparent}.monitor-logs::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.monitor-empty{color:var(--text-dim);font-size:.9rem;padding:1rem 1.2rem;opacity:.5}.monitor-line{font-size:.9rem;padding:.2rem 1.2rem;color:var(--text);line-height:1.5;word-break:break-all}.monitor-line.log-step{color:var(--accent);font-weight:700;padding-top:.3rem}.monitor-line.log-upload{color:var(--warning);font-weight:600}.monitor-line.log-success{color:var(--success);font-weight:600}.monitor-line.log-error{color:var(--danger);font-weight:700}.monitor-line.log-clip{color:var(--text-dim);font-size:.85rem;padding-left:2rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.content{flex:1;padding:2rem;padding-bottom:240px;overflow-y:auto;max-width:1100px}.page h2{font-size:1.3rem;margin-bottom:1.5rem;color:var(--accent);letter-spacing:1px}.error-banner{background:#ff475726;border:1px solid var(--danger);color:var(--danger);padding:.7rem 1rem;border-radius:6px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.error-banner button{background:none;border:none;color:var(--danger);cursor:pointer;font-size:1rem;padding:0 .3rem}.empty-state{color:var(--text-dim);padding:2rem;text-align:center;font-size:.9rem}.form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.2rem;margin-bottom:1rem}.form-section h3{font-size:.95rem;color:var(--text-dim);margin-bottom:.8rem;text-transform:uppercase;letter-spacing:1px}.form-row{margin-bottom:.8rem}.form-row label{display:block;font-size:.8rem;color:var(--text-dim);margin-bottom:.3rem}.form-row-group{display:flex;gap:1rem;margin-bottom:.8rem}.form-row-group .form-row{flex:1;margin-bottom:0}input[type=text],input[type=number],select,textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.5rem .7rem;font-family:inherit;font-size:.85rem;outline:none;transition:border-color .15s}input[type=text]:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}input[type=range]{width:100%;accent-color:var(--accent)}input[type=file]{font-family:inherit;font-size:.85rem;color:var(--text-dim)}input[type=file]::file-selector-button{background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.4rem .8rem;font-family:inherit;cursor:pointer;margin-right:.8rem}input[type=file]::file-selector-button:hover{border-color:var(--accent)}.transcript-area{resize:vertical;min-height:120px}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:.7rem 1.5rem;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .15s;width:100%;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:.6rem 1.2rem;font-family:inherit;font-size:.85rem;cursor:pointer;transition:all .15s}.btn-secondary:hover:not(:disabled){background:#6c5ce726}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-warning{padding:.6rem 1.2rem;border:1px solid var(--warning);background:#ffa5021a;color:var(--warning);border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .15s}.btn-warning:hover:not(:disabled){background:#ffa50233}.btn-warning:disabled{opacity:.4;cursor:not-allowed}.btn-scout{padding:.6rem 1.2rem;border:1px solid #00d2ff;background:#00d2ff1a;color:#00d2ff;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .15s}.btn-scout:hover:not(:disabled){background:#00d2ff33}.btn-montage{padding:.6rem 1.2rem;border:1px solid #f59e0b;background:#f59e0b1a;color:#f59e0b;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .15s}.btn-montage:hover:not(:disabled){background:#f59e0b33}.btn-montage:disabled{opacity:.4;cursor:not-allowed}.btn-scout:disabled{opacity:.4;cursor:not-allowed}.scout-summary{background:#00d2ff14;border:1px solid rgba(0,210,255,.3);border-radius:6px;padding:.6rem 1rem;margin-top:.8rem;font-size:.8rem;color:var(--text-dim);display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.scout-summary strong{color:#00d2ff}.scout-labels{display:flex;gap:.3rem;flex-wrap:wrap}.btn-sm{background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.3rem .6rem;font-family:inherit;font-size:.75rem;cursor:pointer;transition:all .15s}.btn-sm:hover{border-color:var(--accent);color:var(--accent)}.btn-sm.active{background:var(--accent);border-color:var(--accent);color:#fff}.btn-export{font-size:1rem;padding:1rem;margin-top:1rem}.info-bar{background:#6c5ce71a;border:1px solid var(--border);border-radius:6px;padding:.6rem 1rem;margin-top:.8rem;font-size:.8rem;color:var(--text-dim)}.info-bar code{color:var(--accent)}.info-bar strong{color:var(--text)}.hint{font-size:.75rem;color:var(--text-dim);margin-left:.5rem}.clips-toolbar{display:flex;align-items:center;gap:.8rem;margin-bottom:.8rem;font-size:.85rem;color:var(--text-dim)}.clips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.8rem}.clip-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem;transition:all .15s}.clip-card:hover{border-color:var(--accent)}.clip-card.selected{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.clip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.clip-thumbnail{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:6px;overflow:hidden;cursor:pointer;margin-bottom:.5rem;background:#1a1a2e}.clip-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.clip-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#2d2d44)}.clip-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;color:#fffc;background:#00000080;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s;pointer-events:none}.clip-thumbnail:hover .clip-play-icon{color:#fff;background:#6c5ce7cc;transform:translate(-50%,-50%) scale(1.1)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center}.preview-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1rem;width:90vw;max-width:900px;max-height:90vh;display:flex;flex-direction:column;gap:.6rem}.preview-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--accent)}.preview-video{width:100%;max-height:65vh;border-radius:8px;background:#000}.preview-nav{display:flex;justify-content:center;gap:.8rem}.clip-number{font-weight:700;color:var(--accent);font-size:.9rem}.clip-checkbox{font-size:.75rem;color:var(--text-dim);display:flex;align-items:center;gap:.3rem;cursor:pointer}.clip-checkbox input{accent-color:var(--accent)}.clip-times{font-size:1rem;font-weight:600;margin-bottom:.5rem}.clip-meta{display:flex;gap:1rem;font-size:.8rem;color:var(--text-dim);margin-bottom:.4rem}.clip-titles{font-size:.8rem;color:var(--text-dim);margin-top:.3rem}.clip-hook{font-size:.8rem;color:var(--warning);font-style:italic;margin-top:.3rem}.clip-reason{font-size:.78rem;color:var(--text);margin-top:.4rem;padding:.3rem .5rem;background:#6c5ce714;border-radius:4px;line-height:1.3}.clip-events{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}.event-badge{font-size:.68rem;padding:.15rem .4rem;border-radius:3px;background:#00d68f26;color:var(--success);text-transform:uppercase;letter-spacing:.5px}.badge-energy{background:#ffa5002e;color:orange}.badge-speech{background:#00a2ff26;color:#00a2ff}.badge-beat{background:#a855f726;color:#a855f7}.badge-vision{background:#ef444426;color:#ef4444}.clip-reason{font-size:.65rem;color:var(--text-dim);margin-top:.3rem;line-height:1.3;cursor:help}.clip-topics{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.3rem}.topic-badge{font-size:.68rem;padding:.12rem .35rem;border-radius:3px;background:#6c5ce71f;color:var(--accent)}.clip-detail-toggle{margin-top:.5rem;width:100%;text-align:center}.clip-detail-panel{margin-top:.4rem;padding:.5rem;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;font-size:.78rem}.clip-detail-reason{margin-bottom:.4rem;line-height:1.3}.clip-quotes{margin-top:.3rem}.clip-quote{color:var(--text-dim);font-style:italic;margin-top:.2rem;padding-left:.5rem;border-left:2px solid var(--accent)}.video-summary{background:#6c5ce714;border:1px solid var(--border);border-radius:6px;padding:.7rem 1rem;margin-top:.8rem;font-size:.82rem;line-height:1.4;color:var(--text)}.chapters-list{margin-top:.6rem;font-size:.8rem;color:var(--text-dim)}.chapters-items{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem}.chapter-badge{font-size:.72rem;padding:.2rem .5rem;border-radius:4px;background:var(--bg-input);border:1px solid var(--border);color:var(--text)}.hooks-list{margin-top:.8rem;display:flex;flex-direction:column;gap:.5rem}.hook-item{background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:.7rem}.hook-text{font-size:.85rem;margin-bottom:.4rem;color:var(--text)}.hook-actions{display:flex;justify-content:space-between;align-items:center}.hook-score{font-size:.75rem;color:var(--text-dim)}.preview-section{margin-top:1rem}.preview-section h3{font-size:.95rem;color:var(--text-dim);margin-bottom:.5rem}.video-preview{width:100%;max-width:400px;border-radius:8px;border:1px solid var(--border);background:#000}.export-clip-list{display:flex;flex-direction:column;gap:.3rem}.export-clip-item{font-size:.8rem;color:var(--text-dim);padding:.4rem .6rem;background:var(--bg-input);border-radius:4px}.export-results{display:flex;flex-direction:column;gap:.5rem}.export-result-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .8rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;font-size:.8rem}.export-result-item a{color:var(--success);text-decoration:none}.btn-row{display:flex;gap:.8rem;margin-top:.8rem}.btn-row .btn-secondary,.btn-row .btn-primary{width:auto;flex:1}.reframe-track-viz{position:relative;height:60px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;margin-top:.6rem;overflow:hidden}.reframe-track-dot{position:absolute;width:4px;height:4px;background:var(--accent);border-radius:50%;transform:translate(-50%,50%);opacity:.8}.reframe-track-dot:hover{width:7px;height:7px;opacity:1;background:var(--accent-hover);z-index:1}.drop-zone{border:2px dashed var(--border);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-input);margin-bottom:.8rem}.drop-zone:hover{border-color:var(--accent);background:#6c5ce70d}.drop-zone-active{border-color:var(--accent);background:#6c5ce71a;box-shadow:0 0 20px var(--accent-glow)}.drop-zone-has-file{border-style:solid;border-color:var(--success);background:#00d68f0d;padding:1rem}.drop-zone-placeholder{color:var(--text-dim)}.drop-zone-icon{font-size:2rem;color:var(--accent);margin-bottom:.5rem;font-weight:300}.drop-zone-hint{font-size:.75rem;color:var(--text-dim);margin-top:.3rem;opacity:.7}.drop-zone-file{display:flex;align-items:center;gap:.8rem;justify-content:center}.drop-zone-filename{color:var(--success);font-weight:600;font-size:.9rem}.drop-zone-size{color:var(--text-dim);font-size:.8rem}.youtube-section{margin-top:.5rem}.youtube-section label{display:block;font-size:.8rem;color:var(--text-dim);margin-bottom:.3rem}.youtube-row{display:flex;gap:.5rem}.youtube-row input[type=text]{flex:1}.youtube-row .btn-secondary{white-space:nowrap;flex-shrink:0}.library-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;align-items:center}.library-date-group{margin-bottom:1.5rem}.library-date-label{font-size:.9rem;font-weight:700;color:var(--accent);margin-bottom:.6rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.library-thumb{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:.5rem;background:var(--bg-input)}.genre-badge{font-size:.65rem;padding:.15rem .4rem;border-radius:3px;background:#ffa5022e;color:var(--warning);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.library-download{display:inline-block;margin-top:.5rem;font-size:.78rem;color:var(--success);text-decoration:none;font-weight:600}.library-download:hover{text-decoration:underline}.queue-section{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}.queue-section h3{font-size:.9rem;color:var(--text-dim);margin-bottom:.6rem;text-transform:uppercase;letter-spacing:1px}.queue-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.8rem}.queue-item{display:flex;align-items:center;gap:.8rem;padding:.5rem .7rem;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;font-size:.8rem}.queue-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-item-status{font-size:.75rem;white-space:nowrap}.queue-status-waiting .queue-item-status{color:var(--text-dim)}.queue-status-analyzing{border-color:var(--warning)}.queue-status-analyzing .queue-item-status{color:var(--warning);animation:pulse 1.2s infinite}.queue-status-done{border-color:var(--success)}.queue-status-done .queue-item-status{color:var(--success)}.queue-status-error{border-color:var(--danger)}.queue-status-error .queue-item-status{color:var(--danger)}.queue-remove{background:none;border:none;color:var(--danger);cursor:pointer;font-size:.85rem;padding:0 .3rem;opacity:.6;transition:opacity .15s}.queue-remove:hover{opacity:1}.edit-tabs{display:flex;gap:0;margin-bottom:1rem}.edit-tab{padding:.6rem 1.2rem;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;letter-spacing:1px;transition:all .15s}.edit-tab:first-child{border-radius:6px 0 0 6px}.edit-tab:last-child{border-radius:0 6px 6px 0}.edit-tab:not(:first-child){border-left:none}.edit-tab:hover{color:var(--text);background:#6c5ce714}.edit-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.source-preview{position:relative;width:100%;max-width:640px;margin:0 auto 1rem}.source-preview video{width:100%;border-radius:8px;cursor:pointer;background:#000}.clip-player{position:relative;width:100%;max-width:640px;margin:0 auto;outline:none}.clip-player-video{position:relative;cursor:pointer;border-radius:8px 8px 0 0;overflow:hidden;background:#000}.clip-player-video video{width:100%;display:block;background:#000}.clip-player-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;color:#ffffffb3;pointer-events:none;text-shadow:0 2px 8px rgba(0,0,0,.5)}.clip-player-controls{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#1a1a2e;border-radius:0 0 8px 8px;border-top:1px solid rgba(255,255,255,.08)}.clip-player-btn{background:none;border:none;color:#e2e8f0;font-size:.7rem;cursor:pointer;padding:2px 6px;border-radius:3px;transition:background .15s;line-height:1}.clip-player-btn:hover{background:#ffffff1a}.clip-player-playpause{font-size:.9rem}.clip-player-scrub{flex:1;height:6px;background:#ffffff1a;border-radius:3px;position:relative;cursor:pointer}.clip-player-scrub-fill{height:100%;background:#3b82f6;border-radius:3px;pointer-events:none}.clip-player-scrub-head{position:absolute;top:50%;width:12px;height:12px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0006;pointer-events:none}.clip-player-time{font-size:.68rem;color:#94a3b8;white-space:nowrap;font-variant-numeric:tabular-nums;min-width:85px;text-align:right}.clip-player-abs-time{font-size:.6rem;color:#64748b;text-align:right;padding:2px 10px 0}.crop-overlay{position:absolute;border:2px solid var(--accent);background:#6c5ce726;pointer-events:none;transition:left .15s ease,width .15s ease,top .15s ease,height .15s ease;border-radius:4px}.clip-player-video.crop-preview{height:auto!important;margin:0 auto;border:2px solid var(--accent);border-radius:8px}.clip-player-video.crop-preview video{width:100%;height:100%;max-height:none!important}.gemini-suggestion{padding:.6rem .8rem;background:#6c5ce71a;border:1px solid rgba(108,92,231,.25);border-radius:6px;font-size:.85rem;color:var(--accent);margin-bottom:.8rem}.gemini-suggestion strong{color:var(--text)}.preset-chips{display:flex;gap:.4rem;flex-wrap:wrap}.preset-chip{padding:.3rem .7rem;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:.75rem;font-family:inherit;cursor:pointer;transition:all .15s}.preset-chip:hover{border-color:var(--accent);color:var(--accent)}.preset-chip.active{border-color:var(--accent);color:var(--accent);background:#6c5ce71f}.clip-strip{display:flex;gap:.6rem;overflow-x:auto;padding:.5rem 0 .8rem;margin-bottom:.8rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.clip-strip::-webkit-scrollbar{height:6px}.clip-strip::-webkit-scrollbar-track{background:transparent}.clip-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.clip-strip-item{flex-shrink:0;width:160px;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:.4rem;cursor:pointer;transition:all .15s}.clip-strip-item:hover{border-color:var(--accent)}.clip-strip-item.active{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);background:#6c5ce714}.clip-strip-thumb{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:4px;overflow:hidden;background:#1a1a2e;margin-bottom:.3rem}.clip-strip-thumb img{width:100%;height:100%;object-fit:cover;display:block}.clip-strip-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#2d2d44)}.clip-strip-badge{position:absolute;top:4px;left:4px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .35rem;border-radius:3px}.clip-strip-info{display:flex;justify-content:space-between;align-items:center;font-size:.72rem}.clip-strip-time{color:var(--text);font-weight:600}.clip-strip-score{color:var(--text-dim);font-size:.68rem}.clip-strip-hook{font-size:.68rem;color:var(--warning);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.15rem}.ratio-chips{display:flex;gap:.4rem;flex-wrap:wrap}.ratio-chip{display:flex;flex-direction:column;align-items:center;padding:.4rem .7rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-family:inherit;cursor:pointer;transition:all .15s;min-width:70px}.ratio-chip:hover{border-color:var(--accent);color:var(--accent)}.ratio-chip.active{border-color:var(--accent);color:var(--accent);background:#6c5ce71f}.ratio-chip-label{font-size:.85rem;font-weight:700}.ratio-chip-desc{font-size:.62rem;opacity:.7;white-space:nowrap}.studio-layout{display:flex;flex-direction:row;height:calc(100vh - 240px);min-height:500px}.studio-workspace{flex:1;display:flex;flex-direction:column;min-width:0}.studio-empty{flex:1;display:flex;align-items:center;justify-content:center}.media-bin{width:180px;flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.media-bin-header{padding:.5rem .6rem;font-size:.7rem;font-weight:700;letter-spacing:1px;color:var(--accent);border-bottom:1px solid var(--border);flex-shrink:0}.media-bin-list{flex:1;overflow-y:auto;padding:.3rem}.media-bin-list::-webkit-scrollbar{width:4px}.media-bin-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.media-bin-empty{font-size:.75rem;color:var(--text-dim);padding:.8rem .4rem;text-align:center}.media-bin-item{display:flex;gap:.4rem;padding:.35rem;border-radius:6px;cursor:pointer;transition:all .12s;margin-bottom:.2rem}.media-bin-item:hover{background:#6c5ce714}.media-bin-item.active{background:#6c5ce726;outline:1px solid var(--accent)}.media-bin-thumb{position:relative;width:56px;height:32px;border-radius:3px;overflow:hidden;flex-shrink:0;background:#1a1a2e}.media-bin-thumb img{width:100%;height:100%;object-fit:cover}.media-bin-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#2d2d44)}.media-bin-status{position:absolute;top:1px;right:1px;font-size:.5rem;font-weight:800;padding:0 3px;border-radius:2px;line-height:1.3}.media-bin-meta{min-width:0;flex:1}.media-bin-time{font-size:.65rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-bin-score{font-size:.6rem;color:var(--text-dim)}.studio-header{display:flex;align-items:center;gap:1rem;padding:.6rem 1rem;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.studio-header-info{display:flex;align-items:center;gap:.8rem;flex:1}.studio-header-time{font-weight:700;font-size:.95rem;color:var(--accent)}.studio-header-score,.studio-header-viral{font-size:.8rem;color:var(--text-dim)}.studio-clip-switcher{max-width:260px;font-size:.8rem}.studio-main{display:flex;flex:1;min-height:0;overflow:hidden}.studio-preview{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:hidden}.studio-preview .source-preview{max-width:100%;max-height:100%}.studio-preview .source-preview video{max-height:calc(100vh - 420px)}.studio-preview .clip-player{max-width:100%}.studio-preview .clip-player-video video{max-height:calc(100vh - 420px)}.studio-tool-panel{width:380px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-sidebar)}.studio-tool-tabs{display:flex;flex-shrink:0;border-bottom:1px solid var(--border)}.studio-tab-btn{flex:1;padding:.5rem .3rem;border:none;background:transparent;color:var(--text-dim);font-family:inherit;font-size:.7rem;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}.studio-tab-btn:hover{color:var(--text);background:#6c5ce714}.studio-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:#6c5ce71a}.studio-tool-content{flex:1;overflow-y:auto;padding:.8rem}.studio-tool-content::-webkit-scrollbar{width:6px}.studio-tool-content::-webkit-scrollbar-track{background:transparent}.studio-tool-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.studio-timeline{height:48px;flex-shrink:0;background:var(--bg-card);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 1rem}.studio-timeline-bar{flex:1;height:24px;background:var(--bg-input);border-radius:4px;display:flex;align-items:center;padding:0 .8rem}.studio-timeline-label{font-size:.75rem;color:var(--text-dim);letter-spacing:1px}.studio-timeline-dur{margin-left:.4rem;opacity:.6}.scout-timeline-section{flex-shrink:0;background:var(--bg-card);border-top:1px solid var(--border);padding:.6rem 1rem;display:flex;flex-direction:column;gap:.5rem;max-height:360px;overflow-y:auto}.scout-timeline-header{display:flex;align-items:center;justify-content:space-between}.scout-timeline-title{font-size:.8rem;font-weight:600;color:#00d2ff}.scout-timeline-actions{display:flex;gap:.4rem;align-items:center}.btn-scout-create{font-size:.75rem;padding:.3rem .8rem}.scout-timeline-bar-container{position:relative;width:100%}.scout-timeline-ruler{position:relative;height:16px;font-size:.6rem;color:var(--text-dim)}.scout-timeline-tick{position:absolute;top:0;transform:translate(-50%);white-space:nowrap}.scout-timeline-track{position:relative;height:28px;background:var(--bg-input);border-radius:4px;overflow:hidden}.scout-marker{position:absolute;top:2px;height:24px;border-radius:3px;border:1px solid;cursor:pointer;transition:all .12s;min-width:4px;opacity:.8}.scout-marker:hover,.scout-marker.hovered{opacity:1;transform:scaleY(1.15);z-index:2}.scout-marker.selected{opacity:1;z-index:1;box-shadow:0 0 6px #00d2ff66}.scout-candidates-list{display:flex;flex-direction:column;gap:1px;max-height:200px;overflow-y:auto}.scout-candidate-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.3rem .5rem;font-size:.72rem;border-radius:3px;cursor:pointer;transition:background .1s}.scout-candidate-row:hover,.scout-candidate-row.hovered{background:#ffffff0d}.scout-candidate-row.selected{background:#00d2ff14}.scout-candidate-check input{width:14px;height:14px;cursor:pointer}.scout-candidate-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.scout-candidate-time{font-family:monospace;color:var(--text-dim);min-width:80px}.scout-candidate-label{font-weight:600;color:var(--text);min-width:100px}.scout-candidate-conf{color:var(--accent);min-width:35px;text-align:right}.scout-candidate-reason{color:var(--text-dim);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scout-candidate-engines{color:var(--text-dim);opacity:.6;font-size:.65rem;min-width:80px;text-align:right}.scout-candidate-feedback{display:flex;gap:3px;align-items:center;margin-left:4px}.btn-feedback{width:22px;height:22px;border-radius:4px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text);font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all .15s ease}.btn-feedback:hover{transform:scale(1.15)}.btn-feedback-good:hover{background:#22c55e;color:#fff;border-color:#22c55e}.btn-feedback-bad:hover{background:#ef4444;color:#fff;border-color:#ef4444}.feedback-badge{font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:3px}.feedback-good{background:#22c55e33;color:#22c55e}.feedback-bad{background:#ef444433;color:#ef4444}.scout-candidate-notes,.scout-candidate-audit{width:100%;padding:.2rem 0 .1rem 2rem;font-size:.65rem;line-height:1.3}.scout-candidate-notes{color:#f59e0b;border-left:2px solid #f59e0b;margin-top:2px}.scout-candidate-audit{color:#8b5cf6;border-left:2px solid #8b5cf6;margin-top:1px}.scout-notes-label,.scout-audit-label{font-weight:700;margin-right:.3rem}.scout-notes-text{opacity:.9}.scout-audit-score{font-weight:700;color:#22c55e;margin-right:.5rem}.scout-audit-layers{opacity:.75;word-break:break-word}.scout-candidate-split{width:100%;padding:.2rem 0 .1rem 2rem;font-size:.65rem;line-height:1.3;color:#06b6d4;border-left:2px solid #06b6d4;margin-top:1px}.scout-split-label{font-weight:700;margin-right:.3rem}.scout-split-ref{opacity:.9}.hooks-container{width:100%;padding:.4rem .5rem;margin-top:6px;background:#00000040;border-radius:6px;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:4px}.hook-preview{display:flex;align-items:flex-start;gap:.4rem;padding:.35rem .5rem;border-radius:4px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);transition:border-color .2s,background .2s,box-shadow .2s;cursor:default}.hook-preview:hover{background:#ffffff0f}.hook-preview.hook-selected{border-color:#22c55e;background:#22c55e1a;box-shadow:0 0 8px #22c55e26}.hook-label{font-weight:700;font-size:.7rem;color:#94a3b8;white-space:nowrap;min-width:3.5rem}.hook-preview.hook-selected .hook-label{color:#22c55e}.hook-text{flex:1;font-size:.72rem;color:#e2e8f0;line-height:1.35;font-style:italic}.hooks-buttons{display:flex;gap:6px;margin-top:4px;padding-top:4px;border-top:1px solid rgba(255,255,255,.06)}.btn-hook-select{flex:1;font-size:.65rem;font-weight:600;padding:.3rem .4rem;border-radius:4px;background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s;text-align:center}.btn-hook-select:hover{background:#22c55e26;color:#86efac;border-color:#22c55e4d}.btn-hook-select.active{background:#22c55e;color:#fff;border-color:#22c55e;box-shadow:0 0 6px #22c55e4d}.scout-mode-banner{padding:.5rem .8rem;margin-bottom:.5rem;border-radius:6px;font-size:.75rem;font-weight:600;text-align:center;animation:pulse-glow 2s ease-in-out infinite}.scout-mode-banner.mode-theories{background:#8b5cf626;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.scout-mode-banner.mode-hype{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.scout-mode-banner.mode-romance{background:#ec489926;color:#f472b6;border:1px solid rgba(236,72,153,.3)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.7}}.mesclips-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:.8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.mesclips-filter-group{display:flex;flex-direction:column;gap:.3rem}.mesclips-filter-group>label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.mesclips-filter-btns{display:flex;gap:.3rem;flex-wrap:wrap}.mesclips-stats{font-size:.8rem;color:var(--text-dim);margin-bottom:.8rem}.mesclips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.8rem}.mesclip-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .15s;display:flex;flex-direction:column}.mesclip-card:hover{border-color:var(--accent)}.mesclip-thumb{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#1a1a2e}.mesclip-thumb img{width:100%;height:100%;object-fit:cover;display:block}.mesclip-thumb .status-badge{position:absolute;top:6px;right:6px}.mesclip-info{padding:.6rem .8rem;flex:1}.mesclip-time{font-weight:700;font-size:.9rem;margin-bottom:.3rem}.mesclip-actions{display:flex;gap:.4rem;padding:0 .8rem .8rem}.mesclip-actions .btn-primary,.mesclip-actions .btn-secondary{margin-top:0;padding:.4rem .6rem;font-size:.75rem}.status-badge{font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.status-draft{background:#8888a033;color:var(--text-dim)}.status-edited{background:#6c5ce733;color:var(--accent)}.status-exported{background:#00d68f33;color:var(--success)}.exports-list{display:flex;flex-direction:column;gap:.6rem}.export-card{display:flex;gap:1rem;padding:.8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center}.export-thumb{width:120px;height:68px;object-fit:cover;border-radius:6px;flex-shrink:0;background:#1a1a2e}.export-thumb-placeholder{background:linear-gradient(135deg,#1a1a2e,#2d2d44)}.export-card-info{flex:1;min-width:0}.export-card-label{font-weight:700;font-size:.9rem;color:var(--accent)}.export-card-date{font-size:.78rem;color:var(--text-dim);margin-top:.2rem}.export-card-settings{font-size:.75rem;color:var(--text-dim);margin-top:.3rem}.export-card-actions{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.export-card-actions .btn-primary,.export-card-actions .btn-secondary{margin-top:0;padding:.4rem .8rem;font-size:.75rem;width:100px}.tool-action-bar{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.tool-action-bar .btn-secondary{flex:1}.btn-apply{flex:1;padding:.6rem 1rem;background:var(--success);color:#000;border:none;border-radius:6px;font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit;transition:opacity .15s}.btn-apply:hover{opacity:.85}.btn-apply:disabled{opacity:.4;cursor:not-allowed}.settings-stats{display:flex;gap:1rem;flex-wrap:wrap}.settings-stat{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:1rem 1.5rem;text-align:center;min-width:120px}.settings-stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--accent)}.settings-stat-label{display:block;font-size:.75rem;color:var(--text-dim);margin-top:.3rem}.info-success{border-left:3px solid var(--success)}.info-error{border-left:3px solid var(--danger)}.app-layout-v2{min-height:100vh;background:var(--bg)}.content-v2{padding:0;min-height:100vh}.content-v2 .page{padding:2rem 2rem 2rem 3.5rem;max-width:1100px}.hamburger-btn{position:fixed;top:10px;left:10px;z-index:1000;width:36px;height:36px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px}.hamburger-btn span{display:block;width:18px;height:2px;background:var(--text);border-radius:1px;transition:all .2s}.hamburger-btn.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.hamburger-btn.open span:nth-child(2){opacity:0}.hamburger-btn.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:900}.slide-menu{position:fixed;top:0;left:-260px;width:240px;height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:950;transition:left .25s ease;display:flex;flex-direction:column;padding-top:.5rem}.slide-menu.open{left:0}.slide-menu-brand{padding:1.2rem 1rem;font-size:1rem;font-weight:700;letter-spacing:2px;color:var(--accent);border-bottom:1px solid var(--border)}.slide-menu-link{display:block;padding:.7rem 1rem;color:var(--text-dim);text-decoration:none;font-size:.8rem;font-weight:600;font-family:inherit;border:none;background:none;text-align:left;cursor:pointer;width:100%;transition:all .12s}.slide-menu-link:hover{color:var(--text);background:#6c5ce714}.slide-menu-link.active{color:var(--accent);background:#6c5ce71f}.logs-toggle{margin-top:auto;border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem}.logs-live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 1s infinite}.logs-panel{position:fixed;bottom:0;left:0;right:0;height:220px;background:#0c0c14;border-top:2px solid var(--accent);z-index:100;display:flex;flex-direction:column}.logs-panel-header{display:flex;align-items:center;gap:.8rem;padding:.4rem 1rem;font-size:.8rem;font-weight:700;color:var(--accent);background:#6c5ce714;border-bottom:1px solid var(--border);flex-shrink:0}.logs-close{margin-left:auto;background:none;border:none;color:var(--text-dim);font-size:1rem;cursor:pointer;font-family:inherit}.logs-panel-body{flex:1;overflow-y:auto;padding:.3rem 0}.scout-page{display:flex;flex-direction:column;height:100vh}.scout-page-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem .5rem 3.5rem;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;min-height:44px}.scout-header-left{display:flex;align-items:center;gap:.8rem}.scout-style-tag{font-size:.75rem;font-weight:700;letter-spacing:1px;color:var(--accent);background:#6c5ce726;padding:.2rem .7rem;border-radius:4px}.scout-count{font-size:.78rem;color:var(--text-dim)}.scout-progress{font-size:.72rem;color:var(--success);font-weight:600}.scout-header-right{display:flex;align-items:center;gap:.4rem}.scout-empty{flex:1;display:flex;align-items:center;justify-content:center}.scout-body{flex:1;display:flex;min-height:0;overflow:hidden}.scout-player-panel{flex:1;display:flex;flex-direction:column;min-width:0;padding:.8rem;overflow-y:auto}.scout-video-wrapper{position:relative;width:100%;max-width:720px;margin:0 auto;aspect-ratio:16 / 9;background:#0a0a14;border-radius:8px;overflow:hidden;cursor:pointer}.scout-video-wrapper video{width:100%;height:100%;object-fit:contain;display:block}.scout-video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-dim);background:linear-gradient(135deg,#1a1a2e,#2d2d44)}.scout-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;color:#fffc;text-shadow:0 2px 12px rgba(0,0,0,.6);pointer-events:none;transition:opacity .2s}.scout-video-info{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;padding:.5rem .8rem;background:linear-gradient(transparent,#000000d9);font-size:.85rem;font-weight:700;color:#fff;pointer-events:none}.scout-video-info span:last-child{color:var(--accent)}.scout-nav{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.5rem 0;max-width:720px;margin:0 auto;width:100%}.scout-nav-pos{font-size:.8rem;font-weight:600;color:var(--text-dim);min-width:60px;text-align:center}.scout-hooks-panel{max-width:720px;margin:0 auto;width:100%;padding:.5rem 0}.scout-hook-row{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem .6rem;border-radius:4px;margin-bottom:3px;background:#ffffff08;border:1px solid rgba(255,255,255,.05)}.scout-hook-num{font-weight:700;font-size:.75rem;color:var(--accent);min-width:1.2rem;flex-shrink:0}.scout-hook-text{font-size:.78rem;color:#e2e8f0;font-style:italic;line-height:1.4}.scout-no-hooks{font-size:.75rem;color:var(--text-dim);padding:.4rem 0}.scout-vote{display:flex;gap:.6rem;margin-top:.6rem}.scout-vote-btn{flex:1;padding:.7rem 1.5rem;border:2px solid;border-radius:8px;font-family:inherit;font-size:.9rem;font-weight:800;letter-spacing:1px;cursor:pointer;transition:all .15s}.vote-yes{background:#22c55e1a;border-color:#22c55e;color:#22c55e}.vote-yes:hover{background:#22c55e;color:#fff}.vote-no{background:#ef44441a;border-color:#ef4444;color:#ef4444}.vote-no:hover{background:#ef4444;color:#fff}.scout-vote-done{flex:1;text-align:center;padding:.6rem;border-radius:8px;font-size:.85rem;font-weight:700}.scout-vote-done.good{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.scout-vote-done.bad{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.scout-list-panel{width:260px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;background:var(--bg-sidebar);padding:.3rem}.scout-list-panel::-webkit-scrollbar{width:4px}.scout-list-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.scout-list-item{display:flex;align-items:center;gap:.35rem;padding:.4rem;border-radius:5px;cursor:pointer;font-size:.7rem;transition:all .1s;margin-bottom:1px;border:1px solid transparent}.scout-list-item:hover{background:#ffffff0a}.scout-list-item.active{background:#6c5ce726;border-color:var(--accent)}.scout-list-item.selected{background:#00d2ff0f}.scout-list-item.fb-good{border-left:3px solid #22c55e}.scout-list-item.fb-bad{border-left:3px solid #ef4444;opacity:.5}.sli-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.sli-num{color:var(--text-dim);font-weight:600;min-width:22px}.sli-time{font-family:monospace;color:var(--text);font-size:.68rem}.sli-label{color:var(--text-dim);font-size:.62rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sli-conf{color:var(--accent);font-weight:700;font-size:.65rem}.sli-fb{font-weight:800;font-size:.7rem;width:14px;text-align:center}.sli-fb.good{color:#22c55e}.sli-fb.bad{color:#ef4444}.sli-check{width:13px;height:13px;cursor:pointer;flex-shrink:0}.scout-page-footer{display:flex;align-items:center;gap:.6rem;padding:.35rem 1rem .35rem 3.5rem;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0;font-size:.72rem;color:var(--text-dim);min-height:32px}.footer-sep{color:var(--border)}.footer-keys{margin-left:auto;font-size:.65rem;opacity:.5}.mesclips-page{display:flex;flex-direction:column;height:100vh}.mesclips-topbar{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem .5rem 3.5rem;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;min-height:44px}.mesclips-title{font-size:1rem;color:var(--accent);letter-spacing:1px;margin:0}.mesclips-filters-inline{display:flex;gap:.3rem}.mesclips-bulk-actions{display:flex;gap:.3rem;margin-left:auto}.mesclips-main{flex:1;display:flex;min-height:0;overflow:hidden}.mesclips-grid-area{flex:1;overflow-y:auto;padding:.8rem}.mesclips-grid-area.narrow{max-width:50%}.mesclips-grid-area::-webkit-scrollbar{width:6px}.mesclips-grid-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.mesclips-grid-v2{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.6rem}.mesclip-card-v2{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .12s}.mesclip-card-v2:hover{border-color:#6c5ce766}.mesclip-card-v2.editing{border-color:var(--accent);box-shadow:0 0 12px #6c5ce733}.mesclip-card-v2.bulk-selected{border-color:var(--danger);box-shadow:0 0 8px #ff475726}.mesclip-check{position:absolute;top:6px;left:6px;width:16px;height:16px;cursor:pointer;z-index:2;accent-color:var(--accent)}.mesclip-thumb-v2{position:relative;width:100%;aspect-ratio:16 / 9;background:#1a1a2e;cursor:pointer;overflow:hidden}.mesclip-thumb-v2 img{width:100%;height:100%;object-fit:cover;display:block}.mesclip-time-overlay{position:absolute;bottom:4px;left:6px;font-family:monospace;font-size:.72rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8)}.mesclip-score-overlay{position:absolute;bottom:4px;right:6px;font-size:.72rem;font-weight:700;color:var(--accent);text-shadow:0 1px 3px rgba(0,0,0,.8)}.mesclip-hook{padding:.35rem .5rem;font-size:.68rem;color:#e2e8f0;font-style:italic;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;border-bottom:1px solid rgba(255,255,255,.05)}.mesclip-actions-v2{display:flex;gap:.3rem;padding:.3rem .5rem;align-items:center}.btn-edit{flex:2;text-align:center}.btn-del{flex:1;text-align:center;color:var(--danger)!important;border-color:#ff47574d!important}.btn-del:hover{background:#ff475726!important}.mesclips-editor{width:420px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-sidebar);overflow:hidden}.mesclips-editor-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .8rem;font-size:.78rem;font-weight:700;color:var(--accent);border-bottom:1px solid var(--border);flex-shrink:0}.mesclips-editor-preview{flex-shrink:0;padding:.5rem;max-height:40%;display:flex;align-items:center;justify-content:center;overflow:hidden}.mesclips-editor-preview .clip-player-video video{max-height:30vh}.mesclips-editor .studio-tool-panel{flex:1;width:100%;border-left:none}.learning-page{padding:1.5rem;max-width:900px}.learning-title{font-size:1.1rem;color:var(--accent);margin-bottom:.2rem}.learning-subtitle{font-size:.75rem;color:var(--text-dim);margin-bottom:1rem}.learning-form{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}.learning-form-row{margin-bottom:.6rem}.learning-form-row label{display:block;font-size:.65rem;color:var(--text-dim);margin-bottom:2px}.learning-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem}.learning-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.4rem .5rem;font-size:.75rem;font-family:inherit}.learning-input-sm{font-size:.7rem}.learning-btn{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:.5rem 1.2rem;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit}.learning-btn:disabled{opacity:.5;cursor:not-allowed}.learning-btn:hover:not(:disabled){background:var(--accent-hover)}.learning-filter{display:flex;align-items:center;gap:.4rem;margin-bottom:.8rem;font-size:.7rem}.learning-filter-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);padding:2px 8px;font-size:.65rem;cursor:pointer;font-family:inherit}.learning-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.learning-count{margin-left:auto;color:var(--text-dim);font-size:.65rem}.learning-loading,.learning-empty{text-align:center;color:var(--text-dim);padding:2rem;font-size:.8rem}.learning-list{display:flex;flex-direction:column;gap:.5rem}.learning-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.6rem .8rem;cursor:pointer;transition:border-color .2s}.learning-card:hover{border-color:var(--accent)}.learning-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.learning-card-file{font-size:.72rem;font-weight:600;color:var(--text)}.learning-badge{font-size:.55rem;font-weight:700;padding:1px 6px;border-radius:3px;color:#fff}.learning-card-time{font-size:.65rem;color:var(--text-dim);margin-left:auto}.learning-card-del{background:none;border:1px solid var(--danger);color:var(--danger);border-radius:3px;font-size:.6rem;padding:0 4px;cursor:pointer;font-family:inherit}.learning-card-del:hover{background:var(--danger);color:#fff}.learning-card-summary{font-size:.7rem;color:var(--text-dim);line-height:1.4}.learning-card-note{font-size:.65rem;color:#f59e0b;margin-top:.2rem}.learning-card-details{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border);font-size:.68rem;color:var(--text-dim);line-height:1.5}.learning-card-details strong{color:var(--text)}.learning-card-meta{margin-top:.3rem;font-size:.6rem;color:var(--text-dim);opacity:.7}.chat-page{display:flex;flex-direction:column;height:100vh;width:100vw;position:fixed;top:0;left:0;z-index:10;background:var(--bg);gap:0}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}.chat-header h2{font-size:1.1rem;letter-spacing:.1em;color:var(--accent);margin:0}.chat-header-left{display:flex;align-items:center;gap:.75rem}.chat-header-tabs{display:flex;gap:.3rem;margin-left:.5rem}.chat-header-tabs .chat-category-btn{font-size:.78rem;padding:.3rem .8rem;font-weight:700;letter-spacing:.06em}.chat-header-right{display:flex;align-items:center;gap:.5rem}.chat-session-badge{font-size:.72rem;color:var(--text-dim);background:var(--bg-input);padding:.2rem .6rem;border-radius:4px}.chat-video-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.5rem .8rem;border-radius:6px;font-size:.85rem;width:420px;font-family:inherit}.chat-body{flex:1;display:flex;overflow:hidden;gap:0;min-height:0}.chat-messages-wrap{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.chat-templates-view{padding:1.5rem 2rem;overflow-y:auto;flex:1}.tpl-presets-section{margin-bottom:.75rem}.tpl-presets-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.tpl-presets-title{font-size:.78rem;font-weight:700;letter-spacing:.06em;color:var(--accent)}.tpl-presets-list{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.4rem}.tpl-preset-preview{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .7rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;margin-bottom:.4rem}.tpl-preset-preview-text{flex:1;font-size:.78rem;color:var(--text-dim);line-height:1.4;white-space:pre-wrap}.tpl-preset-editor{display:flex;flex-direction:column;gap:.4rem;padding:.6rem .7rem;background:var(--bg-input);border:1px solid var(--accent);border-radius:6px;margin-bottom:.4rem}.tpl-preset-editor-label{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.35rem .6rem;border-radius:4px;font-size:.82rem;font-family:inherit;font-weight:600}.tpl-preset-editor-text{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.35rem .6rem;border-radius:4px;font-size:.78rem;font-family:inherit;resize:vertical;line-height:1.4}.tpl-preset-editor-actions{display:flex;gap:.3rem}.tpl-fill-status{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;margin-top:.75rem;border-radius:8px;background:#6366f11f;border:1px solid rgba(99,102,241,.3)}.tpl-fill-status-spinner{width:14px;height:14px;border:2px solid rgba(99,102,241,.3);border-top-color:var(--accent);border-radius:50%;animation:tpl-spin .8s linear infinite;flex-shrink:0}@keyframes tpl-spin{to{transform:rotate(360deg)}}.tpl-fill-status-text{font-size:.82rem;color:var(--text);font-weight:500}.tpl-fill-error{background:#ef44441f;border-color:#ef44444d}.tpl-fill-error .tpl-fill-status-text{color:#ef4444}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1rem;min-height:0}.chat-empty{text-align:center;margin:auto;color:var(--text-dim);font-size:1rem}.chat-empty .text-dim{font-size:.85rem;margin-top:.5rem;opacity:.6}.chat-bubble{max-width:80%;padding:1rem 1.2rem;border-radius:12px;font-size:.92rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.chat-bubble-user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:2px}.chat-bubble-model{align-self:flex-start;background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:2px}.chat-bubble-label{font-size:.7rem;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.3rem;font-weight:600}.chat-bubble-user .chat-bubble-label{color:#ffffffb3}.chat-bubble-toggle{display:inline-block;margin-left:6px;background:none;border:none;color:var(--accent);cursor:pointer;font-size:.78rem;font-family:inherit;padding:0;text-decoration:underline;opacity:.8}.chat-bubble-toggle:hover{opacity:1}.chat-typing{color:var(--accent);animation:chatPulse 1s infinite}@keyframes chatPulse{0%,to{opacity:1}50%{opacity:.4}}.chat-inline-candidates{margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--border)}.chat-inline-label{font-size:.78rem;color:var(--success);font-weight:600;margin-bottom:.4rem}.chat-inline-card{display:flex;gap:.6rem;align-items:center;padding:.3rem 0;font-size:.82rem}.chat-inline-time{color:var(--accent);font-weight:600;white-space:nowrap}.chat-inline-scene{color:var(--text);font-weight:600}.chat-inline-pov{color:var(--warning);font-style:italic}.chat-candidates-panel{width:320px;border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.chat-candidates-header{padding:.8rem 1rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:600;letter-spacing:.05em;flex-wrap:wrap;gap:.4rem}.chat-candidates-btns{display:flex;gap:.3rem;align-items:center}.chat-min-dur-label{font-size:.7rem;color:var(--text-dim);display:flex;align-items:center;gap:.2rem}.chat-min-dur-input{width:36px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);text-align:center;font-size:.75rem;padding:.15rem}.chat-candidate-dur{margin-left:.4rem;font-size:.7rem;color:var(--text-dim);font-weight:400;background:#ffffff0d;padding:.1rem .35rem;border-radius:4px}.chat-candidate-dur.dur-short{color:#e74c3c;background:#e74c3c1f}.chat-candidate-card.too-short{opacity:.45}.chat-candidate-remove{background:none;border:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:0 .3rem;line-height:1;flex-shrink:0;opacity:.4;transition:opacity .15s,color .15s}.chat-candidate-remove:hover{opacity:1;color:#e74c3c}.chat-cut-progress{margin:8px 0}.chat-cut-progress-bar{height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden}.chat-cut-progress-fill{height:100%;background:var(--accent);transition:width .3s;border-radius:3px}.chat-cut-progress-text{font-size:11px;color:var(--text-dim);margin-top:4px;display:block}.chat-cut-logs{margin-top:6px;max-height:140px;overflow-y:auto;background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-family:SF Mono,Fira Code,monospace;font-size:10px;line-height:1.5}.chat-cut-log-line{color:var(--text-dim);white-space:pre-wrap;word-break:break-all}.chat-cut-log-line.log-warn{color:#e67e22}.chat-cut-log-line.log-ok{color:#2ecc71}.chat-logs-inline{border-top:1px solid var(--border);background:#0003}.chat-logs-inline-header{display:flex;align-items:center;gap:6px;padding:3px 1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.chat-logs-inline-dot{width:6px;height:6px;border-radius:50%;background:#2ecc71;animation:logPulse 2s infinite;flex-shrink:0}@keyframes logPulse{0%,to{opacity:1}50%{opacity:.3}}.chat-logs-inline-header span:nth-child(2){font-size:9px;font-weight:700;letter-spacing:.12em;color:var(--text-dim)}.chat-logs-inline-count{font-size:9px;color:var(--accent);font-weight:600}.chat-logs-inline-clear{margin-left:auto;font-size:9px;background:none;border:none;color:var(--text-dim);cursor:pointer;font-family:inherit;opacity:.5;padding:0}.chat-logs-inline-clear:hover{opacity:1;color:var(--accent)}.chat-logs-inline-chevron{font-size:11px;color:var(--text-dim);margin-left:4px}.chat-logs-inline-body{max-height:130px;overflow-y:auto;padding:2px 1.5rem 6px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:10px;line-height:1.5}.chat-logs-line{color:#666;white-space:pre-wrap;word-break:break-all}.chat-logs-line.log-warn{color:#e67e22}.chat-logs-line.log-error{color:#e74c3c}.chat-logs-inline-empty{color:#444;font-style:italic}.chat-music-selector{display:flex;align-items:center;gap:8px;margin:8px 0}.chat-music-selector label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:600;flex-shrink:0}.chat-music-selector select{flex:1;background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:12px;font-family:inherit}.chat-rendered-card{border:1px solid var(--border);border-radius:8px;padding:.6rem;display:flex;flex-direction:column;gap:.4rem}.chat-rendered-header{display:flex;justify-content:space-between;align-items:center}.chat-rendered-dur{font-size:.7rem;color:var(--text-dim)}.chat-preview-wrap{border-radius:6px;overflow:hidden;background:#000;aspect-ratio:9/16;max-height:220px}.chat-preview-video{width:100%;height:100%;object-fit:contain}.chat-preview-thumb{position:relative;width:100%;height:100%;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-preview-thumb img{width:100%;height:100%;object-fit:cover}.chat-preview-placeholder{width:100%;height:100%;background:var(--bg-input)}.chat-preview-play{position:absolute;background:var(--accent);color:#fff;padding:.3rem .8rem;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.05em}.chat-preview-thumb:hover .chat-preview-play{background:var(--accent-hover)}.chat-candidates-list{flex:1;overflow-y:auto;padding:.6rem;display:flex;flex-direction:column;gap:.5rem}.chat-candidate-card{display:flex;gap:.6rem;padding:.7rem;border-radius:8px;border:1px solid var(--border);cursor:pointer;transition:border-color .15s}.chat-candidate-card:hover{border-color:var(--accent)}.chat-candidate-card.selected{border-color:var(--accent);background:#6c5ce714}.chat-candidate-check{font-size:1rem;color:var(--accent);width:1.4rem;flex-shrink:0;text-align:center}.chat-candidate-info{flex:1;min-width:0}.chat-candidate-time{font-size:.85rem;color:var(--accent);font-weight:600}.chat-candidate-scene{font-size:.82rem;color:var(--text);font-weight:600;margin-top:.2rem;line-height:1.3}.chat-candidate-pov{font-size:.78rem;color:var(--warning);font-style:italic;margin-top:.15rem}.chat-candidate-trigger{font-size:.72rem;color:var(--accent);opacity:.85;margin-top:.1rem}.chat-candidate-reason{font-size:.72rem;color:var(--text-dim);opacity:.7;margin-top:.1rem}.chat-input-bar{display:flex;gap:.8rem;padding:.6rem 1.5rem;border-top:1px solid var(--border);align-items:stretch;flex:0 0 auto;min-height:60px;max-height:120px}.chat-textarea{flex:1;background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.6rem 1rem;border-radius:12px;font-size:.9rem;font-family:inherit;resize:none;min-height:44px;max-height:100px;line-height:1.5;overflow-y:auto}.chat-send-btn{align-self:flex-end;min-height:3rem;padding-left:1.5rem;padding-right:1.5rem;font-size:.9rem}.chat-bubble-system{align-self:center;background:transparent;border:1px dashed var(--border);color:var(--text-dim);font-size:.82rem;max-width:70%;text-align:center}.chat-bubble-system .chat-bubble-label{color:var(--warning)}.chat-video-yt{border-color:red!important}.chat-video-ready{background:var(--success)!important;color:#000!important;font-weight:700}.chat-empty-flow{display:flex;gap:.4rem;align-items:center;margin-top:1rem;font-size:.65rem;color:var(--text-dim);flex-wrap:wrap;justify-content:center}.chat-empty-flow span:nth-child(2n){color:var(--accent)}.chat-presets{display:flex;gap:.5rem;padding:.5rem 1.5rem .8rem;align-items:center;flex-wrap:wrap;border-top:1px solid var(--border)}.chat-presets-label{font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;font-weight:600;margin-right:.3rem}.chat-preset-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);padding:.35rem .8rem;border-radius:14px;font-size:.78rem;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.chat-preset-btn:hover{border-color:var(--accent);color:var(--text)}.chat-preset-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent)}.chat-preset-wrap{display:flex;align-items:center;gap:2px}.chat-preset-edit-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--warning);padding:.3rem .5rem;font-size:.68rem;font-family:inherit;cursor:pointer;border-radius:8px;font-weight:600;letter-spacing:.03em;transition:all .15s}.chat-preset-edit-btn:hover{border-color:var(--warning);background:#ffa5021a}.chat-preset-del-btn{background:none;border:1px solid transparent;color:var(--text-dim);padding:.2rem .4rem;font-size:.82rem;cursor:pointer;border-radius:6px;line-height:1;transition:all .15s;opacity:.4}.chat-preset-del-btn:hover{color:var(--danger, #ef4444);border-color:var(--danger, #ef4444);opacity:1;background:#ef44441a}.chat-preset-add{border-style:dashed;border-color:var(--accent);color:var(--accent);font-weight:700}.chat-preset-reset{color:var(--text-dim);border-color:var(--border);margin-left:auto}.chat-preset-reset:hover{color:var(--danger);border-color:var(--danger)}.chat-preset-editor{border-top:1px solid var(--accent);background:var(--bg-card);padding:.8rem 1rem;display:flex;flex-direction:column;gap:.5rem}.chat-preset-editor-header{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;font-weight:600;letter-spacing:.05em;color:var(--accent)}.chat-preset-editor-actions{display:flex;gap:.4rem}.chat-preset-editor-label{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.4rem .6rem;border-radius:6px;font-size:.85rem;font-family:inherit;font-weight:600}.chat-preset-editor-text{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.6rem .8rem;border-radius:6px;font-size:.82rem;font-family:inherit;resize:vertical;min-height:100px;line-height:1.5}.chat-preset-editor-category{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.4rem .6rem;border-radius:6px;font-size:.82rem;font-family:inherit}.chat-preset-editor-folder{display:flex;gap:.4rem;align-items:center}.chat-preset-editor-folder input{flex:1;background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.35rem .6rem;border-radius:6px;font-size:.78rem;font-family:inherit}.chat-preset-editor-folder input::placeholder{color:var(--text-dim);font-size:.75rem}.chat-presets-categories{display:flex;gap:.3rem;padding:.4rem 1.5rem 0;align-items:center;flex-wrap:wrap}.chat-category-btn{background:none;border:1px solid transparent;color:var(--text-dim);padding:.25rem .6rem;border-radius:12px;font-size:.72rem;font-family:inherit;cursor:pointer;transition:all .15s;letter-spacing:.03em;font-weight:500}.chat-category-btn:hover{color:var(--text);border-color:var(--border)}.chat-category-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);font-weight:700}.chat-preset-autopilot-btn{background:var(--accent);border:1px solid var(--accent);color:#fff;padding:.28rem .55rem;font-size:.65rem;font-family:inherit;cursor:pointer;border-radius:8px;font-weight:800;letter-spacing:.06em;transition:all .15s;text-transform:uppercase}.chat-preset-autopilot-btn:hover{background:var(--accent-hover, #5b4cdb);box-shadow:0 0 8px var(--accent-glow)}.chat-preset-autopilot-btn:disabled{opacity:.4;cursor:not-allowed}.chat-preset-wrap-outer{display:contents}.chat-modules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;width:100%;padding:.4rem 0 .2rem;align-items:start}.chat-module-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:.6rem .5rem;cursor:pointer;transition:all .15s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.2rem}.chat-module-card:hover{border-color:var(--text-dim)}.chat-module-card.selected{border-color:var(--accent);background:var(--accent-glow);box-shadow:0 0 12px var(--accent-glow)}.chat-module-emoji{font-size:1.4rem;line-height:1}.chat-module-label{font-size:.7rem;font-weight:700;color:var(--text);letter-spacing:.04em;white-space:nowrap}.chat-module-desc{font-size:.62rem;color:var(--text-dim);line-height:1.3}.chat-module-send-btn{grid-column:1 / -1;justify-self:center;margin-top:.2rem}.chat-autopilot-phases{display:flex;align-items:center;gap:.8rem;padding:.5rem 1.5rem .4rem;flex-wrap:wrap;border-top:1px solid var(--border);background:var(--bg-card)}.chat-phase-step{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--text-dim);transition:all .2s}.chat-phase-step.active{color:var(--accent);font-weight:700}.chat-phase-step.done{color:var(--success)}.chat-phase-icon{font-size:.7rem}.chat-phase-label{font-size:.72rem;letter-spacing:.03em}.chat-phase-step.active .chat-phase-icon{animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.chat-autopilot-msg{font-size:.72rem;color:var(--text-dim);margin-left:auto;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-source-bar{display:flex;align-items:center;gap:.6rem;padding:.5rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-card)}.chat-drop-zone{flex:0 0 auto;min-width:160px;max-width:240px;border:2px dashed var(--border);border-radius:8px;padding:.4rem .8rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;min-height:38px}.chat-drop-zone:hover{border-color:var(--accent)}.chat-drop-active{border-color:var(--accent)!important;background:#6c5ce714}.chat-drop-has-file{border-style:solid;border-color:var(--success);cursor:default}.chat-drop-label{font-size:.78rem;color:var(--text-dim);white-space:nowrap}.chat-drop-file{display:flex;align-items:center;gap:.4rem}.chat-drop-filename{font-size:.78rem;color:var(--text);font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-drop-size{font-size:.68rem;color:var(--text-dim)}.chat-drop-clear{background:none;border:none;color:var(--danger);font-size:.85rem;cursor:pointer;padding:0 .3rem;font-weight:700}.chat-source-or{font-size:.72rem;color:var(--text-dim);opacity:.5}.chat-yt-row{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.chat-yt-row .chat-video-input{flex:1;min-width:0;width:auto;font-size:.8rem;padding:.4rem .6rem}.chat-dl-btn{white-space:nowrap}.chat-scout-btn{flex-shrink:0}.chat-style-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:.35rem .5rem;border-radius:6px;font-size:.78rem;font-family:inherit;cursor:pointer}.chat-style-select:hover{border-color:var(--accent)}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover{opacity:.85}.music-library-page{display:flex;flex-direction:column;height:100vh;padding:0}.music-topbar{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0}.music-topbar h2{font-size:1.1rem;letter-spacing:2px;color:var(--accent);margin:0}.music-count{font-size:.8rem;color:var(--text-dim);background:#6c5ce71f;padding:2px 10px;border-radius:10px}.music-drop-zone{flex:1;overflow-y:auto;padding:1rem;transition:background .2s}.music-drop-zone.active{background:#00ff880a}.music-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;opacity:.4;gap:.5rem}.music-empty-icon{font-size:3rem}.music-empty-sub{font-size:.75rem}.music-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.6rem}.music-card{display:flex;align-items:center;gap:.8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.7rem 1rem;transition:all .15s}.music-card:hover{border-color:var(--accent)}.music-card.playing{border-color:var(--success);background:#00d68f0f}.music-card-play{width:36px;height:36px;border-radius:50%;background:#6c5ce726;border:1px solid rgba(108,92,231,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;color:var(--accent);flex-shrink:0;transition:all .15s}.music-card-play:hover{background:#6c5ce740}.music-card.playing .music-card-play{background:#00d68f33;border-color:var(--success);color:var(--success)}.music-card-info{flex:1;min-width:0}.music-card-name{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-card-meta{display:flex;gap:.8rem;font-size:.75rem;color:var(--text-dim);margin-top:2px}.music-card-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.2rem;padding:0 4px;opacity:0;transition:all .15s}.music-card:hover .music-card-delete{opacity:1}.music-card-delete:hover{color:var(--danger)}.music-uploading{text-align:center;padding:1rem;font-size:.85rem;color:var(--text-dim)}.beat-sync-panel{background:linear-gradient(135deg,#6c5ce71f,#00d68f14);border:1px solid rgba(108,92,231,.3);border-radius:8px;padding:.8rem;margin-bottom:.8rem}.beat-sync-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.beat-sync-title{font-size:.85rem;font-weight:700;letter-spacing:.05em;background:linear-gradient(90deg,var(--accent),var(--success));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.beat-sync-info{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.6rem}.beat-sync-stat{display:flex;flex-direction:column;gap:1px;background:#0003;border-radius:4px;padding:.3rem .5rem}.beat-sync-label{font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.beat-sync-value{font-size:.85rem;font-weight:600;color:var(--text)}.beat-sync-music{margin-bottom:.6rem}.beat-sync-select{width:100%;padding:.4rem .5rem;margin-top:.3rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.8rem}.beat-sync-no-music{font-size:.75rem;color:var(--text-dim);padding:.3rem 0}.beat-sync-render-btn{width:100%;padding:.5rem;font-weight:700;letter-spacing:.05em}.beat-sync-result{display:flex;flex-direction:column;gap:.4rem}.beat-sync-preview{width:100%;max-height:300px;border-radius:6px;background:#000;object-fit:contain}.beat-sync-result-info{font-size:.75rem;color:var(--text-dim);text-align:center}.beat-sync-precis-badge,.pipeline-precis-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.04em;background:linear-gradient(135deg,var(--accent),var(--success));color:#fff}.beat-sync-trigger-btn{font-weight:700;letter-spacing:.08em;padding:.35rem 1rem;background:linear-gradient(135deg,var(--accent),var(--success));border:none;border-radius:6px;color:#fff;cursor:pointer;white-space:nowrap;flex-shrink:0}.beat-sync-trigger-btn:disabled{opacity:.5;cursor:not-allowed}.tl2-page{display:flex;flex-direction:column;height:100vh;background:#08080e;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.tl2-topbar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#0f0f18;border-bottom:2px solid #1a1a2e;flex-shrink:0}.tl2-name-input{background:#14141f;border:2px solid #2a2a40;border-radius:8px;color:#fff;font-size:1.1rem;font-weight:700;padding:8px 14px;width:260px}.tl2-name-input:focus{border-color:#7c3aed;outline:none}.tl2-loading-badge{background:#7c3aed22;border:1px solid #7c3aed;color:#a78bfa;padding:6px 14px;border-radius:6px;font-size:.8rem;font-weight:700;animation:tl2-pulse 1.5s ease-in-out infinite}@keyframes tl2-pulse{0%,to{opacity:1}50%{opacity:.3}}.tl2-topbar-btns{display:flex;gap:8px;margin-left:auto;flex-shrink:1;overflow-x:auto;overflow-y:hidden}.tl2-btn{padding:8px 20px;border-radius:8px;border:2px solid #333;background:#14141f;color:#ccc;font-size:.85rem;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:all .15s;white-space:nowrap}.tl2-btn:hover{background:#1e1e30;border-color:#555;color:#fff}.tl2-btn:disabled{opacity:.35;cursor:not-allowed}.tl2-btn-outline{border-color:#444}.tl2-btn-render{background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#7c3aed;color:#fff;font-size:.95rem;padding:10px 28px}.tl2-btn-render:hover{background:linear-gradient(135deg,#6d28d9,#5b21b6)}.tl2-btn-sm{padding:5px 12px;font-size:.75rem;border-radius:6px;border:1px solid #444;background:#14141f;color:#ccc;cursor:pointer}.tl2-btn-danger{border-color:#ef4444;color:#ef4444}.tl2-btn-play{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding:0;background:#7c3aed;border-color:#7c3aed;color:#fff}.tl2-btn-play:hover{background:#6d28d9}.tl2-btn-metronome{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;padding:0;background:transparent;border:1px solid #444;color:#888;cursor:pointer;transition:all .15s}.tl2-btn-metronome:hover{border-color:#7c3aed;color:#fff}.tl2-btn-metronome.active{background:#7c3aed33;border-color:#7c3aed;color:#fff}.tl2-transport-bpm{display:flex;align-items:center;gap:6px}.tl2-bpm-transport-input{width:52px;height:28px;background:#1a1a2e;border:1px solid #333;border-radius:4px;color:#fff;font-size:.8rem;font-family:monospace;text-align:center;padding:0 4px}.tl2-bpm-transport-input:focus{border-color:#7c3aed;outline:none}.tl2-bpm-transport-input::placeholder{color:#555}.tl2-bpm-transport-label{font-size:.65rem;color:#888;font-weight:600;letter-spacing:.5px}.tl2-body{display:flex;flex:1;overflow:hidden}.tl2-left-panel{width:280px;flex-shrink:0;background:#0c0c14;border-right:2px solid #1a1a2e;display:flex;flex-direction:column}.tl2-tab-bar{display:flex;border-bottom:2px solid #1a1a2e;flex-shrink:0}.tl2-tab{flex:1;padding:12px;text-align:center;font-size:.85rem;font-weight:800;letter-spacing:.1em;color:#555;background:transparent;border:none;cursor:pointer;transition:all .15s;border-bottom:3px solid transparent}.tl2-tab:hover{color:#888}.tl2-tab.active{color:#a78bfa;border-bottom-color:#7c3aed;background:#0f0f1a}.tl2-panel-scroll{flex:1;overflow-y:auto;padding:4px 0}.tl2-section{padding:12px 14px;border-bottom:1px solid #151520}.tl2-section-title{font-size:.7rem;font-weight:800;letter-spacing:.12em;color:#555;margin-bottom:10px;text-transform:uppercase}.tl2-media-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .12s}.tl2-media-item:hover{background:#16162a}.tl2-media-item.active{background:#2d1b69}.tl2-media-icon{font-size:1.3rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#1a1a2e;border-radius:6px;flex-shrink:0}.tl2-media-info{flex:1;min-width:0}.tl2-media-name{font-size:.82rem;font-weight:600;color:#ddd;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl2-media-meta{font-size:.7rem;color:#666;margin-top:2px}.tl2-video-item{gap:8px}.tl2-empty{color:#444;font-size:.75rem;padding:8px;font-style:italic}.tl2-btn-ai{padding:6px 12px;font-size:.75rem;font-weight:800;letter-spacing:.06em;border-radius:6px;border:2px solid #7c3aed;background:linear-gradient(135deg,#7c3aed33,#6d28d922);color:#a78bfa;cursor:pointer;flex-shrink:0;transition:all .15s}.tl2-btn-ai:hover{background:linear-gradient(135deg,#7c3aed55,#6d28d944);transform:scale(1.05)}.tl2-btn-ai:disabled{opacity:.4;cursor:wait;transform:none}.tl2-slider-label{display:block;font-size:.78rem;color:#888;margin:4px 0}.tl2-slider{width:100%;margin-top:4px;accent-color:#7c3aed}.tl2-slider-orig{accent-color:#3b82f6}.tl2-slider-music{accent-color:#a855f7}.tl2-vol-label{display:flex;justify-content:space-between;align-items:center}.tl2-vol-label strong{color:#ddd}.tl2-info-row{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:#888;margin-top:6px}.tl2-bpm{background:#7c3aed33;color:#a78bfa;padding:3px 10px;border-radius:12px;font-weight:700;font-size:.75rem}.tl2-bpm-row{display:flex;align-items:center;gap:8px;margin-top:6px}.tl2-bpm-label{font-size:.72rem;font-weight:800;color:#a78bfa;letter-spacing:.08em}.tl2-bpm-input{width:72px;padding:5px 8px;border-radius:6px;border:1px solid #7c3aed55;background:#14141f;color:#a78bfa;font-size:.85rem;font-weight:700;font-family:monospace;text-align:center;outline:none;-moz-appearance:textfield}.tl2-bpm-input::-webkit-inner-spin-button,.tl2-bpm-input::-webkit-outer-spin-button{opacity:1}.tl2-bpm-input:focus{border-color:#a78bfa;box-shadow:0 0 8px #7c3aed44}.tl2-effects-hint{padding:30px 20px;text-align:center;color:#444;font-size:.85rem;line-height:1.6}.tl2-selected-seg-info{padding:14px;border-bottom:1px solid #1a1a2e}.tl2-seg-name{font-size:.85rem;font-weight:600;color:#ccc;margin:6px 0}.tl2-seg-effect-current{font-size:.78rem;color:#888;margin-bottom:8px}.tl2-seg-effect-current strong{color:#a78bfa}.tl2-btn-remove-fx{border-color:#ef4444;color:#ef4444;font-size:.7rem;padding:4px 10px}.tl2-fx-stack{padding:8px 14px;border-bottom:1px solid #222}.tl2-fx-stack-empty{padding:10px 14px;border-bottom:1px solid #222}.tl2-fx-stack-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.tl2-fx-stack-list{display:flex;flex-direction:column;gap:3px}.tl2-fx-stack-item{display:flex;align-items:center;gap:5px;padding:5px 6px;background:#14141f;border-radius:5px;border-left:3px solid #666;font-size:.72rem}.tl2-fx-stack-idx{color:#555;font-weight:800;font-size:.65rem;min-width:14px;text-align:center}.tl2-fx-stack-name{font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl2-fx-stack-timing{color:#555;font-size:.6rem;font-family:monospace;white-space:nowrap}.tl2-fx-stack-move{background:none;border:none;color:#555;cursor:pointer;font-size:.6rem;padding:1px 3px;line-height:1}.tl2-fx-stack-move:hover:not(:disabled){color:#fff}.tl2-fx-stack-move:disabled{opacity:.2;cursor:default}.tl2-fx-stack-del{background:none;border:none;color:#ef4444;cursor:pointer;font-size:.7rem;padding:1px 4px;opacity:.6}.tl2-fx-stack-del:hover{opacity:1}.tl2-fx-render-bar{display:flex;align-items:center;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid #1a1a2e}.tl2-fx-auto-toggle{display:flex;align-items:center;gap:4px;font-size:.65rem;font-weight:600;color:#888;cursor:pointer;flex:1}.tl2-fx-auto-toggle input{accent-color:#3b82f6;width:13px;height:13px}.tl2-fx-render-spinner{font-size:.6rem;font-weight:700;color:#3b82f6;animation:tl2-pulse 1s infinite}@keyframes tl2-pulse{0%,to{opacity:1}50%{opacity:.4}}.tl2-solo-render-btn{background:#1a1a2e!important;border-color:#3b82f6!important;color:#3b82f6!important;font-weight:700!important;font-size:.65rem!important;padding:3px 8px!important}.tl2-solo-render-btn:hover{background:#3b82f622!important}.tl2-solo-render-btn:disabled{opacity:.5;cursor:wait}.tl2-fx-debug-panel{margin-top:6px;padding:6px;background:#0a0a14;border-radius:5px;border:1px solid #222}.tl2-fx-debug-status{font-size:.72rem;font-weight:800;margin-bottom:4px}.tl2-fx-debug-section{margin-top:4px}.tl2-fx-debug-title{font-size:.6rem;font-weight:700;color:#555;margin-bottom:2px}.tl2-fx-debug-code{display:block;font-size:.58rem;color:#888;background:#111;padding:4px 6px;border-radius:3px;word-break:break-all;white-space:pre-wrap;max-height:80px;overflow-y:auto;font-family:SF Mono,Fira Code,monospace}.tl2-fx-debug-stderr{color:#f59e0b}.tl2-fx-category{padding:10px 14px;border-bottom:1px solid #111}.tl2-fx-cat-title{font-size:.75rem;font-weight:800;letter-spacing:.08em;color:#888;margin-bottom:8px;padding-left:8px;border-left:3px solid #444;display:flex;align-items:center;gap:6px}.tl2-fx-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.tl2-fx-btn{padding:7px 6px;font-size:.72rem;font-weight:600;border-radius:5px;border:2px solid transparent;background:#14141f;color:#999;cursor:pointer;transition:all .12s;text-align:center}.tl2-fx-btn:hover{background:#1e1e30;color:#ddd;border-color:#333}.tl2-fx-btn.active{color:#fff;font-weight:700}.tl2-fx-grid--thumbs{grid-template-columns:repeat(3,1fr);gap:6px}.tl2-fx-thumb-btn{display:flex;flex-direction:column;padding:3px;border-radius:6px;border:2px solid transparent;background:#14141f;cursor:pointer;overflow:hidden;transition:all .12s;align-items:stretch}.tl2-fx-thumb-btn:hover{border-color:#444;transform:scale(1.03)}.tl2-fx-thumb-btn.active{border-width:2px}.tl2-fx-thumb-img{width:100%;aspect-ratio:9/16;object-fit:cover;border-radius:4px;pointer-events:none;background:#0a0a14}.tl2-fx-thumb-placeholder{width:100%;aspect-ratio:9/16;background:#1a1a2e;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.tl2-fx-thumb-label{font-size:.6rem;font-weight:600;color:#888;margin-top:3px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl2-gs-btn span{margin-right:3px}.tl2-gs-btn.missing{border-style:dashed!important}.tl2-gs-missing{color:#f59e0b;margin-left:4px;font-size:.65rem;font-weight:800}.tl2-gs-hint{padding:6px 10px;font-size:.65rem;color:#555;line-height:1.4}.tl2-gs-hint code{background:#1a1a2e;padding:2px 5px;border-radius:3px;color:#22c55e;font-size:.62rem}.tl2-seg-gs-badge{background:#22c55e!important;font-size:.55rem!important}.tl2-tr-btn span{margin-right:3px}.tl2-tr-btn.missing{border-style:dashed!important}.tl2-tr-dur{font-size:.58rem;color:#666;margin-left:4px}.tl2-seg-tr-badge{background:#a855f7!important;font-size:.55rem!important}.tl2-af-btn span{margin-right:3px}.tl2-seg-af-badge{background:#06b6d4!important;font-size:.55rem!important}.tl2-timeline-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.tl2-preview-row{display:flex;flex:1;min-height:0;border-bottom:2px solid #1a1a2e}.tl2-preview{flex:1;background:#000;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.tl2-preview-video{height:100%;max-width:100%;object-fit:contain;display:block}.tl2-overlay-video{display:block}.tl2-fx-debug-badge{position:absolute;top:6px;left:6px;display:flex;flex-wrap:wrap;gap:3px;z-index:10;pointer-events:none}.tl2-fx-debug-tag{background:#ef4444d9;color:#fff;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:3px;white-space:nowrap}.tl2-preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#444;font-size:.75rem;font-weight:600;letter-spacing:.05em;background:#000}.tl2-preview-info{position:absolute;bottom:4px;left:8px;font-size:.6rem;color:#ffffff80;background:#0009;padding:2px 6px;border-radius:3px;pointer-events:none}.tl2-canvas{flex:1;overflow-x:auto;overflow-y:auto;position:relative;background:#0a0a12}.tl2-tracks-wrap{position:relative;min-height:100%}.tl2-ruler{height:32px;position:relative;background:#0e0e18;border-bottom:2px solid #1a1a2e;cursor:crosshair}.tl2-ruler-tick{position:absolute;top:0;height:100%;border-left:1px solid #252535}.tl2-ruler-tick span{position:absolute;top:6px;left:5px;font-size:.68rem;color:#555;font-weight:600;white-space:nowrap;font-family:monospace}.tl2-ruler-tick.bar{border-left:2px solid #3b3b55}.tl2-ruler-tick.bar span{color:#a78bfa;font-weight:700}.tl2-beat-grid{position:absolute;pointer-events:none}.tl2-grid-line{position:absolute;top:0;height:100%;width:1px;background:#7c3aed1f}.tl2-grid-line.bar{width:2px;background:#7c3aed59}.tl2-track{position:relative;border-bottom:1px solid #151520}.tl2-track-body{position:relative;overflow:visible;height:100%}.tl2-track-icon{font-size:1.1rem}.tl2-track-sidebar{position:sticky;left:0;z-index:20;width:80px;flex-shrink:0;background:#0c0c16;border-right:2px solid #1a1a2e}.tl2-sidebar-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-bottom:1px solid #151520;position:relative}.tl2-sidebar-label span:last-child{font-size:.6rem;font-weight:800;letter-spacing:.1em;color:#555}.tl2-sidebar-del{position:absolute;top:2px;right:2px;background:none;border:none;color:#ef4444;font-size:.55rem;font-weight:700;cursor:pointer;opacity:0;padding:1px 4px;border-radius:3px;transition:opacity .15s}.tl2-sidebar-label:hover .tl2-sidebar-del{opacity:.6}.tl2-sidebar-del:hover{opacity:1!important;background:#ef444433}.tl2-track-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.78rem;color:#333;font-style:italic;white-space:nowrap}.tl2-track-audio{height:90px}.tl2-track-audio .tl2-track-body{background:#0c0c1a}.tl2-music-block{position:absolute;top:4px;bottom:4px;background:#7c3aed1f;border:2px solid rgba(124,58,237,.5);border-radius:6px;cursor:grab;overflow:hidden}.tl2-music-block:active{cursor:grabbing;border-color:#a78bfa}.tl2-music-block.selected{border-color:#fff;background:#7c3aed38}.tl2-waveform-canvas{width:100%;height:100%;display:block}.tl2-music-label{position:absolute;top:4px;left:8px;font-size:.65rem;font-weight:700;color:#a78bfa88;text-transform:uppercase;letter-spacing:.08em}.tl2-ab-handle{position:absolute;top:0;width:8px;height:100%;background:#7c3aed66;cursor:col-resize;z-index:2;transition:background .1s}.tl2-ab-handle.left{left:0;border-radius:6px 0 0 6px}.tl2-ab-handle.right{right:0;border-radius:0 6px 6px 0}.tl2-ab-handle:hover{background:#a78bfab3}.tl2-music-block .tl2-seg-del{opacity:0}.tl2-music-block:hover .tl2-seg-del,.tl2-music-block.selected .tl2-seg-del{opacity:1}.tl2-fade-overlay{position:absolute;top:0;height:100%;pointer-events:none;z-index:1}.tl2-fade-in{left:0;background:linear-gradient(to right,rgba(0,0,0,.7) 0%,transparent 100%);border-radius:6px 0 0 6px}.tl2-fade-out{right:0;background:linear-gradient(to left,rgba(0,0,0,.7) 0%,transparent 100%);border-radius:0 6px 6px 0}.tl2-fade-handle{position:absolute;top:0;width:6px;height:100%;cursor:col-resize;z-index:3;background:#ffffff26;transition:background .1s,opacity .15s}.tl2-fade-handle:hover{background:#ffffff80}.tl2-fade-handle-in{border-right:2px solid rgba(255,255,255,.4)}.tl2-fade-handle-out{border-left:2px solid rgba(255,255,255,.4)}.tl2-fade-handle-idle{opacity:0;width:10px}.tl2-music-block:hover .tl2-fade-handle-idle{opacity:.5}.tl2-fade-handle-idle:hover{opacity:1!important}.tl2-ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999}.tl2-ctx-menu{position:fixed;min-width:180px;background:#1a1a2e;border:1px solid #333;border-radius:8px;box-shadow:0 8px 32px #0009;padding:4px 0;z-index:10000}.tl2-ctx-title{padding:6px 12px;font-size:.7rem;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #222}.tl2-ctx-item{display:block;width:100%;padding:7px 14px;font-size:.8rem;color:#ddd;background:none;border:none;text-align:left;cursor:pointer;transition:background .1s}.tl2-ctx-item:hover{background:#7c3aed4d;color:#fff}.tl2-ctx-sep{height:1px;background:#333;margin:4px 0}.tl2-upload-placeholder{position:relative;height:60px;margin:6px 12px;border:2px dashed rgba(255,255,255,.25);border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;animation:tl2-upload-pulse 1.5s ease-in-out infinite}.tl2-upload-progress-bar{position:absolute;left:0;top:0;height:100%;opacity:.2;transition:width .3s}.tl2-upload-label{position:relative;z-index:1;font-size:.72rem;font-weight:700;color:#fff;letter-spacing:.03em}@keyframes tl2-upload-pulse{0%,to{opacity:.7}50%{opacity:1}}.tl2-upload-toast{position:fixed;bottom:60px;right:16px;z-index:9000;display:flex;flex-direction:column;gap:6px}.tl2-upload-toast-item{display:flex;align-items:center;gap:8px;background:#1a1a2e;border:1px solid #333;border-radius:8px;padding:8px 14px;font-size:.78rem;color:#ddd;box-shadow:0 4px 16px #00000080}.tl2-upload-toast-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:#a855f7;border-radius:50%;animation:tl2-spin .8s linear infinite;flex-shrink:0}@keyframes tl2-spin{to{transform:rotate(360deg)}}.tl2-track-beats{height:36px;cursor:crosshair}.tl2-track-beats .tl2-track-body{background:#0b0b14}.tl2-beat{position:absolute;top:0;width:1px;height:100%;background:#7c3aed40;pointer-events:none}.tl2-beat.manual{background:#22c55e;width:2px}.tl2-beat.downbeat{background:#7c3aed8c;width:2px}.tl2-beat.selected{background:#f59e0b;width:3px;box-shadow:0 0 6px #f59e0bb3;z-index:2}.tl2-beat-select-rect{position:absolute;top:0;height:100%;background:#f59e0b26;border:1px solid rgba(245,158,11,.5);border-radius:2px;pointer-events:none;z-index:3}.tl2-track-video{height:80px}.tl2-track-video .tl2-track-body{background:#0b0b14}.tl2-segment{position:absolute;top:4px;bottom:4px;border-radius:6px;cursor:grab;display:flex;align-items:center;overflow:hidden;min-width:24px;-webkit-user-select:none;user-select:none;border:2px solid #3b82f6;transition:border-color .12s}.tl2-segment:active{cursor:grabbing}.tl2-segment.selected{border-color:#fff!important;box-shadow:0 0 12px #ffffff26}.tl2-seg-content{flex:1;padding:0 18px;overflow:hidden;text-align:center}.tl2-seg-title{font-size:.75rem;font-weight:700;color:#ddd;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl2-seg-meta{font-size:.65rem;color:#888;margin-top:2px;display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}.tl2-seg-fx-badge{display:inline-block;padding:1px 6px;border-radius:3px;color:#fff;font-size:.58rem;font-weight:700}.tl2-seg-handle{position:absolute;top:0;width:8px;height:100%;background:#3b82f666;cursor:col-resize;z-index:2;transition:background .1s}.tl2-seg-handle.left{left:0;border-radius:6px 0 0 6px}.tl2-seg-handle.right{right:0;border-radius:0 6px 6px 0}.tl2-seg-handle:hover{background:#60a5fab3}.tl2-seg-del{position:absolute;top:3px;right:10px;background:none;border:none;color:#ef4444;font-size:.8rem;font-weight:700;cursor:pointer;z-index:3;opacity:0;transition:opacity .15s}.tl2-segment:hover .tl2-seg-del{opacity:1}.tl2-seg-reroll{position:absolute;top:3px;right:28px;background:none;border:none;font-size:.7rem;cursor:pointer;z-index:3;opacity:0;transition:opacity .15s;padding:0;line-height:1}.tl2-segment:hover .tl2-seg-reroll{opacity:1}.tl2-seg-reroll.spinning{opacity:1;animation:tl2-reroll-spin 1s linear infinite}@keyframes tl2-reroll-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tl2-seg-feedback{position:absolute;top:3px;background:none;border:none;font-size:.65rem;cursor:pointer;z-index:3;opacity:0;transition:opacity .15s,transform .1s;padding:0;line-height:1}.tl2-seg-fb-good{right:62px}.tl2-seg-fb-bad{right:46px}.tl2-segment:hover .tl2-seg-feedback{opacity:.7}.tl2-seg-feedback:hover{opacity:1!important;transform:scale(1.3)}.tl2-seg-feedback.active{opacity:1!important;transform:scale(1.2)}.tl2-seg-fb-good.active{filter:drop-shadow(0 0 4px #22c55e)}.tl2-seg-fb-bad.active{filter:drop-shadow(0 0 4px #ef4444)}.tl2-segment.fx-drop-target{border-color:#10b981!important;box-shadow:0 0 12px #10b98180,inset 0 0 8px #10b98126;z-index:5}.tl2-segment.video-drop-target{border-color:#7c3aed!important;box-shadow:0 0 14px #7c3aed99,inset 0 0 10px #7c3aed33;z-index:5}.tl2-track-fx{height:28px;position:relative}.tl2-track-fx .tl2-track-body{background:#0b0b12}.tl2-track-fx .tl2-track-label{position:absolute;left:-36px;top:0;bottom:0;width:34px;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:800;color:#555;letter-spacing:.06em;z-index:2}.tl2-fx-block{position:absolute;top:3px;bottom:3px;border-radius:4px;border:1px solid;font-size:.58rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;cursor:grab;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0;-webkit-user-select:none;user-select:none;min-width:8px}.tl2-fx-block:active{cursor:grabbing}.tl2-fx-block-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;padding:0 2px;pointer-events:none}.tl2-fx-handle{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize;z-index:2;transition:background .15s}.tl2-fx-handle:hover{background:#ffffff40}.tl2-fx-handle.left{left:0;border-radius:4px 0 0 4px}.tl2-fx-handle.right{right:0;border-radius:0 4px 4px 0}.tl2-fx-remove{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:#ef4444b3;border:none;color:#fff;font-size:8px;width:14px;height:14px;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0;line-height:1;z-index:3}.tl2-fx-block:hover .tl2-fx-remove{display:flex}.tl2-playhead{position:absolute;top:0;bottom:0;width:2px;background:#ef4444;z-index:10;pointer-events:none}.tl2-playhead:before{content:"";position:absolute;top:0;left:-6px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:10px solid #ef4444}.tl2-playhead-grab{position:absolute;top:-2px;left:-10px;width:22px;height:18px;cursor:grab;pointer-events:all;z-index:11}.tl2-playhead-grab:active{cursor:grabbing}.tl2-transport{display:flex;align-items:center;gap:16px;padding:10px 20px;background:#0f0f18;border-top:2px solid #1a1a2e;flex-shrink:0}.tl2-time-display{font-family:SF Mono,Fira Code,monospace;font-size:1rem;color:#aaa;font-weight:600;min-width:160px;letter-spacing:.05em}.tl2-transport-right{display:flex;align-items:center;gap:8px;margin-left:auto}.tl2-zoom-label{font-size:.75rem;font-weight:700;color:#555;letter-spacing:.08em}.tl2-zoom-slider{width:130px;accent-color:#7c3aed}.tl2-zoom-val{font-size:.72rem;color:#555;font-family:monospace;min-width:50px}.tl2-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:100;display:flex;align-items:center;justify-content:center}.tl2-modal{background:#14141f;border:2px solid #2a2a40;border-radius:10px;padding:24px;min-width:360px;max-width:500px;max-height:70vh;overflow-y:auto}.tl2-modal h3{margin:0 0 16px;font-size:1.1rem;font-weight:700;color:#e0e0e0}.tl2-template-row{display:flex;justify-content:space-between;align-items:center;padding:10px 8px;border-bottom:1px solid #1a1a2e}.tl2-template-row span{flex:1;font-size:.9rem;font-weight:600}.tl2-seg-thumbs{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;overflow:hidden;border-radius:4px;z-index:0;opacity:.85}.tl2-seg-thumb-img{flex:1;min-width:0;height:100%;object-fit:cover;pointer-events:none}.tl2-segment .tl2-seg-content{position:relative;z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.9),0 0 2px rgba(0,0,0,.7)}.tl2-segment .tl2-seg-handle{z-index:2}.tl2-segment .tl2-seg-del{z-index:3}.tl2-rubber-band{position:absolute;background:#7c3aed26;border:1px solid rgba(124,58,237,.5);z-index:8;pointer-events:none;border-radius:2px}.tl2-coach-toggle{position:absolute;bottom:8px;right:8px;width:36px;height:36px;border-radius:50%;border:2px solid #7c3aed;background:linear-gradient(135deg,#7c3aed44,#6d28d933);color:#a78bfa;font-size:.7rem;font-weight:900;cursor:pointer;z-index:5;transition:all .15s;display:flex;align-items:center;justify-content:center}.tl2-coach-toggle:hover{background:linear-gradient(135deg,#7c3aed66,#6d28d955);transform:scale(1.1)}.tl2-coach-toggle.active{background:#7c3aed;color:#fff;box-shadow:0 0 14px #7c3aed80}.tl2-coach-panel{width:340px;flex-shrink:0;background:#0e0e18;border-left:2px solid #1a1a2e;display:flex;flex-direction:column}.tl2-coach-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #1a1a2e;background:#0c0c14}.tl2-coach-title{font-size:.75rem;font-weight:900;letter-spacing:.12em;color:#a78bfa}.tl2-coach-close{background:none;border:none;color:#666;font-size:1rem;cursor:pointer;padding:2px 6px}.tl2-coach-close:hover{color:#ef4444}.tl2-coach-messages{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:10px}.tl2-coach-hint{color:#555;font-size:.75rem;line-height:1.6;text-align:center;padding:20px 10px}.tl2-coach-msg{max-width:95%;padding:8px 12px;border-radius:10px;font-size:.78rem;line-height:1.5}.tl2-coach-msg.user{align-self:flex-end;background:#2d1b69;color:#ddd;border-bottom-right-radius:2px}.tl2-coach-msg.assistant{align-self:flex-start;background:#14141f;border:1px solid #1a1a2e;color:#ccc;border-bottom-left-radius:2px}.tl2-coach-msg-text{margin-bottom:6px;word-break:break-word}.tl2-coach-suggestions{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.tl2-coach-chip{padding:4px 10px;border-radius:12px;border:1.5px solid;background:transparent;font-size:.68rem;font-weight:700;cursor:pointer;transition:all .12s;white-space:nowrap}.tl2-coach-chip:hover{filter:brightness(1.3);transform:scale(1.05)}.tl2-coach-conf{opacity:.6;font-size:.6rem;margin-left:3px}.tl2-coach-combo{margin-top:8px;padding:8px;background:#7c3aed1a;border:1px solid #7c3aed44;border-radius:8px}.tl2-coach-combo-label{font-size:.65rem;font-weight:900;letter-spacing:.12em;color:#a78bfa;margin-bottom:4px}.tl2-coach-combo-desc{font-size:.72rem;color:#999;margin-bottom:6px}.tl2-coach-combo-btn{width:100%;padding:6px;border-radius:6px;border:1px solid #7c3aed;background:#7c3aed33;color:#a78bfa;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .12s}.tl2-coach-combo-btn:hover{background:#7c3aed55;color:#fff}.tl2-coach-loading{text-align:center;color:#7c3aed;font-size:.72rem;padding:8px;animation:tl2-pulse 1.5s ease-in-out infinite}.tl2-coach-input-wrap{display:flex;gap:6px;padding:8px 10px;border-top:1px solid #1a1a2e;background:#0c0c14}.tl2-coach-input{flex:1;padding:8px 10px;border-radius:6px;border:1px solid #2a2a40;background:#14141f;color:#ddd;font-size:.78rem;outline:none}.tl2-coach-input:focus{border-color:#7c3aed}.tl2-coach-send{padding:8px 14px;border-radius:6px;border:1px solid #7c3aed;background:#7c3aed;color:#fff;font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap}.tl2-coach-send:disabled{opacity:.35;cursor:not-allowed}.tl2-coach-send:hover:not(:disabled){background:#6d28d9}.tl2-shuttle-badge{position:absolute;top:8px;right:8px;background:#ef4444dd;color:#fff;font-size:.72rem;font-weight:800;padding:3px 10px;border-radius:4px;font-family:monospace;z-index:5}.tl2-gap-bar{display:flex;align-items:center;gap:10px;padding:8px 16px;background:linear-gradient(90deg,#7c3aed18,#ef444418);border-top:1px solid #7c3aed44;flex-shrink:0;flex-wrap:wrap}.tl2-gap-label{font-size:.78rem;font-weight:700;color:#ef4444}.tl2-gap-suggest-btn{border-color:#7c3aed!important;color:#a78bfa!important;background:#7c3aed22!important}.tl2-gap-suggest-btn:hover{background:#7c3aed44!important}.tl2-gap-suggestions{display:flex;gap:8px;width:100%;margin-top:4px}.tl2-gap-suggestion{flex:1;display:flex;flex-direction:column;gap:3px;padding:8px 10px;border-radius:8px;border:1.5px solid #7c3aed44;background:#14141f;cursor:pointer;transition:all .12s;text-align:left}.tl2-gap-suggestion:hover{border-color:#7c3aed;background:#1e1e30;transform:scale(1.02)}.tl2-gap-sug-conf{font-size:.65rem;font-weight:900;color:#22c55e}.tl2-gap-sug-desc{font-size:.72rem;color:#ddd;font-weight:600}.tl2-gap-sug-time{font-size:.62rem;color:#666;font-family:monospace}.tl2-shortcut-hints{font-size:.62rem;color:#444;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl2-ai-assist-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;background:#0a0a14;border-top:1px solid #10b98133;flex-shrink:0}.tl2-ai-assist-icon{font-size:.7rem;font-weight:900;color:#10b981;background:#10b98118;border:1px solid #10b98144;border-radius:4px;padding:2px 6px;letter-spacing:.05em;flex-shrink:0}.tl2-ai-assist-input{flex:1;background:#112;border:1px solid #1a1a2e;border-radius:6px;color:#ddd;font-size:.78rem;padding:5px 10px;outline:none;transition:border-color .15s}.tl2-ai-assist-input:focus{border-color:#10b981}.tl2-ai-assist-input::placeholder{color:#444}.tl2-ai-assist-input:disabled{opacity:.5}.tl2-ai-assist-go{background:#10b981;color:#000;border:none;border-radius:5px;font-size:.72rem;font-weight:800;padding:5px 14px;cursor:pointer;letter-spacing:.04em;transition:background .15s;flex-shrink:0}.tl2-ai-assist-go:hover{background:#34d399}.tl2-ai-assist-go:disabled{background:#333;color:#666;cursor:not-allowed}.tl2-ai-assist-msg{font-size:.72rem;color:#10b981;font-weight:600;max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.pro-editor{display:flex;flex-direction:column;height:calc(100vh - 56px);background:var(--bg);overflow:hidden}.pro-topbar{display:flex;align-items:center;gap:12px;padding:6px 12px;background:#0c0c14;border-bottom:1px solid var(--border);flex-shrink:0;min-height:40px}.pro-topbar-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.pro-topbar-title{font-size:.8rem;font-weight:800;letter-spacing:.12em;color:var(--accent)}.pro-topbar-count{font-size:.7rem;color:var(--text-dim);background:var(--bg-input);padding:2px 8px;border-radius:10px}.pro-topbar-filters{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.pro-topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.pro-collapse-btn{background:none;border:1px solid var(--border);color:var(--text-dim);font-size:.7rem;width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.pro-collapse-btn:hover{background:var(--bg-input);color:var(--text)}.pro-filter-btn{background:none;border:1px solid transparent;color:var(--text-dim);font-size:.68rem;font-weight:600;padding:3px 10px;border-radius:4px;cursor:pointer;letter-spacing:.03em;transition:all .15s;white-space:nowrap}.pro-filter-btn:hover{color:var(--text);background:var(--bg-input)}.pro-filter-btn.active{color:#fff;background:var(--accent);border-color:var(--accent)}.pro-filter-btn.danger{color:var(--danger);border-color:var(--danger)}.pro-filter-btn.danger:hover{background:#ff475726}.pro-filter-sep{width:1px;height:16px;background:var(--border);margin:0 6px}.pro-main{display:flex;flex:1;overflow:hidden}.pro-left{width:280px;min-width:240px;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.pro-left-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--text-dim);border-bottom:1px solid var(--border);flex-shrink:0}.pro-left-count{background:var(--bg-input);padding:1px 7px;border-radius:8px;font-size:.65rem;font-weight:600;color:var(--text-dim)}.pro-clip-list{flex:1;overflow-y:auto;padding:4px 0}.pro-clip-list::-webkit-scrollbar{width:4px}.pro-clip-list::-webkit-scrollbar-track{background:transparent}.pro-clip-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.pro-clip-category{margin-bottom:2px}.pro-clip-category-header{display:flex;align-items:center;gap:6px;padding:8px 10px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:2}.pro-clip-category-header:hover{background:#ffffff12}.pro-clip-category-header.cat-sport{border-left:3px solid #6ee7b7}.pro-clip-category-header.cat-cinema{border-left:3px solid #a78bfa}.pro-clip-category-header.cat-montage{border-left:3px solid #fbbf24}.pro-clip-category-header.cat-autre{border-left:3px solid #64748b}.pro-clip-category-header.cat-custom{border-left:3px solid #38bdf8}.pro-clip-category-icon{font-size:.8rem;flex-shrink:0}.pro-clip-category-label{font-size:.72rem;font-weight:800;color:var(--text);text-transform:uppercase;letter-spacing:.05em;flex:1;min-width:0}.pro-clip-group{margin-bottom:1px}.pro-clip-group-header{display:flex;align-items:center;gap:6px;padding:5px 10px 5px 20px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff04;border-bottom:1px solid rgba(255,255,255,.03);position:sticky;top:34px;z-index:1}.pro-clip-group-header:hover{background:#ffffff0a}.pro-clip-group-chevron{font-size:.6rem;color:var(--text-dim);width:10px;flex-shrink:0}.pro-clip-group-label{font-size:.62rem;font-weight:600;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.pro-clip-group-count{font-size:.55rem;font-weight:700;color:var(--accent);background:#6c5ce71f;padding:1px 5px;border-radius:8px;flex-shrink:0}.pro-new-group-btn{background:#38bdf826;color:#38bdf8;border:none;border-radius:4px;font-size:.75rem;font-weight:800;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-left:auto;flex-shrink:0;transition:background .15s}.pro-new-group-btn:hover{background:#38bdf84d}.pro-group-rename-input{background:#0000004d;border:1px solid #38bdf8;color:var(--text);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:1px 4px;border-radius:3px;outline:none;flex:1;min-width:0}.pro-group-delete-btn{background:none;border:none;color:var(--text-dim);font-size:.7rem;cursor:pointer;padding:0 3px;opacity:0;transition:opacity .15s,color .15s;flex-shrink:0}.pro-clip-category-header:hover .pro-group-delete-btn{opacity:1}.pro-group-delete-btn:hover{color:#ef4444}.pro-clip-move-btn{background:none;border:none;font-size:.6rem;cursor:pointer;padding:2px;opacity:0;transition:opacity .15s;flex-shrink:0}.pro-clip-item:hover .pro-clip-move-btn{opacity:1}.pro-clip-move-menu{position:absolute;right:0;top:100%;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:6px;z-index:50;min-width:140px;box-shadow:0 4px 12px #0006;overflow:hidden}.pro-clip-move-item{padding:6px 10px;font-size:.6rem;color:var(--text);cursor:pointer;white-space:nowrap;transition:background .1s}.pro-clip-move-item:hover{background:#6c5ce726}.pro-r2-folder-row{display:flex;align-items:center;gap:6px;padding:2px 20px 4px;font-size:.55rem;color:var(--text-muted, #94a3b8)}.pro-r2-folder-label{opacity:.6;flex-shrink:0}.pro-r2-folder-value{cursor:pointer;padding:1px 4px;border-radius:3px;background:#ffffff0a;transition:background .15s;font-family:monospace;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pro-r2-folder-value:hover{background:#38bdf81f}.pro-r2-folder-input{background:#0000004d;border:1px solid rgba(56,189,248,.4);border-radius:3px;color:var(--text);font-size:.55rem;font-family:monospace;padding:1px 4px;width:120px;outline:none}.pro-r2-upload-btn{background:none;border:none;font-size:.6rem;cursor:pointer;padding:2px;opacity:0;transition:opacity .15s;flex-shrink:0}.pro-clip-category-header:hover .pro-r2-upload-btn{opacity:1}.pro-r2-upload-btn.clip-level{opacity:0;transition:opacity .15s}.pro-clip-item:hover .pro-r2-upload-btn.clip-level{opacity:1}.pro-r2-upload-btn:disabled{cursor:wait;opacity:.7!important}.pro-r2-badge{background:#22c55e;color:#000;font-size:.45rem;font-weight:700;padding:0 3px;border-radius:3px;line-height:1.4;letter-spacing:.5px}.pro-clip-item{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;border-left:3px solid transparent;transition:all .12s;position:relative}.pro-clip-item:hover{background:#ffffff08}.pro-clip-item.active{background:#6c5ce71f;border-left-color:var(--accent)}.pro-clip-item.selected{background:#6c5ce72e;border-left-color:var(--accent);border-left-width:3px}.pro-clip-thumb{width:56px;height:36px;border-radius:4px;overflow:hidden;flex-shrink:0;position:relative;background:#1a1a2e}.pro-clip-thumb img{width:100%;height:100%;object-fit:cover}.pro-clip-thumb-empty{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#222240)}.pro-clip-checkbox{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:3px;border:1.5px solid rgba(255,255,255,.5);background:#00000080;color:#fff;font-size:.6rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s;opacity:0}.pro-clip-item:hover .pro-clip-checkbox,.pro-clip-checkbox.checked,.pro-clip-item.selected .pro-clip-checkbox,.pro-clip-item.selecting-mode .pro-clip-checkbox{opacity:1}.pro-clip-checkbox.checked{background:var(--accent);border-color:var(--accent)}.pro-clip-dur{position:absolute;bottom:1px;right:2px;font-size:.55rem;font-weight:700;color:#fff;background:#000000b3;padding:0 3px;border-radius:2px;line-height:1.3}.pro-clip-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.pro-clip-title{font-size:.72rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.pro-clip-meta{display:flex;align-items:center;gap:5px}.pro-clip-source{font-size:.58rem;font-weight:800;letter-spacing:.06em;padding:1px 5px;border-radius:3px;line-height:1.3}.pro-clip-source.gemini{background:#2d1b69;color:#a78bfa}.pro-clip-source.scout{background:#1b3a2a;color:#6ee7b7}.pro-clip-source.lib{background:#1b2d3a;color:#7dd3fc}.pro-clip-status{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.pro-clip-status.st-draft{color:var(--text-dim)}.pro-clip-status.st-edited{color:var(--warning)}.pro-clip-status.st-exported{color:var(--success)}.pro-clip-score{font-size:.58rem;font-weight:700;color:var(--accent)}.pro-clip-del{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--danger);font-size:1rem;cursor:pointer;opacity:0;transition:opacity .15s;padding:2px 4px;line-height:1}.pro-clip-item:hover .pro-clip-del{opacity:.6}.pro-clip-del:hover{opacity:1!important}.pro-center{flex:1;display:flex;flex-direction:column;min-width:0;background:#08080e}.pro-player-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.pro-player-area .clip-player{width:100%;height:100%}.pro-player-area .clip-player-video{height:calc(100% - 60px)}.pro-player-area .clip-player-video video{max-height:100%}.pro-back-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--accent);font-size:.75rem;font-weight:600;padding:4px 12px;border-radius:4px;cursor:pointer;flex-shrink:0}.pro-back-btn:hover{background:var(--accent);color:#fff}.pro-player-info{display:flex;align-items:center;gap:12px;padding:6px 16px;background:#0c0c14;border-top:1px solid var(--border);flex-shrink:0;min-height:34px}.pro-player-clip-name{font-size:.78rem;font-weight:600;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pro-player-clip-meta{font-size:.7rem;color:var(--text-dim);font-family:SF Mono,Fira Code,monospace;flex-shrink:0}.pro-close-btn{background:none;border:1px solid var(--border);color:var(--text-dim);font-size:.9rem;width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.pro-close-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.pro-player-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px}.pro-player-empty-icon{font-size:3rem;color:var(--border);width:80px;height:80px;border:2px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center}.pro-player-empty-text{font-size:.9rem;font-weight:600;color:var(--text-dim);text-align:center}.pro-player-empty-hint{font-size:.75rem;color:#555;text-align:center;max-width:300px}.pro-resize-handle{width:5px;cursor:col-resize;background:var(--border);flex-shrink:0;transition:background .15s;position:relative}.pro-resize-handle:hover,.pro-resize-handle:active{background:var(--accent)}.pro-right{width:380px;min-width:250px;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.pro-right .studio-tool-panel{height:100%}.pro-right .studio-tool-content{overflow-y:auto}.pro-empty{padding:20px 16px;text-align:center;font-size:.78rem;color:var(--text-dim);line-height:1.5}.pipeline-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg)}.pipeline-source-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#0c0c14;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.pipeline-drop-zone{display:flex;align-items:center;justify-content:center;min-width:140px;height:32px;border:1px dashed var(--border);border-radius:6px;cursor:pointer;font-size:.7rem;color:var(--text-dim);transition:all .15s;padding:0 10px}.pipeline-drop-zone:hover,.pipeline-drop-zone.dragging{border-color:var(--accent);background:#6c5ce714;color:var(--accent)}.pipeline-drop-zone.has-file{border-color:var(--accent);border-style:solid}.pipeline-drop-label{font-size:.7rem}.pipeline-drop-file{display:flex;align-items:center;gap:6px;font-size:.68rem}.pipeline-drop-filename{color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pipeline-drop-size{color:var(--text-dim);font-size:.6rem}.pipeline-drop-clear{background:none;border:none;color:var(--danger);cursor:pointer;font-size:.8rem;padding:0 2px}.pipeline-source-or{font-size:.65rem;color:var(--text-dim)}.pipeline-yt-row{display:flex;align-items:center;gap:4px;flex:1;min-width:160px}.pipeline-yt-input{flex:1;height:30px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.72rem;padding:0 8px;outline:none}.pipeline-yt-input:focus{border-color:var(--accent)}.pipeline-yt-input.is-yt{border-color:red}.pipeline-style-select{height:30px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.7rem;padding:0 6px;outline:none;cursor:pointer}.pipeline-style-select:focus{border-color:var(--accent)}.pipeline-beat-btn,.pipeline-new-btn{white-space:nowrap}.pipeline-status{display:flex;gap:6px;padding:4px 12px;flex-shrink:0}.pipeline-badge{font-size:.6rem;padding:2px 8px;border-radius:10px;background:var(--bg-input);color:var(--text-dim)}.pipeline-badge-ready{background:#00c85326;color:#00c853}.pipeline-beatsync{padding:8px 12px;background:#6c5ce70f;border-bottom:1px solid var(--border);flex-shrink:0}.pipeline-beatsync-header{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;font-weight:700;color:var(--accent);margin-bottom:6px}.pipeline-beatsync-stats{display:flex;gap:12px;font-size:.68rem;color:var(--text-dim);margin-bottom:6px}.pipeline-beatsync-music{margin-bottom:6px}.pipeline-beatsync-nomusic{font-size:.68rem;color:var(--warning)}.pipeline-beatsync-result{margin-top:6px}.pipeline-beatsync-video{width:100%;max-height:160px;border-radius:6px}.pipeline-beatsync-info{font-size:.65rem;color:var(--text-dim);margin-top:4px}.pipeline-beatsync-cuts{margin:6px 0}.pipeline-beatsync-cuts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.pipeline-beatsync-cuts-title{font-size:.62rem;font-weight:700;color:var(--text-dim);letter-spacing:.5px}.pipeline-beatsync-reset-btn{font-size:.58rem!important;padding:1px 6px!important;opacity:.7}.pipeline-beatsync-reset-btn:hover{opacity:1}.pipeline-beatsync-cuts-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}.pipeline-beatsync-cut-card{display:flex;align-items:center;gap:4px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:.64rem}.pipeline-beatsync-cut-num{color:var(--accent);font-weight:700;min-width:22px;font-size:.6rem}.pipeline-beatsync-cut-tc{width:72px;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit;font-size:.62rem;padding:2px 4px;text-align:center}.pipeline-beatsync-cut-tc:focus{border-color:var(--accent);outline:none}.pipeline-beatsync-cut-fx{flex:1;min-width:0;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit;font-size:.6rem;padding:2px 4px}.pipeline-beatsync-cut-fx:focus{border-color:var(--accent);outline:none}.pipeline-beatsync-cut-del{background:none;border:none;color:var(--danger);cursor:pointer;font-size:.8rem;padding:0 2px;opacity:.5;line-height:1}.pipeline-beatsync-cut-del:hover{opacity:1}.pipeline-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.pipeline-messages::-webkit-scrollbar{width:4px}.pipeline-messages::-webkit-scrollbar-track{background:transparent}.pipeline-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.pipeline-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px;color:var(--text-dim)}.pipeline-empty-title{font-size:1rem;font-weight:800;letter-spacing:.1em;color:var(--accent)}.pipeline-empty-hint{font-size:.78rem;max-width:400px;text-align:center;line-height:1.4}.pipeline-empty-flow{display:flex;gap:8px;font-size:.7rem;font-weight:600;color:var(--text-dim);opacity:.7}.pipeline-bubble{padding:8px 12px;border-radius:8px;font-size:.78rem;line-height:1.45;max-width:90%}.pipeline-bubble-user{background:#6c5ce726;align-self:flex-end;border-bottom-right-radius:2px}.pipeline-bubble-model{background:var(--bg-input);align-self:flex-start;border-bottom-left-radius:2px}.pipeline-bubble-system{background:#ffa50214;align-self:center;font-size:.7rem;color:var(--text-dim);text-align:center}.pipeline-bubble-label{font-size:.58rem;font-weight:700;letter-spacing:.08em;color:var(--text-dim);margin-bottom:3px}.pipeline-bubble-text{white-space:pre-wrap;word-break:break-word;color:var(--text)}.pipeline-bubble-system .pipeline-bubble-text{color:var(--text-dim)}.pipeline-typing{color:var(--text-dim);font-style:italic;animation:pulseDim 1.2s ease-in-out infinite}@keyframes pulseDim{0%,to{opacity:.5}50%{opacity:1}}.pipeline-inline-candidates{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.06)}.pipeline-inline-label{font-size:.65rem;font-weight:600;color:var(--accent);margin-bottom:4px}.pipeline-inline-card{display:flex;gap:8px;font-size:.68rem;color:var(--text-dim);padding:2px 0}.pipeline-inline-pov{color:var(--text);font-style:italic;font-size:.66rem}.pipeline-presets{display:flex;align-items:center;gap:4px;padding:6px 12px;flex-wrap:wrap;border-top:1px solid var(--border);flex-shrink:0;background:#0c0c14}.pipeline-presets-label{font-size:.6rem;font-weight:700;letter-spacing:.08em;color:var(--text-dim);margin-right:2px}.pipeline-preset-wrap{display:flex;align-items:center;gap:1px}.pipeline-preset-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);font-size:.62rem;font-weight:600;padding:3px 8px;border-radius:4px;cursor:pointer;white-space:nowrap;transition:all .12s}.pipeline-preset-btn:hover{color:var(--text);border-color:var(--accent)}.pipeline-preset-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pipeline-preset-edit{background:none;border:none;color:var(--text-dim);font-size:.55rem;cursor:pointer;padding:2px 3px;opacity:.5}.pipeline-preset-edit:hover{opacity:1;color:var(--accent)}.pipeline-preset-add{border-style:dashed;color:var(--text-dim)}.pipeline-preset-reset{color:var(--danger);border-color:transparent;background:none;opacity:.6}.pipeline-preset-reset:hover{opacity:1}.pipeline-preset-editor{padding:8px 12px;border-top:1px solid var(--border);background:#6c5ce70a;flex-shrink:0}.pipeline-preset-editor-header{display:flex;align-items:center;justify-content:space-between;font-size:.68rem;font-weight:700;color:var(--accent);margin-bottom:6px}.pipeline-preset-editor-actions{display:flex;gap:4px}.pipeline-preset-editor-label{width:100%;height:28px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.72rem;padding:0 8px;margin-bottom:4px;outline:none}.pipeline-preset-editor-text{width:100%;min-height:80px;max-height:150px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.7rem;padding:6px 8px;resize:vertical;outline:none;font-family:inherit}.pipeline-input-bar{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--border);background:#0c0c14;flex-shrink:0}.pipeline-textarea{flex:1;min-height:36px;max-height:100px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.78rem;padding:8px 10px;resize:none;outline:none;font-family:inherit;line-height:1.3}.pipeline-textarea:focus{border-color:var(--accent)}.pipeline-send-btn{align-self:flex-end;height:36px;min-width:60px}.candidates-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.candidates-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border);flex-shrink:0;gap:6px}.candidates-count{font-size:.7rem;font-weight:700;color:var(--text-dim);letter-spacing:.05em;white-space:nowrap}.candidates-actions{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.candidates-group-picker{display:flex;align-items:center;gap:6px;padding:6px 10px;border-bottom:1px solid var(--border);background:#6c5ce70d}.candidates-group-label{font-size:.62rem;font-weight:600;color:var(--text-dim);white-space:nowrap}.candidates-group-select{flex:1;min-width:0;height:24px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.62rem;padding:0 6px;outline:none;cursor:pointer}.candidates-group-select:focus{border-color:var(--accent)}.candidates-min-dur{display:flex;align-items:center;gap:2px;font-size:.65rem;color:var(--text-dim);font-weight:600}.candidates-min-input{width:32px;height:22px;background:var(--bg-input);border:1px solid var(--border);border-radius:3px;color:var(--text);font-size:.65rem;text-align:center;outline:none;padding:0}.candidates-list{flex:1;overflow-y:auto;padding:4px 0}.candidates-list::-webkit-scrollbar{width:4px}.candidates-list::-webkit-scrollbar-track{background:transparent}.candidates-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.candidate-card{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;cursor:pointer;border-left:3px solid transparent;transition:all .12s;position:relative}.candidate-card:hover{background:#ffffff08}.candidate-card.selected{background:#6c5ce71a;border-left-color:var(--accent)}.candidate-card.too-short{opacity:.45}.candidate-card.rendered{cursor:default;border-left-color:#00c853;padding:10px}.candidate-check{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-dim);flex-shrink:0;margin-top:1px}.candidate-card.selected .candidate-check{color:var(--accent)}.candidate-info{flex:1;min-width:0}.candidate-time-row{display:flex;align-items:center;gap:6px}.candidate-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}.candidate-time{font-size:.72rem;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.candidate-dur{font-size:.62rem;color:var(--text-dim);background:var(--bg-input);padding:1px 5px;border-radius:6px}.candidate-dur.dur-short{color:var(--danger)}.candidate-pov{font-size:.68rem;color:var(--accent);font-style:italic;margin-top:2px;line-height:1.3}.candidate-scene{font-size:.65rem;color:var(--text-dim);margin-top:1px}.candidate-reason{font-size:.62rem;color:var(--text-dim);opacity:.7;margin-top:1px}.candidate-remove{position:absolute;top:4px;right:4px;background:none;border:none;color:var(--text-dim);font-size:.9rem;cursor:pointer;opacity:0;transition:opacity .15s;padding:2px 4px}.candidate-card:hover .candidate-remove{opacity:.5}.candidate-remove:hover{opacity:1!important;color:var(--danger)}.candidate-preview{margin-top:6px;border-radius:6px;overflow:hidden}.candidate-preview-video{width:100%;max-height:140px;border-radius:6px}.candidate-preview-thumb{position:relative;cursor:pointer;border-radius:6px;overflow:hidden}.candidate-preview-thumb img{width:100%;height:auto;display:block}.candidate-preview-empty{width:100%;height:80px;background:linear-gradient(135deg,#1a1a2e,#222240)}.candidate-preview-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.1em;transition:background .15s}.candidate-preview-thumb:hover .candidate-preview-play{background:#6c5ce780}.tl2-pump-section{margin-top:8px}.tl2-select{display:block;width:100%;margin-top:4px;padding:6px 10px;border-radius:6px;border:1px solid #2a2a40;background:#14141f;color:#ddd;font-size:.78rem;font-family:inherit;outline:none;cursor:pointer}.tl2-select:focus{border-color:#7c3aed}.tl2-pump-badge{display:inline-block;margin-top:6px;padding:3px 10px;border-radius:4px;background:linear-gradient(135deg,#7c3aed44,#ef444433);border:1px solid #7c3aed66;color:#c084fc;font-size:.65rem;font-weight:800;letter-spacing:.1em}.tl2-track-text-panel{padding:8px}.tl2-track-text-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.tl2-track-text-input{flex:1;padding:6px 10px;border-radius:6px;border:1px solid #2a2a40;background:#14141f;color:#ddd;font-size:.78rem;font-weight:700;outline:none}.tl2-track-text-input:focus{border-color:#ef4444}.tl2-track-color{width:32px;height:32px;border:1px solid #2a2a40;border-radius:4px;background:#14141f;cursor:pointer;padding:2px}.tl2-btn-track{width:100%;padding:8px;border-radius:6px;border:1.5px solid #ef4444;background:#ef444418;color:#f87171;font-size:.72rem;font-weight:800;letter-spacing:.08em;cursor:pointer;transition:all .12s}.tl2-btn-track:hover:not(:disabled){background:#ef444433;color:#fff}.tl2-btn-track:disabled{opacity:.4;cursor:not-allowed}.tl2-track-objects{margin-top:8px;display:flex;flex-direction:column;gap:4px}.tl2-track-objects-label{font-size:.68rem;color:#888;font-weight:600;margin-bottom:4px}.tl2-track-obj-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;border:1px solid #ef444444;background:#1a0a0a;color:#ddd;font-size:.72rem;cursor:pointer;transition:all .1s}.tl2-track-obj-btn:hover:not(:disabled){border-color:#ef4444;background:#ef444422}.tl2-track-obj-btn:disabled{opacity:.4;cursor:not-allowed}.tl2-track-obj-label{font-weight:700;text-transform:uppercase}.tl2-track-obj-conf{font-size:.6rem;color:#22c55e;font-weight:700}.tl2-track-obj-pos{font-size:.6rem;color:#666;font-family:monospace;margin-left:auto}.clips-grid-container{flex:1;overflow-y:auto;padding:24px}.clips-grid-empty{text-align:center;color:#555;font-size:.9rem;padding:80px 20px}.clips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;max-width:1400px;margin:0 auto}.clips-grid-card{background:#12121e;border:1px solid #1e1e30;border-radius:10px;overflow:visible;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.clips-grid-card:hover{border-color:#3b3b60}.clips-grid-card.previewing{border-color:#7c3aed;box-shadow:0 0 20px #7c3aed26}.clips-grid-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:#0a0a14;cursor:pointer;overflow:hidden;border-radius:10px 10px 0 0}.clips-grid-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.clips-grid-card:hover .clips-grid-thumb img{transform:scale(1.03)}.clips-grid-thumb-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#12121e,#1a1a30);color:#444;font-size:2rem}.clips-grid-video{width:100%;height:100%;object-fit:contain;background:#000}.clips-grid-dur{position:absolute;bottom:6px;right:6px;background:#000c;color:#ddd;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:4px;font-family:monospace}.clips-grid-info{padding:10px 12px 6px}.clips-grid-title{font-size:.78rem;font-weight:600;color:#ddd;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.clips-grid-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.clips-grid-actions{display:flex;gap:6px;padding:6px 12px 10px}.clips-grid-edit-btn{flex:1;padding:6px;border-radius:6px;border:1px solid #7c3aed55;background:#7c3aed18;color:#a78bfa;font-size:.68rem;font-weight:800;letter-spacing:.1em;cursor:pointer;transition:all .12s}.clips-grid-edit-btn:hover{background:#7c3aed33;color:#fff}.clips-grid-del-btn{width:32px;border-radius:6px;border:1px solid #ef444433;background:transparent;color:#666;font-size:1rem;cursor:pointer;transition:all .12s}.clips-grid-del-btn:hover{background:#ef444422;color:#ef4444;border-color:#ef4444}.clips-grid-group{max-width:1400px;margin:0 auto 24px}.clips-grid-group-header{display:flex;align-items:center;gap:10px;padding:10px 4px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid #1e1e30;margin-bottom:14px}.clips-grid-group-header:hover{border-color:#3b3b60}.clips-grid-group-icon{font-size:1.3rem}.clips-grid-group-label{font-size:1rem;font-weight:700;color:#e0e0e8;letter-spacing:.04em;text-transform:uppercase}.clips-grid-group-count{background:#1e1e30;color:#8888a0;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px}.clips-grid-group-chevron{margin-left:auto;color:#555;font-size:.9rem;transition:transform .2s}.clips-grid-group-chevron.collapsed{transform:rotate(-90deg)}.clips-cat-move-wrap{position:relative;flex-shrink:0}.clips-cat-move-btn{background:none;border:1px solid transparent;color:#555;font-size:.8rem;cursor:pointer;padding:2px 6px;border-radius:4px}.clips-cat-move-btn:hover{color:var(--accent);border-color:var(--border);background:var(--bg-input)}.clips-cat-move-menu{position:absolute;right:0;bottom:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;z-index:100;min-width:140px;box-shadow:0 4px 12px #0006;overflow:hidden}.clips-cat-move-item{padding:6px 12px;font-size:.75rem;cursor:pointer;white-space:nowrap;color:var(--text)}.clips-cat-move-item:hover{background:var(--accent);color:#fff}.clips-cat-send-r2{margin-left:auto;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#60a5fa;font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:4px;cursor:pointer;letter-spacing:.04em;transition:all .15s}.clips-cat-send-r2:hover{background:#3b82f640;border-color:#60a5fa;color:#fff}.clips-cat-send-r2.uploading{opacity:.6;cursor:not-allowed}.clips-cat-send-r2:disabled{pointer-events:none}.r2-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999}.r2-picker-modal{background:#16162a;border:1px solid #2a2a45;border-radius:12px;width:360px;max-height:480px;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.r2-picker-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #2a2a45;font-size:.85rem;color:#e0e0e8}.r2-picker-close{background:none;border:none;color:#666;font-size:1.2rem;cursor:pointer}.r2-picker-close:hover{color:#fff}.r2-picker-count{padding:6px 16px;font-size:.7rem;color:#60a5fa;font-weight:600}.r2-picker-list{flex:1;overflow-y:auto;padding:4px 0}.r2-picker-loading{padding:20px;text-align:center;color:#555;font-size:.8rem}.r2-picker-item{display:flex;align-items:center;padding:6px 16px;font-size:.8rem;color:#ccc;transition:background .1s}.r2-picker-item:hover{background:#ffffff08}.r2-picker-item-name{flex:1;cursor:pointer;padding:4px 0}.r2-picker-item-name:hover{color:#fff}.r2-picker-item-send{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:#60a5fa;font-size:.6rem;font-weight:700;padding:3px 8px;border-radius:4px;cursor:pointer;flex-shrink:0}.r2-picker-item-send:hover{background:#3b82f64d;color:#fff}.r2-picker-item-hint{color:#555;font-size:.7rem;margin-left:4px}.r2-picker-new{display:flex;gap:6px;padding:10px 12px;border-top:1px solid #2a2a45}.r2-picker-input{flex:1;background:#0e0e1a;border:1px solid #2a2a45;border-radius:6px;padding:6px 10px;color:#e0e0e8;font-size:.78rem}.r2-picker-input::placeholder{color:#444}.r2-picker-input:focus{outline:none;border-color:#7c3aed}.r2-picker-create-btn{width:34px;background:#7c3aed22;border:1px solid #7c3aed55;border-radius:6px;color:#a78bfa;font-size:1.1rem;font-weight:700;cursor:pointer}.r2-picker-create-btn:hover{background:#7c3aed44;color:#fff}.r2-picker-create-btn:disabled{opacity:.3;cursor:not-allowed}.lyrics-page{padding:1.5rem;max-width:720px;margin:0 auto}.lyrics-source-section .ratio-chips{margin-bottom:.8rem}.lyrics-clips-picker{max-height:260px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:.4rem}.lyrics-clip-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:4px;cursor:pointer;font-size:.82rem;transition:background .12s}.lyrics-clip-item:hover{background:#6c5ce714}.lyrics-clip-item.selected{background:#6c5ce726}.lyrics-clip-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lyrics-clip-meta{font-size:.75rem;color:var(--text-dim);white-space:nowrap}.lyrics-results{margin-top:1rem}.media-browse-btn{font-size:1rem;padding:.3rem .5rem;min-width:36px}.media-browser-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0009;display:flex;align-items:center;justify-content:center}.media-browser-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:560px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006}.media-browser-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid var(--border)}.media-browser-header h3{margin:0;font-size:1rem}.media-browser-close{background:none;border:none;color:var(--text-dim);font-size:1.2rem;cursor:pointer}.media-browser-close:hover{color:var(--text)}.media-browser-content{overflow-y:auto;padding:.6rem 1rem;flex:1}.media-browser-empty{color:var(--text-dim);text-align:center;padding:2rem 0}.media-folder-item{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;border-bottom:1px solid var(--border)}.media-folder-btn{flex:1;display:flex;align-items:center;gap:.6rem;background:none;border:none;color:var(--text);cursor:pointer;padding:.5rem .4rem;border-radius:6px;text-align:left}.media-folder-btn:hover{background:var(--bg-hover, rgba(255,255,255,.05))}.media-folder-icon{font-size:1.3rem}.media-folder-info{display:flex;flex-direction:column;min-width:0}.media-folder-name{font-weight:600;font-size:.9rem}.media-folder-path{font-size:.72rem;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-folder-remove{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.9rem;padding:.3rem;opacity:.5}.media-folder-remove:hover{opacity:1;color:#e55}.media-folder-add{display:flex;gap:.4rem;margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--border)}.media-folder-add input{flex:1;font-size:.8rem;padding:.35rem .5rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text)}.media-browser-breadcrumb{display:flex;align-items:center;gap:.6rem;padding-bottom:.6rem;margin-bottom:.4rem;border-bottom:1px solid var(--border);font-weight:600;font-size:.9rem}.media-browser-count{margin-left:auto;font-size:.75rem;color:var(--text-dim);font-weight:400}.media-browser-select-folder{display:block;width:100%;padding:.55rem .8rem;margin-bottom:.5rem;background:var(--accent);color:#000;border:none;border-radius:8px;font-size:.82rem;font-weight:700;cursor:pointer;text-align:center;letter-spacing:.03em;transition:opacity .15s}.media-browser-select-folder:hover{opacity:.85}.media-browser-files{display:flex;flex-direction:column;gap:.15rem}.media-subfolder-label{font-size:.8rem;font-weight:600;color:var(--accent);padding:.5rem 0 .2rem}.media-file-item{display:flex;align-items:center;justify-content:space-between;background:none;border:none;color:var(--text);cursor:pointer;padding:.4rem .5rem;border-radius:6px;text-align:left;width:100%}.media-file-item:hover{background:var(--bg-hover, rgba(255,255,255,.05))}.media-file-name{font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.media-file-size{font-size:.72rem;color:var(--text-dim);flex-shrink:0;margin-left:.5rem}
