.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}:root{--font-sans: "Geist", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Geist Mono", ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace;--fs-xs: 11px;--fs-sm: 12px;--fs-base: 13px;--fs-md: 14px;--fs-lg: 16px;--fs-xl: 19px;--fs-2xl: 24px;--fs-3xl: 32px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-pill: 999px;--ease-out: cubic-bezier(.2, .8, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .36s;--header-h: 52px;--status-h: 28px;--palette-w: 268px;--inspector-w: 360px;--focus-ring: 0 0 0 2px var(--surface), 0 0 0 4px var(--accent)}:root,[data-theme=light]{color-scheme:light;--surface: oklch(99% .003 95);--surface-2: oklch(97.2% .004 95);--bg: var(--surface);--panel: oklch(100% 0 0);--panel-2: oklch(98% .004 95);--elev: oklch(100% 0 0);--grid-dot: oklch(86% .006 95);--canvas-bg: oklch(98% .004 95);--line: oklch(91% .005 95);--line-strong: oklch(84% .006 95);--line-soft: oklch(94% .004 95);--ink: oklch(20% .01 90);--ink-2: oklch(35% .01 90);--ink-3: oklch(52% .01 90);--ink-mute: oklch(65% .008 90);--accent: oklch(58% .13 195);--accent-2: oklch(48% .14 195);--accent-soft: oklch(94% .03 195);--accent-ink: oklch(98% .005 195);--success: oklch(58% .14 155);--success-soft: oklch(95% .04 155);--warn: oklch(65% .16 70);--warn-soft: oklch(95% .05 70);--danger: oklch(58% .18 25);--danger-soft: oklch(95% .04 25);--info: oklch(58% .14 240);--info-soft: oklch(95% .04 240);--cat-input-h: 240;--cat-clean-h: 60;--cat-transform-h: 295;--cat-output-h: 145;--cat-llm-h: 12;--cat-l: 58%;--cat-c: .13;--cat-soft-l: 95%;--cat-soft-c: .04;--sh-sm: 0 1px 2px oklch(0% 0 0 / .06), 0 1px 1px oklch(0% 0 0 / .04);--sh-md: 0 4px 12px oklch(0% 0 0 / .08), 0 1px 2px oklch(0% 0 0 / .04);--sh-lg: 0 16px 40px oklch(0% 0 0 / .12), 0 4px 8px oklch(0% 0 0 / .06);--sh-node: 0 1px 0 oklch(0% 0 0 / .04), 0 1px 3px oklch(0% 0 0 / .06);--sh-node-sel: 0 0 0 2px var(--accent), 0 6px 16px oklch(0% 0 0 / .12)}[data-theme=dark]{color-scheme:dark;--surface: oklch(16% .005 250);--surface-2: oklch(19% .006 250);--bg: var(--surface);--panel: oklch(20% .006 250);--panel-2: oklch(23% .006 250);--elev: oklch(24% .007 250);--grid-dot: oklch(28% .008 250);--canvas-bg: oklch(15% .006 250);--line: oklch(28% .008 250);--line-strong: oklch(36% .01 250);--line-soft: oklch(24% .007 250);--ink: oklch(96% .005 250);--ink-2: oklch(82% .006 250);--ink-3: oklch(66% .008 250);--ink-mute: oklch(52% .008 250);--accent: oklch(72% .14 195);--accent-2: oklch(80% .13 195);--accent-soft: oklch(28% .06 195);--accent-ink: oklch(15% .01 195);--success: oklch(72% .15 155);--success-soft: oklch(28% .06 155);--warn: oklch(78% .15 70);--warn-soft: oklch(30% .06 70);--danger: oklch(72% .17 25);--danger-soft: oklch(30% .07 25);--info: oklch(72% .14 240);--info-soft: oklch(28% .06 240);--cat-l: 72%;--cat-c: .14;--cat-soft-l: 30%;--cat-soft-c: .06;--sh-sm: 0 1px 2px oklch(0% 0 0 / .4);--sh-md: 0 6px 16px oklch(0% 0 0 / .45), 0 1px 2px oklch(0% 0 0 / .3);--sh-lg: 0 24px 60px oklch(0% 0 0 / .55), 0 4px 12px oklch(0% 0 0 / .35);--sh-node: 0 1px 0 oklch(100% 0 0 / .04), 0 2px 6px oklch(0% 0 0 / .4);--sh-node-sel: 0 0 0 2px var(--accent), 0 8px 24px oklch(0% 0 0 / .5)}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--surface);color:var(--ink);font-family:var(--font-sans);font-size:var(--fs-base);line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none;padding:0}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--line-strong);border:2px solid transparent;background-clip:padding-box;border-radius:999px}*::-webkit-scrollbar-thumb:hover{background:var(--ink-mute);border:2px solid transparent;background-clip:padding-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}::selection{background:var(--accent-soft);color:var(--ink)}.app{display:grid;grid-template-rows:var(--header-h) 1fr var(--status-h);height:100dvh;background:var(--surface);color:var(--ink);position:relative}.onboarding-banner{position:absolute;top:var(--header-h);left:0;right:0;z-index:10;display:flex;align-items:center;gap:var(--sp-2);padding:6px var(--sp-4);background:color-mix(in srgb,var(--accent) 12%,var(--panel));border-bottom:1px solid color-mix(in srgb,var(--accent) 30%,transparent);font-size:var(--fs-sm);color:var(--ink-2)}.onboarding-banner .onboarding-icon{color:var(--accent);flex-shrink:0}.onboarding-banner .onboarding-text{flex:1}.onboarding-banner .onboarding-close{margin-left:auto}.header{display:flex;align-items:center;gap:var(--sp-3);padding:0 var(--sp-4);background:var(--panel);border-bottom:1px solid var(--line);z-index:5}.header-brand{display:flex;align-items:center;gap:var(--sp-2);font-weight:700;letter-spacing:-.01em;color:var(--ink);font-size:var(--fs-md);text-decoration:none}.header-brand .mark{color:var(--accent)}.header-brand .word{display:flex;align-items:baseline;gap:2px}.header-brand .word b{font-weight:700}.header-brand .word span{font-weight:500;color:var(--ink-3);font-size:var(--fs-sm)}.pipeline-name{display:flex;align-items:center;gap:var(--sp-1);padding:4px var(--sp-2);border-radius:var(--r-sm);color:var(--ink-2);font-weight:500;cursor:pointer;margin-left:var(--sp-3);border:1px solid transparent;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pipeline-name:hover{background:var(--surface-2);border-color:var(--line)}.pipeline-name .dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex:none}.pipeline-name-input{height:30px;padding:0 var(--sp-2);border-radius:var(--r-sm);border:1px solid var(--accent);background:var(--surface-2);color:var(--ink);font-size:var(--fs-base);font-weight:500;max-width:260px;outline:none;margin-left:var(--sp-3)}.header-spacer{flex:1}.header-mobile-menu{display:none}.header-actions{display:flex;align-items:center;gap:var(--sp-1)}.header-actions .divider{width:1px;height:22px;background:var(--line);margin:0 var(--sp-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 var(--sp-3);border-radius:var(--r-md);font-size:var(--fs-base);font-weight:500;color:var(--ink-2);background:transparent;border:1px solid transparent;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out);white-space:nowrap}.btn:hover,.btn[aria-pressed=true]{background:var(--surface-2);color:var(--ink)}.btn-icon{width:32px;padding:0}.btn-ghost{color:var(--ink-3)}.btn-outline{border-color:var(--line)}.btn-outline:hover{border-color:var(--line-strong)}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-2);border-color:var(--accent-2);color:var(--accent-ink)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-soft);color:var(--danger)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.kbd{font-family:var(--font-mono);font-size:10px;font-weight:500;padding:1px 5px;border:1px solid var(--line);border-radius:var(--r-xs);background:var(--surface);color:var(--ink-3);margin-left:4px}.main{display:grid;grid-template-columns:var(--palette-w) 1fr var(--inspector-w);min-height:0;position:relative;transition:grid-template-columns var(--dur-slow) var(--ease-out)}.main[data-palette=collapsed]{grid-template-columns:0 1fr var(--inspector-w)}.main[data-inspector=collapsed]{grid-template-columns:var(--palette-w) 1fr 0}.main[data-palette=collapsed][data-inspector=collapsed]{grid-template-columns:0 1fr 0}.palette{background:var(--panel);border-right:1px solid var(--line);overflow:hidden;transition:border-color var(--dur-slow) var(--ease-out);display:flex;flex-direction:column;min-height:0}.palette-search{padding:var(--sp-3);border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:var(--panel);z-index:1}.search-box{display:flex;align-items:center;gap:var(--sp-2);height:34px;padding:0 var(--sp-3);border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);color:var(--ink-3);transition:border-color var(--dur-fast) var(--ease-out)}.search-box:focus-within{border-color:var(--accent)}.search-box input{flex:1;border:none;background:transparent;outline:none;font-size:var(--fs-base);color:var(--ink)}.search-box input::placeholder{color:var(--ink-mute)}.palette-list{overflow-y:auto;padding:var(--sp-2) 0 var(--sp-4);flex:1}.palette-section{margin-top:var(--sp-3)}.palette-section:first-child{margin-top:0}.palette-heading{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);font-size:var(--fs-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}.palette-heading .swatch{width:8px;height:8px;border-radius:2px}.palette-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-4);cursor:grab;-webkit-user-select:none;user-select:none;border-left:2px solid transparent;transition:background var(--dur-fast) var(--ease-out)}.palette-item:hover{background:var(--surface-2);border-left-color:var(--cat-hue)}.palette-item:active{cursor:grabbing}.palette-item .pi-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);background:var(--cat-soft);color:var(--cat-hue);flex:none}.palette-item .pi-text{display:flex;flex-direction:column;min-width:0}.palette-item .pi-name{font-size:var(--fs-base);font-weight:500;color:var(--ink)}.palette-item .pi-desc{font-size:var(--fs-xs);color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-wrap{position:relative;min-width:0;background:var(--canvas-bg);overflow:hidden}.panel-toggle{position:absolute;top:50%;transform:translateY(-50%);z-index:6;display:flex;align-items:center;justify-content:center;width:22px;height:44px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--elev);color:var(--ink-3);cursor:pointer;opacity:.55;transition:opacity var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.panel-toggle:hover{opacity:1;background:var(--surface-2);color:var(--ink)}.panel-toggle-left{left:6px}.panel-toggle-right{right:6px}.react-flow__background{background-color:var(--canvas-bg)!important}.react-flow__background pattern circle{fill:var(--grid-dot)!important}.react-flow__controls{box-shadow:var(--sh-md)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;overflow:hidden}.react-flow__controls-button{background:var(--elev)!important;border-color:var(--line-soft)!important;color:var(--ink-3)!important;fill:var(--ink-3)!important}.react-flow__controls-button:hover{background:var(--surface-2)!important;color:var(--ink)!important;fill:var(--ink)!important}.react-flow__minimap{background:var(--panel)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;opacity:.28;cursor:move!important;transition:opacity var(--dur-base) var(--ease-out);will-change:transform}.react-flow__minimap:hover{opacity:.92}.react-flow__edge-path{stroke:var(--line-strong)!important;stroke-width:1.5!important}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path,.react-flow__connection-path{stroke:var(--accent)!important;stroke-width:2!important}.ff-node{width:220px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-node);overflow:hidden;transition:box-shadow var(--dur-fast) var(--ease-out)}.ff-node:hover{box-shadow:var(--sh-md)}.ff-node[data-selected=true]{border-color:var(--accent);box-shadow:var(--sh-node-sel)}.ff-node[data-status=error]{border-color:var(--danger)}.ff-node[data-status=running]{border-color:var(--info)}.node-head{display:flex;align-items:center;gap:var(--sp-2);padding:8px var(--sp-3);background:var(--cat-soft);border-bottom:1px solid var(--line-soft)}.node-head .icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--r-xs);background:var(--panel);color:var(--cat-hue);flex:none}.node-head .title{flex:1;font-weight:600;font-size:var(--fs-base);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-head .menu{width:22px;height:22px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;color:var(--ink-3)}.node-head .menu:hover{background:var(--panel);color:var(--ink)}.node-body{padding:var(--sp-2) var(--sp-3);font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-2);background:var(--panel);white-space:pre-wrap;word-break:break-word;line-height:1.5;min-height:32px}.node-body .empty{color:var(--ink-mute);font-style:italic;font-family:var(--font-sans)}.node-link-file-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-sans);font-size:var(--fs-xs);font-style:normal;background:var(--accent-soft);color:var(--accent);border-radius:var(--r-pill);padding:1px 8px;margin-bottom:var(--sp-1)}.node-foot{display:flex;align-items:center;gap:var(--sp-2);padding:6px var(--sp-3);border-top:1px solid var(--line-soft);font-size:11px;font-family:var(--font-mono);color:var(--ink-3);background:var(--panel-2)}.node-foot .rows-out{color:var(--ink);font-weight:600;margin-left:auto;display:inline-flex;align-items:center;gap:4px}.node-foot .delta-pos{color:var(--success)}.node-foot .delta-neg{color:var(--warn)}.node-status-dot{width:7px;height:7px;border-radius:50%;background:var(--ink-mute);flex:none}.node-status-dot[data-status=ready]{background:var(--info)}.node-status-dot[data-status=done]{background:var(--success)}.node-status-dot[data-status=error]{background:var(--danger)}.node-status-dot[data-status=running]{background:var(--info);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .7s linear infinite}.react-flow__handle{width:12px!important;height:12px!important;background:var(--panel)!important;border:2px solid var(--cat-hue)!important;border-radius:50%!important;transition:transform var(--dur-fast) var(--ease-out)!important}.react-flow__handle:hover{transform:scale(1.35)!important}.react-flow__handle-left{left:-6px!important}.react-flow__handle-right{right:-6px!important}.inspector{background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;transition:border-color var(--dur-slow) var(--ease-out);min-height:0}.insp-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);color:var(--ink-mute);padding:var(--sp-8);text-align:center}.insp-empty svg{opacity:.3}.insp-empty p{font-size:var(--fs-sm);margin:0}.insp-head{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-4);border-bottom:1px solid var(--line-soft)}.insp-head .icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:var(--cat-soft);color:var(--cat-hue);flex:none}.insp-head .meta{flex:1;min-width:0}.insp-head .title{font-weight:600;font-size:var(--fs-md);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.insp-head .sub{display:inline-flex;align-items:center;gap:4px;margin-top:3px;font-size:var(--fs-xs);color:var(--cat-hue);font-weight:500;text-transform:capitalize;background:var(--cat-soft);border-radius:var(--r-pill);padding:1px 7px;width:fit-content}.insp-body{overflow-y:auto;flex:1;padding:var(--sp-2) 0}.insp-section{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line-soft)}.insp-section:last-child{border-bottom:none}.insp-section--no-pad{padding:0}.insp-preview-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);font-size:var(--fs-xs);font-weight:600;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em}.insp-label{display:flex;align-items:center;justify-content:space-between;font-size:var(--fs-xs);font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-1)}.insp-field{display:flex;flex-direction:column;gap:var(--sp-1);margin-bottom:var(--sp-3)}.insp-field:last-child{margin-bottom:0}.insp-input{width:100%;padding:6px var(--sp-2);border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink);font-size:var(--fs-sm);transition:border-color var(--dur-fast) var(--ease-out)}.insp-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.insp-input::placeholder{color:var(--ink-mute)}textarea.insp-input{resize:vertical;min-height:80px;line-height:1.5}.insp-select{width:100%;height:30px;padding:0 var(--sp-2);border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink);font-size:var(--fs-sm);cursor:pointer;transition:border-color var(--dur-fast) var(--ease-out)}.insp-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.insp-hint{font-size:var(--fs-xs);color:var(--ink-mute);line-height:1.4;margin:0}.insp-row{display:flex;align-items:center;gap:var(--sp-1)}.insp-row .insp-select,.insp-row .insp-input{flex:1;min-width:0}.insp-divider{border:none;border-top:1px solid var(--line-soft);margin:var(--sp-2) 0}.seg{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);padding:2px;gap:2px}.seg button{padding:5px 10px;font-size:var(--fs-sm);font-weight:500;color:var(--ink-3);border-radius:var(--r-sm);transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.seg button:hover{color:var(--ink)}.seg button[aria-pressed=true]{background:var(--panel);color:var(--ink);box-shadow:var(--sh-sm)}.field{height:30px;padding:0 var(--sp-2);border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink);font-size:var(--fs-sm);display:flex;align-items:center;gap:4px;width:100%}.field:focus-within{border-color:var(--accent)}.field-mono{font-family:var(--font-mono);font-size:var(--fs-xs)}.field input,.field select{border:none;background:transparent;width:100%;outline:none;color:inherit;font:inherit}.cond-row{display:grid;grid-template-columns:1fr 86px 1fr 28px;gap:var(--sp-1);align-items:center;margin-bottom:var(--sp-2)}.cond-join{font-size:10px;font-weight:700;color:var(--ink-mute);letter-spacing:.1em;margin:2px 0 4px 6px}.btn-x{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--ink-mute)}.btn-x:hover{background:var(--danger-soft);color:var(--danger)}.add-row{display:flex;gap:var(--sp-2);margin-top:var(--sp-2)}.add-row .btn{height:28px;padding:0 10px;font-size:var(--fs-sm);border:1px dashed var(--line-strong);color:var(--ink-3)}.add-row .btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.preview{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--surface)}.preview-head{display:flex;align-items:center;justify-content:space-between;padding:6px var(--sp-2);border-bottom:1px solid var(--line-soft);font-size:var(--fs-xs);color:var(--ink-mute);background:var(--panel-2)}.preview-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:11px}.preview-table th,.preview-table td{text-align:left;padding:4px var(--sp-2);border-right:1px solid var(--line-soft);white-space:nowrap}.preview-table th:last-child,.preview-table td:last-child{border-right:none}.preview-table thead th{background:var(--panel-2);font-weight:600;color:var(--ink-2);border-bottom:1px solid var(--line);position:sticky;top:0}.preview-table tbody tr:nth-child(2n) td{background:var(--panel-2)}.preview-table .type-badge{display:inline-block;font-size:9px;padding:1px 4px;border-radius:3px;margin-left:4px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:var(--info-soft);color:var(--info)}.preview-table .type-badge[data-t=number]{background:var(--success-soft);color:var(--success)}.preview-table .type-badge[data-t=date]{background:var(--warn-soft);color:var(--warn)}.preview-table .type-badge[data-t=null]{background:var(--danger-soft);color:var(--danger)}.preview-scroll{overflow:auto;max-height:220px}.schema-grid{display:grid;grid-template-columns:20px 1fr auto 100px;gap:4px;align-items:center;font-size:var(--fs-xs)}.schema-grid-header{font-weight:600;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.05em;padding:0 0 4px;border-bottom:1px solid var(--line-soft);margin-bottom:2px}.schema-row{display:contents}.schema-row>*{padding:3px 0}.schema-col-name{font-family:var(--font-mono);color:var(--ink)}.schema-col-samples{color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schema-type-select{height:24px;padding:0 4px;border:1px solid var(--line);border-radius:var(--r-xs);background:var(--surface);color:var(--ink);font-size:10px;font-family:var(--font-mono)}.schema-type-select:focus{border-color:var(--accent);outline:none}.statusbar{display:flex;align-items:center;gap:var(--sp-3);padding:0 var(--sp-4);background:var(--panel);border-top:1px solid var(--line);font-size:11px;font-family:var(--font-mono);color:var(--ink-3)}.statusbar .item{display:inline-flex;align-items:center;gap:6px}.statusbar .item .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.statusbar .dot-warn{background:var(--warn)!important}.statusbar .dot-error{background:var(--danger)!important}.statusbar .spacer{flex:1}.sheet-backdrop{position:fixed;inset:0;background:#0006;z-index:50;opacity:0;pointer-events:none;transition:opacity var(--dur-base)}.sheet-backdrop[data-open=true]{opacity:1;pointer-events:auto}.sheet{position:fixed;background:var(--panel);z-index:51;display:flex;flex-direction:column;box-shadow:var(--sh-lg);transition:transform var(--dur-base) var(--ease-out)}.sheet[data-side=left]{top:0;bottom:0;left:0;width:min(85vw,320px);border-right:1px solid var(--line);transform:translate(-100%)}.sheet[data-side=left][data-open=true]{transform:translate(0)}.sheet[data-side=bottom]{left:0;right:0;bottom:0;max-height:85vh;border-top-left-radius:var(--r-xl);border-top-right-radius:var(--r-xl);border-top:1px solid var(--line);transform:translateY(100%)}.sheet[data-side=bottom][data-open=true]{transform:translateY(0)}.sheet-handle{display:none;width:40px;height:4px;border-radius:2px;background:var(--line-strong);margin:8px auto 0}.sheet[data-side=bottom] .sheet-handle{display:block}.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line-soft)}.sheet-body{overflow-y:auto;flex:1}.mobile-bottombar{display:none}.node-file-action{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:500;border-top:1px solid var(--line-soft);background:var(--panel-2);cursor:pointer;color:var(--accent)}.node-file-action.secondary{color:var(--ink-3)}.node-file-action input[type=file]{display:none}.statusbar .item-dim{color:var(--ink-2)}.statusbar .item-mute{color:var(--ink-mute)}.statusbar .item-warn{color:var(--warn);cursor:default}.preview-table .cell-null{color:var(--ink-mute)}.edge-count-badge{position:absolute;pointer-events:none;font-family:var(--font-mono);font-size:10px;line-height:1;padding:2px 6px;background:var(--elev-2, #f5f5f5);color:var(--ink-2);border:1px solid var(--line);border-radius:10px;white-space:nowrap;box-shadow:0 1px 3px #00000014}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--elev);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:min(520px,92vw);max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--line)}.modal-title{font-size:var(--fs-base);font-weight:600;margin:0}.modal-body{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4)}.modal-desc{color:var(--ink-2);font-size:var(--fs-sm);margin:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--line)}.suggest-dialog{width:min(560px,92vw)}.modal-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--line)}.modal-head .modal-title{flex:1}.modal-foot{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--line)}.modal-foot-spacer{flex:1}.suggest-result{display:flex;flex-direction:column;gap:10px}.suggest-result-name{display:flex;align-items:center;gap:6px;color:var(--ink-2);font-size:var(--fs-sm)}.suggest-result-name-icon{color:var(--accent)}.suggest-result-loading{display:flex;align-items:center;gap:8px;color:var(--ink-mute);font-size:var(--fs-sm)}.suggest-result-explanation{font-size:var(--fs-sm);color:var(--ink-mute);margin:0;line-height:1.5}.suggest-node-list{display:flex;flex-direction:column;gap:4px}@keyframes suggest-appear{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.suggest-node-card{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--r-md);background:var(--surface-2);font-size:var(--fs-sm);animation:suggest-appear .2s ease}.suggest-node-index{color:var(--ink-mute);min-width:20px;text-align:right;font-size:var(--fs-xs)}.suggest-node-label{font-weight:500}.suggest-node-summary{color:var(--ink-mute);font-size:var(--fs-xs);margin-left:auto}.suggest-error{display:flex;gap:8px;color:var(--color-error, #e53);font-size:var(--fs-sm);align-items:flex-start}.suggest-error-icon{flex-shrink:0;margin-top:2px}.stream-cursor{display:inline-block;width:2px;height:.9em;background:currentColor;margin-left:1px;vertical-align:text-bottom;opacity:.6;animation:stream-blink 1s step-end infinite}@keyframes stream-blink{0%,to{opacity:.6}50%{opacity:0}}.consent-message{font-size:var(--fs-sm);color:var(--ink-2);margin:0}.consent-providers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--sp-1)}.consent-provider-item{display:flex;align-items:baseline;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--surface-2);border-radius:var(--r-sm);font-size:var(--fs-sm)}.consent-provider-url{color:var(--ink-3);font-size:var(--fs-xs);font-family:var(--font-mono)}.cost-breakdown{display:flex;flex-direction:column;gap:2px}.cost-breakdown-item{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--surface-2);border-radius:var(--r-sm)}.cost-breakdown-info{display:flex;flex-direction:column;gap:2px;min-width:0}.cost-breakdown-label{font-size:var(--fs-sm);font-weight:500;color:var(--ink-1)}.cost-breakdown-meta{font-size:var(--fs-xs);color:var(--ink-3)}.cost-breakdown-cost{font-size:var(--fs-sm);font-weight:600;color:var(--ink);font-family:var(--font-mono);white-space:nowrap}.cost-total{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3);background:var(--accent-soft);border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:600}.cost-total strong{font-family:var(--font-mono)}.cost-disclaimer{font-size:var(--fs-xs);color:var(--ink-3);margin:0;line-height:1.5}.insp-error{display:flex;gap:var(--sp-2);align-items:flex-start;background:color-mix(in srgb,var(--danger) 8%,var(--panel));border:1px solid color-mix(in srgb,var(--danger) 25%,transparent);border-radius:var(--r-sm);color:var(--danger);font-size:var(--fs-sm);line-height:1.4;word-break:break-word}.insp-error-icon{flex-shrink:0;margin-top:1px}.llm-progress-done{background:color-mix(in srgb,var(--success) 6%,var(--panel))}.llm-progress-header{display:flex;align-items:center;justify-content:space-between;font-size:var(--fs-xs);color:var(--ink-2);margin-bottom:var(--sp-1)}.llm-progress-status{font-weight:500}.llm-progress-done .llm-progress-status{color:var(--success);font-weight:600}.llm-progress-count{font-family:var(--font-mono);color:var(--ink-mute)}.llm-progress-track{height:5px;background:var(--line);border-radius:var(--r-pill);overflow:hidden}.llm-progress-fill{height:100%;background:var(--accent);border-radius:var(--r-pill);transition:width .3s var(--ease-out)}.llm-progress-done .llm-progress-fill{background:var(--success)}.llm-progress-cost{font-size:var(--fs-xs);color:var(--ink-mute);margin-top:var(--sp-1);display:block;font-family:var(--font-mono)}.share-actions{display:flex;flex-direction:column;gap:var(--sp-2)}.share-action-btn{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);cursor:pointer;text-align:left;color:var(--ink-1);transition:background .15s,border-color .15s}.share-action-btn:hover{background:var(--elev-2);border-color:var(--accent)}.share-action-btn svg{color:var(--accent);flex-shrink:0}.share-action-btn strong{display:block;font-size:var(--fs-sm);font-weight:600}.share-action-btn span{font-size:var(--fs-xs);color:var(--ink-3)}.share-url-row{display:flex;gap:var(--sp-2)}.share-url-input{flex:1;padding:var(--sp-2) var(--sp-3);border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-1);font-size:var(--fs-xs);font-family:var(--font-mono, monospace);min-width:0}.share-success{color:var(--success);font-size:var(--fs-sm);margin:0}.share-warning{background:var(--warn-soft);border-width:1px;border-style:solid;border-color:var(--warn);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-sm);color:var(--ink-1)}.share-error{background:var(--danger-soft);border-width:1px;border-style:solid;border-color:var(--danger);border-radius:var(--r-sm);padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm)}.share-error strong{display:block;margin-bottom:var(--sp-1)}.share-footer-actions{display:flex;justify-content:flex-end}.large-file-banner{position:absolute;top:var(--header-h);left:0;right:0;z-index:11;display:flex;align-items:center;gap:var(--sp-2);padding:6px var(--sp-4);background:color-mix(in srgb,var(--warn) 10%,var(--panel));border-bottom:1px solid color-mix(in srgb,var(--warn) 35%,transparent);font-size:var(--fs-sm);color:var(--ink-2)}.large-file-banner-icon{color:var(--warn);flex-shrink:0}.large-file-banner-text{flex:1}.large-file-banner-link{color:var(--accent);font-weight:500;text-decoration:underline}.large-file-banner-close{margin-left:auto}.statusbar-desktop-link{display:flex;align-items:center;gap:var(--sp-1);text-decoration:none;color:var(--ink-mute);font-size:var(--fs-xs);transition:color var(--dur-fast)}.statusbar-desktop-link:hover{color:var(--accent)}.download-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--surface);padding:var(--sp-8) var(--sp-4)}.download-card{background:var(--elev);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:var(--sp-10) var(--sp-8);max-width:480px;width:100%;text-align:center;display:flex;flex-direction:column;gap:var(--sp-4)}.download-icon{font-size:40px;line-height:1}.download-title{font-size:var(--fs-2xl);font-weight:700;margin:0;color:var(--ink)}.download-subtitle{font-size:var(--fs-base);color:var(--ink-2);margin:0;line-height:1.6}.download-loading{color:var(--ink-mute);font-size:var(--fs-sm)}.download-coming-soon{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-6);background:var(--surface-2);border-radius:var(--r-lg)}.download-soon-title{font-size:var(--fs-lg);font-weight:600;color:var(--ink);margin:0}.download-soon-body{font-size:var(--fs-sm);color:var(--ink-2);margin:0;line-height:1.6;text-align:center}.download-no-platform{font-size:var(--fs-sm);color:var(--ink-mute);margin:0}.download-primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);height:44px;padding:0 var(--sp-6);background:var(--accent);color:var(--accent-ink);border-radius:var(--r-md);font-size:var(--fs-md);font-weight:600;text-decoration:none;transition:filter var(--dur-fast)}.download-primary-btn:hover{filter:brightness(1.08)}.download-other{display:flex;flex-direction:column;gap:var(--sp-2)}.download-other p{font-size:var(--fs-sm);color:var(--ink-mute);margin:0}.download-other-links{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap}.download-other-links a{font-size:var(--fs-sm);color:var(--accent);text-decoration:underline}.download-meta{display:flex;gap:var(--sp-4);justify-content:center;font-size:var(--fs-xs);color:var(--ink-mute);font-family:var(--font-mono)}.download-compat{font-size:var(--fs-xs);color:var(--ink-2);background:var(--surface-2);border-radius:var(--r-sm);padding:var(--sp-3);line-height:1.5}@media(max-width:1100px){:root{--inspector-w: 320px;--palette-w: 240px}}@media(max-width:900px){.main{grid-template-columns:1fr}.palette,.inspector{display:none}.mobile-bottombar{display:flex;position:fixed;left:var(--sp-3);right:var(--sp-3);bottom:calc(var(--status-h) + var(--sp-3));background:var(--elev);border:1px solid var(--line);border-radius:var(--r-pill);box-shadow:var(--sh-md);align-items:center;justify-content:space-around;padding:6px;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-bottombar .btn{height:40px;min-width:40px;padding:0 var(--sp-3)}.header .pipeline-name{max-width:140px;font-size:var(--fs-sm)}}@media(max-width:540px){:root{--header-h: 48px}.header-brand .word span{display:none}}.auth-brand{display:flex;align-items:center;gap:var(--sp-2)}.auth-logo{font-size:20px;line-height:1}.auth-oauth-row{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-2)}.auth-oauth-btn{flex:1;height:38px;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:500}.auth-divider{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-xs);color:var(--ink-mute);white-space:nowrap;margin:var(--sp-2) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line)}.form-field{display:flex;flex-direction:column;gap:5px}.form-label{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2)}.form-input-wrap{position:relative;display:flex;align-items:center}.form-input-icon{position:absolute;left:10px;color:var(--ink-mute);pointer-events:none;z-index:1;flex:none}.form-input{width:100%;height:38px;padding:0 var(--sp-3);border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-size:var(--fs-sm);transition:border-color var(--dur-fast) var(--ease-out)}.form-input:focus{border-color:var(--accent);outline:none}.form-input::placeholder{color:var(--ink-mute)}.form-input-icon-left{padding-left:32px}.auth-modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(4px)}.auth-modal{background:var(--elev);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:440px;padding:var(--sp-6)}.auth-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}.auth-modal-title{font-size:var(--fs-lg);font-weight:600}.auth-modal-tabs{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-5)}.auth-tab{flex:1;padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:500;background:transparent;border:1px solid transparent;cursor:pointer;color:var(--ink-2);transition:all .15s}.auth-tab.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.auth-field{margin-bottom:var(--sp-4)}.auth-label{display:block;font-size:var(--fs-sm);font-weight:500;margin-bottom:6px}.auth-input{width:100%;height:38px;padding:0 var(--sp-3);border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:var(--fs-sm)}.auth-input:focus{outline:2px solid var(--accent);border-color:transparent}.auth-error{display:flex;align-items:center;gap:var(--sp-2);color:var(--danger);font-size:var(--fs-sm);margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--danger-soft);border-radius:var(--r-sm)}.auth-submit{width:100%;height:40px;border-radius:var(--r-md);background:var(--accent);color:var(--accent-ink);font-weight:600;font-size:var(--fs-sm);border:none;cursor:pointer;transition:opacity .15s}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;padding-top:var(--sp-3);font-size:var(--fs-sm);color:var(--ink-2)}.auth-switch p{margin:0}.auth-footer{text-align:center;margin-top:var(--sp-4);font-size:var(--fs-sm);color:var(--ink-2)}.auth-footer button{background:none;border:none;cursor:pointer;color:var(--accent);font-size:inherit;text-decoration:underline}.auth-skip{width:100%;margin-top:var(--sp-3);background:transparent;border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-2);font-size:var(--fs-sm);color:var(--ink-2);cursor:pointer}.link-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--accent);font-size:inherit;text-decoration:underline}.modal-footer{display:flex;align-items:center;justify-content:center;padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--line)}.dashboard{display:flex;flex-direction:row;height:100vh;background:var(--bg)}.dash-sidebar{width:220px;min-width:220px;display:flex;flex-direction:column;background:var(--elev);border-right:1px solid var(--line);overflow-y:auto;padding:var(--sp-4) 0 0}.dash-brand{display:flex;align-items:center;gap:var(--sp-2);padding:0 var(--sp-4) var(--sp-4);border-bottom:1px solid var(--line);margin-bottom:var(--sp-2)}.dash-logo{font-size:20px;line-height:1}.dash-wordmark{font-size:var(--fs-base)}.dash-nav{list-style:none;margin:0;padding:0}.dash-nav-item{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) var(--sp-4);background:none;border:none;cursor:pointer;font-size:var(--fs-sm);color:var(--ink-2);transition:background .12s,color .12s;text-align:left}.dash-nav-item:hover{background:var(--surface-2);color:var(--ink)}.dash-nav-item--active{color:var(--accent);font-weight:500}.dash-nav-item--active:hover{background:var(--accent-soft)}.dash-nav-count{margin-left:auto;font-size:var(--fs-xs);color:var(--ink-3);background:var(--surface-2);border-radius:var(--r-pill);padding:1px 7px}.dash-plan-card{margin-top:auto;padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:var(--sp-2)}.dpc-user{display:flex;align-items:center;gap:var(--sp-2)}.dpc-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:var(--fs-sm);font-weight:600}.dpc-info{display:flex;flex-direction:column;min-width:0}.dpc-name{font-size:var(--fs-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dpc-plan{font-size:var(--fs-xs)}.dpc-plan--free{color:var(--ink-3)}.dpc-plan--pro{color:var(--accent)}.dpc-usage{display:flex;flex-direction:column;gap:3px}.dpc-usage-bar{height:4px;background:var(--line);border-radius:var(--r-pill);overflow:hidden}.dpc-usage-fill{height:100%;background:var(--accent);border-radius:var(--r-pill);transition:width .3s}.dpc-usage-label{font-size:var(--fs-xs);color:var(--ink-3)}.dpc-logout{width:100%;justify-content:flex-start!important;gap:var(--sp-2);font-size:var(--fs-xs)!important}.dash-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.dash-topbar{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--line);background:var(--elev);flex-shrink:0}.dash-search-wrap{position:relative;flex:1;max-width:360px}.dash-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-mute);pointer-events:none}.dash-search{width:100%;height:34px;padding:0 var(--sp-3) 0 32px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);color:var(--ink);font-size:var(--fs-sm);transition:border-color var(--dur-fast) var(--ease-out)}.dash-search:focus{outline:none;border-color:var(--accent)}.dash-topbar-actions{display:flex;align-items:center;gap:var(--sp-2);margin-left:auto}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-4);padding:var(--sp-5);overflow-y:auto;flex:1;align-content:start}.dash-list{display:flex;flex-direction:column;overflow-y:auto;flex:1}.dash-loading{flex:1;display:flex;align-items:center;justify-content:center}.dash-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);color:var(--ink-2);padding:var(--sp-8) var(--sp-6);text-align:center}.dash-error p{margin:0;font-size:var(--fs-sm)}.dash-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-4);padding:var(--sp-8) var(--sp-6);color:var(--ink-2);text-align:center}.dash-empty h3{margin:0;font-size:var(--fs-lg);color:var(--ink)}.dash-empty p{margin:0;font-size:var(--fs-sm)}.dash-empty-icon{color:var(--ink-3)}.pc-thumb{border-radius:var(--r-md);overflow:hidden;aspect-ratio:5 / 3}.pc-thumb svg{width:100%;height:100%;display:block}.pc-body{display:flex;flex-direction:column;gap:var(--sp-1)}.pc-title-row{display:flex;align-items:center;gap:var(--sp-1)}.pc-name{flex:1;font-weight:600;font-size:var(--fs-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pc-meta{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-xs);color:var(--ink-3)}.pc-meta span{display:flex;align-items:center;gap:3px}.pc-tags{display:flex;flex-wrap:wrap;gap:4px}.pc-menu-wrap{position:relative;flex-shrink:0}.pc-menu-btn{opacity:0;transition:opacity .12s}.pipeline-card:hover .pc-menu-btn,.pc-menu-wrap:focus-within .pc-menu-btn{opacity:1}.pc-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:30;background:var(--elev);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-md);min-width:140px;display:flex;flex-direction:column}.pc-menu-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-sm);background:none;border:none;cursor:pointer;color:var(--ink);text-align:left;transition:background .1s;width:100%}.pc-menu-item:hover{background:var(--surface-2)}.pc-menu-item--danger{color:var(--danger, #e55)}.pc-menu-item--danger:hover{background:color-mix(in srgb,#e55 10%,var(--elev))}.pc-menu-sep{height:1px;background:var(--line);margin:2px 0}.pc-star-badge{position:absolute;top:6px;right:6px;color:var(--warn, #f5a623);line-height:0}.pc-thumb{position:relative}.confirm-modal{width:min(380px,92vw)}.confirm-modal-danger-icon{color:var(--danger, #e55);flex-shrink:0}.btn-danger-solid{background:var(--danger, #e55);color:#fff;border-color:var(--danger, #e55)}.btn-danger-solid:hover{background:color-mix(in srgb,var(--danger, #e55) 85%,black)}.dash-tag-bar{display:flex;flex-wrap:wrap;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--line)}.tag-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);font-size:var(--fs-xs);cursor:pointer;transition:background .1s,border-color .1s,color .1s}.tag-filter-chip:hover{background:var(--surface-2);color:var(--ink)}.tag-filter-chip--active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:500}.pipeline-list-row{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line);cursor:pointer;transition:background .1s}.pipeline-list-row:hover{background:var(--surface-2)}.plr-name{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.plr-title{font-weight:500;font-size:var(--fs-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plr-tags{display:flex;flex-wrap:wrap;gap:3px}.plr-meta{display:flex;align-items:center;gap:4px;font-size:var(--fs-xs);color:var(--ink-3);white-space:nowrap}.tag-chip{font-size:10px;padding:1px 6px;border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent);font-weight:500}.inline-rename{flex:1;font:inherit;font-weight:500;background:var(--surface);border:1px solid var(--accent);border-radius:var(--r-sm);padding:1px 6px;outline:none;color:var(--ink)}.plan-limit-banner{display:flex;align-items:center;gap:var(--sp-3);background:color-mix(in srgb,var(--warn, #f90) 10%,var(--elev));border:1px solid color-mix(in srgb,var(--warn, #f90) 30%,transparent);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm);margin:var(--sp-4) var(--sp-5) 0;flex-shrink:0}.plan-limit-banner--full{background:color-mix(in srgb,var(--danger, #e55) 10%,var(--elev));border-color:color-mix(in srgb,var(--danger, #e55) 30%,transparent)}.plb-left{flex:1;display:flex;align-items:center;gap:var(--sp-2)}.plb-upgrade{flex-shrink:0}.pipeline-card{background:var(--elev);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-4);cursor:pointer;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:var(--sp-2);position:relative}.pipeline-card:hover{border-color:var(--accent);box-shadow:var(--sh-md)}.pipeline-card-name{font-weight:600;font-size:var(--fs-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pipeline-card-meta{font-size:var(--fs-xs);color:var(--tx-2)}.pipeline-card-actions{display:flex;gap:var(--sp-1);margin-top:auto;padding-top:var(--sp-2)}.pipeline-card--list{flex-direction:row;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-4)}.pipeline-card--list .pipeline-card-name{flex:1}.pipeline-card--list .pipeline-card-actions{margin-top:0;padding-top:0}.auth-gate{position:relative;width:100%;height:100vh;overflow:hidden}.auth-gate-bg{position:absolute;inset:0;filter:blur(8px) saturate(.7);opacity:.5;pointer-events:none}.auth-gate-bg-header{height:52px;background:var(--panel);border-bottom:1px solid var(--line)}.auth-gate-bg-columns{display:grid;grid-template-columns:240px 1fr 320px;height:calc(100% - 52px)}.auth-gate-bg-panel{background:var(--panel);border-right:1px solid var(--line)}.auth-gate-bg-panel--right{border-right:none;border-left:1px solid var(--line)}.auth-gate-bg-canvas{background:var(--canvas-bg);background-image:radial-gradient(var(--grid-dot) 1px,transparent 1px);background-size:22px 22px}.auth-gate-overlay{position:absolute;inset:0;background:#00000059}.auth-gate-modal-wrap{position:absolute;inset:0;display:grid;place-items:center;padding:var(--sp-4)}.auth-gate-modal{width:100%;max-width:420px;background:var(--panel);border-radius:16px;box-shadow:var(--sh-lg);border:1px solid var(--line);padding:32px;max-height:calc(100vh - 2 * var(--sp-4));overflow-y:auto}.auth-gate-modal-brand{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:24px}.auth-gate-modal-logo{font-size:28px;line-height:1;color:var(--accent)}.auth-gate-modal-wordmark{font-size:18px;font-weight:700}.auth-gate-modal-title{margin:0 0 6px;font-size:22px;font-weight:700;letter-spacing:-.01em}.auth-gate-modal-subtitle{margin:0 0 24px;color:var(--ink-3);font-size:13px}.auth-gate-oauth{display:flex;flex-direction:column;gap:var(--sp-2);margin-bottom:16px}.auth-gate-oauth-btn{width:100%;height:40px;justify-content:center}.auth-gate-divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}.auth-gate-divider-line{flex:1;height:1px;background:var(--line)}.auth-gate-field{margin-bottom:12px}.auth-gate-label{display:block;font-size:11px;font-weight:600;color:var(--ink-2);letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px}.auth-gate-label--row{display:flex;justify-content:space-between;align-items:center}.auth-gate-forgot{background:none;border:none;padding:0;cursor:pointer;color:var(--accent);text-transform:none;letter-spacing:0;font-weight:500;font-size:11px}.auth-gate-field .field{height:38px}.auth-gate-submit{width:100%;height:40px;margin-top:4px}.auth-gate-switch{margin:16px 0 0;font-size:12px;color:var(--ink-3);text-align:center}.auth-gate-continue{width:100%;height:32px;color:var(--ink-3);font-size:12px;margin-top:var(--sp-2)}.brand-accent{color:var(--accent)}.dpc-usage-fill{width:var(--fill, 0%)}.plan-banner{display:flex;align-items:center;gap:var(--sp-3);background:color-mix(in srgb,var(--warn, #f90) 12%,var(--elev));border:1px solid color-mix(in srgb,var(--warn, #f90) 35%,transparent);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm);margin-bottom:var(--sp-4)}.plan-banner-msg{flex:1}.plan-banner-upgrade{background:var(--warn, #f90);color:#fff;border-radius:var(--r-sm);padding:var(--sp-1) var(--sp-3);font-weight:600;font-size:var(--fs-xs);border:none;cursor:pointer}.save-status{display:flex;align-items:center;gap:5px;font-size:var(--fs-xs);padding:2px 8px;border-radius:var(--r-pill);border:1px solid var(--line);background:transparent;color:var(--tx-2);transition:color .2s,border-color .2s;user-select:none}.save-status--idle{color:var(--tx-3, var(--tx-2))}.save-status--saving{color:var(--accent);border-color:var(--accent)}.save-status--saved{color:var(--ok, #2c9);border-color:var(--ok, #2c9)}.save-status--offline{color:var(--err, #e55);border-color:var(--err, #e55)}.desktop-modal{background:var(--elev);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:520px;padding:var(--sp-6)}.desktop-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-3)}.desktop-modal-title{font-size:var(--fs-lg);font-weight:600}.desktop-modal-desc{color:var(--tx-2);font-size:var(--fs-sm);margin-bottom:var(--sp-5)}.desktop-platforms{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3);margin-bottom:var(--sp-5)}.desktop-platform-btn{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-3);border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg);cursor:pointer;transition:border-color .15s,box-shadow .15s}.viz-overlay{box-shadow:0 -4px 24px #0000002e}.viz-panel{display:flex;flex-direction:column;background:var(--panel);border-top:1px solid var(--line);height:100%;overflow:hidden}.viz-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-4);border-bottom:1px solid var(--line);flex-shrink:0}.viz-panel-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-4);min-height:0}.viz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-4)}.viz-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;min-height:260px}.viz-card-head{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line-soft);background:var(--panel);flex-shrink:0}.viz-card-title{font-size:var(--fs-sm);font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.viz-card-body{flex:1;min-height:0;padding:var(--sp-3)}.viz-card-footer{font-size:var(--fs-xs);color:var(--ink-mute);padding:var(--sp-1) var(--sp-3);border-top:1px solid var(--line-soft);text-align:right}.viz-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--ink-mute);text-align:center;gap:var(--sp-2)}.viz-empty p{max-width:320px;font-size:var(--fs-sm);line-height:1.5}.btn-active{background:var(--accent-soft);color:var(--accent-2)}font-size: var(--fs-sm); } .desktop-platform-btn:hover{border-color:var(--accent);box-shadow:var(--sh-sm)}.desktop-platform-btn--cta{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg))}.dp-icon{color:var(--tx-1)}.dp-label{font-weight:600}.dp-ext{font-size:var(--fs-xs);color:var(--tx-2)}.dp-cta{font-size:var(--fs-xs);color:var(--accent);font-weight:600}.desktop-modal-footer{display:flex;justify-content:flex-end}.debug-toolbar{display:flex;align-items:center;gap:2px;padding:2px 4px;border-radius:var(--r-md);background:var(--bg);border:1px solid var(--line)}.debug-toolbar--active{border-color:var(--accent)}.debug-toolbar-sep{width:1px;height:18px;background:var(--line);margin:0 2px}.debug-log-label{font-size:10px;font-weight:700;letter-spacing:.05em}.exec-log{display:flex;flex-direction:column;height:100%;background:var(--bg)}.exec-log-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line)}.exec-log-title{font-size:var(--fs-sm);font-weight:600}.exec-log-empty{padding:var(--sp-4) var(--sp-3);color:var(--tx-2);font-size:var(--fs-sm)}.exec-log-list{flex:1;overflow-y:auto;margin:0;padding:var(--sp-2) 0;list-style:none}.exec-log-entry{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line);font-size:var(--fs-xs)}.exec-log-entry--error .exec-log-icon{color:var(--err, #e55)}.exec-log-entry--ok .exec-log-icon{color:var(--ok, #2c9)}.exec-log-name{font-weight:600}.exec-log-type,.exec-log-rows{color:var(--tx-2)}.exec-log-duration{display:flex;align-items:center;gap:3px;color:var(--tx-3, var(--tx-2));margin-left:auto}.exec-log-error{color:var(--err, #e55);width:100%;margin-top:2px}.data-inspector{display:flex;flex-direction:column;height:100%;background:var(--bg)}.data-inspector--empty{align-items:center;justify-content:center;color:var(--tx-2);font-size:var(--fs-sm)}.data-inspector-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line)}.data-inspector-title{font-size:var(--fs-sm);font-weight:600}.data-inspector-count{font-size:var(--fs-xs);color:var(--tx-2)}.data-inspector-schema{display:flex;flex-wrap:wrap;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line)}.di-col-tag{display:inline-flex;align-items:center;gap:4px;background:var(--elev);border:1px solid var(--line);border-radius:var(--r-pill);padding:2px 8px;font-size:var(--fs-xs)}.di-col-tag span{color:var(--tx-2)}.data-inspector-table-wrap{flex:1;overflow:auto}.data-inspector-table{border-collapse:collapse;width:100%;font-size:var(--fs-xs)}.data-inspector-table th,.data-inspector-table td{padding:5px 10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}.data-inspector-table th{font-weight:600;background:var(--elev);position:sticky;top:0}.data-inspector-table tr:hover td{background:var(--bg-hover, color-mix(in srgb, var(--accent) 5%, var(--bg)))}.di-null{color:var(--tx-2);font-style:italic}
