.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.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{--bg: #f7f6f2;--canvas-bg: #f7f6f2;--panel: #ffffff;--panel-2: #f1f0eb;--panel-hover: #ebeae5;--border: #e6e4dd;--border-strong: #d3d1c9;--text: #1c1c1e;--text-2: #3a3a3c;--muted: #8e8e8e;--muted-2: #a8a8a8;--accent: #ef6e0f;--accent-2: #ff8a30;--accent-soft: #fff1e4;--accent-ring: rgba(239,110,15,.18);--danger: #e25d5d;--ok: #34a853;--blue: #4a80f5;--radius-xs: 6px;--radius-sm: 8px;--radius: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-1: 0 1px 2px rgba(20,20,20,.06), 0 1px 1px rgba(20,20,20,.04);--shadow-2: 0 2px 6px rgba(20,20,20,.06), 0 4px 12px rgba(20,20,20,.06);--shadow-3: 0 6px 18px rgba(20,20,20,.08), 0 12px 36px rgba(20,20,20,.08);--shadow-4: 0 12px 32px rgba(20,20,20,.12), 0 24px 60px rgba(20,20,20,.14);--side-bg: #1d1d1f;--side-bg-2: #28282a;--side-bg-3: #323234;--side-border: #38383a;--side-text: #f2f2f2;--side-text-2: #cfcfd1;--side-muted: #8e8e93;--side-active: #5e96ff;--sidebar-width: 296px;--topbar-height: 52px;--ease: cubic-bezier(.22,.61,.36,1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:13px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}button{font-family:inherit;color:inherit;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit}kbd{font-family:-apple-system,SF Mono,ui-monospace,Menlo,Consolas,monospace;font-size:10px;font-weight:500;padding:2px 5px;background:#0000000f;border:1px solid rgba(0,0,0,.05);border-bottom-width:2px;border-radius:4px;color:var(--muted);line-height:1;letter-spacing:.3px}::selection{background:var(--accent-soft);color:var(--text)}.app{display:grid;grid-template-columns:1fr var(--sidebar-width);grid-template-rows:var(--topbar-height) 1fr;height:100vh;width:100vw;background:var(--canvas-bg);position:relative;overflow:hidden}.topbar{grid-column:1 / -1;grid-row:1}.canvas-wrap{grid-column:1;grid-row:2;min-width:0;min-height:0}.sidebar{grid-column:2;grid-row:2;min-width:0;min-height:0}.topbar{grid-column:1 / -1;display:flex;align-items:center;padding:0 14px;gap:4px;background:#ffffffb8;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border);z-index:10}.topbar .brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;letter-spacing:-.2px;margin-right:10px;-webkit-user-select:none;user-select:none}.topbar .group{display:flex;align-items:center;gap:2px;padding:0 4px;border-right:1px solid var(--border);margin-right:4px}.topbar .group:last-of-type{border-right:none}.topbar .spacer{flex:1}.topbar .hint{font-size:11px;color:var(--muted);letter-spacing:.1px;display:flex;align-items:center;gap:8px}.topbar .hint kbd{background:#0000000d;border-color:#0000000a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 10px;border-radius:var(--radius-sm);background:transparent;color:var(--text-2);border:1px solid transparent;font-size:12.5px;font-weight:500;letter-spacing:-.1px;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease),transform .15s var(--ease);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover:not(:disabled){background:#0000000d;color:var(--text)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}.btn.icon{width:32px;padding:0;color:var(--muted)}.btn.icon:hover:not(:disabled){color:var(--text)}.btn.outline{background:#fff;border-color:var(--border);color:var(--text)}.btn.outline:hover:not(:disabled){border-color:var(--border-strong);background:#fff}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-1)}.btn.primary:hover:not(:disabled){background:var(--accent-2);border-color:var(--accent-2)}.btn.ghost{background:transparent;color:var(--muted)}.btn.ghost:hover:not(:disabled){background:#0000000d;color:var(--text)}.btn.tiny{height:24px;padding:0 8px;font-size:11px;gap:4px}.btn.pill{border-radius:999px}.btn-row{display:inline-flex;align-items:center;gap:4px}.canvas-wrap{position:relative;overflow:hidden;background:var(--canvas-bg)}.react-flow__background{background:var(--canvas-bg)}.react-flow__attribution{display:none}.react-flow__controls{bottom:20px;left:20px;background:#ffffffd9;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-2);overflow:hidden;display:flex;flex-direction:column}.react-flow__controls-button{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text-2);width:32px;height:32px;transition:background .12s var(--ease)}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls-button:hover{background:#0000000f}.react-flow__controls-button svg{fill:currentColor;max-width:14px;max-height:14px}.react-flow__minimap{bottom:20px;right:20px;background:#ffffffd9;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-2);width:168px;height:108px;overflow:hidden}.react-flow__minimap-mask{fill:#1414140a}.react-flow__minimap-node{fill-opacity:.85;stroke:#ffffffb3;stroke-width:1}.react-flow__handle{width:12px;height:12px;background:#fff;border:2px solid var(--accent);box-shadow:0 0 0 2px #ffffffd9,0 1px 2px #00000014;transition:transform .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease);opacity:0}.react-flow__node:hover .react-flow__handle,.react-flow__node.selected .react-flow__handle,.react-flow__handle.connecting,.react-flow__handle:hover{opacity:1}.react-flow__handle:hover{background:var(--accent);transform:scale(1.25);box-shadow:0 0 0 4px #ef6e0f38,0 2px 4px #0000001a}.react-flow__handle-right{right:-6px}.react-flow__handle-left{left:-6px}.react-flow__node.selected .nc-card,.react-flow__node.selected .nc-image,.react-flow__node.selected .nc-empty,.react-flow__node.selected .nc-sticky{box-shadow:0 0 0 2px var(--accent),var(--shadow-3)}.nc-image{position:relative;background:#fff;border-radius:var(--radius-lg);overflow:visible;box-shadow:var(--shadow-2);border:1px solid var(--border);transition:box-shadow .2s var(--ease)}.nc-image:hover{box-shadow:var(--shadow-3)}.nc-image .img-box{position:relative;border-radius:calc(var(--radius-lg) - 1px);overflow:hidden;background:var(--panel-2);width:100%}.nc-image img{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.nc-image .close-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#1414148c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:none;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.85);transition:opacity .15s var(--ease),transform .15s var(--ease),background .15s;padding:0}.nc-image:hover .close-btn{opacity:1;transform:scale(1)}.nc-image .close-btn:hover{background:#141414d9}.nc-image .aspect-badge,.nc-image .res-badge{position:absolute;bottom:10px;padding:3px 8px;font-size:10px;font-weight:500;background:#14141499;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border-radius:6px;letter-spacing:.3px;-webkit-user-select:none;user-select:none}.nc-image .aspect-badge{left:10px}.nc-image .res-badge{right:10px}.nc-image .hover-toolbar{position:absolute;top:-46px;left:50%;transform:translate(-50%) translateY(4px);display:flex;align-items:center;gap:1px;padding:4px;background:#fffffff2;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-3);opacity:0;pointer-events:none;transition:opacity .18s var(--ease),transform .18s var(--ease);white-space:nowrap}.react-flow__node.selected .nc-image .hover-toolbar,.nc-image:hover .hover-toolbar{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.nc-image .hover-toolbar .tbtn{width:30px;height:30px;background:transparent;border:none;border-radius:7px;color:var(--text-2);display:flex;align-items:center;justify-content:center;transition:background .12s var(--ease),color .12s var(--ease);padding:0}.nc-image .hover-toolbar .tbtn:hover{background:var(--panel-2);color:var(--text)}.nc-image .hover-toolbar .tbtn:active{background:var(--panel-hover)}.nc-image .hover-toolbar .tbtn.accent{color:var(--accent)}.nc-image .hover-toolbar .tbtn.accent:hover{background:var(--accent-soft)}.nc-image .hover-toolbar .sep{width:1px;align-self:stretch;background:var(--border);margin:4px 3px}.nc-image .status-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;font-size:12px;color:var(--text-2)}.spinner{display:inline-block;width:22px;height:22px;border:2.5px solid var(--panel-2);border-top-color:var(--accent);border-radius:50%;animation:nc-spin .85s linear infinite}@keyframes nc-spin{to{transform:rotate(360deg)}}.nc-empty{width:300px;height:220px;background:#fff;border-radius:var(--radius-lg);border:1.5px dashed var(--border-strong);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;transition:border-color .15s var(--ease),background .15s var(--ease),transform .15s var(--ease);position:relative;box-shadow:var(--shadow-1)}.nc-empty:hover{border-color:var(--accent)}.nc-empty.dragging{border-color:var(--accent);background:var(--accent-soft);transform:scale(1.02)}.nc-empty .icon-box{width:48px;height:48px;background:var(--panel-2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.nc-empty .pick-btn{background:var(--accent);color:#fff;border:none;border-radius:999px;padding:7px 18px;font-size:12.5px;font-weight:500;cursor:pointer;box-shadow:var(--shadow-1);display:inline-flex;align-items:center;gap:6px;transition:background .15s var(--ease),transform .12s var(--ease)}.nc-empty .pick-btn:hover{background:var(--accent-2)}.nc-empty .pick-btn:active{transform:scale(.97)}.nc-empty .hint{font-size:11px;color:var(--muted);text-align:center;letter-spacing:.1px}.nc-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-2);overflow:hidden;min-width:280px;max-width:360px;transition:box-shadow .2s var(--ease)}.nc-card:hover{box-shadow:var(--shadow-3)}.nc-card .card-header{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--border);font-size:12.5px;font-weight:600;letter-spacing:-.1px;background:linear-gradient(to bottom,#fff,#fdfdfb)}.nc-card .card-header .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px #34a85333}.nc-card .card-header .thumb{width:24px;height:24px;border-radius:5px;object-fit:cover;border:1px solid var(--border)}.nc-card .card-header .title-icon{color:var(--accent)}.nc-card .card-header .x{width:22px;height:22px;background:transparent;border:none;border-radius:5px;color:var(--muted);display:flex;align-items:center;justify-content:center;padding:0}.nc-card .card-header .x:hover{background:var(--panel-2);color:var(--text)}.nc-card .card-body{padding:12px 14px}.nc-card textarea{width:100%;border:none;outline:none;resize:none;background:transparent;color:var(--text);font-size:13.5px;line-height:1.45;min-height:56px}.nc-card textarea::placeholder{color:var(--muted-2)}.nc-card .card-footer{display:flex;align-items:center;gap:6px;padding:8px 10px;border-top:1px solid var(--border);background:#fbfaf6}.nc-card .model-chip{flex:1;min-width:0;display:inline-flex;align-items:center;gap:6px;padding:5px 9px;background:#fff;border:1px solid var(--border);border-radius:7px;font-size:11px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nc-card .model-chip .dot-sm{width:6px;height:6px;border-radius:50%;background:var(--ok);flex-shrink:0}.nc-card .auto-chip{padding:5px 9px;background:#fff;border:1px solid var(--border);border-radius:7px;font-size:11px;color:var(--text-2);cursor:pointer;display:inline-flex;align-items:center;gap:4px;font-weight:500}.nc-card .auto-chip:hover{border-color:var(--border-strong)}.nc-card .select-chip{position:relative;display:inline-flex;align-items:center;gap:5px;padding:5px 7px 5px 8px;background:#fff;border:1px solid var(--border);border-radius:7px;font-size:11px;font-weight:500;color:var(--text-2);cursor:pointer;transition:border-color .12s,background .12s;min-width:0}.nc-card .select-chip:hover{border-color:var(--border-strong);background:#fafaf7}.nc-card .select-chip>svg{color:var(--muted);flex-shrink:0}.nc-card .select-chip>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nc-card .select-chip select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;background:transparent}.nc-card .select-chip:after{content:"";width:5px;height:5px;border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:rotate(45deg) translateY(-1px);margin-left:1px;flex-shrink:0}.nc-card .play-btn{width:32px;height:32px;background:var(--accent);color:#fff;border:none;border-radius:50%;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #ef6e0f66;transition:background .12s var(--ease),transform .12s var(--ease),box-shadow .15s var(--ease)}.nc-card .play-btn:hover:not(:disabled){background:var(--accent-2);transform:scale(1.06);box-shadow:0 3px 10px #ef6e0f80}.nc-card .play-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.nc-card .bookmark{width:30px;height:30px;background:transparent;border:1px solid var(--border);border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);padding:0;transition:color .12s,border-color .12s}.nc-card .bookmark.active{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.nc-card .bookmark:hover{color:var(--text);border-color:var(--border-strong)}.nc-card .progress{height:3px;background:var(--panel-2);border-radius:2px;overflow:hidden;margin-top:10px;position:relative}.nc-card .progress>div{position:absolute;top:0;left:0;height:100%;width:35%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px;animation:nc-progress 1.4s ease-in-out infinite}@keyframes nc-progress{0%{transform:translate(-100%)}to{transform:translate(280%)}}.nc-material{min-width:290px}.nc-material .material-preview{margin:0;aspect-ratio:16/10;background-color:var(--panel-2);background-size:cover;background-position:center;position:relative;border-bottom:1px solid var(--border)}.nc-material .material-preview .marker{position:absolute;width:22px;height:22px;border:2px dashed var(--accent);background:#ef6e0f47;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 0 4px #ef6e0f1f}.nc-material .tab-row{display:flex;gap:4px;padding:8px 8px 4px;border-bottom:1px solid var(--border)}.nc-material .tab-row .tab{flex:1;padding:7px 10px;font-size:12px;font-weight:500;text-align:center;background:transparent;color:var(--muted);border:none;cursor:pointer;border-radius:var(--radius-xs);transition:background .12s,color .12s}.nc-material .tab-row .tab:hover:not(.active){background:var(--panel-2);color:var(--text)}.nc-material .tab-row .tab.active{background:var(--accent);color:#fff;box-shadow:var(--shadow-1)}.nc-material .option-row{padding:11px 14px;display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:500;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.nc-material .option-row:hover{background:var(--panel-2)}.nc-material .option-row:last-child{border-bottom:none}.nc-material .option-row .label-w-icon{display:flex;align-items:center;gap:8px;color:var(--text)}.nc-material .option-row .icon{color:var(--muted)}.nc-material .option-row .chev{display:flex;align-items:center;gap:4px;color:var(--muted-2);font-size:11.5px;font-weight:400}.nc-material .material-note{padding:12px 14px;font-size:11px;color:var(--muted);text-align:center;border-top:1px solid var(--border);background:#fbfaf6;display:flex;align-items:center;justify-content:center;gap:6px}.nc-sticky{width:220px;min-height:160px;padding:16px;background:linear-gradient(135deg,#fff8b8,#ffe98a);border-radius:4px;box-shadow:var(--shadow-3),0 1px #0000000d inset;font-size:14px;font-family:-apple-system,PingFang SC,system-ui,sans-serif;line-height:1.55;color:#5a4a00;transform:rotate(-.4deg)}.nc-sticky textarea{width:100%;height:100%;border:none;outline:none;resize:none;background:transparent;font:inherit;color:inherit;min-height:130px}.nc-sticky textarea::placeholder{color:#5a4a0066}.react-flow__edge-path{stroke:var(--accent);stroke-width:2;fill:none;filter:drop-shadow(0 1px 2px rgba(239,110,15,.25))}.react-flow__edge.selected .react-flow__edge-path{stroke-width:3}.nc-edge-dot{fill:var(--accent);filter:drop-shadow(0 1px 2px rgba(239,110,15,.4))}.sidebar{background:var(--side-bg);color:var(--side-text);border-left:1px solid #000;display:flex;flex-direction:column;overflow:hidden;padding:14px 12px 12px;gap:12px;font-size:12.5px}.sidebar .side-brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:0 4px 4px;border-bottom:1px solid var(--side-border)}.sidebar .side-quick{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.sidebar .side-quick button{background:var(--side-bg-2);color:var(--side-text);border:1px solid var(--side-border);border-radius:var(--radius-sm);padding:9px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;font-weight:500;transition:background .12s var(--ease),border-color .12s var(--ease),transform .1s}.sidebar .side-quick button:hover{background:var(--side-bg-3);border-color:#46464a}.sidebar .side-quick button:active{transform:scale(.97)}.sidebar .side-quick button .icon{color:var(--side-text-2)}.sidebar .side-quick button:hover .icon{color:var(--accent-2)}.sidebar .tabs{display:flex;gap:2px;border-bottom:1px solid var(--side-border);padding-bottom:0}.sidebar .tabs .tab{padding:8px 0;font-size:12.5px;font-weight:500;color:var(--side-muted);cursor:pointer;border-bottom:2px solid transparent;flex:1;text-align:center;margin-bottom:-1px;transition:color .12s var(--ease),border-color .12s var(--ease)}.sidebar .tabs .tab:hover{color:var(--side-text-2)}.sidebar .tabs .tab.active{color:var(--side-text);border-bottom-color:var(--accent)}.sidebar .sub-tabs{display:flex;gap:4px;flex-wrap:wrap}.sidebar .sub-tabs .pill{padding:5px 11px;background:var(--side-bg-2);color:var(--side-muted);border:1px solid var(--side-border);border-radius:999px;font-size:11.5px;font-weight:500;cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease)}.sidebar .sub-tabs .pill:hover:not(.active){color:var(--side-text-2);background:var(--side-bg-3)}.sidebar .sub-tabs .pill.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 6px #ef6e0f66}.sidebar .tab-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:var(--side-border) transparent;padding-right:2px}.sidebar .tab-body::-webkit-scrollbar{width:6px}.sidebar .tab-body::-webkit-scrollbar-thumb{background:var(--side-border);border-radius:3px}.sidebar input,.sidebar textarea,.sidebar select{background:var(--side-bg-2);color:var(--side-text);border:1px solid var(--side-border);border-radius:var(--radius-xs);padding:7px 9px;font-size:12px;outline:none;width:100%;transition:border-color .12s,box-shadow .12s}.sidebar input:focus,.sidebar textarea:focus,.sidebar select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ef6e0f2e}.sidebar textarea{resize:vertical;min-height:64px;line-height:1.5}.sidebar label{font-size:10px;color:var(--side-muted);display:block;margin-bottom:5px;text-transform:uppercase;letter-spacing:.6px;font-weight:600}.sidebar .aspect-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.sidebar .aspect-grid button{padding:6px 0;background:var(--side-bg-2);color:var(--side-muted);border:1px solid var(--side-border);border-radius:var(--radius-xs);font-size:10.5px;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.sidebar .aspect-grid button:hover:not(.active){color:var(--side-text-2)}.sidebar .aspect-grid button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sidebar .side-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 12px;font-size:12.5px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .12s var(--ease),transform .1s;box-shadow:0 2px 6px #ef6e0f59}.sidebar .side-btn:hover:not(:disabled){background:var(--accent-2)}.sidebar .side-btn:active:not(:disabled){transform:scale(.98)}.sidebar .side-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.sidebar .side-btn.secondary{background:var(--side-bg-2);border:1px solid var(--side-border);color:var(--side-text);box-shadow:none}.sidebar .side-btn.secondary:hover:not(:disabled){background:var(--side-bg-3);border-color:#46464a}.sidebar .side-section-title{font-size:10.5px;color:var(--side-muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600;display:flex;align-items:center;gap:6px;margin-top:-2px}.sidebar .queue-item{background:var(--side-bg-2);border:1px solid var(--side-border);border-radius:var(--radius-sm);padding:9px 10px;font-size:11px}.sidebar .queue-item .row{display:flex;justify-content:space-between;align-items:center;gap:6px}.sidebar .queue-item .status{display:inline-flex;align-items:center;gap:4px;font-weight:500;font-size:11px}.sidebar .queue-item .status-pending{color:var(--side-muted)}.sidebar .queue-item .status-running{color:var(--side-active)}.sidebar .queue-item .status-done{color:var(--ok)}.sidebar .queue-item .status-error{color:var(--danger)}.sidebar .queue-item .prompt{margin-top:5px;color:var(--side-text-2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:11px}.sidebar .queue-item .thumbs{display:flex;gap:4px;margin-top:7px}.sidebar .queue-item .thumbs img{width:46px;height:46px;border-radius:5px;object-fit:cover;cursor:pointer;border:1px solid var(--side-border);transition:border-color .12s,transform .12s}.sidebar .queue-item .thumbs img:hover{border-color:var(--accent);transform:scale(1.04)}.sidebar .library-item{background:var(--side-bg-2);border:1px solid var(--side-border);border-radius:var(--radius-sm);padding:9px 10px;cursor:pointer;transition:border-color .12s,background .12s}.sidebar .library-item:hover{border-color:var(--accent);background:var(--side-bg-3)}.sidebar .library-item .title{font-size:12px;font-weight:600;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}.sidebar .library-item .preview{font-size:11px;color:var(--side-muted);line-height:1.45;max-height:42px;overflow:hidden}.sidebar .library-item .del{background:transparent;border:none;color:var(--side-muted);font-size:11px;padding:2px 6px;border-radius:4px;cursor:pointer}.sidebar .library-item .del:hover{color:var(--danger);background:#e25d5d1a}.sidebar .icon-btn-row{display:flex;gap:4px;align-items:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14141473;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:nc-fade-in .15s var(--ease)}@keyframes nc-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px 26px;min-width:500px;max-width:720px;max-height:86vh;overflow-y:auto;box-shadow:var(--shadow-4);animation:nc-pop-in .2s var(--ease)}@keyframes nc-pop-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal h2{margin:0 0 14px;font-size:18px;font-weight:600;letter-spacing:-.4px;display:flex;align-items:center;gap:8px}.modal h2 .close-x{margin-left:auto;width:28px;height:28px;background:transparent;border:none;border-radius:7px;color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.modal h2 .close-x:hover{background:var(--panel-2);color:var(--text)}.modal .field{margin-bottom:12px}.modal .field label{display:block;font-size:11px;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.modal input,.modal textarea,.modal select{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;outline:none;background:#fff;font-family:inherit;color:var(--text);transition:border-color .12s,box-shadow .12s}.modal input:focus,.modal textarea:focus,.modal select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.modal textarea{resize:vertical;min-height:90px;line-height:1.55}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.modal .warn-banner{background:linear-gradient(to right,#fff5e8,#fff9ef);border:1px solid #f6d6a3;color:#774010;padding:11px 14px;border-radius:var(--radius);font-size:12px;margin-bottom:16px;line-height:1.55;display:flex;gap:10px}.modal .warn-banner .icon{color:#d97706;flex-shrink:0;margin-top:1px}.modal .warn-banner code{background:#0000000d;padding:1px 5px;border-radius:3px;font-size:11px}.modal .provider-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;transition:border-color .12s,box-shadow .12s}.modal .provider-card:hover{border-color:var(--border-strong)}.modal .provider-card .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.modal .provider-card .name{font-weight:600;font-size:13px;display:flex;align-items:center;gap:8px}.modal .provider-card .chip{display:inline-flex;align-items:center;background:var(--accent);color:#fff;padding:2px 8px;border-radius:999px;font-size:10.5px;font-weight:500;letter-spacing:.2px}.modal .meta{font-size:11.5px;color:var(--muted);line-height:1.5}.modal .meta code{background:#0000000a;padding:1px 5px;border-radius:3px;color:var(--text-2)}.mask-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f0feb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:950;display:flex;flex-direction:column;animation:nc-fade-in .2s var(--ease)}.mask-toolbar{padding:12px 18px;background:#1c1c1ee0;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(255,255,255,.08);display:flex;gap:14px;align-items:center;color:#fff}.mask-toolbar h3{font-size:14px;font-weight:600;margin:0;display:flex;align-items:center;gap:8px;letter-spacing:-.2px}.mask-toolbar .control-group{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#ffffffc7}.mask-toolbar input[type=range]{accent-color:var(--accent);width:140px}.mask-toolbar .btn{color:#fff}.mask-toolbar .btn:hover:not(:disabled){background:#ffffff1a;color:#fff}.mask-toolbar .btn.outline{background:transparent;border-color:#ffffff26;color:#fff}.mask-toolbar .btn.outline:hover:not(:disabled){border-color:#ffffff4d}.mask-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.mask-hint{padding:10px 18px;color:#ffffff80;font-size:11.5px;text-align:center;letter-spacing:.1px}.row-flex{display:flex;align-items:center;gap:6px}.flex-1{flex:1}.muted-text{color:var(--muted);font-size:11px}.popover-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-3);padding:5px;z-index:50;animation:nc-pop-in .12s var(--ease)}.popover-menu .menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:6px;text-align:left;font-size:12.5px;color:var(--text);cursor:pointer}.popover-menu .menu-item:hover{background:var(--panel-2)}.popover-menu .menu-item .icon{color:var(--muted);flex-shrink:0}.popover-menu .menu-item .sub{display:block;font-size:10.5px;color:var(--muted);margin-top:2px}.popover-menu .menu-sep{height:1px;background:var(--border);margin:4px 2px}.popover-wrap{position:relative;display:inline-flex}.app.sidebar-collapsed{grid-template-columns:1fr 0}.app.sidebar-collapsed .sidebar{transform:translate(100%);pointer-events:none;visibility:hidden;overflow:hidden}.sidebar{transition:transform .25s var(--ease);overflow:hidden}.sidebar-toggle{position:absolute;top:calc(var(--topbar-height) + 16px);right:0;width:26px;height:46px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px) saturate(180%);backdrop-filter:blur(12px) saturate(180%);border:1px solid var(--border);border-right:none;border-radius:10px 0 0 10px;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;padding:0;z-index:20;box-shadow:var(--shadow-1);transition:right .25s var(--ease),background .12s,color .12s}.sidebar-toggle:hover{background:#fff;color:var(--text)}.app:not(.sidebar-collapsed) .sidebar-toggle{right:var(--sidebar-width)}.app.sidebar-collapsed .sidebar-toggle{right:0}.sidebar .side-brand .close-btn{margin-left:auto;background:transparent;border:none;color:var(--side-muted);width:22px;height:22px;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.sidebar .side-brand .close-btn:hover{background:var(--side-bg-2);color:var(--side-text)}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;max-height:460px;overflow-y:auto;padding:2px}.proj-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .12s,box-shadow .12s,transform .12s;display:flex;flex-direction:column}.proj-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-2);transform:translateY(-1px)}.proj-card.current{border-color:var(--accent);box-shadow:0 0 0 2px #ef6e0f26}.proj-card .proj-thumb{aspect-ratio:16/10;background:#ededea;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.proj-card .proj-thumb img{width:100%;height:100%;object-fit:cover}.proj-card .proj-badge{position:absolute;top:6px;left:6px;display:inline-flex;align-items:center;gap:3px;background:var(--accent);color:#fff;font-size:10px;padding:2px 6px;border-radius:999px;font-weight:500}.proj-card .proj-meta{padding:10px 12px;display:flex;flex-direction:column;gap:4px;background:#fff}.proj-card .proj-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-card .proj-info{font-size:10.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-card .proj-actions{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.proj-card .proj-actions .btn.tiny{border:1px solid var(--border);background:#fff}.proj-card .proj-actions .btn.tiny:hover{background:var(--panel-2)}
