:root{--surface-root:oklch(0.936 0.009 238);--surface-panel:oklch(0.912 0.01 232);--surface-elevated:oklch(0.982 0.005 230);--surface-quiet:oklch(0.956 0.006 232);--surface-media:oklch(0.205 0.018 237);--canvas:oklch(0.985 0.004 235);--canvas-grid:oklch(0.79 0.012 236);--canvas-panel:oklch(0.972 0.005 232);--text-strong:oklch(0.18 0.014 238);--text:oklch(0.285 0.012 238);--text-muted:oklch(0.49 0.011 238);--text-on-dark:oklch(0.93 0.012 224);--text-muted-on-dark:oklch(0.72 0.012 224);--line:oklch(0.805 0.012 235);--line-strong:oklch(0.69 0.014 235);--accent:oklch(0.67 0.147 158);--accent-ink:oklch(0.18 0.036 158);--warning:oklch(0.72 0.135 78);--danger:oklch(0.59 0.165 28);--success:oklch(0.64 0.13 151);--info:oklch(0.58 0.105 226);--port-image:oklch(0.56 0.135 218);--port-text:oklch(0.55 0.13 294);--port-video-clip:oklch(0.62 0.15 38);--port-full-video:oklch(0.55 0.14 18);--port-audio:oklch(0.58 0.14 350);--shadow-soft:0 14px 32px color-mix(in oklch,var(--text-strong),transparent 90%);--shadow-tight:0 7px 18px color-mix(in oklch,var(--text-strong),transparent 92%)}*{box-sizing:border-box}body,html{min-height:100%;margin:0;overflow-x:hidden;background:var(--surface-root);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:15px;letter-spacing:0}button,input,select,textarea{font:inherit}button{min-height:36px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);color:var(--text-strong);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;font-weight:660}button:disabled{cursor:not-allowed;opacity:.45}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid color-mix(in oklch,var(--text-strong),var(--accent) 34%);outline-offset:2px;box-shadow:0 0 0 4px color-mix(in oklch,var(--accent),transparent 78%)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.app-shell{--graph-library-width:240px;--inspector-width:360px;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,var(--inspector-width));min-height:100vh;max-width:100vw;background:var(--surface-root)}.inspector{background:var(--surface-panel);border-color:var(--line);position:relative;border-left:1px solid var(--line);padding:0;overflow:auto;min-width:0;container-type:inline-size;background:color-mix(in oklch,var(--surface-panel),var(--surface-root) 28%)}.graph-focus{grid-template-columns:minmax(0,1fr) minmax(320px,var(--inspector-width))}.graph-focus.graph-inspector-closed{grid-template-columns:minmax(0,1fr) 0}.graph-focus .mode-tabs,.graph-focus .topbar{display:none}.graph-focus .workspace{grid-template-rows:minmax(0,1fr);min-height:100vh}.graph-focus .work-surface{padding:0;overflow:hidden}.graph-focus .graph-shell{height:100vh;min-height:100vh;border:0;border-radius:0;box-shadow:none}.graph-inspector-closed .inspector,.graph-library-resize-handle,.inspector-resize-handle{display:none}body.graph-library-resizing,body.inspector-resizing{cursor:col-resize;-webkit-user-select:none;-moz-user-select:none;user-select:none}body.graph-library-resizing *,body.inspector-resizing *{cursor:col-resize!important}.home-shell{min-height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr);background:var(--surface-root)}.home-header{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;border-bottom:1px solid var(--line);background:color-mix(in oklch,var(--surface-panel),var(--surface-root) 38%)}.home-header .brand-mark{margin:0}.home-tabs{display:flex;align-items:center;gap:6px;padding:5px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.home-tabs button{min-height:34px}.home-tabs .active{border-color:var(--surface-media);background:var(--surface-media);color:var(--text-on-dark)}.home-surface{width:min(1120px,calc(100vw - 32px));margin:0 auto;padding:24px 0 40px}.home-projects{display:grid;grid-gap:16px;gap:16px}.home-section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}.home-section-heading h1{margin:0}.home-project-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.home-project-actions .import-project-control{margin-top:0}.home-surface>.panel-section{padding:4px 0 32px}.home-surface .panel-heading{margin-bottom:4px}.onboarding-shell{min-height:100vh;display:grid;place-items:center;padding:32px 18px;background:radial-gradient(circle at 50% 0,color-mix(in oklch,var(--info),transparent 86%),transparent 34%),linear-gradient(135deg,oklch(.965 .01 245),oklch(.995 .004 250) 46%,oklch(.96 .01 265))}.onboarding-surface{width:min(920px,100%);max-width:100%;min-height:min(650px,calc(100vh - 64px));display:grid;grid-template-rows:auto minmax(0,1fr);border:1px solid color-mix(in oklch,var(--line),transparent 16%);border-radius:16px;background:color-mix(in oklch,var(--surface-elevated),transparent 8%);box-shadow:0 24px 70px color-mix(in oklch,var(--text-strong),transparent 90%)}.onboarding-rail{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;grid-gap:16px 22px;gap:16px 22px;padding:22px 26px 18px;border-bottom:1px solid color-mix(in oklch,var(--line),transparent 20%)}.onboarding-rail .brand-mark{margin-bottom:0}.onboarding-current-pill{justify-self:end;min-height:34px;display:inline-flex;align-items:center;gap:8px;max-width:100%;padding:0 12px;border:1px solid color-mix(in oklch,var(--line),transparent 20%);border-radius:999px;background:color-mix(in oklch,var(--surface-elevated),transparent 14%);color:var(--text-muted);font-size:.8rem;box-shadow:0 1px 0 color-mix(in oklch,var(--text-strong),transparent 96%)}.onboarding-current-pill>span{width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklch,var(--accent),transparent 84%)}.onboarding-current-pill strong{color:var(--text-strong);font-size:.8rem}.onboarding-current-pill small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.onboarding-steps{grid-column:1/-1;width:100%;min-width:0;max-width:100%;display:flex;gap:8px;margin:0;padding:0;overflow-x:auto;list-style:none}.onboarding-steps li{min-height:34px;display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;padding:0 10px 0 5px;border:1px solid color-mix(in oklch,var(--line),transparent 34%);border-radius:999px;background:color-mix(in oklch,var(--surface-elevated),transparent 24%);color:var(--text-muted)}.onboarding-steps li span{width:24px;height:24px;display:grid;place-items:center;border-radius:999px;background:color-mix(in oklch,var(--surface-panel),var(--surface-elevated) 42%);color:var(--text-muted);font-size:.72rem;font-weight:780}.onboarding-steps li strong{color:inherit;font-size:.78rem;white-space:nowrap}.onboarding-steps li.active{border-color:color-mix(in oklch,var(--info),var(--line) 34%);background:color-mix(in oklch,var(--info),var(--surface-elevated) 91%);color:var(--text-strong)}.onboarding-steps li.active span,.onboarding-steps li.complete span{background:var(--accent);color:var(--accent-ink)}.onboarding-panel{min-width:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);padding:18px 28px 42px}.onboarding-topline{min-height:36px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--text-muted);font-size:.78rem;font-weight:760}.onboarding-nav-actions{min-width:0;display:flex;align-items:center;gap:10px}.ghost-inline-action{min-height:32px;border-color:transparent;background:transparent;color:var(--text-muted);padding:0 6px}.ghost-inline-action:hover{color:var(--text-strong);background:color-mix(in oklch,var(--surface-panel),transparent 42%)}.onboarding-back-action{gap:5px;padding-left:4px}.onboarding-back-action:disabled{opacity:.48;pointer-events:none}.onboarding-maker-strip{justify-self:center;display:inline-flex;align-items:center;gap:10px;margin-top:6px;padding:6px 12px 6px 6px;border:1px solid color-mix(in oklch,var(--line),transparent 28%);border-radius:999px;background:color-mix(in oklch,var(--surface-elevated),transparent 18%);color:var(--text);box-shadow:0 1px 0 color-mix(in oklch,var(--text-strong),transparent 96%)}.onboarding-maker-avatar{width:32px;height:32px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--accent),var(--line) 36%);border-radius:999px;background:linear-gradient(135deg,color-mix(in oklch,var(--accent),white 4%),color-mix(in oklch,var(--info),var(--surface-elevated) 56%));color:var(--accent-ink);font-size:.72rem;font-weight:860;letter-spacing:0}.onboarding-maker-copy{min-width:0;display:grid;grid-gap:1px;gap:1px;text-align:left}.onboarding-maker-copy small,.onboarding-maker-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.onboarding-maker-copy strong{color:var(--text-strong);font-size:.8rem;font-weight:760}.onboarding-maker-copy small{color:var(--text-muted);font-size:.74rem;font-weight:620}.onboarding-stage{min-width:0;display:grid;place-items:center}.onboarding-step-panel{width:min(680px,100%);align-self:center;display:grid;justify-items:center;grid-gap:20px;gap:20px;padding:42px 0 28px;text-align:center}.onboarding-icon{width:64px;height:64px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--line),var(--info) 18%);border-radius:18px;background:color-mix(in oklch,var(--surface-elevated),var(--info) 8%);color:color-mix(in oklch,var(--info),var(--text-strong) 30%);box-shadow:0 14px 34px color-mix(in oklch,var(--info),transparent 88%)}.onboarding-copy{display:grid;justify-items:center;grid-gap:12px;gap:12px}.onboarding-copy h1{max-width:11ch;font-size:2.28rem;line-height:1.04;letter-spacing:0}.onboarding-body{display:grid;grid-gap:10px;gap:10px;justify-items:center;max-width:60ch;color:var(--text-muted);font-size:1rem;line-height:1.62}.onboarding-body p{margin:0}.onboarding-soft-note{width:-moz-fit-content;width:fit-content;margin-top:4px!important;padding:8px 12px;border:1px solid color-mix(in oklch,var(--line),transparent 28%);border-radius:999px;background:color-mix(in oklch,var(--surface-elevated),transparent 18%);color:var(--text);font-size:.86rem;font-weight:650;line-height:1.3}.compact-instructions{display:grid;grid-gap:8px;gap:8px;margin:0;padding-left:20px;text-align:left}.compact-instructions li{padding-left:2px}.onboarding-key-field{display:grid;grid-gap:7px;gap:7px;width:min(460px,100%);color:var(--text-muted);font-size:.78rem;font-weight:760;text-transform:uppercase}.onboarding-key-field input{min-height:44px;padding:10px 12px;color:var(--text-strong);text-transform:none;text-align:left}.onboarding-status{width:-moz-fit-content;width:fit-content;margin:0;padding:7px 9px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 50%);border-radius:8px;background:color-mix(in oklch,var(--accent),var(--surface-elevated) 91%);color:var(--text-strong);font-size:.82rem;font-weight:680}.onboarding-credit-card{width:min(420px,100%);display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 36%);border-radius:12px;background:color-mix(in oklch,var(--accent),var(--surface-elevated) 88%);color:var(--text);text-align:left;box-shadow:0 10px 28px color-mix(in oklch,var(--accent),transparent 91%)}.onboarding-credit-card svg{flex:0 0 auto;color:color-mix(in oklch,var(--accent),var(--text-strong) 28%)}.onboarding-credit-card span{min-width:0;display:grid;grid-gap:2px;gap:2px}.onboarding-credit-card strong{color:var(--text-strong);font-size:.86rem;font-weight:760}.onboarding-credit-card small{color:var(--text-muted);font-size:.8rem;font-weight:640}.onboarding-actions{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.onboarding-actions button,.onboarding-link-button{min-height:40px}.onboarding-link-button{border:1px solid color-mix(in oklch,var(--line),transparent 16%);border-radius:12px;background:color-mix(in oklch,var(--surface-elevated),transparent 8%);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 14px;font-weight:700;text-decoration:none;box-shadow:0 1px 0 color-mix(in oklch,var(--text-strong),transparent 96%)}.onboarding-link-button:hover{border-color:color-mix(in oklch,var(--info),var(--line) 45%);background:var(--surface-elevated);box-shadow:0 10px 24px color-mix(in oklch,var(--info),transparent 90%)}.onboarding-link-button:disabled{opacity:.52;cursor:not-allowed;box-shadow:none}.project-config-screen{max-width:1120px}.project-config-intro{max-width:72ch;margin:0}.project-config-name{max-width:520px}.project-config-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start}.panel-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:.82rem;font-weight:650;line-height:1.35}.brand-mark{display:flex;align-items:center;gap:9px;color:var(--text-strong);font-weight:780;margin-bottom:18px;letter-spacing:0}.primary-action{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:760}.spin-icon{animation:spin-icon .8s linear infinite}@keyframes spin-icon{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.spin-icon{animation:none}}.danger-action{border-color:color-mix(in oklch,var(--danger),var(--line));color:var(--danger)}.danger-action:focus-visible,.danger-action:hover{border-color:var(--danger);background:color-mix(in oklch,var(--danger),var(--surface-elevated) 88%);color:var(--text-strong)}.import-project-control{min-height:40px;margin-top:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);color:var(--text-strong);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;position:relative;overflow:hidden}.import-project-control:focus-within{outline:2px solid color-mix(in oklch,var(--text-strong),var(--accent) 34%);outline-offset:2px;box-shadow:0 0 0 4px color-mix(in oklch,var(--accent),transparent 78%)}.import-project-control input{position:absolute;inset:0;cursor:pointer;opacity:0}.project-import-status{margin:8px 0 0;color:var(--text-muted);font-size:.82rem;line-height:1.35}.project-search{display:grid;grid-gap:6px;gap:6px;margin-top:18px;color:var(--text-muted);font-size:.78rem;font-weight:700;text-transform:uppercase}.project-search input{min-width:0;min-height:40px;padding:9px 11px;color:var(--text-strong);text-transform:none}.project-list{display:grid;grid-gap:10px;gap:10px;margin-top:18px}.project-row{width:100%;min-height:68px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;grid-gap:8px;gap:8px;border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 14%);padding:8px;text-align:left;box-shadow:0 1px 0 color-mix(in oklch,var(--text-strong),transparent 96%)}.project-row.active{border-color:var(--accent);background:color-mix(in oklch,var(--accent),var(--surface-elevated) 90%);box-shadow:inset 0 0 0 1px color-mix(in oklch,var(--accent),transparent 42%)}.project-row.archived{opacity:.78}.project-switch{min-width:0;min-height:48px;justify-content:flex-start;border:0;background:transparent;padding:0 4px;text-align:left}.project-switch>span:last-child{min-width:0}.project-row-actions{display:flex;align-items:center;gap:5px}.project-row-actions .icon-button{width:34px;min-height:34px}.project-row-warning{grid-column:1/-1;margin:4px 0 0;padding:8px 9px;border:1px solid color-mix(in oklch,var(--danger),var(--line) 52%);border-radius:8px;background:color-mix(in oklch,var(--danger),var(--surface-elevated) 91%);color:var(--text-strong);font-size:.78rem;line-height:1.35}.archived-projects{margin-top:14px}.archived-list{margin-top:8px}.archived-label{pointer-events:none}.ghost-action{width:100%;justify-content:flex-start;color:var(--text-muted)}.empty-list{margin:0;color:var(--text-muted);font-size:.86rem;line-height:1.4}.empty-state{min-height:124px;display:grid;align-content:center;justify-items:start;grid-gap:8px;gap:8px;padding:18px;border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 12%)}.empty-state strong{color:var(--text-strong);font-size:.98rem}.empty-state span{color:var(--text-muted);font-size:.86rem;line-height:1.4}.project-thumb{width:38px;height:38px;border-radius:7px;background:var(--surface-media);color:var(--text-on-dark);display:grid;place-items:center}.project-row small,.project-row strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clip-copy small,.clip-copy span,.flow-node small,.muted,.project-row small{color:var(--text-muted)}.workspace{min-width:0;grid-template-rows:auto minmax(0,1fr)}.topbar,.workspace{display:grid;background:var(--surface-root)}.topbar{min-height:72px;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;justify-content:flex-start;grid-gap:12px;gap:12px;padding:12px 24px;border-bottom:1px solid var(--line)}.topbar-project-meta{min-width:0;display:grid;grid-template-columns:minmax(180px,300px) auto;align-items:center;grid-gap:10px;gap:10px}.project-identity{min-width:0;display:grid;grid-gap:3px;gap:3px}.workspace-back-button{min-height:38px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px 0 10px;border-color:color-mix(in oklch,var(--text-muted),var(--line) 64%);background:color-mix(in oklch,var(--surface-elevated),var(--surface-root) 34%);color:var(--text-strong);font-weight:760}.workspace-back-button:hover{border-color:var(--surface-media);background:color-mix(in oklch,var(--surface-media),var(--surface-elevated) 88%)}.topbar>.workspace-back-button{width:40px;min-width:40px;padding:0}.clip-secondary-action span,.mode-tabs button span,.node-secondary-action span,.topbar>.workspace-back-button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.project-name-field{display:block;max-width:none;margin-top:0;color:var(--text-muted);font-size:.78rem;text-transform:uppercase}.project-name-field>span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.project-name-field input{width:100%;min-height:34px;padding:5px 10px;color:var(--text-strong);font-size:1rem;font-weight:780;text-transform:none}.project-title-static{color:var(--text-strong);font-size:1rem;line-height:1.1}.project-meta-row{display:flex;flex-wrap:nowrap;gap:6px;margin-top:0;overflow:hidden}.project-meta-row span{min-height:24px;border:1px solid var(--line);border-radius:999px;background:var(--surface-quiet);color:var(--text-muted);font-size:.75rem;font-weight:720;padding:0 8px}.project-meta-row span,.resume-notice{display:inline-flex;align-items:center}.resume-notice{grid-column:1/-1;width:-moz-fit-content;width:fit-content;max-width:min(540px,100%);min-height:28px;margin-top:-2px;gap:7px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 55%);border-radius:8px;background:color-mix(in oklch,var(--accent),var(--surface-elevated) 90%);color:var(--text-strong);padding:5px 6px 5px 9px;font-size:.82rem;line-height:1.25}.resume-notice span{min-width:0;overflow-wrap:anywhere}.resume-notice .icon-button{width:28px;min-height:28px}.eyebrow{margin:0 0 2px;color:var(--text-muted);font-size:.7rem;text-transform:uppercase;font-weight:780}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:1.16rem;line-height:1.12}h1,h2{color:var(--text-strong)}h2{font-size:1rem}.button-row,.clip-actions,.toolbar-row,.topbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.topbar-actions{flex-wrap:nowrap;justify-content:flex-end}.topbar-actions .provider-mode,.topbar-actions .status-pill{width:34px;min-width:34px;justify-content:center;gap:0;padding:0;overflow:hidden;font-size:0}.topbar-actions .provider-mode:before,.topbar-actions .status-pill svg{font-size:.74rem}.topbar-actions .provider-mode:before{content:"Kie"}.node-action-bar{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;margin:0;padding:0 0 14px;border-bottom:1px solid var(--line);background:transparent;overflow-x:auto}.node-action-bar.source-actions{justify-content:space-between;gap:12px}.node-action-note{min-width:0;color:var(--text-muted);font-size:.78rem;font-weight:680;line-height:1.35}.node-action-bar button{min-height:38px;flex:0 0 auto;padding:0 10px}.node-action-bar .node-remove-action{border-color:color-mix(in oklch,var(--danger),var(--line) 36%);background:color-mix(in oklch,var(--danger),var(--surface-elevated) 94%);color:color-mix(in oklch,var(--danger),var(--text-strong) 28%)}.provider-mode{min-height:28px;display:inline-flex;align-items:center;padding:0 10px;border:1px solid var(--line);border-radius:999px;color:var(--text-muted);font-size:.78rem;font-weight:700;white-space:nowrap}.provider-mode.real{border-color:color-mix(in oklch,var(--warning),var(--line));color:var(--warning);background:color-mix(in oklch,var(--warning),transparent 91%)}.provider-mode.mock{color:var(--success);background:color-mix(in oklch,var(--success),transparent 92%)}.provider-onboarding{display:grid;grid-template-columns:22px minmax(0,1fr);align-items:start;grid-gap:10px;gap:10px;padding:12px;border:1px solid color-mix(in oklch,var(--warning),var(--line) 50%);border-radius:8px;background:color-mix(in oklch,var(--warning),var(--surface-elevated) 90%);color:var(--text-strong)}.provider-onboarding.ready{border-color:color-mix(in oklch,var(--success),var(--line) 50%);background:color-mix(in oklch,var(--success),var(--surface-elevated) 90%)}.provider-onboarding span,.provider-onboarding strong{display:block}.provider-onboarding strong{margin-bottom:4px;font-size:.9rem}.provider-onboarding span{color:var(--text);font-size:.82rem;font-weight:650;line-height:1.4}.icon-button{width:38px;padding:0}.node-status,.status-pill{min-height:28px;display:inline-flex;align-items:center;gap:6px;padding:0 10px;border:1px solid var(--line);border-radius:999px;font-size:.74rem;font-weight:740;white-space:nowrap}.node-status.complete,.status-pill.saved{border-color:color-mix(in oklch,var(--success),var(--line) 54%);color:var(--text-strong);background:color-mix(in oklch,var(--success),var(--surface-elevated) 86%)}.node-status.pending,.node-status.polling,.node-status.running,.node-status.waiting_callback,.status-pill.saving{border-color:color-mix(in oklch,var(--info),var(--line) 56%);color:var(--text-strong);background:color-mix(in oklch,var(--info),var(--surface-elevated) 88%)}.node-status.stale,.node-status.waiting_input,.status-pill.dirty{border-color:color-mix(in oklch,var(--warning),var(--line) 54%);color:var(--text-strong);background:color-mix(in oklch,var(--warning),var(--surface-elevated) 86%)}.node-status.failed{border-color:color-mix(in oklch,var(--danger),var(--line) 52%);color:var(--text-strong);background:color-mix(in oklch,var(--danger),var(--surface-elevated) 88%)}.inspector-tabs,.mode-tabs{display:flex;gap:6px;padding:10px 24px;border-bottom:1px solid var(--line);background:color-mix(in oklch,var(--surface-panel),var(--surface-root) 50%)}.topbar .mode-tabs{min-width:0;padding:0;border-bottom:0;background:transparent}.inspector-tabs button,.mode-tabs button{text-transform:capitalize}.mode-tabs button{width:44px;min-width:44px;padding:0}.inspector-tabs .active,.mode-tabs .active{border-color:var(--surface-media);background:var(--surface-media);color:var(--text-on-dark)}.work-surface{min-height:0;overflow:auto;padding:14px 24px 24px}.clip-stack{display:grid;grid-gap:12px;gap:12px}.toolbar-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.selection-count,.toolbar-row button{flex:0 0 auto}.clip-secondary-action,.node-secondary-action{width:38px;min-width:38px;padding:0}.outputs-toolbar{align-items:center}.clip-bulk-action{flex:0 0 auto;min-width:0;padding:0 11px}.clip-row{position:relative;min-height:122px;display:grid;grid-template-columns:26px 34px 78px minmax(0,1fr) auto;align-items:center;grid-gap:14px;gap:14px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);box-shadow:var(--shadow-tight)}.clip-row.selected{border-color:var(--accent)}.clip-row.reorderable{cursor:-webkit-grab;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.clip-row.reorderable:active{cursor:-webkit-grabbing;cursor:grabbing}.clip-row.dragging{z-index:12;transform:translate3d(var(--drag-x,0),var(--drag-y,0),0) scale(1.012);background:color-mix(in oklch,var(--accent),var(--surface-elevated) 94%);box-shadow:0 18px 42px color-mix(in oklch,var(--surface-media),transparent 78%);opacity:.96;pointer-events:none}.clip-row.dragging,.clip-row.drop-target{border-color:color-mix(in oklch,var(--accent),var(--surface-media) 18%)}.clip-row.drop-target{background:color-mix(in oklch,var(--accent),var(--surface-elevated) 96%);box-shadow:inset 0 0 0 1px color-mix(in oklch,var(--accent),transparent 58%)}.clip-row.drop-target:after{content:"";position:absolute;inset:-5px;border:2px solid color-mix(in oklch,var(--accent),var(--surface-media) 22%);border-radius:11px;pointer-events:none;animation:reorderTargetPulse .62s ease-out}.clip-select{width:26px;min-height:28px;display:grid;place-items:center}.clip-select input{width:18px;height:18px}.clip-index{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;gap:1px;background:var(--surface-panel);color:var(--text-strong);font-weight:700}.clip-drag-handle{border:1px solid color-mix(in oklch,var(--accent),var(--line) 38%);background:color-mix(in oklch,var(--accent),var(--surface-elevated) 90%);color:var(--accent);cursor:-webkit-grab;cursor:grab}.clip-drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.clip-preview{width:78px;aspect-ratio:9/16;border-radius:8px;background:var(--surface-media);color:var(--surface-elevated);display:grid;place-items:center;overflow:hidden}.clip-preview video{width:100%;height:100%;object-fit:cover}.clip-copy{min-width:0}.clip-trim-row{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;margin-top:4px}.clip-trim-row small{display:inline-flex;align-items:center;min-height:30px;overflow:visible;white-space:nowrap}.clip-trim-row label{display:grid;grid-gap:2px;gap:2px;color:var(--text-muted);font-size:.72rem;font-weight:700;text-transform:uppercase}.clip-trim-row input{width:64px;min-height:30px;padding:5px 7px;color:var(--text-strong)}.selection-count{min-height:34px;display:inline-flex;align-items:center;padding:0 10px;border:1px solid var(--line);border-radius:999px;background:var(--surface-quiet);color:var(--text-muted);font-size:.78rem;font-weight:760}.clip-actions .icon-button{width:34px;min-height:34px;padding:0}.clip-actions{flex-wrap:nowrap;justify-content:flex-end}.clip-actions button{flex:0 0 auto}.clip-run-action{min-width:78px}.clip-selection-note{margin:-4px 0 0;color:var(--text-muted);font-size:.84rem;line-height:1.35}.clip-copy small,.clip-copy span,.clip-copy strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clip-copy .clip-trim-row small{display:inline-flex;align-items:center;min-height:30px;overflow:visible;white-space:nowrap}.inline-warning{color:var(--warning)!important;white-space:normal!important;overflow-wrap:anywhere}.source-upload-feedback{display:inline-flex;align-items:center;gap:7px;min-height:28px;margin-top:8px;border:1px solid color-mix(in oklch,var(--line),var(--surface-panel) 24%);border-radius:8px;background:var(--surface-panel);color:var(--text);padding:6px 8px;font-size:.78rem;font-weight:680;line-height:1.3;overflow-wrap:anywhere}.source-upload-feedback.success{border-color:color-mix(in oklch,var(--success),var(--line) 45%);background:color-mix(in oklch,var(--success),var(--surface-elevated) 92%);color:var(--text-strong)}.source-upload-feedback.error{border-color:color-mix(in oklch,var(--danger),var(--line) 38%);background:color-mix(in oklch,var(--danger),var(--surface-elevated) 91%);color:var(--text-strong)}.graph-shell{height:calc(100vh - 176px);min-height:548px;border:1px solid var(--line-strong);border-radius:8px;position:relative;box-shadow:0 18px 38px color-mix(in oklch,var(--text-strong),transparent 91%)}.graph-shell,.graph-shell .react-flow{overflow:hidden;background:var(--canvas)}.graph-shell.graph-drop-active{border-color:color-mix(in oklch,var(--accent),var(--line) 18%);box-shadow:inset 0 0 0 2px color-mix(in oklch,var(--accent),transparent 52%),0 18px 38px color-mix(in oklch,var(--text-strong),transparent 91%)}.graph-shell .react-flow__background{opacity:.74}.graph-shell .react-flow__viewport{-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-origin:0 0;will-change:transform}.graph-shell .react-flow__edge-path{stroke:oklch(.55 .018 236);stroke-width:1.7;shape-rendering:geometricPrecision;vector-effect:non-scaling-stroke}.graph-shell .react-flow__edge{cursor:pointer}.graph-shell .react-flow__edge.typed-edge.image .react-flow__edge-path{stroke:var(--port-image)}.graph-shell .react-flow__edge.typed-edge.text .react-flow__edge-path{stroke:var(--port-text)}.graph-shell .react-flow__edge.typed-edge.video_clip .react-flow__edge-path{stroke:var(--port-video-clip)}.graph-shell .react-flow__edge.typed-edge.full_video .react-flow__edge-path{stroke:var(--port-full-video)}.graph-shell .react-flow__edge.typed-edge.audio .react-flow__edge-path{stroke:var(--port-audio)}.graph-shell .react-flow__edge.selected .react-flow__edge-path{stroke:var(--accent);stroke-width:2}.graph-shell .react-flow__edge:hover .react-flow__edge-path{stroke:var(--danger);stroke-width:1.7}.graph-shell .react-flow__edge-textbg{fill:color-mix(in oklch,var(--canvas),var(--surface-elevated) 40%)}.graph-shell .react-flow__edge-text{fill:var(--text-muted);font-size:10px;font-weight:680}.graph-shell .react-flow__node,.graph-shell .react-flow__nodes,.graph-shell .react-flow__nodesselection{overflow:visible}.graph-top-chrome{position:absolute;z-index:5;top:12px;left:12px;right:64px;max-width:none;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;justify-content:space-between;grid-gap:8px;gap:8px;pointer-events:none}.graph-back-button,.graph-status-actions,.graph-view-tabs{min-height:40px;display:flex;align-items:center;gap:6px;padding:5px;border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--canvas) 18%);box-shadow:0 12px 24px color-mix(in oklch,var(--text-strong),transparent 92%);pointer-events:auto}.graph-view-tabs{min-width:0;justify-self:center}.graph-back-button{width:40px;min-width:40px;padding:0}.graph-back-button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.graph-view-tabs button{min-height:30px;text-transform:capitalize}.graph-top-chrome .graph-view-tabs button{width:34px;min-width:34px;padding:0}.graph-top-chrome .graph-view-tabs button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.graph-view-tabs .active{border-color:var(--surface-media);background:var(--surface-media);color:var(--text-on-dark)}.graph-status-actions{padding-left:8px;justify-self:end}.graph-status-actions .provider-mode,.graph-status-actions .status-pill{width:34px;min-width:34px;justify-content:center;gap:0;padding:0;overflow:hidden;font-size:0}.graph-status-actions .provider-mode:before,.graph-status-actions .status-pill svg{font-size:.74rem}.graph-status-actions .provider-mode:before{content:"Kie"}.graph-status-actions .icon-button{width:34px;min-height:34px}.graph-toolbar{position:absolute;z-index:4;top:12px;left:64px;right:auto;min-height:46px;display:flex;align-items:center;justify-content:flex-start;gap:8px;flex-wrap:nowrap;width:-moz-fit-content;width:fit-content;max-width:calc(100% - 232px);padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--canvas) 22%);box-shadow:0 14px 28px color-mix(in oklch,var(--text-strong),transparent 91%)}.graph-toolbar button{min-height:34px;border-color:var(--line);background:var(--surface-elevated);color:var(--text-strong)}.graph-toolbar .primary-action{border-color:var(--accent);background:var(--accent);color:var(--accent-ink)}.graph-toolbar-actions,.graph-toolbar-primary{display:flex;align-items:center;gap:7px;min-width:0}.history-shortcuts{display:flex;align-items:center;gap:6px;padding-left:2px}.history-shortcuts button{gap:6px}.graph-secondary-action{width:34px;min-width:34px;padding:0}.graph-secondary-action span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.graph-node-library{display:none;position:absolute;z-index:4;top:84px;left:12px;bottom:16px;width:var(--graph-library-width);align-content:start;gap:20px;overflow:auto;padding:16px 12px;border:1px solid var(--line);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--canvas) 18%);box-shadow:0 14px 28px color-mix(in oklch,var(--text-strong),transparent 91%)}.graph-focus.graph-library-open .graph-node-library{display:grid}.graph-library-title{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 2px}.graph-library-title strong{color:var(--text-strong);font-size:1.05rem}.graph-library-title span{min-width:24px;min-height:24px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:999px;background:var(--surface-quiet);color:var(--text-muted);font-size:.74rem;font-weight:760}.graph-library-group{display:grid;grid-gap:8px;gap:8px}.graph-library-group h3{margin:0 0 2px;padding:0 2px;color:var(--text-muted);font-size:.74rem;font-weight:780;text-transform:uppercase}.graph-library-group button{--node-accent:var(--accent);width:100%;min-height:68px;display:grid;grid-template-columns:32px minmax(0,1fr) 20px;align-items:center;justify-content:stretch;grid-gap:10px;gap:10px;padding:7px 8px;border-color:color-mix(in oklch,var(--line),var(--node-accent) 14%);background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 2%);color:var(--text-strong);cursor:-webkit-grab;cursor:grab;text-align:left}.graph-library-group button:focus-visible,.graph-library-group button:hover{border-color:color-mix(in oklch,var(--line-strong),var(--node-accent) 34%);background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 6%)}.graph-library-group button:active{cursor:-webkit-grabbing;cursor:grabbing}.graph-library-group button>span:not(.graph-library-icon){min-width:0}.graph-library-group strong{font-size:.9rem}.graph-library-group small,.graph-library-group strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.graph-library-group small{color:var(--text-muted);font-size:.72rem;font-weight:650}.graph-library-group small b{color:var(--text);font-weight:760}.graph-library-icon{width:32px;height:32px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--line),var(--node-accent) 32%);border-radius:7px;background:color-mix(in oklch,var(--surface-quiet),var(--node-accent) 10%);color:color-mix(in oklch,var(--text),var(--node-accent) 34%)}.node-type-image{--node-accent:var(--port-image)}.node-type-text,.node-type-text_transform{--node-accent:var(--port-text)}.node-type-nano_banana_pro_image{--node-accent:var(--success)}.node-type-animate_image{--node-accent:var(--warning)}.node-type-seedance_2_video{--node-accent:color-mix(in oklch,var(--warning),var(--danger) 34%)}.node-type-video_upscale{--node-accent:color-mix(in oklch,var(--info),var(--accent) 28%)}.node-type-video_downscale{--node-accent:color-mix(in oklch,var(--port-video-clip),var(--accent) 22%)}.node-type-video{--node-accent:var(--port-video-clip)}.node-type-audio{--node-accent:var(--port-audio)}.node-type-stitch_video{--node-accent:var(--port-full-video)}.graph-action-rail{position:absolute;z-index:4;top:16px;right:16px;display:grid;grid-gap:10px;gap:10px}.graph-action-rail button{width:38px;padding:0;border-radius:8px;border-color:var(--line);background:var(--surface-elevated);box-shadow:0 10px 22px color-mix(in oklch,var(--text-strong),transparent 92%)}.graph-action-rail button,.graph-notice{min-height:38px;color:var(--text-strong)}.graph-notice{position:absolute;z-index:5;top:72px;left:12px;right:12px;max-width:520px;display:flex;align-items:center;gap:8px;border:1px solid color-mix(in oklch,var(--warning),var(--line));border-radius:8px;background:color-mix(in oklch,var(--warning),var(--surface-elevated) 88%);padding:6px 7px 6px 10px;font-size:.84rem;line-height:1.3;box-shadow:0 12px 24px color-mix(in oklch,var(--text-strong),transparent 92%)}.graph-notice span{min-width:0;overflow-wrap:anywhere}.graph-notice .icon-button{width:28px;min-height:28px;margin-left:auto}.graph-drop-toast{position:absolute;z-index:5;top:118px;left:12px;max-width:min(430px,calc(100% - 24px));min-height:36px;display:flex;align-items:center;gap:8px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 42%);border-radius:8px;background:color-mix(in oklch,var(--accent),var(--surface-elevated) 88%);color:var(--text-strong);padding:7px 10px;font-size:.84rem;font-weight:720;line-height:1.3;box-shadow:0 12px 24px color-mix(in oklch,var(--text-strong),transparent 92%);pointer-events:none}.graph-drop-toast.loading{border-color:color-mix(in oklch,var(--info),var(--line) 36%);background:color-mix(in oklch,var(--info),var(--surface-elevated) 90%)}.graph-drop-toast.error{border-color:color-mix(in oklch,var(--danger),var(--line) 34%);background:color-mix(in oklch,var(--danger),var(--surface-elevated) 90%)}.graph-drop-toast.loading svg,.source-upload-feedback.loading svg{animation:spin-icon .9s linear infinite}.graph-drop-toast span{min-width:0;overflow-wrap:anywhere}.graph-drop-target{position:absolute;z-index:6;inset:0;display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .17s ease-out}.graph-drop-active .graph-drop-target{opacity:1}.graph-drop-target>div{width:min(360px,calc(100% - 40px));min-height:132px;display:grid;place-items:center;grid-gap:8px;gap:8px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 34%);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--canvas) 10%);color:var(--text-strong);padding:20px;text-align:center;box-shadow:0 18px 42px color-mix(in oklch,var(--text-strong),transparent 88%)}.graph-drop-target strong{font-size:1rem}.graph-drop-target span{max-width:28ch;color:var(--text-muted);font-size:.86rem;line-height:1.35}.graph-shell .react-flow__controls,.graph-shell .react-flow__minimap{border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:0 10px 22px color-mix(in oklch,var(--text-strong),transparent 92%)}.graph-shell .react-flow__controls-button{width:32px;height:32px;background:var(--surface-elevated);border-bottom:1px solid var(--line);color:var(--text-strong)}.graph-shell .react-flow__controls-zoomin{order:0}.graph-shell .react-flow__controls-zoomout{order:1}.graph-shell .react-flow__controls-fitview{order:2}.graph-shell .react-flow__controls-interactive{order:3}.graph-shell .react-flow__minimap{background:color-mix(in oklch,var(--surface-elevated),var(--canvas) 25%)}.flow-node{--node-accent:var(--accent);--node-tint:color-mix(in oklch,var(--canvas-panel),var(--node-accent) 4%);--node-border:color-mix(in oklch,var(--line),var(--node-accent) 20%);width:300px;min-height:0;border:1px solid var(--node-border);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 2%);box-shadow:0 10px 24px color-mix(in oklch,var(--text-strong),transparent 92%);contain:layout;padding:8px;position:relative;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased}.flow-node:after{display:none}.flow-node .react-flow__handle{--port-color:var(--accent);width:12px;height:12px;border:2px solid var(--surface-elevated);background:var(--port-color);box-shadow:0 0 0 1px color-mix(in oklch,var(--port-color),transparent 48%)}.flow-node .react-flow__handle.connectingfrom,.flow-node .react-flow__handle.connectingto,.flow-node .react-flow__handle:hover{box-shadow:0 0 0 4px color-mix(in oklch,var(--port-color),transparent 76%)}.flow-node .typed-handle.image{--port-color:var(--port-image)}.flow-node .typed-handle.text{--port-color:var(--port-text)}.flow-node .typed-handle.video_clip{--port-color:var(--port-video-clip)}.flow-node .typed-handle.full_video{--port-color:var(--port-full-video)}.flow-node .typed-handle.audio{--port-color:var(--port-audio)}.flow-node.selected{border-color:var(--node-accent);box-shadow:0 0 0 2px color-mix(in oklch,var(--node-accent),transparent 66%),0 16px 30px color-mix(in oklch,var(--text-strong),transparent 88%)}.flow-node.related{border-color:var(--node-accent);box-shadow:0 0 0 2px color-mix(in oklch,var(--node-accent),transparent 76%),0 12px 22px color-mix(in oklch,var(--text-strong),transparent 92%)}.flow-node.value-media{background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 2%);border-color:color-mix(in oklch,var(--node-accent),var(--line) 34%)}.flow-node.value-media:after{opacity:0}.flow-node.image{--node-accent:var(--port-image);width:300px}.flow-node.image_transform{--node-accent:var(--accent)}.flow-node.nano_banana_pro_image{--node-accent:var(--success);width:270px}.flow-node.text,.flow-node.text_transform{--node-accent:var(--port-text)}.flow-node.text{width:288px}.flow-node.animate_image{--node-accent:var(--warning)}.flow-node.seedance_2_video{--node-accent:color-mix(in oklch,var(--warning),var(--danger) 34%);width:270px}.flow-node.video_upscale{--node-accent:color-mix(in oklch,var(--info),var(--accent) 28%);width:284px}.flow-node.video_downscale{--node-accent:color-mix(in oklch,var(--port-video-clip),var(--accent) 22%);width:284px}.flow-node.video{--node-accent:var(--port-video-clip);width:306px}.flow-node.split_scenes{--node-accent:var(--port-image);width:294px}.flow-node.audio{--node-accent:var(--port-audio);width:288px}.flow-node.stitch_video{--node-accent:var(--port-full-video)}.flow-node-header{min-height:30px;display:grid;grid-template-columns:24px minmax(0,1fr) auto;align-items:center;grid-gap:8px;gap:8px;padding:0 0 7px;color:var(--text-strong)}.flow-node.can-run .flow-node-header{grid-template-columns:24px minmax(0,1fr) auto 30px}.flow-node-header strong{min-width:0;overflow:hidden;color:var(--text-strong);font-size:.88rem;font-weight:780;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.flow-node-header small{min-height:22px;display:inline-flex;align-items:center;border:1px solid color-mix(in oklch,var(--node-accent),var(--line) 48%);border-radius:999px;background:color-mix(in oklch,var(--surface-quiet),var(--node-accent) 7%);color:color-mix(in oklch,var(--text-muted),var(--node-accent) 18%);font-size:.7rem;font-weight:760;line-height:1;padding:0 7px;white-space:nowrap}.flow-node-type-icon{width:24px;height:24px;display:inline-grid;place-items:center;border:1px solid color-mix(in oklch,var(--node-accent),var(--line) 38%);border-radius:6px;background:color-mix(in oklch,var(--surface-quiet),var(--node-accent) 10%);color:color-mix(in oklch,var(--text),var(--node-accent) 34%)}.flow-node-run-button{width:30px;min-width:30px;height:28px;min-height:28px;border-color:color-mix(in oklch,var(--node-accent),var(--line) 28%);border-radius:7px;background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 12%);color:color-mix(in oklch,var(--text-strong),var(--node-accent) 28%);padding:0;box-shadow:none}.flow-node-run-button:focus-visible,.flow-node-run-button:hover{border-color:var(--node-accent);background:color-mix(in oklch,var(--surface-elevated),var(--node-accent) 22%);color:var(--text-strong)}.flow-node-run-button.confirm{border-color:var(--accent);background:var(--accent);color:var(--accent-ink)}.flow-node-run-button.is-loading{border-color:color-mix(in oklch,var(--info),var(--node-accent) 28%);background:color-mix(in oklch,var(--info),var(--surface-elevated) 86%);color:var(--text-strong)}.flow-node-run-button:disabled{opacity:.42}.flow-node-run-button.is-loading:disabled{opacity:1}.flow-port-label{--port-color:var(--accent);position:absolute;z-index:6;width:auto;height:24px;display:flex;align-items:center;gap:8px;pointer-events:none;transform:translateY(-50%)}.flow-port-label.input{left:-12px;transform:translate(-100%,-50%);flex-direction:row;justify-content:flex-end}.flow-port-label.output{right:-12px;transform:translate(100%,-50%);flex-direction:row;justify-content:flex-start}.flow-port-label.image{--port-color:var(--port-image)}.flow-port-label.text{--port-color:var(--port-text)}.flow-port-label.video_clip{--port-color:var(--port-video-clip)}.flow-port-label.full_video{--port-color:var(--port-full-video)}.flow-port-label.audio{--port-color:var(--port-audio)}.flow-port-label .react-flow__handle{pointer-events:all;position:absolute;top:50%;transform:translateY(-50%)}.flow-port-label.input .react-flow__handle{left:auto;right:-19px}.flow-port-label.output .react-flow__handle{right:auto;left:-19px}.flow-port-label span{max-width:128px;min-height:22px;display:inline-flex;align-items:center;border:1px solid color-mix(in oklch,var(--port-color),var(--canvas) 54%);border-radius:999px;background:color-mix(in oklch,var(--canvas),var(--port-color) 8%);color:color-mix(in oklch,var(--text-strong),var(--port-color) 18%);box-shadow:0 5px 12px color-mix(in oklch,var(--text-strong),transparent 93%);font-size:.66rem;font-weight:780;line-height:1;overflow:hidden;opacity:0;padding:0 8px;text-overflow:ellipsis;transform:translateX(4px);transition:opacity .14s ease,transform .14s ease;white-space:nowrap}.flow-node.connecting .flow-port-label span,.flow-node.related .flow-port-label span,.flow-node.selected .flow-port-label span,.flow-node:hover .flow-port-label span,.react-flow__node:hover .flow-port-label span{opacity:1;transform:translateX(0)}.flow-port-label.input span{margin-right:0;transform:translateX(-4px)}.flow-port-label.output span{margin-left:0}.flow-node-preview{min-height:0;border:1px solid color-mix(in oklch,var(--line),var(--node-accent) 12%);border-radius:8px;background:var(--node-tint);overflow:hidden}.flow-node-preview.media{display:grid;place-items:center}.flow-node-preview.media,.flow-node-preview.media.portrait{background:color-mix(in oklch,var(--canvas),var(--node-accent) 2%)}.flow-node-preview img,.flow-node-preview video{width:100%;height:auto;max-height:390px;display:block;object-fit:contain}.graph-video-preview{position:relative;width:100%;display:grid;place-items:center}.graph-video-play-button{position:absolute;left:10px;bottom:10px;width:34px;min-height:34px;display:inline-grid;place-items:center;border:1px solid color-mix(in oklch,var(--surface-elevated),var(--line) 34%);border-radius:999px;background:color-mix(in oklch,var(--surface-media),transparent 16%);color:var(--surface-elevated);box-shadow:0 10px 24px color-mix(in oklch,var(--text-strong),transparent 72%);cursor:pointer}.graph-video-play-button:hover{background:color-mix(in oklch,var(--surface-media),var(--accent) 12%)}.graph-video-play-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.flow-node-preview.text{height:154px;display:grid;grid-template-rows:minmax(0,1fr) auto;grid-gap:9px;gap:9px;padding:14px 16px 12px;background:var(--node-tint)}.flow-node-preview.audio{min-height:54px;display:grid;align-items:center;padding:8px;background:var(--node-tint)}.flow-node-preview.audio audio{width:100%;height:30px}.flow-node-preview.scenes{min-height:184px;display:grid;align-content:stretch;padding:8px;background:color-mix(in oklch,var(--canvas),var(--node-accent) 3%)}.scene-graph-preview{min-width:0;display:grid;grid-template-rows:minmax(0,1fr) auto;grid-gap:8px;gap:8px}.scene-graph-strip{min-height:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:5px;gap:5px}.scene-graph-more,.scene-graph-tile{min-width:0;min-height:42px;aspect-ratio:16/10;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--line),var(--node-accent) 18%);border-radius:5px;background:var(--surface-media);overflow:hidden}.scene-graph-tile img{width:100%;height:100%;max-height:none;object-fit:cover}.scene-graph-more{color:var(--text-muted);font-size:.78rem;font-weight:820}.scene-graph-meta{min-height:24px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--text-muted);font-size:.68rem;font-weight:760}.scene-graph-meta strong{min-width:0;overflow:hidden;color:var(--text-strong);text-overflow:ellipsis;white-space:nowrap}.scene-graph-meta span{flex:none;white-space:nowrap}.primitive-preview-fallback{display:inline-grid;place-items:center;gap:7px;color:var(--text-muted);font-size:.72rem;font-weight:760;text-align:center}.primitive-preview-fallback small{color:var(--text-muted);font-size:.68rem;font-weight:780}.primitive-output-collection{min-height:56px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);color:var(--text-muted);font-size:.82rem;font-weight:760}.flow-node-preview p{margin:0;color:var(--text-strong);font-size:.82rem;font-weight:660;line-height:1.34;display:-webkit-box;overflow:hidden;overflow-wrap:anywhere;-webkit-box-orient:vertical;-webkit-line-clamp:7}.flow-node-text-count{width:-moz-fit-content;width:fit-content;min-height:22px;display:inline-flex;align-items:center;border:1px solid color-mix(in oklch,var(--node-accent),var(--line) 58%);border-radius:999px;background:color-mix(in oklch,var(--canvas),var(--node-accent) 8%);color:color-mix(in oklch,var(--text-muted),var(--node-accent) 18%);font-size:.68rem;font-weight:780;line-height:1;padding:0 8px;white-space:nowrap}.flow-node-preview.empty{min-height:118px;display:grid;place-items:center;color:color-mix(in oklch,var(--node-accent),var(--text-muted) 32%);background:linear-gradient(135deg,color-mix(in oklch,var(--node-accent),transparent 90%) 25%,transparent 25%) 0 0 /16px 16px,linear-gradient(135deg,transparent 75%,color-mix(in oklch,var(--node-accent),transparent 90%) 75%) 0 0 /16px 16px,var(--node-tint)}.flow-node-footer{min-height:26px;display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:7px 0 0;color:var(--text-muted)}.flow-node-footer span,.flow-node-footer strong{min-width:0;overflow:hidden;font-size:.7rem;font-weight:760;line-height:1;text-overflow:ellipsis;white-space:nowrap}.flow-node-footer strong{color:color-mix(in oklch,var(--success),var(--text) 28%)}.batch-panel,.panel-section{display:grid;grid-gap:14px;gap:14px}.batch-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.summary-box{min-height:72px;display:grid;align-content:center;grid-gap:4px;gap:4px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);box-shadow:0 1px 0 color-mix(in oklch,var(--text-strong),transparent 96%)}.summary-box span{color:var(--text-muted);font-size:.78rem;font-weight:700;text-transform:uppercase}.summary-box strong{color:var(--text-strong);font-size:1.05rem}.batch-table{display:grid;grid-template-columns:44px minmax(150px,1.1fr) minmax(180px,1.5fr) 120px 100px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface-elevated)}.batch-table>*{min-height:52px;display:flex;align-items:center;padding:10px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);min-width:0}.batch-head{min-height:38px;color:var(--text-muted);font-size:.78rem;font-weight:800;text-transform:uppercase;background:var(--surface-panel)}.danger-text{color:var(--danger)}.inspector-tabs{position:-webkit-sticky;position:sticky;z-index:8;top:0;display:flex;gap:6px;padding:14px;flex-wrap:wrap;border-bottom:1px solid var(--line);background:color-mix(in oklch,var(--surface-panel),var(--surface-root) 20%)}.inspector-tabs button{min-height:38px;flex:1 1;border-color:color-mix(in oklch,var(--line),var(--surface-panel) 26%);background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 18%)}.inspector>.panel-section{padding:16px 18px 24px}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--line)}.panel-heading>div{min-width:0;display:grid;grid-gap:4px;gap:4px}.panel-heading h2{margin:0;font-size:1rem;line-height:1.2}.panel-heading p{max-width:58ch;margin:0;color:var(--text-muted);font-size:.8rem;font-weight:650;line-height:1.35}.node-config-grid{display:grid;grid-template-columns:1fr;grid-gap:0;gap:0;align-items:start}.node-summary-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:-2px}.node-summary-strip span{min-height:28px;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;background:var(--surface-quiet);color:var(--text-muted);font-size:.76rem;font-weight:740;padding:0 9px;text-transform:capitalize}.node-io-panel,.node-main-config,.settings-group{display:grid;grid-gap:12px;gap:12px;min-width:0;padding:16px 0;border:0;border-top:1px solid var(--line);border-radius:0;background:transparent}.node-main-config,.settings-group{background:transparent}.node-default-stack{display:grid;grid-gap:14px;gap:14px}.project-config-fieldset{min-width:0;margin:0;padding:0;border:0}.project-config-fieldset:disabled{opacity:.58}.node-default-block{display:grid;grid-gap:11px;gap:11px;padding:12px;border:1px solid color-mix(in oklch,var(--line),var(--surface-panel) 22%);border-radius:8px;background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 16%)}.node-default-block h4{margin:0;color:var(--text-strong);font-size:.9rem;line-height:1.2}.node-io-panel h3,.node-main-config h3,.settings-group h3{margin:0;color:var(--text-strong);font-size:.76rem;font-weight:820;letter-spacing:.02em;text-transform:uppercase}.section-caption{margin:-5px 0 0;color:var(--text-muted);font-size:.76rem;font-weight:650;line-height:1.35}.io-input-group{display:grid;grid-gap:8px;gap:8px;padding:2px 0 12px;border-bottom:1px solid color-mix(in oklch,var(--line),transparent 38%)}.io-input-group:last-child{border-bottom:0;padding-bottom:0}.io-input-title,.io-output-row{display:grid;grid-gap:3px;gap:3px;min-width:0}.io-output-row{padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.io-type{color:var(--text-muted);font-size:.68rem;font-weight:750;overflow-wrap:anywhere;text-transform:uppercase}.io-choice-list{display:grid;grid-gap:8px;gap:8px}.io-choice-list.compact{gap:7px}.io-picker-disclosure{display:grid;grid-gap:8px;gap:8px}.io-picker-disclosure summary{width:-moz-fit-content;width:fit-content;min-height:28px;display:inline-flex;align-items:center;border:0;border-radius:6px;background:color-mix(in oklch,var(--surface-quiet),var(--surface-panel) 20%);color:var(--text-muted);cursor:pointer;font-size:.78rem;font-weight:740;list-style:none;padding:0 9px}.io-picker-disclosure summary::-webkit-details-marker{display:none}.io-picker-disclosure summary:after{content:"+";margin-left:8px;color:var(--text-muted);font-weight:820}.io-picker-disclosure[open] summary:after{content:"−"}.io-source-option{--source-color:var(--accent);width:100%;min-height:44px;display:grid;grid-template-columns:22px minmax(0,1fr);align-items:center;grid-gap:9px;gap:9px;padding:7px 9px;border:1px solid color-mix(in oklch,var(--line),var(--source-color) 12%);border-radius:7px;background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 10%);color:var(--text-strong);text-align:left;box-shadow:none;justify-content:stretch}.io-source-option-shell{--source-color:var(--accent);position:relative;display:grid;grid-template-columns:minmax(0,1fr);grid-gap:7px;gap:7px;align-items:stretch}.io-source-option-shell.reorderable{cursor:-webkit-grab;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.io-source-option-shell.reorderable:active{cursor:-webkit-grabbing;cursor:grabbing}.io-source-option.image{--source-color:var(--port-image)}.io-source-option.text{--source-color:var(--port-text)}.io-source-option.video_clip{--source-color:var(--port-video-clip)}.io-source-option.full_video{--source-color:var(--port-full-video)}.io-source-option.audio{--source-color:var(--port-audio)}.io-source-option-shell:has(.io-source-option.image){--source-color:var(--port-image)}.io-source-option-shell:has(.io-source-option.text){--source-color:var(--port-text)}.io-source-option-shell:has(.io-source-option.video_clip){--source-color:var(--port-video-clip)}.io-source-option-shell:has(.io-source-option.full_video){--source-color:var(--port-full-video)}.io-source-option-shell:has(.io-source-option.audio){--source-color:var(--port-audio)}.io-source-option:focus-visible,.io-source-option:hover{border-color:var(--source-color);background:color-mix(in oklch,var(--source-color),var(--surface-elevated) 94%)}.io-source-option.selected{border-color:var(--source-color);background:color-mix(in oklch,var(--source-color),var(--surface-elevated) 91%)}.io-source-option.reorderable{grid-template-columns:58px minmax(0,1fr);cursor:-webkit-grab;cursor:grab}.io-source-option.reorderable:active{cursor:-webkit-grabbing;cursor:grabbing}.io-source-option-shell.dragging .io-source-option{transform:translate3d(var(--drag-x,0),var(--drag-y,0),0) scale(1.018);border-color:color-mix(in oklch,var(--source-color),var(--surface-media) 24%);background:color-mix(in oklch,var(--source-color),var(--surface-elevated) 86%);box-shadow:0 12px 28px color-mix(in oklch,var(--source-color),transparent 82%);opacity:.96;pointer-events:none;transition:none}.io-source-option-shell.drop-target .io-source-option{transform:scale(1.01);border-color:color-mix(in oklch,var(--source-color),var(--surface-media) 18%);background:color-mix(in oklch,var(--source-color),var(--surface-elevated) 88%);box-shadow:inset 0 0 0 1px color-mix(in oklch,var(--source-color),transparent 50%)}.io-source-option-shell.drop-target:after{content:"";position:absolute;inset:-4px;border:2px solid color-mix(in oklch,var(--source-color),var(--surface-media) 28%);border-radius:9px;pointer-events:none;animation:reorderTargetPulse .62s ease-out}.io-source-option:disabled{opacity:.52;cursor:not-allowed}.io-source-drag{width:52px;min-height:30px;display:inline-grid;grid-template-columns:20px 28px;align-items:center;gap:4px}.io-source-grip{min-height:30px;display:grid;place-items:center;color:color-mix(in oklch,var(--source-color),var(--text-muted) 34%)}.io-source-order{min-height:28px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--source-color),var(--line) 28%);border-radius:999px;background:color-mix(in oklch,var(--source-color),var(--surface-elevated) 88%);color:color-mix(in oklch,var(--source-color),var(--text-strong) 24%);font-size:.74rem;font-weight:860}.io-source-check{width:17px;height:17px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--source-color),var(--line) 38%);border-radius:5px;color:var(--source-color);font-size:.75rem;font-weight:850}.io-source-copy{min-width:0;display:grid;grid-gap:2px;gap:2px}.io-source-copy small,.io-source-copy strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.io-source-copy strong{color:var(--text-strong);font-size:.84rem;font-weight:760}.io-source-copy small{color:var(--text-muted);font-size:.69rem;font-weight:720}.node-output-preview{display:grid;grid-gap:11px;gap:11px;padding:12px;border:1px solid color-mix(in oklch,var(--accent),var(--line) 70%);border-radius:8px;background:color-mix(in oklch,var(--accent),var(--surface-elevated) 94%)}.node-output-preview.empty{border-color:var(--line);background:var(--surface-elevated)}.output-preview-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.output-preview-heading span,.output-preview-heading strong{display:block}.output-preview-heading strong{color:var(--text-strong);font-size:.88rem}.node-output-preview.empty span,.output-preview-heading span{color:var(--text-muted);font-size:.74rem;font-weight:690}.output-preview-heading button{min-height:30px;padding:0 9px;white-space:nowrap}.node-output-preview img,.node-output-preview video{width:100%;max-height:280px;border:1px solid var(--line);border-radius:8px;background:var(--surface-media);object-fit:contain}.node-output-preview audio{width:100%}.node-output-preview textarea{min-height:132px;max-height:260px;font-size:.86rem}.output-preview-meta{display:flex;flex-wrap:wrap;gap:6px}.output-preview-meta span{min-height:22px;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;background:var(--surface-elevated);color:var(--text-muted);font-size:.7rem;font-weight:720;padding:0 7px}.scene-output-list{display:grid;grid-gap:8px;gap:8px;margin-top:10px}.scene-output-row{display:grid;grid-template-columns:22px 54px minmax(0,1fr) 30px;align-items:center;grid-gap:8px;gap:8px;min-height:58px;padding:7px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.scene-output-index{color:var(--text-muted);font-size:.72rem;font-weight:780;text-align:center}.scene-output-row img,.scene-output-thumb{width:54px;height:42px;border:1px solid var(--line);border-radius:6px;background:var(--surface-media);object-fit:cover}.scene-output-copy{display:grid;grid-gap:2px;gap:2px;min-width:0}.scene-output-copy small,.scene-output-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-output-copy strong{color:var(--text-strong);font-size:.78rem;font-weight:760}.scene-output-copy small{color:var(--text-muted);font-size:.68rem;font-weight:720}.scene-output-row button{width:30px;height:30px;padding:0}.workflow-run-notice{display:flex;align-items:flex-start;gap:9px;padding:10px;border:1px solid color-mix(in oklch,var(--info),var(--line) 60%);border-radius:8px;background:color-mix(in oklch,var(--info),var(--surface-elevated) 92%);color:var(--text-strong);font-size:.84rem;font-weight:680;line-height:1.35}.subtle-inline-action{width:-moz-fit-content;width:fit-content;min-height:28px;padding:0 9px;color:var(--text-muted);background:transparent}label{display:grid;grid-gap:7px;gap:7px;color:var(--text-strong);font-weight:650}.parameter-label{display:inline-flex;align-items:center;gap:6px;min-width:0}.info-tip{width:16px;height:16px;display:inline-grid;flex:0 0 auto;place-items:center;border:1px solid color-mix(in oklch,var(--info),var(--line) 36%);border-radius:999px;background:color-mix(in oklch,var(--info),var(--surface-elevated) 92%);color:color-mix(in oklch,var(--info),var(--text-strong) 34%);cursor:help;font-size:.68rem;font-weight:860;line-height:1}@keyframes reorderTargetPulse{0%{opacity:0;transform:scale(.985)}45%{opacity:1}to{opacity:1;transform:scale(1)}}.info-tip:focus-visible{outline:2px solid color-mix(in oklch,var(--info),var(--accent) 40%);outline-offset:2px}.toggle-row{display:flex;grid-template-columns:none;align-items:center;gap:9px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.toggle-row input{width:18px;height:18px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated);color:var(--text-strong);padding:10px 11px}input:disabled,select:disabled,textarea:disabled{border-color:color-mix(in oklch,var(--port-text),var(--line) 62%);background:color-mix(in oklch,var(--port-text),var(--surface-elevated) 91%);color:var(--text);cursor:not-allowed;opacity:1}.injected-field{gap:8px}.injected-field textarea{min-height:116px}.injected-field-source{display:block;color:var(--text-muted);font-size:.76rem;font-weight:680;line-height:1.35}input[type=file]{min-height:44px;padding:7px;color:var(--text-muted)}input[type=file]::-webkit-file-upload-button{min-height:28px;margin-right:10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-elevated);color:var(--text-strong);cursor:pointer;font:inherit;font-weight:700;padding:0 10px}input[type=file]::file-selector-button{min-height:28px;margin-right:10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-elevated);color:var(--text-strong);cursor:pointer;font:inherit;font-weight:700;padding:0 10px}textarea{min-height:128px;resize:vertical}.field-note{margin-top:-2px;color:var(--text-muted);font-size:.76rem;font-weight:650;line-height:1.35;text-transform:none}.advanced-settings{display:grid;grid-gap:11px;gap:11px}.advanced-settings summary{width:-moz-fit-content;width:fit-content;min-height:30px;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:7px;background:color-mix(in oklch,var(--surface-elevated),var(--surface-panel) 18%);color:var(--text-muted);cursor:pointer;font-size:.78rem;font-weight:760;list-style:none;padding:0 10px}.advanced-settings summary::-webkit-details-marker{display:none}.advanced-settings summary:after{content:"+";margin-left:8px;font-weight:820}.advanced-settings[open] summary:after{content:"-"}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:11px;gap:11px}.toggle-stack{display:grid;grid-gap:8px;gap:8px}.toggle-stack label{display:flex;align-items:center;gap:8px;min-height:34px}.toggle-stack input{width:16px;height:16px}.cost-confirm{display:flex;align-items:flex-start;gap:9px;padding:10px;border:1px solid color-mix(in oklch,var(--warning),var(--line));border-radius:8px;background:color-mix(in oklch,var(--warning),transparent 90%)}.cost-confirm.failure{border-color:color-mix(in oklch,var(--danger),var(--line));background:color-mix(in oklch,var(--danger),transparent 91%)}.version-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.version-row>div{min-width:0;flex:1 1}.saved-key,.version-row small,.version-row strong{display:block}.branch-row{align-items:stretch}.history-heading{padding-top:8px;border-top:1px solid var(--line)}.history-controls{display:flex;flex-wrap:wrap;gap:8px}.key-status,.saved-key{color:var(--text-muted);font-weight:500}.key-status{font-size:.82rem}.storage-list{display:grid;grid-gap:8px;gap:8px;margin:0}.storage-list div{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}.storage-list dt{color:var(--text-muted)}.storage-list dd{margin:0;color:var(--text-strong);font-weight:700}.job-list{display:grid;grid-gap:8px;gap:8px}.job-row{display:grid;grid-template-columns:auto 1fr;grid-gap:2px 10px;gap:2px 10px;padding:9px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-elevated)}.job-row small,.job-row span{color:var(--text-muted)}.job-row small{grid-column:1/-1}@media (min-width:1041px){.app-shell{height:100dvh;overflow:hidden}.inspector,.workspace{min-height:0;height:100dvh;max-height:100dvh}.app-shell:not(.graph-inspector-closed) .inspector-resize-handle{position:absolute;z-index:12;top:0;bottom:0;left:-6px;display:block;width:12px;min-width:12px;min-height:100%;border:0;border-radius:0;padding:0;background:transparent;cursor:col-resize;touch-action:none}.inspector-resize-handle:after{content:"";position:absolute;top:10px;bottom:10px;left:5px;width:2px;border-radius:999px;background:transparent;transition:background .16s ease-out,box-shadow .16s ease-out}.inspector-resize-handle:focus-visible:after,.inspector-resize-handle:hover:after,body.inspector-resizing .inspector-resize-handle:after{background:color-mix(in oklch,var(--accent),var(--line) 36%);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent),transparent 84%)}.graph-focus.graph-library-open .graph-library-resize-handle{position:absolute;z-index:12;top:0;right:-6px;bottom:0;display:block;width:12px;min-width:12px;min-height:100%;border:0;border-radius:0;padding:0;background:transparent;cursor:col-resize;touch-action:none}.graph-library-resize-handle:after{content:"";position:absolute;top:10px;right:5px;bottom:10px;width:2px;border-radius:999px;background:transparent;transition:background .16s ease-out,box-shadow .16s ease-out}.graph-library-resize-handle:focus-visible:after,.graph-library-resize-handle:hover:after,body.graph-library-resizing .graph-library-resize-handle:after{background:color-mix(in oklch,var(--accent),var(--line) 36%);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent),transparent 84%)}.graph-focus.graph-library-open .graph-node-library{display:grid;top:0;left:0;bottom:0;width:var(--graph-library-width);border-top:0;border-bottom:0;border-left:0;border-radius:0;box-shadow:none;background:var(--surface-panel);padding:18px 14px}.graph-focus.graph-library-open .graph-shell .react-flow{width:calc(100% - var(--graph-library-width))!important;margin-left:var(--graph-library-width)}.graph-focus.graph-library-open .graph-top-chrome{left:calc(var(--graph-library-width) + 16px)}.graph-focus.graph-library-open .graph-toolbar{left:calc(var(--graph-library-width) + 68px)}}@media (max-width:1040px){.onboarding-shell{place-items:stretch;padding:14px}.onboarding-surface{min-height:calc(100vh - 28px);grid-template-columns:1fr}.onboarding-panel{padding:18px}.app-shell,.graph-focus,.graph-focus.graph-inspector-closed{grid-template-columns:1fr}.project-list{display:flex;overflow-x:auto}.project-row{min-width:min(220px,82vw)}.inspector{border-left:0;border-top:1px solid var(--line);padding:16px}.graph-focus .inspector{max-height:46vh}.node-config-grid{grid-template-columns:1fr}.home-header{align-items:flex-start;flex-direction:column}.home-tabs{max-width:100%;overflow-x:auto}.topbar{grid-template-columns:auto minmax(0,1fr) auto}.topbar .mode-tabs{grid-column:2;grid-row:2;justify-self:start}.topbar-project-meta{grid-template-columns:minmax(150px,1fr) auto}}@media (max-width:680px){.onboarding-shell{padding:0}.onboarding-surface{min-height:100vh;border:0;border-radius:0}.onboarding-topline{align-items:flex-start;flex-direction:column}.onboarding-nav-actions{width:100%;justify-content:space-between}.onboarding-maker-strip{justify-self:stretch;max-width:100%}.onboarding-maker-copy{flex:1 1 auto}.onboarding-rail{grid-template-columns:1fr;justify-items:start;overflow:hidden}.onboarding-current-pill{justify-self:start;max-width:100%}.onboarding-step-panel{align-self:start;padding:28px 0}.onboarding-actions{align-items:stretch;flex-direction:column}.onboarding-actions button,.onboarding-link-button{width:100%}.onboarding-copy h1{font-size:1.86rem}.mode-tabs,.topbar,.work-surface{padding-left:14px;padding-right:14px}.mode-tabs,.topbar-actions{overflow-x:auto;flex-wrap:nowrap}.topbar{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px}.workspace-back-button{width:-moz-fit-content;width:fit-content}.topbar-project-meta{grid-column:2/-1;grid-template-columns:minmax(0,1fr);gap:7px}.project-meta-row{overflow-x:auto}.topbar .mode-tabs{grid-column:1/2;grid-row:2;justify-self:start}.topbar-actions{grid-column:2/-1;grid-row:2;justify-self:end}.graph-top-chrome{left:12px;right:76px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center}.graph-toolbar{top:64px;left:12px;align-items:center;justify-content:flex-start;width:calc(100% - 104px);max-width:calc(100% - 104px);overflow-x:auto;overflow-y:visible;flex-wrap:nowrap}.history-shortcuts{flex:0 0 auto;overflow-x:auto}.graph-action-rail button,.graph-shell .react-flow__controls-button,.graph-toolbar button{min-height:44px}.graph-action-rail button,.graph-shell .react-flow__controls-button{width:44px}.graph-toolbar button,.graph-toolbar-actions,.graph-toolbar-primary,.history-shortcuts button{flex:0 0 auto}.graph-shell .react-flow__minimap{display:none}.flow-node{width:292px}.graph-status-actions .provider-mode{display:none}.flow-node.nano_banana_pro_image,.flow-node.seedance_2_video,.flow-node.video_downscale,.flow-node.video_upscale{width:236px}.topbar{align-items:flex-start;flex-direction:column}.resume-notice{width:100%}.clip-row{grid-template-columns:24px 28px 64px minmax(0,1fr)}.clip-row,.project-row,.version-row{min-width:0}.clip-actions{grid-column:1/-1}.clip-actions button{flex:1 1}.clip-actions .icon-button{flex:0 0 38px}.batch-summary,.batch-table,.two-col{grid-template-columns:1fr}.batch-head{display:none}.batch-table>*{border-right:0}}@media (prefers-reduced-motion:no-preference){.clip-row,.onboarding-link-button,button{transition:background .18s cubic-bezier(.16,1,.3,1),border-color .18s cubic-bezier(.16,1,.3,1),box-shadow .18s cubic-bezier(.16,1,.3,1),opacity .14s cubic-bezier(.16,1,.3,1),transform .18s cubic-bezier(.16,1,.3,1)}.onboarding-stage{animation:onboardingStepIn .26s cubic-bezier(.16,1,.3,1)}.onboarding-icon{animation:onboardingIconSettle .42s cubic-bezier(.16,1,.3,1)}.clip-row.dragging{transition:background .12s cubic-bezier(.16,1,.3,1),border-color .12s cubic-bezier(.16,1,.3,1),box-shadow .12s cubic-bezier(.16,1,.3,1)}.io-source-option{transition:background .16s cubic-bezier(.16,1,.3,1),border-color .16s cubic-bezier(.16,1,.3,1),box-shadow .16s cubic-bezier(.16,1,.3,1),transform .18s cubic-bezier(.16,1,.3,1)}.flow-node{transition:background .18s ease-out,border-color .18s ease-out,box-shadow .18s ease-out}}@keyframes onboardingStepIn{0%{opacity:.72;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes onboardingIconSettle{0%{opacity:0;transform:scale(.9)}60%{opacity:1;transform:scale(1.035)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.clip-row,.graph-drop-target,.io-source-option,.onboarding-link-button{transition:none}.clip-row.drop-target:after,.io-source-option-shell.drop-target:after,.onboarding-icon,.onboarding-stage{animation:none}}