.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.map-root{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(1200px 700px at 50% 18%,#11141d,#080a0f 60%,#06070b);color:#eef1f6}.map-root .react-flow{background:transparent}.map-root .react-flow__controls{background:#11141d;border:1px solid #232838;border-radius:10px;overflow:hidden}.map-root .react-flow__controls button{background:#11141d;color:#cdd4e0;border-bottom:1px solid #232838}.map-root .react-flow__controls button:hover{background:#1a1f2c}.tl{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 0 0 1px #232838,0 18px 60px #00000080;background:#0b0d14}.tl-cv{display:block}.tl-play{position:absolute;top:0;bottom:0;width:2px;left:0;background:#fff;box-shadow:0 0 10px #fff;pointer-events:none}.kf{width:188px;border-radius:13px;overflow:hidden;cursor:pointer;background:#0c0e15;box-shadow:0 0 0 1px #262c3c,0 10px 28px #00000073;transition:transform .18s cubic-bezier(.2,.8,.3,1),box-shadow .18s}.kf:hover{transform:scale(1.14);box-shadow:0 0 0 1.5px #ff9bb0,0 22px 50px #000000a6;z-index:10}.kf img{display:block;width:100%;aspect-ratio:16/9;object-fit:cover}.kf-mood{padding:6px 9px;font-size:12px;color:#c8cfdd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kf-climax{box-shadow:0 0 0 1.5px #ff4d6d,0 0 26px #ff4d6d73}.kf-flag{position:absolute;top:7px;left:7px;background:#ff4d6d;color:#fff;font-size:11px;padding:2px 7px;border-radius:20px;font-weight:600}.kf-sel{box-shadow:0 0 0 2px #7fd0ff,0 0 30px #7fd0ff66}.map-hud{position:fixed;bottom:18px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;max-width:94vw;flex-wrap:wrap;justify-content:center;background:#11141ddb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #232838;border-radius:14px;padding:10px 14px;z-index:21}.hud-play{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;background:#ff4d6d;color:#fff;display:grid;place-items:center}.hud-play.on{background:#2a3142}.hud-play svg,.sb-play svg{display:block}.hud-play,.sb-play{display:grid;place-items:center;padding:0;line-height:0}.hud-meta{display:flex;flex-direction:column;line-height:1.35}.hud-meta b{font-size:14px}.hud-meta .nm-muted{font-size:12px;color:#8c97ab;margin-top:4px}.dock-songsel{background:transparent;border:none;color:#eef1f6;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;padding:2px 20px 2px 4px;margin:-2px 0 2px;border-radius:6px;width:fit-content;max-width:220px;align-self:flex-start;outline:none;transition:background .12s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238c97ab' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.dock-songsel:hover{background-color:#ffffff12}.dock-songsel option{background:#11141d;color:#eef1f6}.hud-title-txt{font-size:14px;display:inline-flex;align-items:center;gap:5px}.hud-edit{border:none;background:transparent;color:#6b7587;cursor:pointer;font-size:12px;padding:2px 4px;border-radius:6px;line-height:1;opacity:0;transition:opacity .12s,color .12s,background .12s}.hud-meta:hover .hud-edit{opacity:1}.hud-edit:hover{color:#ff9bb0;background:#ffffff12}.hud-title-edit{background:#0c0e15;border:1px solid #2a3142;color:#eef1f6;font-size:14px;font-weight:700;font-family:inherit;padding:4px 9px;border-radius:8px;max-width:260px;width:100%;box-sizing:border-box;outline:none;transition:border-color .12s,box-shadow .12s}.hud-title-edit:focus{border-color:#ff4d6d;box-shadow:0 0 0 3px #ff4d6d2e}.map-pop{position:fixed;top:0;right:0;bottom:0;left:0;background:#040509b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:50}.pop-card{position:relative;width:min(560px,92vw);background:#11141d;border:1px solid #262c3c;border-radius:16px;overflow:hidden;box-shadow:0 30px 90px #0009}.pop-card img{width:100%;display:block}.pop-body{padding:14px 18px 18px}.pop-time{font-size:12px;color:#ff9bb0;letter-spacing:.04em;margin-bottom:6px}.pop-body p{margin:0;color:#d7dce6;line-height:1.5}.intro-card{width:min(460px,92vw);text-align:center}.intro-card h1{font-size:26px;margin:0 0 6px}.intro-card>p{color:#9aa4b8;margin:0 0 22px}.intro-drop{border:1.5px dashed #2e3850;border-radius:16px;padding:34px 20px;cursor:pointer;background:#0c0e15;transition:border-color .15s,background .15s}.intro-drop:hover{border-color:#ff4d6d;background:#0f1219}.drop-ico{font-size:30px;margin-bottom:8px}.intro-drop .nm-muted{display:block;margin-top:6px;font-size:12px;color:#6b7280}.intro-or{color:#5c6678;margin:16px 0;font-size:13px}.intro-yt{width:100%;box-sizing:border-box;background:#0c0e15;border:1px solid #262c3c;border-radius:10px;padding:12px 14px;color:#eef1f6;font-size:14px}.intro-yt::placeholder{color:#5c6678}.intro-go{width:100%;margin-top:16px;padding:12px;border:none;border-radius:10px;background:#ff4d6d;color:#fff;font-size:14px;cursor:pointer}.nm-muted{color:#8c97ab}.kf-play{position:absolute;bottom:30px;right:7px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;font-size:10px;display:grid;place-items:center;opacity:.85}.kf:hover .kf-play{background:#ff4d6d;opacity:1}.hud-final{margin-left:6px;border:none;cursor:pointer;background:#1f2533;color:#eef1f6;border:1px solid #313749;border-radius:10px;padding:9px 13px;font-size:13px}.hud-final:hover{background:#2a3142;border-color:#ff4d6d}.hud-diem{font-size:.9em;opacity:.7;font-weight:600;white-space:nowrap}.hud-final.pulse{border-color:#ff4d6d;animation:hudpulse 1.4s ease-out infinite}@keyframes hudpulse{0%,to{box-shadow:0 0 #ff4d6d8c}50%{box-shadow:0 0 0 7px #ff4d6d00}}.hud-final.pulse-big{border-color:#ff4d6d;font-weight:700;background:#2a1820;animation:hudpulsebig 1.05s ease-out infinite}@keyframes hudpulsebig{0%,to{box-shadow:0 0 #ff4d6db3;transform:scale(1)}50%{box-shadow:0 0 0 12px #ff4d6d00;transform:scale(1.06)}}.map-root.ready-final .react-flow__node{animation:shotready 1.8s ease-in-out infinite}@keyframes shotready{0%,to{filter:brightness(1)}50%{filter:brightness(1.18) saturate(1.1)}}.final-card{width:min(900px,94vw);position:relative}.final-close{position:absolute;top:-38px;right:0;background:#11141dd9;color:#eef1f6;border:1px solid #313749;border-radius:10px;padding:6px 12px;cursor:pointer}.pop-acts{display:flex;gap:8px;margin-top:12px}.pop-block{margin-top:14px}.pop-bl-lb{display:block;font-size:12px;font-weight:600;color:#c8cfdd;margin-bottom:6px}.pop-warn{color:#ffb86b;font-weight:400;font-size:11px}.pop-edited{color:#7ee0a3;font-weight:400;font-size:11px}.pop-btns{display:flex;gap:8px;margin-top:8px}.pop-regen{flex:1;padding:9px;border:1px solid #2a3142;border-radius:9px;background:#1a1f2c;color:#dfe4ee;font-size:13px;cursor:pointer}.pop-regen:hover:not(:disabled){background:#232a3a;border-color:#ff9bb0}.pop-regen:disabled{opacity:.5;cursor:not-allowed}.pop-revert{flex:0 0 auto;padding:9px 12px;border:1px solid #2a3142;border-radius:9px;background:#1a1f2c;color:#c8cfdd;font-size:13px;cursor:pointer;white-space:nowrap}.pop-revert:hover:not(:disabled){background:#232a3a;border-color:#7ee0a3}.pop-revert:disabled{opacity:.5;cursor:not-allowed}.pop-acts button{flex:1;background:#1a1f2c;color:#dfe4ee;border:1px solid #2a3142;border-radius:9px;padding:9px 6px;font-size:12px;cursor:pointer;white-space:nowrap}.pop-acts button:hover{background:#232a3a;border-color:#ff9bb0}.land{overflow:hidden}.land-map-live{position:absolute;top:0;right:0;bottom:0;left:0}.land-map-live .react-flow__controls{background:#11141d;border:1px solid #232838;border-radius:10px;overflow:hidden}.land-top{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:12px 18px;box-sizing:border-box;background:linear-gradient(to bottom,#06070bd9,#06070b00)}.land-brand{flex-shrink:0}.land-brand{font-size:17px;font-weight:700;color:#eef1f6}.land-brand .beta{font-size:10px;color:#ffcf6b;border:1px solid #5a4a1e;border-radius:6px;padding:1px 6px;margin-left:6px;vertical-align:middle}.land-trybtn{flex:0 0 auto;width:auto;background:#ff4d6d;color:#fff;border:none;border-radius:22px;padding:10px 22px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:0 6px 18px #ff4d6d66}.land-trybtn:hover{background:#ff6b86}.trybtn-wrap{position:relative;flex-shrink:0;display:inline-block}.trybtn-gis{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;overflow:hidden;cursor:pointer}.trybtn-gis>div,.trybtn-gis iframe{width:100%!important;height:100%!important}.land-dock{position:fixed;bottom:18px;left:50%;transform:translate(-50%);z-index:22;display:flex;align-items:center;gap:12px;max-width:94vw;background:#11141de0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #232838;border-radius:18px;padding:10px 14px;box-shadow:0 14px 50px #00000080}.dock-play{width:44px;height:44px;flex-shrink:0;border-radius:50%;border:none;background:#ff4d6d;color:#fff;font-size:15px;cursor:pointer}.dock-play.on{background:#2a3142}.dock-songs{display:flex;gap:8px;overflow-x:auto}.dock-watch{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;cursor:pointer;background:linear-gradient(135deg,#ff4d6d,#ff7a52);color:#fff;border:none;border-radius:12px;padding:11px 20px;font-size:14px;font-weight:700;white-space:nowrap;box-shadow:0 6px 20px #ff4d6d61;transition:transform .12s,box-shadow .12s}.dock-watch:hover{transform:translateY(-1px);box-shadow:0 10px 26px #ff4d6d80}.land.playing .land-map-live{inset:0 0 auto 0;height:46vh;transition:height .35s ease}.mv-player{position:fixed;left:50%;bottom:26px;transform:translate(-50%);z-index:25;width:min(900px,92vw);animation:mvzoom .4s cubic-bezier(.2,.8,.3,1)}.mv-player video{width:100%;display:block;border-radius:16px;box-shadow:0 24px 80px #000000bf}.mv-close{position:absolute;top:-38px;right:0;background:#11141de0;color:#eef1f6;border:1px solid #313749;border-radius:10px;padding:6px 13px;cursor:pointer}@keyframes mvzoom{0%{opacity:0;transform:translate(-50%) scale(.55) translateY(60px)}to{opacity:1;transform:translate(-50%) scale(1) translateY(0)}}.kf-active{box-shadow:0 0 0 2px #ff4d6d,0 0 32px #ff4d6da6!important;z-index:6}.kf.kf-active img{transform:scale(1.04)}.kf-gen{animation:kfgen 1.1s ease-in-out infinite;z-index:7}.kf-gen:after{content:"● đang tạo";position:absolute;top:-9px;left:50%;transform:translate(-50%);font-size:9px;font-weight:700;color:#061018;background:#4da3ff;padding:1px 7px;border-radius:7px;white-space:nowrap}@keyframes kfgen{0%,to{box-shadow:0 0 0 2px #4da3ff,0 0 16px #4da3ff66}50%{box-shadow:0 0 0 3px #4da3ff,0 0 36px #4da3fff2}}.sc-item{display:flex;align-items:center;gap:9px;background:#0f1219;border:1px solid #262c3c;border-radius:11px;padding:5px 13px 5px 5px;cursor:pointer;white-space:nowrap}.sc-item:hover{border-color:#3a4256}.sc-item.on{border-color:#ff4d6d;background:#1a1320}.sc-item img{width:52px;height:30px;object-fit:cover;border-radius:6px}.sc-info{display:flex;flex-direction:column;text-align:left}.sc-info b{font-size:13px;color:#eef1f6}.sc-info span{font-size:11px;color:#8c97ab}.ws-stepbar{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:6px;max-width:94vw;overflow-x:auto;background:#11141dd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #232838;border-radius:16px;padding:5px 6px}.ws-stepitem{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7688;padding:6px 14px;border-radius:11px;white-space:nowrap;flex-shrink:0}@media(max-width:720px){.ws-stepitem{padding:5px 8px;font-size:12px}.ws-stepbar{gap:4px}}.ws-stepitem .ws-stepnum{width:19px;height:19px;border-radius:50%;background:#2a3142;color:#aab2c2;display:grid;place-items:center;font-size:11px}.ws-stepitem.on{color:#fff;background:#ff4d6d22}.ws-stepitem.on .ws-stepnum{background:#ff4d6d;color:#fff}.ws-stepitem.done{color:#9aa4b8}.ws-stepitem.done .ws-stepnum{background:#2f6b46;color:#cfe}.lang-sel{flex-shrink:0;height:28px;max-width:132px;padding:0 6px;margin-left:6px;cursor:pointer;border:1px solid #2c3346;border-radius:8px;background:#282e3eb3;color:#c4ccda;font-size:12px;font-weight:600;vertical-align:middle}.lang-sel:hover{border-color:#6f86ff;background:#6f86ff24;color:#eef1f6}.lang-sel option{background:#11141d;color:#eef1f6}.land-brand .lang-sel{font-weight:600}.ov-center{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:15}.cf-gender{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.cf-gender select{background:#0c0e15;color:#eef1f6;border:1px solid #2a3142;border-radius:8px;padding:7px 10px}.confirm-card .primary{width:100%}.kf-scene{width:100%;aspect-ratio:16/9;display:grid;place-items:center;text-align:center;background:linear-gradient(135deg,#161a26,#1d2233);color:#9aa4b8;font-size:12px;padding:8px}.pop-scene{aspect-ratio:16/9;display:grid;place-items:center;background:linear-gradient(135deg,#161a26,#1d2233);color:#c8cfdd;font-size:15px}.pop-edit{width:100%;box-sizing:border-box;min-height:70px;background:#0c0e15;color:#eef1f6;border:1px solid #2a3142;border-radius:9px;padding:10px;font-size:13px;resize:vertical;margin-bottom:4px}.ws-usermenu{position:fixed;top:14px;right:18px;z-index:22}.step-songsel{background:#0f1219;color:#eef1f6;border:1px solid #2a3142;border-radius:9px;padding:6px 11px;font-size:13px;cursor:pointer;max-width:280px}.ws-songbar{position:fixed;top:14px;left:18px;z-index:22;display:flex;align-items:center;gap:6px}.cf-wide{width:min(900px,95vw)}.struct-cv{width:100%;height:54px;display:block;border-radius:10px;box-shadow:0 0 0 1px #1f2433;margin-bottom:14px;background:#0b0d14}.ghost.danger{border-color:#5a2230;color:#ff8197}.ghost.danger:hover{border-color:#ff4d6d;background:#ff4d6d14;color:#ff9bb0}.songbar-del{flex-shrink:0;width:36px;height:36px;border-radius:10px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;line-height:1;background:#0f1219;border:1px solid #2a3142;color:#ff8197;font-size:15px}.songbar-del:hover{border-color:#ff4d6d;background:#ff4d6d14}.songbar-new{flex-shrink:0;height:36px;padding:0 12px;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:4px;line-height:1;white-space:nowrap;background:#0f1219;border:1px solid #2a3142;color:#9fb4ff;font-size:13px;font-weight:600}.songbar-new:hover{border-color:#6f86ff;background:#6f86ff1a}.songbar-new:disabled{opacity:.4;cursor:not-allowed}.cf-acts{display:flex;gap:10px;margin-top:6px}.cf-acts .primary{flex:1}.ghost{background:transparent;border:1px solid #313749;color:#aab2c2;border-radius:10px;padding:12px 16px;font-size:14px;cursor:pointer;white-space:nowrap}.ghost:hover{border-color:#ff4d6d;color:#fff}.pop-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:51;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;background:#11141dc7;color:#fff;font-size:24px;line-height:1;display:grid;place-items:center;transition:background .15s}.pop-nav:hover{background:#ff4d6d}.pop-nav.prev{left:24px}.pop-nav.next{right:24px}.pop-card{max-height:92vh;display:flex;flex-direction:column}.pop-card video,.pop-card img{max-height:64vh;object-fit:contain;background:#000}.pop-body{overflow-y:auto}.cf-ratio{display:flex;gap:8px;margin:4px 0 12px}.cf-ratio button{flex:1;background:#0c0e15;border:1px solid #2a3142;color:#aab2c2;border-radius:10px;padding:9px;font-size:13px;cursor:pointer}.cf-ratio button.on{border-color:#ff4d6d;color:#fff;background:#1a1320}.cf-styles{display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 10px}.cf-styles button{background:#0c0e15;border:1px solid #2a3142;color:#aab2c2;border-radius:20px;padding:7px 14px;font-size:13px;cursor:pointer}.cf-styles button.on{border-color:#ff4d6d;color:#fff;background:#1a1320}.cf-brief{width:100%;box-sizing:border-box;background:#0c0e15;border:1px solid #262c3c;border-radius:10px;padding:10px 12px;color:#eef1f6;font-size:13px;resize:vertical;min-height:54px;margin-bottom:12px}.cf-brief::placeholder{color:#5c6678}.pop-edit{width:100%;box-sizing:border-box;background:#0c0e15;border:1px solid #2a3142;border-radius:9px;padding:9px 11px;color:#eef1f6;font-size:13px;resize:vertical;min-height:60px;margin:8px 0}.sb-player{display:flex;align-items:center;gap:12px;margin:8px 0 14px}.sb-play{flex-shrink:0;width:46px;height:46px;border-radius:50%;border:none;cursor:pointer;background:#ff4d6d;color:#fff;font-size:15px}.sb-play.on{background:#2a3142}.sb-play:hover{background:#ff6b86}.sb-wrap{position:relative;flex:1;min-width:0;height:64px;cursor:pointer;border-radius:10px;overflow:hidden;box-shadow:0 0 0 1px #1f2433;background:#0b0d14}.sb-wrap .struct-cv{width:100%;height:100%;display:block;vertical-align:top}.sb-head{position:absolute;top:0;bottom:0;width:2px;left:0;background:#fff;box-shadow:0 0 8px #fff;pointer-events:none}.cf-cols{display:grid;grid-template-columns:1fr 320px;gap:22px;text-align:left}.cf-left{min-width:0}.cf-chips{display:flex;flex-wrap:wrap;gap:7px;margin:4px 0 12px}.cf-chips span{background:#11141d;border:1px solid #232838;border-radius:8px;padding:5px 10px;font-size:12px;color:#c8cfdd;white-space:nowrap}.cf-chips span.hot{border-color:#5a2230;color:#ff9bb0}.cf-lyric{max-height:220px;overflow-y:auto;white-space:pre-wrap;line-height:1.6;font-size:13px;color:#aab2c2;background:#0b0d14;border:1px solid #1f2433;border-radius:10px;padding:12px 14px}.cf-right{display:flex;flex-direction:column}@media(max-width:760px){.cf-cols{grid-template-columns:1fr}.cf-right{margin-top:8px}}.sb-wrap{box-shadow:none!important;border:1px solid #232838}.cf-lyric{display:flex;flex-direction:column;gap:4px}.cf-ly{display:flex;gap:8px;align-items:baseline}.cf-ly-t{flex-shrink:0;font-size:11px;color:#5c6678;font-variant-numeric:tabular-nums;min-width:30px}.cf-ly-x{white-space:pre-line}.cf-title{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.cf-title h2{margin:0;font-size:20px;font-weight:700;color:#fff;line-height:1.3;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cf-badge{flex-shrink:0;font-size:11px;color:#6ee7a8;border:1px solid #2f6b46;border-radius:20px;padding:2px 10px;white-space:nowrap}.cf-field{margin-bottom:14px}.cf-lb{display:block;font-size:12px;color:#8c97ab;margin-bottom:7px;font-weight:500}.cf-count{float:right;font-style:normal;font-size:11px;font-weight:600;color:#6b7587}.pop-edwrap{position:relative}.pop-cnt{position:absolute;right:9px;bottom:9px;float:none;background:#0c0e15b8;padding:1px 7px;border-radius:6px;pointer-events:none}.cf-style-in{width:100%;box-sizing:border-box;background:#0c0e15;border:1px solid #262c3c;border-radius:10px;padding:10px 13px;color:#eef1f6;font-size:13px;margin-bottom:8px;font-family:inherit;line-height:1.5;resize:vertical;min-height:42px}.cf-style-in:focus{outline:none;border-color:#ff4d6d}.cf-style-in::placeholder{color:#5c6678}.cf-styles button{padding:6px 12px;font-size:12px}.cf-brief{margin-bottom:0}.cf-gender,.cf-ratio{margin-bottom:14px}@media(max-width:640px){.ws-stepbar{top:54px;gap:2px;padding:4px 6px;max-width:96vw}.ws-stepitem{padding:5px 7px;font-size:11px;gap:5px}.ws-stepitem .ws-stepnum{width:18px;height:18px}.lang-sel{height:26px;max-width:50px;margin-left:4px;padding:0 4px;font-size:11px;text-overflow:ellipsis}.ws-songbar{left:8px;top:9px;gap:4px;max-width:140px}.step-songsel{max-width:84px;padding:8px;font-size:12px;text-overflow:ellipsis}.songbar-new{width:36px;height:36px;padding:0;justify-content:center;font-size:0}.songbar-new:before{content:"+";font-size:18px;line-height:1}.songbar-del{width:36px;height:36px;font-size:15px}.ws-usermenu{right:8px;top:9px}.ws-usermenu .um-name{display:none}.ws-usermenu .usermenu-btn{gap:5px;padding:6px 9px}.ws-usermenu .um-credit{font-size:12px}.cf-wide{width:94vw}.cf-cols{grid-template-columns:1fr;gap:16px}.cf-right{margin-top:4px}.cf-acts{flex-wrap:wrap}.sb-play{width:40px;height:40px}.map-hud{bottom:10px;padding:7px 10px;gap:8px;max-width:94vw;width:94vw;flex-wrap:nowrap;justify-content:space-between;box-sizing:border-box}.hud-play{width:40px;height:40px;flex-shrink:0;font-size:14px}.hud-meta{min-width:0;flex:1 1 auto;overflow:hidden}.hud-meta b,.hud-meta .hud-title-txt{font-size:13px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hud-meta .nm-muted{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.hud-edit{opacity:1;flex-shrink:0}.hud-final{flex-shrink:0;padding:0 12px;min-height:38px;font-size:12px;margin-left:0;white-space:nowrap;display:inline-flex;align-items:center}.hud-title-edit{max-width:150px}.dock-watch{flex-shrink:0;padding:0 14px;min-height:38px;font-size:12px;gap:5px;box-shadow:0 4px 14px #ff4d6d57}.pop-card{width:94vw}.pop-card video,.pop-card img{max-height:52vh}.pop-nav{width:38px;height:38px;font-size:20px}.pop-nav.prev{left:4px}.pop-nav.next{right:4px}.pop-btns{flex-wrap:wrap}.pop-regen,.pop-revert{min-height:38px}.map-root .react-flow__controls,.land .react-flow__controls{bottom:86px}.land-top{padding:9px 11px;gap:8px;flex-wrap:wrap}.land-brand{font-size:15px;display:flex;align-items:center;gap:6px;min-width:0}.land-trybtn{padding:0 18px;min-height:40px;font-size:13px}.land .lang-sel{height:36px;min-height:36px;max-width:76px;margin-left:0;font-size:12px;padding:0 6px}.land .ws-songbar{top:100px;left:10px;max-width:60vw}.land .step-songsel{max-width:56vw;min-height:36px}.land .hud-play{width:40px;height:40px}.land .dock-watch{min-height:38px}.dock-songs{max-width:46vw}}@media(max-width:414px){.ws-stepbar{max-width:98vw;gap:1px;padding:4px}.ws-stepitem{padding:5px;font-size:10.5px;gap:4px}.ws-stepitem .ws-stepnum{width:17px;height:17px;font-size:10px}.lang-sel{max-width:42px}.ws-songbar{max-width:124px}.step-songsel{max-width:72px}.cf-chips span{font-size:11px;padding:4px 8px}.map-hud{gap:6px;padding:7px 9px}.land .land-brand .beta{display:none}.land .land-brand{font-size:14px}.land .lang-sel{max-width:64px;font-size:11px}.land-trybtn{padding:0 14px;font-size:12px}.land .ws-songbar{max-width:70vw}.land .step-songsel{max-width:64vw}}.map-root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(255,120,150,.24) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,255,.21) 1px,transparent 1px);background-size:46px 46px;transform:perspective(620px) rotateX(62deg) scale(2.4);transform-origin:50% 88%;-webkit-mask-image:linear-gradient(to top,#000 5%,transparent 78%);mask-image:linear-gradient(to top,#000 5%,transparent 78%);animation:gridflow 22s linear infinite;opacity:.95}.map-root:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(255,120,150,.13) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,255,.11) 1px,transparent 1px);background-size:46px 46px;transform:perspective(620px) rotateX(-62deg) scale(2.4);transform-origin:50% 12%;-webkit-mask-image:linear-gradient(to bottom,#000 5%,transparent 72%);mask-image:linear-gradient(to bottom,#000 5%,transparent 72%);animation:gridflowdn 26s linear infinite;opacity:.8}@keyframes gridflow{0%{background-position:0 0}to{background-position:0 46px}}@keyframes gridflowdn{0%{background-position:0 46px}to{background-position:0 0}}.lf-floor{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;overflow:hidden;perspective:620px;perspective-origin:50% 88%}.lf-stage{position:absolute;left:50%;bottom:15%;width:min(880px,92vw);height:0;transform:translate(-50%) rotateX(62deg);transform-origin:50% 100%;transform-style:preserve-3d}.lf-line{position:absolute;left:50%;bottom:0;white-space:nowrap;will-change:transform,opacity,filter;backface-visibility:hidden;font-weight:800;letter-spacing:.01em;line-height:1.1;font-size:clamp(20px,4.4vw,46px);transform:translate3d(-50%,0,0)}.lf-base{position:relative;display:inline-block}.lf-fill{position:absolute;left:0;top:0}.lf-base{color:#96a5c852;-webkit-text-stroke:.5px rgba(120,140,190,.25);text-shadow:0 1px 0 rgba(0,0,0,.5)}.lf-fill{color:#fff;background:linear-gradient(90deg,#ffd86b,#ff6b9d 55%,#b98bff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 18px rgba(255,140,180,.55),0 0 40px rgba(180,120,255,.35);filter:drop-shadow(0 0 6px rgba(255,180,210,.6))}@media(max-width:640px){.lf-stage{width:94vw;bottom:12%}.lf-line{font-size:clamp(17px,6.2vw,34px)}}.map-root .react-flow,.land .land-map-live{position:absolute;z-index:4}.flow-shell{position:absolute;top:0;right:0;bottom:0;left:0;transition:transform .6s cubic-bezier(.2,.8,.3,1)}.map-root.watching .flow-shell{transform:translateY(-34vh)}.map-root.watching .react-flow{opacity:.95;pointer-events:none}.mv-stage{position:fixed;left:50%;top:53%;transform:translate(-50%,-50%);width:min(820px,64vw);z-index:30;perspective:1500px;animation:mvstage-in .55s cubic-bezier(.2,.8,.3,1)}.mv-stage video{width:100%;display:block;border-radius:14px;transform:rotateX(11deg);transform-origin:50% 80%;border:1px solid rgba(255,155,180,.4);box-shadow:0 0 0 1px #ff78964d,0 40px 90px #000000c7,0 0 90px #ff5a824d,0 0 180px #788cff33;background:#000}.mv-stage:after{content:"";position:absolute;left:50%;bottom:-9%;transform:translate(-50%);width:84%;height:60px;border-radius:50%;pointer-events:none;background:radial-gradient(ellipse at center,rgba(255,90,130,.34),rgba(120,140,255,.12) 45%,transparent 72%);filter:blur(16px)}.mv-close{position:absolute;top:10px;right:10px;z-index:2;width:30px;height:30px;padding:0;display:grid;place-items:center;border-radius:50%;font-size:20px;line-height:1;font-weight:300;background:#080a0f8c;color:#fff;border:1px solid rgba(255,255,255,.22);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:transform .15s,border-color .15s,background .15s}.mv-close:hover{border-color:#ff4d6d;background:#ff4d6d73;transform:scale(1.12)}.mv-close svg{display:block}.mv-playbtn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;width:76px;height:76px;border-radius:50%;border:none;cursor:pointer;padding:0;background:#ff4d6deb;color:#fff;display:grid;place-items:center;box-shadow:0 10px 36px #ff4d6d8c,0 0 0 8px #ff4d6d26;transition:transform .15s,background .15s}.mv-playbtn svg{display:block}.mv-playbtn:hover{transform:translate(-50%,-50%) scale(1.08);background:#ff4d6d}@keyframes mvstage-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 36px)) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.map-root.watching .map-hud{opacity:.55;transition:opacity .3s}.map-root.watching .map-hud:hover{opacity:1}.map-root.watching .map-hud .hud-play,.map-root.watching .map-hud .dock-watch,.map-root.watching .map-hud .hud-final,.map-root.watching .react-flow__controls{display:none}.map-root.watching .lf-stage{bottom:9%;transition:bottom .5s ease}@media(max-width:640px){.map-root.watching .react-flow{height:100%;opacity:1;pointer-events:auto}.map-root.watching .map-hud{opacity:1}.mv-stage{display:none}.map-root:after{opacity:.4}}.ws-busy{position:fixed;top:66px;left:50%;transform:translate(-50%);z-index:40;display:flex;align-items:center;gap:11px;padding:8px 18px 8px 10px;border-radius:30px;background:#11141deb;border:1px solid #2a3142;box-shadow:0 12px 40px #00000080}.ws-orbit{position:relative;width:30px;height:30px;flex-shrink:0}.ws-orbit span{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid transparent;border-top-color:#ff4d6d;animation:orbit 1.1s cubic-bezier(.5,.1,.5,.9) infinite}.ws-orbit span:nth-child(2){top:5px;right:5px;bottom:5px;left:5px;border-top-color:#7fb0ff;animation-duration:1.5s;animation-direction:reverse}.ws-orbit span:nth-child(3){top:10px;right:10px;bottom:10px;left:10px;border-top-color:#ffcf6b;animation-duration:.9s}@keyframes orbit{to{transform:rotate(360deg)}}.ws-busy-txt{font-size:13px;font-weight:600;color:#fff;white-space:nowrap}.ws-busy-sub{font-size:12px;color:#8c97ab;animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@media(max-width:640px){.ws-busy{top:58px;padding:7px 14px 7px 9px}.ws-busy-txt{font-size:12px}}.intro-loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px}.intro-loading .ws-orbit{width:56px;height:56px}.intro-loading .ws-orbit span:nth-child(2){top:8px;right:8px;bottom:8px;left:8px}.intro-loading .ws-orbit span:nth-child(3){top:16px;right:16px;bottom:16px;left:16px}.intro-loading .ws-busy-txt{font-size:16px}.ws-stop{margin-top:6px;background:transparent;border:1px solid #5a2230;color:#ff8197;border-radius:20px;padding:7px 18px;font-size:13px;cursor:pointer}.ws-stop:hover{border-color:#ff4d6d;background:#ff4d6d1a;color:#ff9bb0}.ws-stop.pill{margin:0 0 0 4px;padding:5px 13px;font-size:12px}:root{--bg: #0a0b0f;--panel: #14161e;--line: #2e3340;--txt: #f0f2f5;--mut: #c2c8d4;--acc: #ff4d6d;--ok: #4cd98a;--lock: #3a3f4a}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--txt);font:17px/1.6 system-ui,Segoe UI,Roboto,sans-serif}.app{max-width:1480px;margin:0 auto;padding:20px}.top{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}.top .proj{color:var(--mut)}.top button{margin-left:auto}button{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--txt);border-radius:8px;padding:9px 16px;font-size:15px}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--acc);border-color:var(--acc);color:#fff;font-weight:600}button.danger{background:#b3203a;border-color:#b3203a;color:#fff}button.ghost{background:transparent}button.mini{padding:3px 9px;font-size:13px}.ghost.mini.is-disabled{opacity:.45;pointer-events:none}.err{color:#ff7a90}.lyric-missing{display:inline-block;color:#ffce6b;font-weight:700;background:#ffb0201f;border:1px solid rgba(255,176,32,.5);border-radius:6px;padding:2px 8px}.muted{color:var(--mut)}textarea,input[type=text],input[type=search],input:not([type]){background:#0f1219;color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:11px 13px;font:inherit;width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s,background .15s}textarea{resize:vertical;line-height:1.55}textarea:focus,input:focus{outline:none;border-color:var(--acc);background:#12141d;box-shadow:0 0 0 3px #ff4d6d29}textarea::placeholder,input::placeholder{color:#5d6470}.newproj{max-width:560px;margin:40px auto;display:flex;flex-direction:column;gap:12px}.newproj .row{display:flex;gap:8px}.newproj textarea{white-space:pre-wrap;line-height:1.5;resize:vertical}.ratio-pick{display:flex;flex-direction:column;gap:8px}.ratio-label{font-size:18px;font-weight:700;color:var(--txt)}.ratio-opts{display:flex;gap:10px}.ratio-opt{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--txt);transition:all .12s}.ratio-opt:hover{border-color:#4a5263}.ratio-opt.on{border-color:var(--ok);background:#143020;color:#fff;box-shadow:0 0 0 1px var(--ok) inset}.ratio-box{display:inline-block;background:#4a5263;border-radius:2px}.ratio-opt.on .ratio-box{background:var(--ok)}.ratio-box.land{width:26px;height:15px}.ratio-box.port{width:15px;height:26px}.create-btn{background:var(--ok);border:none;color:#08130c;font-weight:700;font-size:16px;padding:13px;border-radius:10px;cursor:pointer}.create-btn:hover:not(:disabled){filter:brightness(1.08)}.create-btn:disabled{background:#243a2e;color:#6f8a7b;cursor:not-allowed}.lipsync-row{display:flex;align-items:center;gap:9px;margin-top:-2px;font-size:15px;color:var(--txt);cursor:pointer;-webkit-user-select:none;user-select:none}.lipsync-row input{width:17px;height:17px;cursor:pointer;accent-color:var(--ok);flex:none}.help-q{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;background:#5a6b7a;color:#fff;font-size:11px;font-weight:700;cursor:help;flex:none}.help-q:hover{background:var(--ok);color:#08130c}.stepbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:16px 0}.step{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#f0f2f5}.step:disabled{opacity:.9;cursor:not-allowed}.step.run:disabled{opacity:1}.step.locked:disabled{opacity:.6}@keyframes spin{to{transform:rotate(360deg)}}.step .ic.spinning{display:inline-block;animation:spin 1s linear infinite}.step.ready{background:#1c2740;border-color:#5585ff}.step.done{background:#14301f;border-color:#4cd98a}.step.locked{background:#20232c;border-color:#4a5263;color:#aeb6c4}.step.run{background:#3a1119;border-color:var(--acc)}.step .ic{font-weight:700;font-size:16px}.step.ready .ic{color:#7aaaff}.step.done .ic{color:#4cd98a}.step.run .ic{color:var(--acc)}.steprow{display:flex;align-items:flex-start;gap:20px;width:100%}.steps{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;flex:1 1 auto;min-width:0}.step-col{display:flex;flex-direction:column;align-items:stretch;gap:8px;position:relative}.step-arrow{flex:0 0 auto;align-self:flex-start;height:50px;display:inline-flex;align-items:center;color:#aab2c0;font-size:20px;font-weight:800;-webkit-user-select:none;user-select:none}.step{min-height:50px}.step{position:relative}.step.viewing{box-shadow:0 0 0 2px #fff,0 0 12px #fff5}.view-badge{position:absolute;top:-9px;right:-7px;width:22px;height:22px;display:grid;place-items:center;background:#fff;font-size:12px;border-radius:50%;box-shadow:0 2px 6px #0008}.step-act{font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:8px;align-self:center;width:auto}.step-act.muted{border:none;background:transparent;color:#aab2c0}.act-run{color:var(--acc);font-weight:600}.confirm{color:#ffd0d8;gap:8px;flex-wrap:wrap}.confirm .mini,.step-act.mini{padding:4px 10px;font-size:13px}.stepbar-right{flex:0 0 auto;align-self:flex-start;margin-left:auto;padding-left:24px;border-left:1px solid var(--line)}.jobinfo{display:inline-block;margin-top:10px;color:#c2c8d4;font-size:13px;background:#14161e;border:1px solid var(--line);border-radius:6px;padding:5px 12px}.tabview{padding-top:8px}.step.ready{cursor:pointer}.step.locked:disabled{cursor:not-allowed;opacity:.8}.player{background:linear-gradient(135deg,#16181f,#1d1622);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:16px}.player-top{display:flex;align-items:center;gap:18px}.disc-wrap{position:relative;width:76px;height:76px;flex:0 0 auto}.disc{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,#1b1b24 0,#1b1b24 2px,#2e2e3a 2px,#2e2e3a 4px),radial-gradient(circle at 50% 50%,#ff4d6d 0,#ff4d6d 16%,#23232e 16%,#23232e);box-shadow:0 6px 20px #0000008c,inset 0 0 0 2px #4a4a58}.disc:before{content:"";position:absolute;left:50%;top:5%;width:3px;height:30%;transform:translate(-50%);border-radius:3px;background:linear-gradient(180deg,#fffc,#fff0)}.disc:after{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;transform:translate(-50%,-50%);border-radius:50%;background:#16181f;box-shadow:0 0 0 2px #ff4d6d}.disc.spin{animation:vinyl 3.2s linear infinite}@keyframes vinyl{to{transform:rotate(360deg)}}.disc-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;z-index:2;background:#ff4d6deb;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #ff4d6d80}.disc-btn:hover{background:#ff4d6d;transform:translate(-50%,-50%) scale(1.08)}.player-body{flex:1;min-width:0}.player-title{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--txt)}.wave-canvas{width:100%}.player-time{display:block;margin-top:6px;font-size:12px;color:var(--mut);font-variant-numeric:tabular-nums}.lyrics{margin-top:14px;max-height:168px;overflow-y:auto;padding:8px 4px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:3px;-webkit-mask-image:linear-gradient(transparent,#000 16%,#000 84%,transparent);mask-image:linear-gradient(transparent,#000 16%,#000 84%,transparent)}.lk{text-align:center;font-size:14px;color:#8c97ab;padding:3px 6px;border-radius:6px;cursor:pointer;transition:color .25s,transform .25s,font-size .25s}.lk:hover{color:#9aa3b5}.lk.done{color:#8089a0}.lk.on{color:#ff9bb0;font-weight:700;font-size:16px;transform:scale(1.05)}.materials{display:flex;gap:12px;flex-wrap:wrap;padding:12px 0}.thumb,.ph{position:relative}.thumb{width:108px;text-align:center;font-size:13px;color:#c2c8d4}.thumb-img{position:relative;width:108px;height:108px}.thumb-img .ph{width:108px;height:108px;aspect-ratio:auto}.thumb-img img.dim{opacity:.3;filter:blur(2px)}.thumb img{width:108px;height:108px;object-fit:cover;border-radius:8px;display:block}.thumb .mini{position:absolute;top:4px;right:4px}.ph{width:100%;aspect-ratio:16/9;display:grid;place-items:center;background:#111319;color:var(--mut);border-radius:8px;font-size:15px}.scene{border-top:1px solid var(--line);padding:14px 0}.scene-h{margin-bottom:10px}.shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.shot{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px}.shot.run{border-color:var(--acc)}.shot .media{position:relative;cursor:default;overflow:hidden;border-radius:7px;background:#0c0c0c}.shot .media img,.shot .media video{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:7px;background:#000;display:block;transition:opacity .3s ease,transform .25s ease}.shot .media img{opacity:0}.shot .media img.ready{opacity:1}.shot .media.clickable{cursor:zoom-in}.shot .media.clickable:hover img{transform:scale(1.06)}.play-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff;font-size:15px;padding-left:3px;pointer-events:none;transition:transform .2s ease,background .2s ease}.shot .media.clickable:hover .play-badge{transform:translate(-50%,-50%) scale(1.14);background:#ff4d6dd9}.shot .media.rendering{cursor:default}.shot .media.rendering img,.shot .media.rendering video{opacity:.3;filter:blur(2px)}.render-spin{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:34px;color:#fff;text-shadow:0 2px 8px #000a;animation:spin 1s linear infinite;pointer-events:none}.vid-done{position:absolute;bottom:6px;right:6px;background:#163d28cc;color:#6dffaa;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600;pointer-events:none}.meta{margin-top:7px;display:flex;align-items:center;gap:7px}.tag{font-size:13px;background:#20242d;border-radius:5px;padding:2px 8px;color:#c2c8d4}.tag.sing{background:#3a2030;color:#ff9bb0}.line{font-size:14px;margin-top:4px;color:var(--txt)}.beat{font-size:13px;color:#b0b8c8;margin-top:3px;min-height:30px}.regen{display:flex;gap:6px;margin-top:6px}.regen button{flex:1}.singer-sw{position:relative;margin-top:6px}.singer-cur{width:100%;display:flex;align-items:center;gap:6px;justify-content:center;font-size:13px;padding:5px 8px;border-radius:6px;cursor:pointer;background:#211a2b;color:#e6c8ff;border:1px solid #3a2f4a}.singer-cur:hover{border-color:#6b4f8f;background:#281f36}.singer-cur .caret{opacity:.6;font-size:11px}.singer-menu{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:20;display:flex;flex-direction:column;gap:2px;padding:4px;border-radius:8px;background:var(--panel);border:1px solid #3a2f4a;box-shadow:0 8px 24px #00000080}.singer-menu button{text-align:left;font-size:13px;padding:7px 10px;border-radius:5px;background:transparent;color:var(--txt);border:1px solid transparent;cursor:pointer}.singer-menu button:hover{background:#281f36;border-color:#4a3a63}.singer-menu button.on{background:#2f2440;color:#e6c8ff;font-weight:600}.regen-edit{margin-top:6px;display:flex;flex-direction:column;gap:6px}.regen-edit textarea{width:100%;resize:vertical;font:inherit;font-size:13px;padding:6px 8px;border-radius:6px;background:#14161e;color:var(--txt);border:1px solid var(--line);box-sizing:border-box}.regen-act{display:flex;gap:6px}.regen-act .primary{flex:1}.regen-act .warn-text{flex:1;font-size:12px;color:#ffd0d8;align-self:center}.edited{color:#ffcf6d;font-size:12px}.film{border-top:1px solid var(--line);padding:16px 0}.film video{max-width:100%;max-height:75vh;border-radius:10px;background:#000;display:block;margin:0 auto}.dialog{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px 28px;max-width:500px;width:90vw;box-shadow:0 12px 40px #000a}.dialog h3{margin:0 0 14px;font-size:22px}.dialog p{margin:0 0 18px;font-size:16px;line-height:1.6;color:var(--txt)}.dialog .chk{display:flex;align-items:flex-start;gap:10px;font-size:16px;cursor:pointer;margin-bottom:22px;padding:12px 14px;border-radius:9px;border:1px solid transparent}.dialog .chk input{margin-top:3px;flex:0 0 auto;width:18px;height:18px;accent-color:#ff4d6d}.dialog .chk.danger-on{border-color:#b3203a;background:#2a0e16;color:#ff9bb0}.danger-text{color:#ff6b85}.dialog-act{display:flex;justify-content:flex-end;gap:12px}.del-modal input{width:100%;margin:4px 0 20px}.del-modal .dialog-act{margin-top:4px}.dialog-act button{font-size:15px;padding:10px 20px}.regen-modal{width:min(620px,92vw)}.regen-modal h3{margin:0 0 12px;font-size:18px}.regen-ta{width:100%;box-sizing:border-box;resize:vertical;min-height:240px;font:inherit;font-size:15px;line-height:1.55;padding:12px 14px;border-radius:10px;background:#14161e;color:var(--txt);border:1px solid var(--line);margin-bottom:14px}.lb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e0;display:flex;align-items:center;justify-content:center;gap:8px}.lb-content{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:85vw}.lb-img{max-width:85vw;max-height:78vh;object-fit:contain;border-radius:10px;display:block}.lb-info{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.lb-line{color:var(--mut);font-size:14px}.lb-prompt{display:flex;gap:10px;align-items:flex-start;max-width:760px;width:100%;justify-content:center}.lb-prompt .lb-line{text-align:left;line-height:1.5}.lb-copy{flex:0 0 auto;align-self:flex-start;background:#78c8ff29;color:#7fd0ff;border:1px solid rgba(120,200,255,.3);border-radius:8px;padding:5px 11px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.lb-copy:hover{background:#78c8ff47}.lb-close{position:absolute;top:14px;right:18px;font-size:20px;color:#fff;background:#ffffff1f;border:none;border-radius:6px;width:36px;height:36px;padding:0;cursor:pointer;z-index:1001}.lb-close:hover{background:#ffffff38}.lb-nav{font-size:42px;color:#fff;background:#ffffff14;border:none;border-radius:8px;width:48px;height:64px;padding:0;cursor:pointer;flex-shrink:0}.lb-nav:hover:not(:disabled){background:#ffffff2e}.lb-nav:disabled{opacity:.2;cursor:not-allowed}.lb-counter{position:absolute;bottom:14px;left:50%;transform:translate(-50%);color:var(--mut);font-size:13px;background:#00000080;padding:3px 10px;border-radius:20px;pointer-events:none}.studio{padding:16px;display:flex;flex-direction:column;gap:16px}.bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.run-status{font-family:monospace;font-size:13px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px}.panel-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.steps{display:flex;gap:12px;flex-wrap:wrap;align-items:stretch}.steps .step{display:flex;flex-direction:column;align-items:stretch;gap:6px;flex:1;min-width:180px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;font-weight:400}.steps .step.lock{opacity:.55}.steps .step.done{border-color:#4cd98a55}.steps .step-h{font-weight:600;font-size:15px}.steps .step-sub{font-size:13px}.steps .step-act{display:flex;gap:8px;margin-top:auto}.steps .step-act button{flex:1 1 0;min-width:0;height:40px;white-space:nowrap;display:flex;align-items:center;justify-content:center;padding:0 10px;font-size:14px}.reset-btn{background:#2c3344;color:#d6dbe6;border:1px solid #3c465a;border-radius:8px;cursor:pointer}.reset-btn:hover:not(:disabled){background:#384155;border-color:#51607a}.reset-btn:disabled{opacity:.5;cursor:not-allowed}.shot-line{font-size:12px;color:#aeb6c4;margin-top:4px;max-height:32px;overflow:hidden;line-height:1.3}.tag.vid{background:#163d28;color:#6dffaa}.shot .regen{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.shot .regen .mini{flex:1;font-size:12px;padding:4px 6px}.film{width:100%;max-height:480px;margin-top:8px;border-radius:8px}.regen-note{margin:0 0 12px!important;font-size:13px!important;color:var(--mut)!important;line-height:1.5!important}.regen-modal .dialog-act{flex-wrap:wrap}@property --bd-ang{syntax: "<angle>"; initial-value: 0deg; inherits: false;}.steps .step.active{position:relative;border-color:transparent;box-shadow:0 0 22px -8px var(--acc)}.steps .step.active:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;padding:2px;pointer-events:none;background:conic-gradient(from var(--bd-ang),transparent 0%,var(--acc) 18%,#ffd0d8 30%,var(--acc) 45%,transparent 62%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:bd-spin 2.4s linear infinite}@keyframes bd-spin{to{--bd-ang: 360deg}}.steps .step.active .step-h{color:var(--acc)}.proj-list{display:flex;flex-direction:column;gap:10px}.proj-row{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:transform .12s,border-color .12s,background .12s,box-shadow .12s}.proj-row:hover{border-color:var(--acc);background:#181a23;transform:translateY(-2px);box-shadow:0 6px 18px #00000059}.proj-ic{width:42px;height:42px;flex:0 0 auto;display:grid;place-items:center;font-size:22px;background:#1b1e27;border:1px solid var(--line);border-radius:10px}.proj-row:hover .proj-ic{border-color:var(--acc)}.proj-info{flex:1;min-width:0}.proj-name{font-size:17px;font-weight:700;color:var(--txt);display:flex;align-items:baseline;gap:8px}.proj-slug{font-size:12px;font-weight:400;color:var(--mut)}.proj-brief{font-size:13px;color:var(--mut);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90%}.proj-arrow{font-size:22px;color:var(--mut);flex:0 0 auto;transition:transform .12s,color .12s}.proj-row:hover .proj-arrow{color:var(--acc);transform:translate(3px)}.proj-del{flex:0 0 auto;align-self:center;display:grid;place-items:center;line-height:1;background:transparent;border:1px solid transparent;color:var(--mut);padding:6px 8px;margin-top:3px;border-radius:8px;font-size:15px;opacity:0;transition:opacity .12s,color .12s,border-color .12s}.proj-row:hover .proj-del{opacity:1}.proj-del:hover{color:#ff6b85;border-color:#b3203a;background:#2a0e16}.run-banner{background:#2a1119;border:1px solid var(--acc);color:#ffd0d8;border-radius:10px;padding:10px 16px;font-size:14px;margin-bottom:14px}.proj-row.is-running{position:relative;border-color:transparent;box-shadow:0 0 26px -8px var(--acc)}.proj-row.is-running:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;padding:2px;pointer-events:none;background:conic-gradient(from var(--bd-ang),transparent 0%,var(--acc) 18%,#ffd0d8 30%,var(--acc) 45%,transparent 62%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:bd-spin 2.4s linear infinite}.proj-running{flex:0 0 auto;font-size:12px;font-weight:800;color:var(--acc);background:#ff4d6d24;border:1px solid rgba(255,77,109,.4);border-radius:999px;padding:3px 11px}.proj-row.is-locked{cursor:not-allowed;opacity:.42}.proj-row.is-locked:hover{border-color:var(--line);background:var(--panel);transform:none;box-shadow:none}.proj-row.is-locked:hover .proj-ic{border-color:var(--line)}.proj-row.is-locked:hover .proj-arrow{color:var(--mut);transform:none}.field-label{display:block;font-size:18px;font-weight:700;color:var(--txt);margin-bottom:8px}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:10px}.preset-card{cursor:pointer;border:2px solid transparent;border-radius:10px;overflow:hidden;background:var(--panel);transition:border-color .12s}.preset-card:hover{border-color:#4a5263}.preset-card.on{border-color:var(--acc)}.preset-thumb{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,#1a1d26,#23262f)}.preset-thumb img{width:100%;height:100%;object-fit:cover;display:block}.preset-zoom{position:absolute;top:5px;right:5px;width:26px;height:26px;padding:0;font-size:13px;border:none;border-radius:6px;background:#0000008c;color:#fff;cursor:pointer;opacity:0;transition:opacity .12s}.preset-card:hover .preset-zoom{opacity:1}.preset-check{position:absolute;top:5px;left:6px;background:var(--acc);color:#fff;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;box-shadow:0 1px 4px #0008}.preset-label{padding:7px 9px;font-size:13px;font-weight:600;text-align:center}.preset-text{width:100%;box-sizing:border-box;font:inherit;font-size:12px;line-height:1.45;padding:8px 10px;border-radius:8px;background:#14161e;color:var(--mut);border:1px solid var(--line);resize:vertical}.io-music{display:flex;align-items:stretch;gap:10px;margin-bottom:12px}.io-music .player{flex:1;min-width:0;margin-bottom:0}.upload-mp3{flex:1;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 10px;cursor:pointer;padding:18px 14px;border:1.5px dashed #4a5263;border-radius:10px;color:var(--mut);font-size:15px;text-align:center;transition:border-color .15s,background .15s}.upload-mp3 small{flex-basis:100%;font-size:12px;opacity:.7}.upload-mp3:hover{border-color:var(--acc);color:var(--txt)}.upload-mp3.drag{border-color:var(--acc);background:#ffffff0d;color:var(--txt)}.lyric-head{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.preset-custom-thumb{display:grid;place-items:center;font-size:30px;color:var(--mut);background:repeating-linear-gradient(45deg,#1a1d26,#1a1d26 8px,#20242f 8px,#20242f 16px)}.preset-card.preset-custom.on .preset-custom-thumb{color:var(--acc)}.field-hint{font-size:14px;color:var(--mut);font-weight:400;display:block;margin-top:4px}.preset-label,.step-sub,.tag,.shot-line,button.mini{font-size:14px}.run-status,.regen-note{font-size:14px!important}.loading-box{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;min-width:280px;max-width:90vw}.loading-box p{margin:0;font-size:16px;color:var(--txt)}.spinner{width:44px;height:44px;border-radius:50%;border:4px solid rgba(255,255,255,.18);border-top-color:var(--acc);animation:spin .8s linear infinite}.io-field{display:flex;flex-direction:column;gap:5px}.io-field-label{font-size:14px;font-weight:600;color:var(--txt)}.credit-badge{background:#2a1f0c;border:1px solid #6b5320;color:#ffcf6b;border-radius:999px;padding:6px 14px;font-weight:700;font-size:14px;cursor:pointer}.credit-badge:hover{border-color:#ffcf6b}.center{min-height:100vh;display:grid;place-items:center;padding:20px}.tos-card{max-width:560px}.tos-card h2{margin:0 0 4px}.tos-list{margin:14px 0;padding-left:20px;display:flex;flex-direction:column;gap:8px;line-height:1.5}.tos-list li{color:var(--txt)}.tos-agree{display:flex;align-items:center;gap:9px;margin:16px 0;font-size:15px;cursor:pointer}.tos-agree input{width:18px;height:18px}.tos-act{display:flex;justify-content:space-between;gap:10px}.r{text-align:right}.pos{color:var(--ok)}.neg{color:var(--acc)}.sm{font-size:12px}.usermenu{position:relative}.usermenu-btn{display:inline-flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:5px 12px 5px 6px;cursor:pointer}.usermenu-btn:hover{border-color:#4a5263}.usermenu-btn img{width:24px;height:24px;border-radius:50%}.um-name{font-size:14px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-credit{background:#2a1f0c;color:#ffcf6b;border-radius:999px;padding:2px 9px;font-weight:700;font-size:13px}.um-caret{color:var(--mut);font-size:12px}.usermenu-pop{position:absolute;right:0;top:calc(100% + 6px);z-index:50;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px;min-width:220px;box-shadow:0 10px 30px #00000080;display:flex;flex-direction:column;gap:2px}.um-bal{padding:8px 12px;font-size:13px;color:var(--mut)}.um-bal b{color:#ffcf6b}.usermenu-pop button{background:transparent;border:none;text-align:left;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--txt);cursor:pointer}.usermenu-pop button:hover{background:#1d212b}.um-sep{height:1px;background:var(--line);margin:4px 0}.um-store{padding:8px 12px}.um-store-h{display:flex;justify-content:space-between;gap:10px;font-size:13px;color:var(--mut)}.um-store-h b{color:var(--txt)}.um-bar{height:6px;background:#1d212b;border-radius:4px;margin:6px 0;overflow:hidden}.um-bar-fill{display:block;height:100%;background:var(--acc);border-radius:4px;transition:width .2s}.um-bar-fill.danger{background:#b3203a}.um-store-buy{width:100%;color:var(--acc)!important;font-size:13px}.buy-gb{display:flex;gap:8px;margin:14px 0}.gb-opt{flex:1;padding:10px 0;background:#14161d;border:1px solid var(--line);border-radius:8px;color:var(--txt)}.gb-opt.on{border-color:var(--acc);background:#181a23;color:var(--acc)}.buy-total{font-size:16px;margin:0 0 16px}.buy-total .danger-text{color:#ffcf6b}.um-uid{display:flex;align-items:center;gap:6px;margin:8px 12px 0;padding-top:8px;border-top:1px solid var(--bd, #2a2f3a);font-size:11px;color:var(--mut)}.um-uid-lb{opacity:.6}.um-uid-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;opacity:.85}.um-uid-copy{flex:none;padding:2px 7px;border:1px solid var(--bd, #2a2f3a);border-radius:6px;background:transparent;color:var(--mut);cursor:pointer;font-size:12px}.um-uid-copy:hover{color:var(--acc);border-color:var(--acc)}.um-ver{padding:8px 12px 4px;font-size:11px;color:var(--mut);opacity:.7;text-align:center}.contact-email{display:block;font-size:18px;font-weight:700;color:var(--acc);text-align:center;margin:12px 0 16px;text-decoration:none}.plans-modal{max-width:760px;width:94vw;text-align:left}.plans-note{font-size:13px;color:var(--mut);margin:-4px 0 18px;line-height:1.55}.plans-note b{color:#6fe0a0}.plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:620px){.plans-grid{grid-template-columns:1fr}}.plan-card{border:1px solid var(--line);border-radius:14px;padding:16px;background:#0f1219}.plan-free{border-color:#2e6b46}.plan-pro{border-color:#6b5320;background:linear-gradient(160deg,#1a1608,#0f1219)}.plan-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.plan-name{font-size:18px;font-weight:900;letter-spacing:.5px}.plan-tag{font-size:11px;font-weight:800;border-radius:999px;padding:2px 9px;white-space:nowrap}.plan-tag.now{background:#4cd98a29;color:#6fe0a0;border:1px solid rgba(76,217,138,.4)}.plan-tag.up{background:#ffd36b24;color:#ffd36b;border:1px solid rgba(255,211,107,.45)}.plan-feats{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}.plan-feats li{font-size:13.5px;line-height:1.45;color:var(--txt)}.plan-cta{display:block;text-align:center;margin-top:14px;padding:10px;border-radius:9px;background:linear-gradient(90deg,#ff3d63,#ff7a59);color:#fff;font-weight:800;font-size:14px;text-decoration:none}.plan-cta:hover{filter:brightness(1.08)}.plans-modal .dialog-act{margin-top:18px}.lyric-modal{max-width:640px;width:94vw;text-align:left}.lyric-modal .card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.lyric-modal .card-h b{font-size:19px}.lyric-hint{font-size:13px;color:var(--mut);margin:0 0 14px;line-height:1.5}.lyric-act{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px}.lyric-uploading{font-size:13px;color:var(--mut);margin-right:auto}.hist-modal{width:min(980px,96vw);max-width:980px;max-height:85vh;overflow:auto;text-align:left;padding:0}.hist-modal .card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);z-index:2}.hist-modal .card-h b{font-size:19px}.hist-modal .hist-filter{padding:16px 24px 4px;margin:0}.hist-modal table{width:100%;padding:8px 24px 22px;border-collapse:collapse}.hist-tbl th{font-size:12px;color:var(--mut);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:6px 10px;border-bottom:1px solid var(--line)}.hist-tbl td{padding:10px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}.hist-tbl tbody tr:hover{background:#ffffff08}.hist-act{font-weight:500;white-space:nowrap}.hist-ico{margin-right:8px}.hist-shot{color:var(--mut);font-weight:400;font-size:13px}.hist-tag{margin-left:8px;font-size:11px;padding:1px 7px;border-radius:999px;background:#4ade8026;color:var(--ok);vertical-align:middle}.hist-song{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#c9cedb}.hist-amt{font-weight:700;white-space:nowrap}.hist-close{flex:0 0 auto;width:34px;height:34px;display:grid;place-items:center;padding:0;border-radius:50%;background:#1d212b;border:1px solid var(--line);color:var(--mut);font-size:15px;line-height:1;cursor:pointer}.hist-close:hover{background:#2a2f3b;color:#fff;border-color:#4a5263}.cr-tag{display:inline-flex;align-items:center;gap:4px;margin-left:9px;background:#78c8ff29;color:#7fd0ff;border-radius:999px;padding:1px 9px;font-size:12px;font-weight:800;vertical-align:middle;line-height:1.6}.cr-tag.light{background:#ffffff47;color:#fff}.hist-filter{display:flex;gap:10px;margin-bottom:14px;flex-wrap:nowrap}.range-chip{background:#0f1219;border:1px solid var(--line);color:var(--mut);border-radius:999px;padding:7px 16px;font-size:13px;cursor:pointer;white-space:nowrap}.range-chip:hover{border-color:#4a5263;color:var(--txt)}.char-count{text-align:right;font-size:11px;color:var(--mut);margin-top:3px}.char-count.over{color:#ff6b85;font-weight:700}.range-chip.on{background:var(--acc);border-color:var(--acc);color:#fff;font-weight:600}.credit-warn{background:#2a1f0c;border:1px solid #6b5320;color:#ffcf6b;border-radius:10px;padding:10px 14px;font-size:14px;margin:0 0 10px}.step-cost{font-size:13px;font-weight:700;color:#7fd0ff;margin:2px 0 6px}.meta-cost{margin-left:auto;font-size:12px;font-weight:800;color:#7fd0ff;background:#78c8ff24;border-radius:999px;padding:1px 8px}.film-head{display:flex;align-items:center;gap:14px;margin-bottom:8px}.dl-btn{background:var(--ok);color:#08130c;font-weight:700;font-size:14px;padding:7px 16px;border-radius:8px;text-decoration:none}.dl-btn:hover{filter:brightness(1.08)}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:48px;padding:56px 20px;background:radial-gradient(1100px 520px at 50% -8%,rgba(255,77,109,.16),transparent 60%),radial-gradient(800px 480px at 85% 110%,rgba(120,200,255,.12),transparent 55%),var(--bg)}.login-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;max-width:720px}.login-brand{font-size:20px;font-weight:800;letter-spacing:.3px;color:var(--txt);opacity:.9;display:inline-flex;align-items:center;gap:9px}.beta-badge{font-size:11px;font-weight:800;letter-spacing:1px;color:#ffd36b;background:#ffd36b24;border:1px solid rgba(255,211,107,.45);border-radius:999px;padding:2px 9px;transform:translateY(-1px)}.login-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:center;padding:20px;pointer-events:none}.login-brand-top{font-size:clamp(26px,4vw,36px);font-weight:900;letter-spacing:.3px;color:var(--txt);display:inline-flex;align-items:center;gap:12px;text-shadow:0 2px 18px rgba(255,77,109,.25)}.login-brand-top .beta-badge{font-size:13px;transform:translateY(-3px)}.login-headline{margin:14px 0 0;font-size:clamp(28px,4.2vw,44px);line-height:1.1;font-weight:900;letter-spacing:-.5px}.login-headline span{background:linear-gradient(90deg,#ff4d6d,#ff9a6b 60%,#ffd36b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login-sub{margin:0;font-size:clamp(15px,2vw,18px);color:var(--mut);max-width:560px;line-height:1.5}.login-roadmap{display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;gap:7px;margin-top:8px;width:max-content;max-width:96vw}.rm-step{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;background:var(--panel);border:1px solid var(--line);border-radius:999px}.rm-ic{font-size:15px;line-height:1}.rm-label{font-size:12.5px;font-weight:600;color:var(--txt);white-space:nowrap}.rm-arrow{color:var(--acc);font-weight:800;font-size:14px;flex:0 0 auto}@media(max-width:720px){.login-roadmap{flex-wrap:wrap;width:auto;gap:8px}.rm-arrow{display:none}}.login-cta{position:relative;width:360px;height:50px;margin-top:14px}.try-free-btn{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;border:none;border-radius:999px;cursor:pointer;font-size:17px;font-weight:800;color:#fff;background:linear-gradient(90deg,#ff3d63,#ff7a59);box-shadow:0 10px 30px #ff4d6d66;display:flex;align-items:center;justify-content:center;gap:8px;transition:filter .15s,transform .15s}.login-cta:hover .try-free-btn{filter:brightness(1.07);transform:translateY(-1px)}.try-free-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;padding:2px;pointer-events:none;background:conic-gradient(from var(--bd-ang),transparent 0%,#fff 10%,#ffd36b 20%,transparent 38%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:bd-spin 2.4s linear infinite}.gis-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;opacity:.01;overflow:hidden;display:flex;align-items:center;justify-content:center;transform:scaleY(1.4)}.login-modes{display:flex;gap:12px;margin-top:2px;flex-wrap:wrap;justify-content:center;width:100%;max-width:740px}.mode-card{flex:1 1 320px;display:flex;align-items:center;gap:13px;padding:14px 16px;background:var(--panel);border:1px solid var(--line);border-radius:16px;text-align:left}.mode-card.open{border-color:#ff4d6d73;box-shadow:0 0 0 1px #ff4d6d1f}.mode-card.soon{opacity:.62}.mode-ic{font-size:27px;line-height:1}.mode-body{display:flex;flex-direction:column;gap:3px;min-width:0}.mode-name{font-size:16px;font-weight:800;color:var(--txt);display:flex;align-items:center;gap:8px}.mode-desc{font-size:12.5px;color:var(--mut);line-height:1.35}.mode-tag{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px;white-space:nowrap}.mode-tag.tag-open{color:#6fe0a0;background:#6fe0a021}.mode-tag.tag-soon{color:#ffd36b;background:#ffd36b21}@media(max-width:640px){.login-modes{flex-direction:column}.mode-card{flex:1 1 auto}}.login-note{margin:10px 0 0;font-size:15px;font-weight:700;color:#6fe0a0;opacity:1;letter-spacing:.2px}.login-showcase{width:100%;max-width:1040px;display:flex;flex-direction:column;align-items:center;gap:18px}.showcase-label{font-size:15px;font-weight:700;color:var(--mut);letter-spacing:.3px}.sc-carousel{width:100%;display:flex;align-items:center;gap:14px}.sc-arrow{flex:0 0 auto;width:46px;height:46px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--txt);font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s}.sc-arrow:hover{background:var(--acc);border-color:var(--acc);color:#fff;transform:scale(1.06)}.sc-stage{flex:1 1 auto;min-width:0;display:grid;grid-template-columns:1.15fr 1fr;background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 10px 34px #00000073}.sc-video{width:100%;aspect-ratio:16/9;background:#000;display:block;align-self:center}.sc-meta{padding:20px 22px;display:flex;flex-direction:column;gap:11px;min-width:0;text-align:left;background:linear-gradient(180deg,rgba(255,255,255,.025),transparent 40%)}.sc-title{font-size:19px;font-weight:800;display:flex;align-items:center;gap:9px;background:linear-gradient(90deg,#fff,#ffd0c0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.sc-count{font-size:11px;font-weight:700;color:var(--mut);background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:1px 8px;-webkit-text-fill-color:var(--mut)}.sc-style{font-size:11.5px;line-height:1.5;color:var(--mut);font-weight:500;opacity:.82;border-left:2px solid var(--acc);padding-left:9px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sc-concept{margin:2px 0 0;font-size:13.5px;line-height:1.72;color:#c2cad6;font-style:italic;overflow-y:auto;max-height:168px;padding-right:8px;-webkit-mask-image:linear-gradient(180deg,#000 calc(100% - 26px),transparent);mask-image:linear-gradient(180deg,#000 calc(100% - 26px),transparent)}.sc-concept::-webkit-scrollbar{width:5px}.sc-concept::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}.sc-concept::-webkit-scrollbar-track{background:transparent}.sc-dots{display:flex;gap:8px}.sc-dots button{width:9px;height:9px;border-radius:999px;border:0;background:var(--line);cursor:pointer;padding:0;transition:width .2s,background .2s}.sc-dots button.on{background:var(--acc);width:22px}@media(max-width:820px){.sc-stage{grid-template-columns:1fr}.sc-concept{max-height:130px}.sc-arrow{width:40px;height:40px;font-size:22px}}.toaster{position:fixed;left:50%;bottom:26px;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;max-width:92vw}.toast{pointer-events:auto;cursor:pointer;padding:12px 18px;border-radius:12px;font-size:14px;font-weight:600;line-height:1.4;box-shadow:0 10px 30px #00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:toast-in .25s ease;max-width:480px}.toast.err{background:#ff4d6d29;border:1px solid rgba(255,77,109,.55);color:#ffd7de}.toast.ok{background:#6fe0a024;border:1px solid rgba(111,224,160,.5);color:#d7ffe8}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.app{padding:12px}.studio{padding:10px;gap:12px}.panel{padding:12px}.panel-h{flex-wrap:wrap;gap:6px}.io-music{flex-direction:column}.steps .step{min-width:0;flex:1 1 100%}.shots{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.bar{gap:8px}.login-cta{width:100%;max-width:360px}}
