:root{color:#172226;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f7f6;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}button,input,textarea,select{font-family:inherit}.react-flow{--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:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--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:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--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:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--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 #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.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:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--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:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--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:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--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 #00000014;--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{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.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;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:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.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:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;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%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;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{z-index:5;margin:15px;position:absolute}.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{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.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{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.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{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;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));padding:10px;font-size:12px}.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{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.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-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.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))}.app-shell{color:#172226;background:#f4f7f6;width:100vw;height:100vh;overflow:hidden}.topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-sizing:border-box;z-index:10;background:#fafcfbf0;border-bottom:1px solid #dce4e2;justify-content:space-between;align-items:center;height:68px;padding:0 18px;display:flex;position:relative}.topbar>div,.topbar nav{align-items:center;gap:12px;display:flex}.brand-mark{color:#f8fbfb;background:#176c72;border-radius:8px;place-items:center;width:38px;height:38px;font-weight:800;display:grid}.topbar h1{letter-spacing:0;margin:0;font-size:18px;font-weight:750;line-height:1.15}.topbar p{color:#647173;margin:3px 0 0;font-size:12px}.toolbar-button,.icon-button,.primary-button{color:#172226;cursor:pointer;font:inherit;background:#fff;border:1px solid #ccd8d6;border-radius:7px;justify-content:center;align-items:center;gap:7px;display:inline-flex}.toolbar-button{height:36px;padding:0 12px;font-size:13px;font-weight:650}.toolbar-button:hover,.icon-button:hover{background:#f5fbfa;border-color:#8fb6b8}.toolbar-button:disabled{cursor:not-allowed;color:#8a989a;background:#f3f6f5}.toolbar-button.danger:not(:disabled){color:#9f1e2d;border-color:#efbcc3}.workspace{height:calc(100vh - 68px);position:relative}.save-toast{z-index:25;color:#176239;pointer-events:none;background:#ecfbf2;border:1px solid #bfe8d1;border-radius:8px;max-width:min(520px,100vw - 32px);padding:9px 13px;font-size:13px;font-weight:700;line-height:1.35;position:absolute;top:14px;left:50%;transform:translate(-50%);box-shadow:0 14px 32px #142f3329}.save-toast.failed{color:#a11d2e;background:#fff0f2;border-color:#f0c4ca}.react-flow{background-color:#edf3f2;background-image:linear-gradient(90deg,#176c720d 1px,#0000 1px),linear-gradient(#176c720d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:80px 80px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box}.react-flow__node{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.react-flow__edge-path,.react-flow__connection-path{stroke:#176c72;stroke-width:3.2px}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:#0f555a;stroke-width:4.2px}.react-flow__handle{background:#176c72;border:3px solid #fff;width:15px;height:15px;box-shadow:0 0 0 2px #176c7247,0 5px 12px #142f3338}.react-flow__handle-left{left:-8px}.react-flow__handle-right{right:-8px}.react-flow__handle:hover,.react-flow__handle.connectingfrom,.react-flow__handle.connectingto{background:#0f555a;box-shadow:0 0 0 5px #176c722e,0 6px 14px #142f3342}.canvas-node{box-sizing:border-box;background:#fff;border:1px solid #cfdddb;border-radius:8px;width:330px;padding:14px;position:relative;box-shadow:0 16px 40px #142f331f}.prompt-node{width:390px}.result-node,.reference-node{width:360px}.node-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.node-head.compact-head{min-height:30px;margin-bottom:4px}.node-head.generate-head{margin-bottom:8px}.node-head.align-right{justify-content:flex-end}.node-head.floating-head{z-index:2;margin:0;position:absolute;top:10px;right:10px}.node-kicker{color:#176c72;text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:800;line-height:1}.generate-title{color:#111b1e;letter-spacing:0;font-size:17px;font-weight:750;line-height:1.2}.icon-button{width:30px;height:30px;padding:0}.icon-button.danger:not(:disabled){color:#9f1e2d;border-color:#efbcc3}.node-title{color:#101a1d;box-sizing:border-box;border:0;border-bottom:1px solid #e4ecea;outline:none;width:100%;margin-bottom:12px;padding:0 0 9px;font-size:17px;font-weight:750;line-height:1.2}.node-static-title{color:#101a1d;letter-spacing:0;margin:0 36px 12px 0;font-size:17px;font-weight:750;line-height:1.2}.prompt-input,.settings-panel input,.generate-node input,.generate-node select{color:#152123;box-sizing:border-box;width:100%;font:inherit;background:#fbfdfd;border:1px solid #cedbd9;border-radius:6px;outline:none}.prompt-input{resize:vertical;min-height:134px;padding:10px;font-size:13px;line-height:1.45}.prompt-input:focus,.settings-panel input:focus,.generate-node input:focus,.generate-node select:focus{border-color:#278991;box-shadow:0 0 0 3px #2789911f}.prompt-count{color:#69787a;text-align:right;margin-top:6px;font-size:11px;font-weight:800;line-height:1}.prompt-count.near-limit{color:#a86b00}.generate-node label,.settings-panel label{color:#586668;gap:6px;font-size:12px;font-weight:700;display:grid}.compact-field{margin-top:8px}.generate-head+.compact-field{margin-top:0}.generate-node input,.generate-node select,.settings-panel input{height:36px;padding:0 10px;font-size:13px;font-weight:500}.form-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px;margin:10px 0 12px;display:grid}.form-grid.single{grid-template-columns:minmax(0,1fr)}.ratio-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-top:10px;display:grid}.ratio-option,.resolution-option,.quality-option{color:#5f6d70;cursor:pointer;font:inherit;background:#fbfdfd;border:1px solid #cedbd9;border-radius:7px}.ratio-option{place-items:center;gap:4px;min-height:58px;padding:7px 5px 6px;font-size:11px;font-weight:800;line-height:1.15;display:grid}.ratio-option:hover,.resolution-option:hover,.quality-option:hover{border-color:#8fb6b8}.ratio-option.selected,.resolution-option.selected,.quality-option.selected{color:#176c72;background:#eefafa;border-color:#278991}.ratio-frame-mini{place-items:center;width:34px;height:28px;display:grid}.ratio-box-mini{border:2px solid;border-radius:3px;transform:scale(.72)}.auto-box-mini{border:2px dashed;border-radius:5px;place-items:center;width:25px;height:22px;font-size:7px;font-weight:900;display:grid}.resolution-row,.quality-row{gap:8px;margin-top:10px;display:grid}.resolution-row{grid-template-columns:repeat(4,minmax(0,1fr))}.quality-row{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:12px}.resolution-option,.quality-option{height:34px;font-size:12px;font-weight:850}.custom-size-panel.compact{background:#f7fbfa;border:1px solid #d9e4e2;border-radius:7px;margin-top:10px;padding:10px}.custom-size-fields{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:end;gap:8px;display:grid}.custom-size-field{gap:5px;display:grid}.custom-size-field input{width:100%}.custom-size-separator{color:#69787a;padding-bottom:8px;font-weight:900}.primary-button{color:#fff;background:#176c72;border-color:#176c72;width:100%;height:40px;font-size:14px;font-weight:750}.primary-button:disabled,.icon-button:disabled{cursor:progress;opacity:.74}.status-pill{color:#5b6668;background:#edf2f1;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:800;line-height:1}.status-pill.pending,.status-pill.running{color:#705000;background:#fff4c9}.status-pill.done{color:#176239;background:#dff5e9}.status-pill.failed{color:#9f1e2d;background:#ffe2e6}.meta-line{color:#69787a;word-break:break-all;margin:10px 0 0;font-size:11px}.error-line{color:#a11d2e;margin:10px 0 0;font-size:12px;line-height:1.4}.success-line{color:#176239;background:#ecfbf2;border:1px solid #bfe8d1;border-radius:7px;margin:0;padding:8px 10px;font-size:12px;font-weight:700;line-height:1.4}.result-node h3{color:#111b1e;letter-spacing:0;margin:0;font-size:17px}.result-title-row{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.result-title-main{align-items:center;gap:8px;min-width:0;display:flex}.result-mode-toggle{background:#f7fbfa;border:1px solid #d6e1df;border-radius:7px;grid-template-columns:1fr 1fr;display:inline-grid;overflow:hidden}.result-mode-toggle button{color:#69787a;cursor:pointer;background:0 0;border:0;height:28px;padding:0 8px;font-size:11px;font-weight:850}.result-mode-toggle button.active{color:#fff;background:#176c72}.result-frame{background:#f6faf9;border:1px solid #d9e4e2;border-radius:7px;min-height:280px;display:grid;overflow:hidden}.empty-result{color:#8a9b9d;place-items:center;min-height:280px;display:grid}.image-stack{grid-template-columns:repeat(3,minmax(0,1fr));align-content:start;gap:8px;padding:10px;display:grid}.image-stack figure{min-width:0;margin:0}.result-preview-button{aspect-ratio:1;cursor:zoom-in;background:0 0;border:0;border-radius:6px;width:100%;padding:0;overflow:hidden}.result-loading-tile{aspect-ratio:1;color:#6c7f82;background:#eefafa;border:1px dashed #a9bfbd;border-radius:6px;place-items:center;width:100%;display:grid}.image-stack img{object-fit:cover;background:#fff;border-radius:6px;width:100%;height:100%;display:block}.image-stack figcaption{color:#627174;justify-content:space-between;align-items:center;gap:5px;margin-top:6px;font-size:11px;font-weight:750;display:flex}.image-stack figcaption>span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.upload-zone{color:#5f7072;cursor:pointer;background:#f7fbfa;border:1px dashed #a9bfbd;border-radius:7px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:82px;font-size:13px;font-weight:750;display:flex}.upload-zone:hover,.upload-zone.dragging{color:#176c72;background:#eefafa;border-color:#278991}.upload-zone span{line-height:1.2}.upload-zone input{display:none}.reference-library-button{color:#31585d;cursor:pointer;background:#fff;border:1px solid #c8d8d6;border-radius:7px;justify-content:center;align-items:center;gap:7px;width:100%;min-height:38px;margin-top:8px;font-size:13px;font-weight:800;display:inline-flex}.reference-library-button:hover:not(:disabled){color:#176c72;background:#f4fbfa;border-color:#278991}.reference-library-button:disabled{cursor:not-allowed;opacity:.5}.reference-library-modal{z-index:120;background:#0d1d2175;justify-content:center;align-items:center;padding:22px;display:flex;position:fixed;inset:0}.reference-library-panel{background:#fff;border-radius:8px;flex-direction:column;width:min(920px,100%);max-height:min(720px,100vh - 44px);display:flex;overflow:hidden;box-shadow:0 24px 70px #0f232847}.reference-library-header,.reference-library-footer{border-bottom:1px solid #e2ebea;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.reference-library-footer{border-top:1px solid #e2ebea;border-bottom:0;flex-wrap:wrap}.reference-library-header h2{color:#162d31;margin:0;font-size:18px;line-height:1.2}.reference-library-tabs{gap:8px;padding:12px 18px 0;display:flex}.reference-library-tabs button,.reference-library-pagination button,.reference-library-actions button{color:#425c61;cursor:pointer;background:#fff;border:1px solid #c8d8d6;border-radius:7px;min-height:34px;font-size:13px;font-weight:800}.reference-library-tabs button{padding:0 14px}.reference-library-tabs button.active,.reference-library-actions button.primary{color:#fff;background:#278991;border-color:#278991}.reference-library-body{min-height:300px;padding:16px 18px;overflow:auto}.reference-library-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.reference-library-card{color:#263d42;text-align:left;cursor:pointer;background:#f4f8f7;border:2px solid #0000;border-radius:8px;min-width:0;padding:0;overflow:hidden}.reference-library-card.active{border-color:#278991}.reference-library-card.disabled{cursor:not-allowed;opacity:.58}.reference-library-card img{aspect-ratio:1;object-fit:cover;background:#e8efee;width:100%;display:block}.reference-library-card span,.reference-library-card small{text-overflow:ellipsis;white-space:nowrap;min-width:0;padding:8px 10px 0;display:block;overflow:hidden}.reference-library-card span{font-size:13px;font-weight:850}.reference-library-card small{color:#64777a;padding-top:4px;padding-bottom:9px;font-size:11px;font-weight:750}.reference-library-empty,.reference-library-error{color:#66787b;text-align:center;font-size:13px;font-weight:750}.reference-library-error{color:#a13c32;text-align:left;margin:0 18px 12px}.reference-library-pagination,.reference-library-actions{align-items:center;gap:8px;display:flex}.reference-library-pagination button,.reference-library-actions button{padding:0 13px}.reference-library-pagination button:disabled,.reference-library-actions button:disabled{cursor:not-allowed;opacity:.52}.reference-library-pagination span{color:#53676b;font-size:13px;font-weight:800}.reference-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px;display:grid}.reference-grid figure{aspect-ratio:1;background:#edf3f2;border-radius:7px;margin:0;position:relative;overflow:hidden}.reference-thumb{cursor:grab;outline:2px solid #0000;transition:opacity .16s,outline-color .16s,transform .16s}.reference-thumb:hover{outline-color:#27899147}.reference-thumb.dragging{cursor:grabbing;opacity:.46;outline-color:#278991;transform:scale(.96)}.reference-grid img{object-fit:cover;width:100%;height:100%;display:block}.thumb-index{color:#fff;background:#112226b8;border-radius:999px;place-items:center;min-width:22px;height:22px;padding:0 6px;font-size:11px;font-weight:850;display:inline-grid;position:absolute;top:5px;left:5px}.mini-delete{color:#fff;cursor:pointer;background:#781422d1;border:1px solid #ffffffbd;border-radius:6px;place-items:center;width:24px;height:24px;padding:0;display:grid;position:absolute;top:5px;right:5px}.settings-panel{z-index:7;box-sizing:border-box;background:#fffffff5;border:1px solid #ccd8d6;border-radius:8px;gap:12px;width:360px;max-height:calc(100% - 28px);padding:16px;display:grid;position:absolute;top:14px;right:14px;overflow:auto;box-shadow:0 18px 50px #112a2d29}.settings-panel h2{color:#111b1e;letter-spacing:0;margin:0;font-size:17px}.settings-panel p{color:#687779;margin:0;font-size:12px;line-height:1.5}.mini-text-button{color:#176c72;cursor:pointer;background:#fff;border:1px solid #ccd8d6;border-radius:6px;height:28px;padding:0 9px;font-size:12px;font-weight:850}.mini-text-button:disabled{cursor:not-allowed;color:#8a989a;background:#f3f6f5}.mini-text-button.danger{color:#9f1e2d;border-color:#efbcc3}.mini-text-button.full-width{width:100%;height:34px}.provider-list{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:10px;display:grid}.provider-card{background:#f8fbfa;border:1px solid #d9e4e2;border-radius:8px;gap:10px;padding:10px;display:grid}.provider-card-head{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.model-list-head{color:#586668;justify-content:space-between;align-items:center;gap:10px;font-size:12px;font-weight:800;display:flex}.model-list{gap:7px;max-height:210px;padding-right:2px;display:grid;overflow:auto}.model-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.settings-save-button{color:#fff;cursor:pointer;background:#176c72;border:1px solid #176c72;border-radius:7px;justify-content:center;align-items:center;gap:7px;height:40px;font-size:14px;font-weight:850;display:inline-flex}.settings-save-button:disabled{cursor:progress;opacity:.76}.panel-divider{background:#e3ebea;height:1px;margin:2px 0}.preview-modal{z-index:30;background:#081316b8;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.preview-content{background:#f7fbfa;border:1px solid #ffffff29;border-radius:8px;grid-template-rows:auto minmax(0,1fr);width:min(1180px,96vw);max-height:94vh;display:grid;overflow:hidden;box-shadow:0 24px 80px #00000057}.preview-head{background:#fff;border-bottom:1px solid #d9e4e2;justify-content:space-between;align-items:center;gap:14px;min-height:58px;padding:12px 14px;display:flex}.preview-head h2{color:#111b1e;letter-spacing:0;margin:0;font-size:15px}.preview-head p{color:#69787a;margin:4px 0 0;font-size:12px;font-weight:700}.preview-actions{align-items:center;gap:8px;display:flex}.preview-actions a,.preview-actions button{color:#176c72;cursor:pointer;background:#fff;border:1px solid #d6e1df;border-radius:7px;place-items:center;width:34px;height:34px;display:inline-grid}.preview-error{color:#b42336;margin:0 18px 10px;font-size:12px;font-weight:750}.preview-content>img{object-fit:contain;background:#edf3f2;place-self:center;width:auto;max-width:100%;height:auto;max-height:calc(94vh - 59px)}.canvas-help{color:#314145;background:#ffffffeb;border:1px solid #cfdcda;border-radius:8px;align-items:center;gap:8px;padding:9px 11px;font-size:12px;font-weight:700;display:flex;box-shadow:0 10px 28px #142f331f}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=760px){.topbar{flex-direction:column;align-items:flex-start;gap:10px;height:auto;min-height:74px;padding:12px}.topbar nav{width:100%}.toolbar-button{flex:1}.workspace{height:calc(100vh - 122px)}.settings-panel{width:auto;left:12px;right:12px}.reference-library-modal{padding:12px}.reference-library-panel{max-height:calc(100vh - 24px)}.reference-library-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.reference-library-footer,.reference-library-pagination,.reference-library-actions{width:100%}.reference-library-pagination,.reference-library-actions{justify-content:space-between}}
