.canvas-page{height:100vh;background:var(--bg-base);overflow:hidden}.canvas-page,.canvas-topbar{display:flex;flex-direction:column}.canvas-topbar{height:auto;background:var(--bg-elevated);border-bottom:1px solid var(--border);align-items:stretch;flex-shrink:0;z-index:10}.canvas-topbar-row1{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);height:44px;flex-shrink:0;overflow:hidden}.canvas-search-input,.canvas-topbar-actions{min-width:0}.canvas-topbar .btn.btn-sm{height:26px;padding:0 8px;font-size:12px}.canvas-topbar-row2{border-top:1px solid hsla(0,0%,100%,.06);padding:4px var(--space-3)}.canvas-tool-groups{display:flex;align-items:flex-start;flex-wrap:nowrap;gap:8px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin}.canvas-tool-section{border:1px solid var(--border);border-radius:8px;background:hsla(0,0%,100%,.02);padding:4px}.canvas-tool-section-toggle{border:none;background:transparent;color:var(--text-secondary);font-size:12px;height:24px;padding:0 8px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.canvas-tool-section-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.canvas-topbar-title h1{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.canvas-topbar-meta{font-size:11px;color:var(--text-muted)}.canvas-tool-group{flex-wrap:wrap;row-gap:3px;background:transparent;padding:0}.canvas-mode-group,.canvas-tool-group{display:flex;align-items:center;gap:var(--space-1)}.canvas-mode-group{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-1)}.canvas-mode-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:var(--transition)}.canvas-mode-btn em{font-style:normal;font-size:10px;color:var(--text-muted);padding:1px 4px;border-radius:4px;background:hsla(0,0%,100%,.04)}.canvas-mode-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.canvas-mode-btn.active{color:var(--accent);background:var(--accent-light)}.canvas-body{display:flex;flex:1;overflow:hidden;position:relative}.canvas-left-panel{width:188px;background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.canvas-left-panel.collapsed{width:58px;transition:width .18s ease}.canvas-left-panel.collapsed:hover{width:188px}.canvas-left-panel.collapsed .canvas-panel-header{padding:6px;justify-content:center}.canvas-left-panel.collapsed .canvas-panel-tabs{flex-direction:column;gap:6px}.canvas-left-panel.collapsed .canvas-panel-tab{min-width:40px;padding:4px 0;font-size:11px}.canvas-left-panel.collapsed:not(:hover) .canvas-layer-item .btn,.canvas-left-panel.collapsed:not(:hover) .canvas-layer-item span,.canvas-left-panel.collapsed:not(:hover) .canvas-panel-tab span,.canvas-left-panel.collapsed:not(:hover) .canvas-selection-summary,.canvas-left-panel.collapsed:not(:hover) .canvas-tool-add,.canvas-left-panel.collapsed:not(:hover) .canvas-tool-item span{display:none}.canvas-left-panel.collapsed:not(:hover) .canvas-layer-item,.canvas-left-panel.collapsed:not(:hover) .canvas-tool-item{justify-content:center;padding:6px 4px}.canvas-panel-header{padding:var(--space-2) var(--space-2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.canvas-panel-tabs{display:flex;gap:var(--space-1)}.canvas-panel-tab{padding:var(--space-1) var(--space-2);background:none;border:none;border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.canvas-panel-tab-icon{flex-shrink:0}.canvas-panel-tab:hover{color:var(--text-primary)}.canvas-panel-tab.active{background:var(--accent-light);color:var(--accent)}.canvas-panel-search{padding:var(--space-3);border-bottom:1px solid var(--border)}.canvas-toolbox{flex:1;overflow-y:auto;padding:6px}.canvas-tool-item{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:6px 8px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:var(--transition);background:none;color:var(--text-secondary);font-size:12px;text-align:left}.canvas-tool-item:hover{background:var(--bg-hover);border-color:var(--border)}.canvas-tool-icon{width:22px;height:22px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.canvas-tool-add{margin-left:auto;opacity:0;transition:var(--transition)}.canvas-tool-item:hover .canvas-tool-add{opacity:1}.canvas-layers{flex:1;overflow-y:auto;padding:6px}.canvas-layer-item{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:6px 8px;border-radius:var(--radius);cursor:pointer;transition:var(--transition);background:none;border:1px solid transparent;color:var(--text-secondary);text-align:left}.canvas-layer-item:hover{background:var(--bg-hover);border-color:var(--border)}.canvas-layer-item.active{background:var(--accent-light);border-color:rgba(99,102,241,.35);color:var(--text-primary)}.canvas-selection-summary{margin-bottom:var(--space-2);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:hsla(0,0%,100%,.03)}.canvas-selection-summary-title{font-size:12px;font-weight:600;color:var(--text-primary)}.canvas-selection-summary-meta{margin:4px 0 10px;font-size:11px;color:var(--text-secondary)}.canvas-flow{flex:1;background:var(--bg-base);position:relative}.canvas-flow.snapping{box-shadow:inset 0 0 0 1px rgba(99,102,241,.28)}.canvas-double-click-tip{position:absolute;top:10px;left:12px;z-index:8;font-size:11px;color:var(--text-muted);background:rgba(18,18,22,.72);border:1px solid var(--border);border-radius:999px;padding:4px 10px;pointer-events:none}.canvas-remote-cursor{position:absolute;z-index:12;pointer-events:none;transform:translate(10px,10px)}.canvas-remote-cursor-dot{display:block;width:10px;height:10px;border-radius:999px;background:var(--presence-color,#22c55e);box-shadow:0 0 0 2px rgba(12,14,18,.9)}.canvas-remote-cursor-card{margin-top:6px;display:inline-flex;flex-direction:column;gap:2px;min-width:70px;padding:5px 8px;border:1px solid var(--presence-color,rgba(34,197,94,.35));border-radius:8px;background:rgba(17,24,20,.92);color:#d1fae5;font-size:11px;white-space:nowrap;box-shadow:0 10px 24px rgba(0,0,0,.22)}.canvas-remote-cursor-card strong{font-size:11px;font-weight:600}.canvas-remote-cursor-avatar{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;font-size:9px;font-weight:700;color:#fff;flex-shrink:0;margin-right:4px}.canvas-remote-cursor-card span{color:rgba(209,250,229,.78)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spin{animation:spin 1s linear infinite}@keyframes canvas-colab-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(1.55)}}.canvas-colab-dot-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:#22c55e;margin-right:4px;vertical-align:middle;animation:none}.canvas-colab-following{box-shadow:0 0 0 1px rgba(34,197,94,.35),0 0 6px 0 rgba(34,197,94,.2);transition:box-shadow .2s ease}@keyframes canvas-follow-banner-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.canvas-follow-banner{display:flex;align-items:center;gap:8px;padding:5px 16px;background:rgba(34,197,94,.1);border-bottom:1px solid rgba(34,197,94,.25);animation:none}.canvas-follow-banner-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;animation:none}.canvas-status-online{color:var(--success);border-color:rgba(34,197,94,.3)}.canvas-context-color-row{display:flex;align-items:center;padding:4px 12px 6px;gap:6px}.canvas-context-color-swatch{width:16px;height:16px;border-radius:50%;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;flex-shrink:0}.canvas-context-color-swatch:hover{transform:scale(1.25);box-shadow:0 0 0 2px hsla(0,0%,100%,.35)}.canvas-right-panel{width:280px;background:var(--bg-elevated);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.canvas-panel-body{flex:1;overflow-y:auto;padding:var(--space-4);gap:var(--space-4)}.canvas-field,.canvas-panel-body{display:flex;flex-direction:column}.canvas-field{gap:var(--space-2)}.canvas-field-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.canvas-batch-panel{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:hsla(0,0%,100%,.02)}.custom-node{background:var(--bg-elevated);border:2px solid var(--border);border-radius:var(--radius-lg);min-width:180px;max-width:220px;box-shadow:var(--shadow);overflow:hidden;transition:var(--transition)}.custom-node:hover{box-shadow:var(--shadow-lg)}.custom-node-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:12px;font-weight:600}.custom-node-header-label{flex:1;white-space:normal;word-break:break-word;line-height:1.25}.custom-node-body{padding:var(--space-3)}.custom-node-thumbnail{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);border-bottom:1px solid hsla(0,0%,100%,.08);overflow:hidden}.custom-node-thumbnail img,.custom-node-thumbnail video{width:100%;height:100%;object-fit:cover;display:block}.custom-node-thumb-play{position:absolute;right:8px;bottom:8px;font-size:10px;line-height:1;padding:3px 6px;border-radius:999px;background:rgba(0,0,0,.62);color:#fff;border:1px solid hsla(0,0%,100%,.2)}.custom-node-label{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.custom-node-sub-block{margin-top:10px;padding-top:8px;border-top:1px solid hsla(0,0%,100%,.08)}.custom-node-sub-title{font-size:10px;font-weight:600;color:#fbbf24;margin-bottom:4px}.custom-node-sub-desc{line-height:1.45}.custom-node-desc,.custom-node-sub-desc{font-size:11px;color:var(--text-secondary)}.custom-node-desc{line-height:1.4}.canvas-analyze-btn{min-width:118px;font-weight:700;box-shadow:0 0 0 1px rgba(251,191,36,.25),0 8px 18px rgba(79,70,229,.24)}.canvas-analyze-btn:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.custom-node-status{padding:0 var(--space-3) var(--space-2)}.custom-node.locked{opacity:.86;box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.2)}.custom-handle{width:10px;height:10px;border:2px solid var(--bg-base);background:var(--accent);border-radius:50%}.canvas-snap-line{position:absolute;pointer-events:none;z-index:8;opacity:.9;animation:snapPulse .48s ease-out}.canvas-snap-distance{position:absolute;z-index:9;pointer-events:none;font-size:11px;color:var(--text-primary);background:rgba(20,22,28,.9);border:1px solid var(--border);border-radius:999px;padding:2px 7px}@keyframes snapPulse{0%{opacity:.35}to{opacity:.95}}.canvas-snap-line-x{top:0;bottom:0;width:1px;border-left:1px dashed var(--accent)}.canvas-snap-line-y{left:0;right:0;height:1px;border-top:1px dashed var(--accent)}.custom-node-status span{font-size:10px;padding:2px var(--space-2);border-radius:var(--radius-full);font-weight:500}.status-idle{background:var(--bg-surface);color:var(--text-muted)}.status-running{background:var(--warning-bg);color:var(--warning)}.status-done{background:var(--success-bg);color:var(--success)}.status-error{background:var(--danger-bg);color:var(--danger)}.custom-handle{width:10px!important;height:10px!important;background:var(--accent)!important;border:2px solid var(--bg-elevated)!important}.node-content-text{padding:0}.node-text-preview{padding:var(--space-2) var(--space-3);max-height:120px;overflow:hidden}.node-text-line{font-size:11px;line-height:1.5;color:var(--text-secondary);margin:0;white-space:pre-wrap;word-break:break-word}.node-text-more{font-size:10px;color:var(--text-muted);margin:4px 0 0}.node-text-empty{flex-direction:column;align-items:center;gap:6px;padding:16px var(--space-3);font-size:11px}.node-text-empty,.node-text-meta{display:flex;color:var(--text-muted)}.node-text-meta{gap:var(--space-2);padding:2px var(--space-3) var(--space-2);font-size:10px}.node-content-script{padding:0}.node-script-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:hsla(0,0%,100%,.05);border-bottom:1px solid hsla(0,0%,100%,.06)}.node-script-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:var(--bg-elevated)}.node-script-stat-val{font-size:16px;font-weight:700;color:var(--text-primary)}.node-script-stat em{font-style:normal;font-size:10px;color:var(--text-muted)}.node-script-body{padding:var(--space-2) var(--space-3)}.node-script-preview{display:flex;gap:6px;font-size:11px;color:var(--text-secondary);line-height:1.4}.node-script-icon{flex-shrink:0;margin-top:2px;color:var(--text-muted)}.node-script-empty{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 0}.node-content-analysis{padding:0}.node-analysis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:hsla(0,0%,100%,.05)}.node-analysis-cell{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px 8px;background:var(--bg-elevated);border-top:2px solid transparent}.node-analysis-num{font-size:18px;font-weight:800;color:var(--text-primary)}.node-analysis-cell em{font-style:normal;font-size:10px;color:var(--text-muted)}.node-analysis-bar{display:flex;height:4px;border-radius:2px;overflow:hidden;margin:0 var(--space-3) var(--space-2)}.node-analysis-bar-seg{min-width:4px;transition:flex .3s ease}.node-analysis-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px var(--space-3);color:var(--text-muted);font-size:11px}.node-content-character{padding:0}.node-character-portrait{position:relative;width:100%;aspect-ratio:3/4;background:hsla(0,0%,100%,.04);overflow:hidden}.node-character-portrait img{width:100%;height:100%;object-fit:cover;display:block}.node-character-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:4px;background:rgba(0,0,0,.5);color:#fff;font-size:11px;opacity:0;transition:opacity .2s}.node-character-portrait:hover .node-character-overlay{opacity:1}.node-character-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-character-info{padding:var(--space-2) var(--space-3)}.node-character-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.node-content-scene{padding:0}.node-scene-preview{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);overflow:hidden}.node-scene-preview img{width:100%;height:100%;object-fit:cover;display:block}.node-scene-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:4px;background:rgba(0,0,0,.5);color:#fff;font-size:11px;opacity:0;transition:opacity .2s}.node-scene-preview:hover .node-scene-overlay{opacity:1}.node-scene-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-scene-info{padding:var(--space-2) var(--space-3)}.node-scene-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.node-content-image{padding:0}.node-image-preview{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);overflow:hidden}.node-image-preview img{width:100%;height:100%;object-fit:cover;display:block}.node-image-overlay{position:absolute;right:6px;bottom:6px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;opacity:0;transition:opacity .2s}.node-image-preview:hover .node-image-overlay{opacity:1}.node-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-image-info{padding:var(--space-2) var(--space-3)}.node-image-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.node-content-video{padding:0}.node-video-player{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;cursor:pointer}.node-video-player video{width:100%;height:100%;object-fit:cover;display:block}.node-video-controls{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);color:#fff;transition:opacity .2s}.node-video-controls.playing{opacity:0}.node-video-player:hover .node-video-controls.playing{opacity:1}.node-video-poster{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);overflow:hidden}.node-video-poster img{width:100%;height:100%;object-fit:cover;display:block}.node-video-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-video-info{padding:var(--space-2) var(--space-3)}.node-video-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.node-content-audio{padding:0}.node-audio-player{display:flex;align-items:center;gap:8px;padding:10px var(--space-3);background:hsla(0,0%,100%,.03);border-bottom:1px solid hsla(0,0%,100%,.06)}.node-audio-play-btn{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s}.node-audio-play-btn:hover{transform:scale(1.1)}.node-audio-wave{flex:1;position:relative;height:28px;overflow:hidden}.node-audio-bars{display:flex;align-items:flex-end;gap:2px;height:100%}.node-audio-bar{width:3px;border-radius:1px;background:hsla(0,0%,100%,.12);transition:background .15s}.node-audio-bar.active,.node-audio-progress{background:var(--accent)}.node-audio-progress{position:absolute;bottom:0;left:0;height:2px;border-radius:1px}.node-audio-time{font-size:10px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.node-audio-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-audio-info{padding:var(--space-2) var(--space-3)}.node-audio-desc{font-size:11px;color:var(--text-secondary);line-height:1.4}.node-content-storyboard{padding:0}.node-storyboard-media{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);overflow:hidden}.node-storyboard-media img,.node-storyboard-media video{width:100%;height:100%;object-fit:cover;display:block}.node-storyboard-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:11px}.node-storyboard-info{padding:var(--space-2) var(--space-3)}.node-storyboard-shot{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;background:rgba(167,139,250,.15);color:#a78bfa;margin-bottom:4px}.node-storyboard-desc{font-size:11px;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.node-storyboard-models{display:flex;gap:4px;flex-wrap:wrap}.node-storyboard-dialogues{padding:4px 6px;border-top:1px solid hsla(0,0%,100%,.06);background:rgba(0,0,0,.15)}.node-storyboard-dialogue-line{display:flex;align-items:flex-start;gap:4px;font-size:10px;line-height:1.4;color:#fbbf24;margin-bottom:2px}.node-storyboard-dialogue-line:last-child{margin-bottom:0}.node-storyboard-dialogue-icon{flex-shrink:0;margin-top:2px;color:#f59e0b;opacity:.7}.node-storyboard-dialogue-name{font-weight:600;color:#f59e0b;flex-shrink:0}.node-storyboard-dialogue-text{color:#fde68a;word-break:break-all}.node-content-storyboard--anime{background:linear-gradient(135deg,rgba(30,20,60,.6),rgba(10,10,30,.6))}.node-content-storyboard--anime .node-storyboard-media{border:1.5px solid rgba(255,100,130,.4);border-radius:2px;box-shadow:inset 0 0 0 1px rgba(100,200,255,.15),0 0 8px rgba(255,100,130,.15)}.node-content-storyboard--anime .node-storyboard-placeholder{background:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(255,100,130,.03) 0,rgba(255,100,130,.03) 9px)}.node-storyboard-anime-badge{position:absolute;top:4px;left:4px;display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;padding:2px 5px;border-radius:2px;background:rgba(255,80,120,.85);color:#fff;letter-spacing:.5px;text-transform:uppercase;backdrop-filter:blur(4px);border:1px solid rgba(255,200,220,.5);box-shadow:0 1px 4px rgba(0,0,0,.4)}.node-storyboard-shot--anime{background:rgba(255,80,120,.2)!important;color:#ff7096!important;border:1px solid rgba(255,80,120,.3)!important;border-radius:2px!important;font-family:monospace;letter-spacing:.3px}.node-storyboard-desc--anime{color:rgba(180,210,255,.9)!important;font-size:10px!important;letter-spacing:.2px}.img-model--anime{background:rgba(80,180,255,.15)!important;color:#5bc8ff!important;border-color:rgba(80,180,255,.3)!important}.vid-model--anime{background:rgba(255,100,130,.15)!important;color:#ff7096!important;border-color:rgba(255,100,130,.3)!important}.node-content-compose{padding:0}.node-compose-preview{position:relative;width:100%;aspect-ratio:16/9;background:hsla(0,0%,100%,.04);overflow:hidden}.node-compose-preview video{width:100%;height:100%;object-fit:cover;display:block}.node-compose-done-badge{position:absolute;bottom:6px;right:6px;display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:#22c55e;background:rgba(0,0,0,.7);padding:2px 8px;border-radius:4px}.node-compose-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px var(--space-3);color:var(--text-muted);font-size:12px;cursor:pointer}.node-compose-placeholder:hover{color:var(--node-compose)}.node-compose-spinner{animation:compose-spin 1s linear infinite}@keyframes compose-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.node-compose-error{color:var(--danger);font-size:11px}.node-compose-info{padding:var(--space-2) var(--space-3)}.node-compose-stats{font-size:11px;color:var(--text-secondary);font-weight:500}.node-compose-desc{font-size:11px;color:var(--text-muted);line-height:1.4;margin-top:4px}.canvas-statusbar{height:32px;border-top:1px solid var(--border);background:rgba(18,18,22,.92);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);flex-shrink:0;gap:var(--space-3)}.canvas-statusbar-left,.canvas-statusbar-right{display:flex;align-items:center;gap:var(--space-2);min-width:0}.canvas-statusbar-right{color:var(--text-muted);font-size:11px;overflow:hidden;white-space:nowrap}.canvas-status-pill,.canvas-status-toggle{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 8px;border-radius:999px;font-size:11px}.canvas-status-pill{color:var(--text-secondary);background:hsla(0,0%,100%,.04)}.canvas-status-toggle{border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.canvas-status-toggle.active,.canvas-status-toggle:hover{color:var(--text-primary);background:var(--bg-hover)}.canvas-page.zen-mode .canvas-topbar{border-bottom:none}.canvas-page.zen-mode .canvas-double-click-tip{top:8px;left:8px;opacity:.72}.canvas-zen-help-trigger{position:absolute;top:8px;right:10px;z-index:9}.canvas-hotkey-overlay{position:fixed;inset:0;z-index:1200;background:rgba(4,6,10,.62);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px)}.canvas-hotkey-panel{width:min(680px,calc(100vw - 32px));border:1px solid var(--border);border-radius:12px;background:rgba(20,22,28,.98);box-shadow:var(--shadow-lg)}.canvas-hotkey-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.canvas-hotkey-header h3{margin:0;font-size:14px}.canvas-hotkey-grid{padding:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.canvas-hotkey-grid>div{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:hsla(0,0%,100%,.02)}.canvas-hotkey-grid strong{font-size:12px;color:var(--text-primary)}.canvas-hotkey-grid span{font-size:12px;color:var(--text-secondary)}.canvas-context-menu{position:fixed;z-index:50;min-width:150px;padding:6px;border:1px solid var(--border);border-radius:var(--radius);background:rgba(28,28,34,.96);box-shadow:var(--shadow-lg);backdrop-filter:blur(12px)}.canvas-context-menu-item{width:100%;display:flex;align-items:center;justify-content:flex-start;border:none;background:transparent;color:var(--text-secondary);font-size:12px;border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:var(--transition)}.canvas-context-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.canvas-context-menu-item:disabled{opacity:.45;cursor:not-allowed}.canvas-context-menu-item.danger{color:var(--danger)}.canvas-context-sep{height:1px;margin:4px 2px;background:var(--border)}.canvas-template-quick-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.canvas-template-quick-label{font-size:11px;color:var(--text-muted);min-width:30px}.canvas-modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(5,7,12,.58);backdrop-filter:blur(5px)}.canvas-modal{width:min(820px,calc(100vw - 24px));max-height:calc(100vh - 48px);overflow:hidden;border:1px solid var(--border);border-radius:12px;background:rgba(22,24,29,.98);box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.canvas-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.canvas-modal-header h3{margin:0;font-size:15px}.canvas-modal-body{padding:14px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto;min-height:0}.canvas-modal-body-cols{display:grid;grid-template-columns:1fr 192px;gap:14px;align-items:start}.canvas-modal-footer{padding:12px 14px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.canvas-node-thumbs{display:flex;flex-direction:column;gap:8px}.canvas-node-thumb-label{font-size:11px;color:var(--text-secondary);font-weight:600;margin-bottom:2px}.canvas-node-thumb{position:relative;width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;cursor:zoom-in;background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:border-color .16s}.canvas-node-thumb:hover{border-color:var(--accent)}.canvas-node-thumb img{width:100%;height:100%;object-fit:cover}.canvas-node-thumb-placeholder{font-size:11px;color:var(--text-muted,#555);text-align:center;padding:8px;line-height:1.4}.canvas-node-thumb-storyboard{aspect-ratio:16/9}.canvas-node-thumb-video{aspect-ratio:16/9;position:relative}.canvas-node-thumb-video-badge{position:absolute;bottom:6px;left:6px;background:rgba(0,0,0,.65);color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;pointer-events:none}.canvas-node-chat{border-top:1px solid var(--border);padding:12px 14px 14px;display:flex;flex-direction:column;gap:8px;flex-shrink:0}.canvas-node-chat-title{font-size:12px;color:var(--text-secondary);font-weight:600;display:flex;align-items:center;gap:6px}.canvas-node-chat-messages{max-height:360px;min-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin}.canvas-node-chat-msg{padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.canvas-node-chat-msg.user{background:rgba(79,70,229,.18);align-self:flex-end;max-width:88%;border-radius:8px 8px 2px 8px}.canvas-node-chat-msg.assistant{background:var(--bg-surface);align-self:flex-start;max-width:92%;border-radius:8px 8px 8px 2px;border:1px solid var(--border)}.canvas-node-chat-msg-updates{margin-top:6px;padding-top:6px;border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}.canvas-node-chat-input-row{display:flex;gap:8px;align-items:flex-end}.canvas-node-chat-input-row textarea{flex:1;resize:none;min-height:36px;max-height:240px;font-size:12px;padding:8px 10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);outline:none;transition:border-color .16s}.canvas-node-chat-input-row textarea:focus{border-color:var(--accent)}.canvas-lightbox-overlay{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.9);backdrop-filter:blur(8px);cursor:zoom-out}.canvas-lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 0 80px rgba(0,0,0,.6)}.canvas-lightbox-close{position:absolute;top:16px;right:16px;background:hsla(0,0%,100%,.1);border:none;color:#fff;border-radius:50%;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:background .16s}.canvas-lightbox-close:hover{background:hsla(0,0%,100%,.22)}@media (max-width:1280px){.canvas-mode-btn em,.canvas-mode-btn span,.canvas-statusbar-right{display:none}.canvas-left-panel{width:150px}.canvas-hotkey-grid{grid-template-columns:1fr}}@media (max-width:960px){.canvas-page.mobile .canvas-topbar-row1{height:auto;min-height:44px;padding:6px var(--space-2);flex-wrap:wrap;gap:6px}.canvas-page.mobile .canvas-mode-group{width:100%;overflow-x:auto;padding:4px;order:5}.canvas-page.mobile .canvas-mode-group::-webkit-scrollbar{height:4px}.canvas-page.mobile .canvas-topbar-actions{margin-left:0!important;width:100%;overflow-x:auto;order:6;padding-bottom:2px}.canvas-page.mobile .canvas-search-input{width:132px!important}.canvas-page.mobile .canvas-topbar-row2{padding:6px var(--space-2)}.canvas-page.mobile .canvas-left-panel.mobile-drawer{position:absolute;left:0;top:0;bottom:0;width:min(86vw,260px);max-width:260px;z-index:22;transform:translateX(-104%);transition:transform .2s ease;border-right:1px solid var(--border);box-shadow:var(--shadow-lg)}.canvas-page.mobile .canvas-left-panel.mobile-drawer.open{transform:translateX(0)}.canvas-page.mobile .canvas-left-panel.collapsed,.canvas-page.mobile .canvas-left-panel.collapsed:hover{width:min(86vw,260px)}.canvas-mobile-backdrop{position:absolute;inset:0;z-index:21;background:rgba(0,0,0,.42)}.canvas-mobile-drawer-trigger{position:absolute;top:10px;left:10px;z-index:12;border:1px solid var(--border);border-radius:999px;background:rgba(20,22,28,.92);color:var(--text-secondary);font-size:12px;padding:5px 10px}.canvas-page.mobile .canvas-double-click-tip{top:44px}.canvas-page.mobile .canvas-statusbar{height:auto;min-height:32px;padding:6px var(--space-2)}.canvas-page.mobile .canvas-statusbar-left{flex-wrap:wrap}.canvas-context-menu{min-width:170px;padding:8px}.canvas-context-menu-item{padding:10px 12px;font-size:13px;min-height:38px}.canvas-edge-style-bar{bottom:auto;top:52px;max-width:calc(100vw - 24px);flex-wrap:wrap;gap:6px;padding:8px 10px}.canvas-analysis-legend{top:auto;bottom:42px;right:auto;left:8px;min-width:0;font-size:10px;padding:6px 8px}.canvas-analysis-legend-item,.canvas-analysis-legend-title{font-size:10px}.canvas-page.mobile .canvas-hotkey-grid{grid-template-columns:1fr}.canvas-page.mobile .canvas-modal-overlay{align-items:flex-end}.canvas-page.mobile .canvas-modal{width:100vw;max-width:100vw;border-radius:12px 12px 0 0;max-height:90vh}.canvas-page.mobile .canvas-mode-btn{padding:8px 10px;min-height:36px}}.canvas-mobile-fab{position:absolute;bottom:52px;right:12px;z-index:12;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);cursor:pointer;transition:var(--transition)}.canvas-mobile-fab:active,.canvas-mobile-fab:hover{opacity:.85;transform:scale(1.06)}.anchor-node .custom-node-header{padding:4px 8px;font-size:11px;border-radius:4px 4px 0 0}.anchor-node .custom-node-body{padding:4px 8px;min-height:20px}.anchor-node .custom-node-status,.anchor-node .custom-node-thumbnail{display:none}.anchor-node{min-width:80px;opacity:.85}.canvas-anchor-collapse-hint{font-size:10px;color:var(--text-muted);text-align:center;padding:2px 0 4px}.canvas-edge-style-bar{position:absolute;bottom:52px;left:50%;transform:translateX(-50%);z-index:20;display:flex;align-items:center;gap:8px;background:rgba(18,18,22,.95);border:1px solid var(--border);border-radius:8px;padding:6px 12px;backdrop-filter:blur(12px);box-shadow:0 4px 16px rgba(0,0,0,.3);font-size:12px;color:var(--text-secondary);pointer-events:all}.canvas-edge-style-bar label{font-size:11px;color:var(--text-muted);margin-right:2px}.canvas-edge-style-bar .edge-color-swatch{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s}.canvas-edge-style-bar .edge-color-swatch.active,.canvas-edge-style-bar .edge-color-swatch:hover{border-color:#fff}.canvas-edge-style-bar .edge-dash-btn,.canvas-edge-style-bar .edge-width-btn{padding:2px 7px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:11px;transition:background .15s,color .15s}.canvas-edge-style-bar .edge-dash-btn.active,.canvas-edge-style-bar .edge-width-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.canvas-edge-style-sep{width:1px;height:18px;background:var(--border)}.canvas-template-tag{display:inline-flex;align-items:center;height:16px;padding:0 6px;border-radius:999px;font-size:10px;background:rgba(99,102,241,.18);color:#a5b4fc;cursor:pointer;user-select:none;transition:background .15s}.canvas-template-tag:hover{background:rgba(99,102,241,.35)}.canvas-template-tag-group{font-size:11px;font-weight:600;color:var(--text-muted);padding:4px 4px 2px;margin-top:2px}.canvas-analysis-legend{position:absolute;top:12px;right:14px;z-index:10;background:rgba(18,18,22,.9);border:1px solid var(--border);border-radius:8px;padding:8px 10px;backdrop-filter:blur(10px);min-width:220px}.canvas-analysis-legend-title{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.canvas-analysis-legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);margin-bottom:4px}.canvas-analysis-legend-item:last-child{margin-bottom:0}.canvas-analysis-legend-line{width:28px;height:0;border-top:2px solid;border-radius:999px;flex-shrink:0}.canvas-analysis-legend-line.dashed{border-top-style:dashed}.missing-relation-node{box-shadow:0 0 0 2px #ef4444,0 0 12px 2px rgba(239,68,68,.25)!important}.custom-node-missing-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#ef4444;color:#fff;font-size:11px;font-weight:700;margin-left:auto;flex-shrink:0;line-height:1}.custom-node-model-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.custom-node-model-tag{font-size:10px;padding:1px 6px;border-radius:999px;font-weight:500;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-node-model-tag.img-model{background:rgba(99,102,241,.15);color:#a5b4fc;border:1px solid rgba(99,102,241,.3)}.custom-node-model-tag.vid-model{background:rgba(249,115,22,.15);color:#fdba74;border:1px solid rgba(249,115,22,.3)}.canvas-jobs-fab{position:fixed;bottom:56px;right:16px;z-index:30;display:flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;background:rgba(18,20,26,.94);border:1px solid var(--border);color:var(--text-secondary);font-size:12px;cursor:pointer;backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(0,0,0,.35);transition:background .16s,border-color .16s;pointer-events:all}.canvas-jobs-fab:hover{background:rgba(30,32,42,.98);border-color:var(--accent)}.canvas-jobs-fab-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;border-radius:999px;padding:1px 6px;min-width:16px;text-align:center}.canvas-jobs-panel{position:fixed;bottom:100px;right:16px;z-index:30;width:360px;max-height:480px;display:flex;flex-direction:column;background:rgba(16,18,24,.97);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.5);backdrop-filter:blur(14px);overflow:hidden;pointer-events:all}.canvas-jobs-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-primary);flex-shrink:0}.canvas-jobs-list{flex:1;overflow-y:auto;padding:6px 0}.canvas-jobs-list::-webkit-scrollbar{width:4px}.canvas-jobs-list::-webkit-scrollbar-track{background:transparent}.canvas-jobs-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.canvas-job-item{display:grid;grid-template-columns:32px 1fr auto;gap:8px;align-items:center;padding:8px 14px;border-bottom:1px solid hsla(0,0%,100%,.04);transition:background .12s}.canvas-job-item:last-child{border-bottom:none}.canvas-job-item:hover{background:hsla(0,0%,100%,.03)}.canvas-job-icon{width:32px;height:32px;border-radius:6px;overflow:hidden;background:hsla(0,0%,100%,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0}.canvas-job-icon img{width:100%;height:100%;object-fit:cover}.canvas-job-info{min-width:0}.canvas-job-title{font-size:12px;color:var(--text-primary);margin-bottom:3px}.canvas-job-meta,.canvas-job-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-job-meta{font-size:11px;color:var(--text-muted)}.canvas-job-status{flex-shrink:0;font-size:11px;padding:2px 7px;border-radius:999px;font-weight:600}.canvas-job-status.queued,.canvas-job-status.running{background:rgba(99,102,241,.18);color:#a5b4fc}.canvas-job-status.done{background:rgba(34,197,94,.15);color:#86efac}.canvas-job-status.dead,.canvas-job-status.error,.canvas-job-status.failed{background:rgba(239,68,68,.15);color:#fca5a5}.canvas-jobs-empty{padding:28px 14px;text-align:center;font-size:12px;color:var(--text-muted)}