*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:#0f0f0f;color:#e5e7eb;font-family:system-ui,sans-serif;min-height:100vh}.join{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 24px;min-height:100vh;justify-content:center}.join-logo{font-size:28px;font-weight:700}.join-sub{color:#ffffff80;font-size:13px}.join-input{width:280px;padding:9px 14px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff12;color:#e5e7eb;font-size:14px}.join-input:focus{outline:none;border-color:#7c3aed}.join-error{color:#f87171;font-size:13px}.join-btn{padding:10px 36px;background:#7c3aed;color:#fff;border:none;border-radius:7px;font-size:15px;font-weight:600;cursor:pointer}.join-btn:hover{background:#6d28d9}.join-hint{font-size:12px;color:#fff6}.join-hint a{color:#a78bfa}.live{display:flex;flex-direction:column;gap:8px;padding:12px;height:100vh;overflow:hidden}.live-main{display:flex;gap:10px;flex:1;min-height:0;overflow:hidden}.live-left{display:flex;flex-direction:column;gap:8px;flex:72;min-width:0;overflow:hidden}.reconnecting-banner{background:#f59e0b;color:#000;text-align:center;padding:6px;font-size:13px;font-weight:600;margin:-12px -12px 0}.warning-bar{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:#fbbf24;font-size:12px;padding:6px 10px;border-radius:5px}.top-bar{display:flex;align-items:center;gap:10px}.title-input{flex:1;padding:7px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#e5e7eb;font-size:14px;font-weight:600}.title-input:focus{outline:none;border-color:#7c3aed}.title-input::placeholder{font-weight:400;color:#ffffff4d}.viewer-count{font-size:13px;color:#9ca3af;white-space:nowrap}.director{display:flex;flex-direction:column;gap:8px}.main-view-wrap{position:relative;width:100%;background:#000;border-radius:8px;overflow:hidden;border:2px solid rgba(124,58,237,calc(var(--level,0) * 1.2));box-shadow:0 0 calc(var(--level,0) * 24px) rgba(124,58,237,calc(var(--level,0) * .7));transition:border-color .1s,box-shadow .1s}.main-canvas{display:block;width:100%;height:auto;max-height:58vh;object-fit:contain;background:#000}.composite-rec-dot{position:absolute;top:8px;right:10px;width:8px;height:8px;border-radius:50%;background:#ef4444;box-shadow:0 0 6px #ef4444;animation:rec-pulse 1.2s ease-in-out infinite}.thumbs-row{display:flex;gap:6px;justify-content:center}.thumb{position:relative;width:160px;aspect-ratio:16/9;flex:none;background:#000;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid rgba(124,58,237,calc(var(--level,0) * 1.2));box-shadow:0 0 calc(var(--level,0) * 14px) rgba(124,58,237,calc(var(--level,0) * .6));transition:border-color .1s,box-shadow .1s,outline .1s;outline:2px solid transparent}.thumb:hover{outline:2px solid rgba(124,58,237,.5)}.thumb-hidden{display:none}.thumb-video{width:100%;height:100%;object-fit:cover;display:block}.thumb-label{position:absolute;bottom:4px;left:6px;font-size:10px;background:#0009;color:#fff;padding:1px 5px;border-radius:3px;pointer-events:none}.thumb-both-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;gap:2px;padding:10px;opacity:.4}.thumb-both-left,.thumb-both-right{flex:1;border-radius:3px;background:#ffffff80}.tile-controls{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:8px;opacity:0;background:#00000059;transition:opacity .15s}.main-view-wrap:hover .tile-controls,.thumb:hover .tile-controls{opacity:1}.tile-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:none;background:#ffffff26;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .12s}.tile-btn:hover{background:#ffffff47}.tile-btn-off{background:#dc262680}.tile-btn-off:hover{background:#dc2626b3}.tile-btn-on{background:#8b5cf699}.tile-btn-on:hover{background:#8b5cf6cc}.audio-bars{position:absolute;bottom:6px;right:8px;display:flex;align-items:flex-end;gap:2px;height:16px}.audio-bars span{width:3px;background:#a78bfa;border-radius:2px;animation:bar-bounce .5s ease-in-out infinite;transform-origin:bottom}.audio-bars span:nth-child(2){animation-delay:.15s}.audio-bars span:nth-child(3){animation-delay:.3s}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes bar-bounce{0%,to{height:3px}50%{height:calc(3px + var(--level,.5) * 13px)}}.top-bar-right{display:flex;align-items:center;gap:10px}.timer{font-size:13px;color:#f87171;font-weight:600;font-variant-numeric:tabular-nums}.controls-rows{display:flex;flex-direction:column;gap:4px}.controls{display:flex;gap:6px;flex-wrap:wrap}.btn{padding:6px 12px;border:none;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;background:#ffffff1a;color:inherit;transition:background .15s}.btn-icon{display:inline-flex;align-items:center;gap:5px}.btn:hover{background:#ffffff2e}.btn-off{background:#ffffff0d;color:#fff6}.btn-golive{background:#16a34a;color:#fff}.btn-golive:hover{background:#15803d}.btn-end{background:#dc2626;color:#fff}.btn-end:hover{background:#b91c1c}.btn-record{background:#dc262633;color:#fca5a5;border:1px solid rgba(220,38,38,.3)}.btn-record:hover{background:#dc26264d}.btn-stop{background:#f59e0b;color:#000}.rec-indicator{font-size:12px;font-weight:700;color:#f87171;animation:rec-blink 1s ease-in-out infinite}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.3}}.btn-leave{background:#ff505026;color:#fca5a5}.live-body,.show-notes-panel{display:flex;flex-direction:column;gap:6px;flex:1;min-height:0;overflow:hidden}.show-notes-wrap{position:relative;flex:1;display:flex;overflow:hidden}.show-notes-input{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e5e7eb;font-size:13px;line-height:1.6;padding:10px 28px 10px 12px;resize:none;font-family:inherit;overflow-y:auto}.show-notes-input:focus{outline:none;border-color:#7c3aed}.show-notes-preview{flex:1;overflow-y:auto;padding:10px 28px 10px 12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:13px;line-height:1.6;color:#e5e7eb}.show-notes-preview h1,.show-notes-preview h2,.show-notes-preview h3{color:#fff;margin:.6em 0 .3em;font-weight:700}.show-notes-preview h1{font-size:1.2em}.show-notes-preview h2{font-size:1.1em}.show-notes-preview h3{font-size:1em}.show-notes-preview p{margin:.3em 0}.show-notes-preview ul,.show-notes-preview ol{margin:.3em 0;padding-left:1.4em}.show-notes-preview li{margin:.15em 0}.show-notes-preview a{color:#a78bfa;text-decoration:underline}.show-notes-preview a:hover{color:#c4b5fd}.show-notes-preview strong{color:#fff}.show-notes-preview code{background:#ffffff1a;padding:1px 5px;border-radius:3px;font-size:12px}.show-notes-preview hr{border:none;border-top:1px solid rgba(255,255,255,.15);margin:.6em 0}.show-notes-empty{color:#ffffff4d;font-size:13px}.notes-toggle-btn{position:absolute;top:7px;right:7px;background:none;border:none;cursor:pointer;color:#ffffff4d;display:flex;align-items:center;padding:2px}.notes-toggle-btn:hover{color:#ffffffb3}.chat-side{flex:28;min-width:220px;display:flex;flex-direction:column;gap:6px;overflow:hidden}.section-label{font-size:11px;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.participants{display:flex;flex-direction:column;gap:4px}.participant{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:3px 0}.participant-actions{display:flex;gap:8px}.kick-btn{font-size:10px;color:#fbbf24;background:none;border:none;cursor:pointer}.ban-btn{font-size:10px;color:#f87171;background:none;border:none;cursor:pointer}.chat{display:flex;flex-direction:column;gap:6px;flex:1;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;min-height:0;padding:8px;background:#0003;border-radius:6px}.chat-msg{font-size:13px;display:flex;gap:6px}.chat-who{color:#a78bfa;font-weight:600;white-space:nowrap}.chat-text{color:#ffffffd9;word-break:break-word}.chat-input-row{display:flex;gap:6px}.chat-input-wrap{position:relative;flex:1;display:flex}.chat-input{flex:1;padding:7px 28px 7px 10px;border-radius:5px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:inherit;font-size:13px}.chat-input:focus{outline:none;border-color:#7c3aed}.slow-mode-btn{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#ffffff4d;display:flex;align-items:center;padding:2px}.slow-mode-btn:hover{color:#fff9}.slow-mode-btn.active{color:#f59e0b}.chat-send{padding:7px 14px;background:#7c3aed;color:#fff;border:none;border-radius:5px;font-size:13px;cursor:pointer}.chat-send:hover{background:#6d28d9}.upload-progress{position:relative;height:22px;width:120px;background:#ffffff14;border-radius:4px;overflow:hidden;display:flex;align-items:center}.upload-bar{position:absolute;left:0;top:0;bottom:0;background:#7c3aed;transition:width .4s ease}.upload-label{position:relative;z-index:1;font-size:11px;font-weight:600;color:#e5e7eb;padding:0 6px;white-space:nowrap}.settings-panel{display:flex;flex-direction:column;gap:8px;padding:12px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.settings-row{display:flex;align-items:center;gap:10px}.settings-row label{font-size:12px;color:#ffffff80;width:52px;flex-shrink:0}.settings-input{flex:1;padding:6px 10px;border-radius:5px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#e5e7eb;font-size:13px}.settings-input:focus{outline:none;border-color:#7c3aed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center}.modal{background:#1e1e1e;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:20px;width:340px;max-width:calc(100vw - 32px);display:flex;flex-direction:column;gap:8px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.modal-title{font-size:15px;font-weight:700}.modal-close{background:none;border:none;color:#ffffff80;font-size:16px;cursor:pointer;padding:2px 4px}.modal-close:hover{color:#fff}.modal-section-label{font-size:11px;color:#fff6;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.settings-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:#ffffffb3;cursor:pointer}.settings-toggle input{accent-color:#7c3aed;width:14px;height:14px;cursor:pointer}.recordings-modal{width:min(640px,calc(100vw - 32px));max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.recordings-empty{font-size:13px;color:#fff6;padding:8px 0}.rec-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;overflow-y:auto;flex:1;min-height:0;align-items:start}.rec-folder{border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#e5e7eb;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column}.rec-folder:hover{border-color:#7c3aed80;background:#7c3aed14}.rec-folder-icon{display:flex;align-items:center;justify-content:center;height:80px;color:#a78bfa;background:#7c3aed1a;border-radius:8px 8px 0 0}.rec-card{border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#e5e7eb;transition:border-color .15s}.rec-card:hover{border-color:#7c3aed66}.rec-thumb-wrap{border-radius:8px 8px 0 0;overflow:hidden;background:#111}.rec-thumb-sizer{position:relative;width:100%;height:0;padding-bottom:56.25%}.rec-thumb-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.rec-duration{position:absolute;bottom:5px;right:6px;background:#000000bf;color:#fff;font-size:11px;font-weight:600;padding:1px 5px;border-radius:3px;font-variant-numeric:tabular-nums}.rec-info{padding:8px 10px}.rec-name{font-size:12px;color:#e5e7eb;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.rec-meta{font-size:11px;color:#fff6;margin-bottom:6px}.rec-actions{display:flex;gap:6px}.rec-action-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#ffffffb3;text-decoration:none;transition:background .15s}.rec-action-btn:hover{background:#ffffff1f;color:#fff}.rec-action-delete{color:#f87171;border-color:#dc262633}.rec-action-delete:hover{background:#dc262633!important;color:#fca5a5!important}.signal{position:absolute;top:6px;right:8px;display:flex;align-items:flex-end;gap:2px;height:14px}.signal span{width:3px;border-radius:1px;background:#fff3}.signal span:nth-child(1){height:4px}.signal span:nth-child(2){height:8px}.signal span:nth-child(3){height:13px}.signal.sig-excellent span.on{background:#4ade80}.signal.sig-good span.on{background:#fbbf24}.signal.sig-poor span.on{background:#f87171}.signal.sig-lost span{background:#ffffff26}.postprod-strip{display:flex;flex-direction:column;gap:4px;padding:8px 12px;border-top:1px solid rgba(255,255,255,.07);background:#0003}.postprod-idle{font-size:11px;color:#2d3748}.postprod-job{display:flex;align-items:center;gap:8px;font-size:11px;font-family:ui-monospace,monospace;flex-wrap:wrap}.postprod-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.postprod-dot-downloading{background:#60a5fa;animation:rec-pulse 1s infinite}.postprod-dot-encoding{background:#c084fc;animation:rec-pulse .6s infinite}.postprod-dot-uploading{background:#34d399;animation:rec-pulse 1s infinite}.postprod-dot-done{background:#4ade80}.postprod-dot-error{background:#f87171}.postprod-dot-waiting{background:#78716c}.postprod-status{font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#a78bfa;width:72px;flex-shrink:0}.postprod-files{color:#94a3b8}.postprod-time{color:#475569;margin-left:auto}.postprod-progress{color:#7c3aed;width:100%;padding-left:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.postprod-error{color:#f87171;width:100%;padding-left:14px}.postprod-link{color:#4ade80;text-decoration:none;padding-left:14px}.postprod-link:hover{text-decoration:underline}.postprod-dismiss{background:none;border:none;color:#4a5568;cursor:pointer;font-size:14px;line-height:1;padding:0 0 0 4px;flex-shrink:0}.postprod-dismiss:hover{color:#94a3b8}.postprod-clear-all{background:none;border:none;color:#4a5568;cursor:pointer;font-size:10px;font-family:ui-monospace,monospace;text-transform:uppercase;letter-spacing:.06em;padding:2px 0;align-self:flex-end}.postprod-clear-all:hover{color:#94a3b8}.soundboard{display:flex;flex-direction:column;gap:6px;padding:8px 0 2px}.sb-tabs{display:flex;align-items:center;gap:4px}.sb-tab{padding:3px 10px;border-radius:5px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#94a3b8;font-size:11px;font-weight:600;cursor:pointer;transition:background .1s}.sb-tab:hover{background:#ffffff1a}.sb-tab-active{background:#8b5cf64d;border-color:#7c3aed;color:#e9d5ff}.soundboard-vol{display:flex;align-items:center;gap:6px;margin-left:auto}.soundboard-vol-label{font-size:13px}.soundboard-slider{width:72px;accent-color:#7c3aed;cursor:pointer;height:4px}.soundboard-vol-pct{font-size:11px;color:#94a3b8;width:28px;text-align:right}.sb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.sound-pad{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 2px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:7px;cursor:pointer;transition:background .1s,transform .08s;-webkit-user-select:none;user-select:none;min-height:52px}.sound-pad:hover{background:#ffffff1c}.sound-pad:active{background:#8b5cf659;border-color:#7c3aed;transform:scale(.95)}.sound-pad-empty{opacity:.45}.sound-emoji{font-size:18px;line-height:1}.sound-label{font-size:9px;color:#94a3b8;letter-spacing:.03em;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 2px}.overlay-pad{padding:0;overflow:hidden;aspect-ratio:16 / 9;min-height:unset}.overlay-pad-active{border-color:#7c3aed;box-shadow:0 0 8px #8b5cf699}.overlay-thumb{width:100%;height:100%;object-fit:cover;display:block}.viewer-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;z-index:8;pointer-events:none}.viewer-overlay-fade{animation:overlay-fade-in var(--overlay-dur, .8s) ease forwards}.viewer-overlay-fade-out{animation:overlay-fade-out var(--overlay-dur, .8s) ease forwards}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes overlay-fade-out{0%{opacity:1}to{opacity:0}}.timer-overlay{position:absolute;z-index:9;pointer-events:none}.timer-overlay-text{font-size:clamp(24px,6vw,64px);font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 0 20px rgba(0,0,0,.9),0 2px 6px rgba(0,0,0,.8);letter-spacing:-.02em;cursor:grab;pointer-events:all;white-space:nowrap;-webkit-user-select:none;user-select:none}.timer-overlay-text:active{cursor:grabbing}.timer-overlay-urgent .timer-overlay-text{animation:timer-pulse .5s ease-in-out infinite alternate}@keyframes timer-pulse{0%{opacity:1}to{opacity:.3}}.timer-color-pick{width:26px;height:26px;border:none;border-radius:4px;padding:1px;cursor:pointer;background:none;flex-shrink:0}.timer-font-btn{background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:#94a3b8;font-size:11px;padding:2px 7px;cursor:pointer}.timer-font-btn:hover{background:#ffffff1f}.timer-font-active{background:#7c3aed66!important;border-color:#7c3aedb3!important;color:#e9d5ff!important}.particle-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}.overlay-timer-row{display:flex;align-items:center;gap:6px;grid-column:1 / -1;padding:2px 2px 0}.timer-duration-input{display:flex;align-items:center;gap:1px}.timer-num{width:28px;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:#e2e8f0;font-size:12px;font-family:ui-monospace,monospace;text-align:center;padding:2px 0}.timer-num:disabled{opacity:.4}.timer-colon{color:#4a5568;font-size:12px;font-family:ui-monospace,monospace;padding:0 1px}.timer-btn{background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:#e2e8f0;font-size:12px;padding:2px 7px;cursor:pointer}.timer-btn:hover{background:#ffffff24}.timer-remaining{font-size:11px;font-family:ui-monospace,monospace;color:#a78bfa;margin-left:2px}.viewer-overlay-glitch{animation:overlay-glitch .5s steps(1) forwards}@keyframes overlay-glitch{0%{clip-path:inset(0 0 0 0);transform:none;filter:none}6%{clip-path:inset(22% 0 55% 0);transform:translate(-8px);filter:hue-rotate(80deg) saturate(4)}12%{clip-path:inset(0 0 0 0);transform:translate(6px,-1px);filter:none}18%{clip-path:inset(64% 0 9% 0);transform:translate(10px);filter:hue-rotate(-100deg) saturate(3)}24%{clip-path:inset(0 0 0 0);transform:none;filter:none;opacity:.6}30%{clip-path:inset(38% 0 38% 0);transform:translate(-5px,2px);filter:saturate(6) brightness(1.4);opacity:1}36%{clip-path:inset(0 0 0 0);transform:none;filter:none}42%{clip-path:inset(78% 0 4% 0);transform:translate(-7px) skew(3deg);filter:hue-rotate(40deg)}48%{opacity:0;transform:translate(4px)}54%{opacity:1;transform:none;filter:none;clip-path:inset(0 0 0 0)}60%{clip-path:inset(12% 0 72% 0);transform:translate(6px);filter:hue-rotate(-60deg)}66%{clip-path:inset(0 0 0 0);transform:none;filter:none}to{clip-path:inset(0 0 0 0);transform:none;filter:none;opacity:1}}.overlay-transition-chip{align-self:center;padding:3px 10px;border-radius:999px;background:#7c3aed2e;border:1px solid rgba(124,58,237,.5);color:#a78bfa;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.overlay-transition-chip:hover{background:#7c3aed59}.music-chip-active{background:#7c3aed80!important;color:#e9d5ff!important}.overlay-speed-row{display:flex;align-items:center;gap:5px;grid-column:1 / -1;padding:2px 2px 0}.overlay-speed-label{font-size:10px;color:#4a5568;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.overlay-speed-val{font-size:10px;color:#4a5568;font-family:ui-monospace,monospace;width:28px}.music-scrubber{padding:4px 12px 8px;display:flex;flex-direction:column;gap:4px}.music-scrubber-empty{height:52px;align-items:center;justify-content:center;color:#2d3748;font-size:11px}.music-waveform{width:100%;height:36px;cursor:col-resize;display:block;touch-action:none}.music-scrubber-times{display:flex;justify-content:space-between;font-size:10px;font-family:ui-monospace,monospace;color:#475569}.ctx-menu{position:fixed;z-index:9999;background:#1e1e2e;border:1px solid #3d3d5c;border-radius:8px;padding:4px;box-shadow:0 8px 24px #00000080;min-width:140px}.ctx-item{display:block;width:100%;text-align:left;background:none;border:none;color:#e2e8f0;font-size:13px;padding:7px 12px;border-radius:5px;cursor:pointer}.ctx-item:hover{background:#ffffff12}.ctx-item-danger{color:#f87171}.ctx-item-danger:hover{background:#f871711f}@media (max-width: 600px){.live{padding:8px;gap:8px}.thumbs-row{gap:4px}.thumb{width:calc(50% - 2px)}.main-canvas{max-height:40vh}.controls{gap:5px}.btn{padding:8px 10px;font-size:11px}.chat-messages{max-height:180px}.title-input{font-size:13px}}.text-overlay-input{width:100%;box-sizing:border-box;background:#111827;border:1px solid #374151;border-radius:6px;color:#e2e8f0;font-size:13px;padding:8px 10px;resize:vertical;font-family:inherit;grid-column:1 / -1}.text-overlay-input:focus{outline:none;border-color:#7c3aed}.text-overlay-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap;grid-column:1 / -1}.text-show-btn{grid-column:1 / -1;align-self:flex-start}.text-overlay{position:absolute;left:0;right:0;z-index:11;pointer-events:none;display:flex}.text-overlay-lower{bottom:0}.text-overlay-upper{top:0}.text-overlay-center{top:50%;transform:translateY(-50%);justify-content:center}.text-overlay-inner{padding:10px 18px;display:flex;flex-direction:column;gap:3px;width:100%}.text-overlay-center .text-overlay-inner{width:auto;border-radius:8px;text-align:center}.text-overlay-headline{font-size:clamp(14px,3.5cqw,32px);font-weight:700;line-height:1.2}.text-overlay-sub{font-size:clamp(11px,2.2cqw,20px);opacity:.85;line-height:1.3}@keyframes tc-fade-in{0%{opacity:0}to{opacity:1}}@keyframes tc-fade-out{0%{opacity:1}to{opacity:0}}@keyframes tc-slide-up-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes tc-slide-up-out{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes tc-slide-left-in{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes tc-slide-left-out{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes tc-slide-right-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes tc-slide-right-out{0%{transform:translate(0)}to{transform:translate(100%)}}.tc-anim-enter.tc-fade{animation:tc-fade-in .4s ease forwards}.tc-anim-exit.tc-fade{animation:tc-fade-out .4s ease forwards}.tc-anim-enter.tc-slide-up{animation:tc-slide-up-in .4s ease forwards}.tc-anim-exit.tc-slide-up{animation:tc-slide-up-out .4s ease forwards}.tc-anim-enter.tc-slide-left{animation:tc-slide-left-in .4s ease forwards}.tc-anim-exit.tc-slide-left{animation:tc-slide-left-out .4s ease forwards}.tc-anim-enter.tc-slide-right{animation:tc-slide-right-in .4s ease forwards}.tc-anim-exit.tc-slide-right{animation:tc-slide-right-out .4s ease forwards}.tc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:4px 0}.tc-slot{background:#1a1a2e;border:1px solid #2d3748;border-radius:5px;padding:5px 6px;font-size:11px;color:#9ca3af;cursor:pointer;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:border-color .15s,color .15s;min-height:36px;display:flex;align-items:center}.tc-slot:hover{border-color:#7c3aed;color:#e2e8f0}.tc-slot-empty{color:#4b5563;border-style:dashed}.tc-slot-empty:hover{color:#9ca3af}.tc-slot-editing{border-color:#a78bfa;color:#e2e8f0;background:#1e1b4b}.tc-slot-live{border-color:#10b981;color:#10b981;background:#052e16}.tc-editor{display:flex;flex-direction:column;gap:7px;padding-top:8px;border-top:1px solid #2d3748;margin-top:4px}.tc-editor-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tc-editor-label{font-size:11px;color:#6b7280;width:42px;flex-shrink:0}.tc-editor-input{flex:1;background:#111827;border:1px solid #374151;border-radius:5px;color:#e2e8f0;font-size:12px;padding:5px 8px;font-family:inherit;min-width:0}.tc-editor-input:focus{outline:none;border-color:#7c3aed}.tc-editor-chips{display:flex;gap:4px;flex-wrap:wrap}.tc-chip{background:#1f2937;border:1px solid #374151;border-radius:4px;color:#9ca3af;font-size:11px;padding:3px 7px;cursor:pointer;white-space:nowrap}.tc-chip:hover{border-color:#7c3aed;color:#e2e8f0}.tc-chip-active{background:#4c1d95;border-color:#7c3aed;color:#e2e8f0}.tc-editor-actions{display:flex;gap:6px;margin-top:2px}.tc-btn-show{background:#059669;border:none;border-radius:5px;color:#fff;font-size:12px;font-weight:600;padding:5px 14px;cursor:pointer}.tc-btn-show:hover{background:#047857}.tc-btn-hide{background:#374151;border:none;border-radius:5px;color:#e2e8f0;font-size:12px;font-weight:600;padding:5px 14px;cursor:pointer}.tc-btn-hide:hover{background:#4b5563}.tc-btn-delete{background:none;border:1px solid #374151;border-radius:5px;color:#6b7280;font-size:12px;padding:5px 10px;cursor:pointer;margin-left:auto}.tc-btn-delete:hover{border-color:#ef4444;color:#ef4444}.tc-font-size-row{display:flex;align-items:center;gap:6px;flex:1}.tc-font-size-val{font-size:11px;color:#9ca3af;width:28px;text-align:right}.vc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px 0}.vc-slot{background:#1a1a2e;border:1px solid #2d3748;border-radius:5px;padding:6px 8px;font-size:11px;color:#9ca3af;cursor:pointer;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:border-color .15s,color .15s;min-height:40px;display:flex;align-items:center}.vc-slot:hover{border-color:#7c3aed;color:#e2e8f0}.vc-slot-empty{color:#4b5563;border-style:dashed}.vc-slot-empty:hover{color:#9ca3af}.vc-slot-active{border-color:#10b981;color:#10b981;background:#052e16}.vc-controls{display:flex;flex-direction:column;gap:6px;padding-top:8px;border-top:1px solid #2d3748;margin-top:4px}.vc-controls-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.vc-label{font-size:11px;color:#6b7280;width:42px;flex-shrink:0}.vc-corner-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:72px}.vc-corner-btn{background:#1f2937;border:1px solid #374151;border-radius:3px;color:#9ca3af;font-size:13px;padding:3px;cursor:pointer;text-align:center}.vc-corner-btn:hover{border-color:#7c3aed;color:#e2e8f0}.vc-corner-btn-active{background:#4c1d95;border-color:#7c3aed;color:#e2e8f0}.vc-stop-btn{background:#dc2626;border:none;border-radius:5px;color:#fff;font-size:12px;font-weight:600;padding:5px 14px;cursor:pointer}.vc-stop-btn:hover{background:#b91c1c}
