:root{--ink: #1c2430;--muted: #697386;--grid: rgba(28, 36, 48, .06);--line: #1d2430;--blue: #2864f0;--blue-soft: #eef4ff;--panel: #ffffff;--red: #d94c4c;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;color:var(--ink)}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button,textarea,input,select{font:inherit}button{cursor:pointer}.app-shell,.workspace,.canvas-frame{width:100%;height:100%}.app-shell{overflow:hidden}.app-shell.is-grabbing,.app-shell.is-grabbing *{cursor:grabbing!important}.workspace{background-color:#f8fafc;background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:24px 24px}.canvas-frame{position:relative;overflow:hidden}.canvas-viewport{width:100%;height:100%;cursor:grab;overflow:auto;scrollbar-width:none}.canvas-viewport.panning{cursor:grabbing}.canvas-viewport::-webkit-scrollbar{display:none}.canvas-scaled{position:relative;min-width:100%;min-height:100%}.canvas-world{position:relative;min-width:100%;min-height:100%;transform-origin:0 0}.connections{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none}.edge-path{fill:none;stroke:var(--line);stroke-linecap:round;stroke-width:2.7;opacity:.62;pointer-events:none}.edge-flow{fill:none;stroke:var(--blue);stroke-dasharray:9 22;stroke-dashoffset:0;stroke-linecap:round;stroke-width:3.1;opacity:.88;pointer-events:none;animation:edge-flow 1.05s linear infinite;filter:drop-shadow(0 0 4px rgba(47,109,246,.28))}.edge-draft{stroke:var(--blue);stroke-dasharray:7 11;stroke-width:2.6;opacity:.78;animation:edge-flow .95s linear infinite}.edge-hit-area{fill:none;stroke:transparent;stroke-linecap:round;stroke-width:18;cursor:pointer;pointer-events:stroke}.edge-handle{fill:#fff;stroke:var(--blue);stroke-width:2.5;cursor:grab;opacity:.82;pointer-events:all}.edge-handle:active{cursor:grabbing}.edge-group.active .edge-path{stroke:var(--blue);opacity:.42}.edge-group.active .edge-flow{opacity:1;stroke-width:3.4}.edge-group.active .edge-handle{opacity:1;filter:drop-shadow(0 3px 8px rgba(40,100,240,.28))}@keyframes edge-flow{to{stroke-dashoffset:-31}}.canvas-node{position:absolute;z-index:2;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.canvas-node.selected{outline:3px solid rgba(40,100,240,.32);outline-offset:3px}.node-image{overflow:visible;background:transparent;border-radius:7px}.image-preview{display:block;width:100%;height:100%;object-fit:cover;border-radius:7px;pointer-events:none}.image-ref{position:absolute;left:8px;top:8px;z-index:5;display:inline-flex;height:24px;align-items:center;padding:0 8px;color:var(--ink);background:#ffffffe6;border:1px solid #d8dee8;border-radius:999px;box-shadow:0 8px 18px #26334d1f;font-size:12px;font-weight:760;opacity:0;pointer-events:none;transition:opacity .12s ease}.node-image:hover .image-ref,.node-image.selected .image-ref{opacity:1}.image-preview-muted{opacity:.34}.image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2864f014,#1c243005),#fff;border:1px solid #d8dee8;border-radius:7px}.image-state{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:grid;place-items:center;gap:8px;align-content:center;color:var(--ink);background:#ffffffad;border:1px solid #d8dee8;border-radius:7px;font-size:13px;font-weight:760;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.image-state-error{color:var(--red);background:#fff6f6d1;border-color:#ffd2d2}.image-spinner{width:24px;height:24px;border:3px solid rgba(40,100,240,.18);border-top-color:var(--blue);border-radius:50%;animation:spin .82s linear infinite}.image-actions{position:absolute;top:8px;right:8px;z-index:5;display:flex;gap:6px;opacity:0;transition:opacity .12s ease}.node-image:hover .image-actions,.node-image.selected .image-actions{opacity:1}.image-actions button,.image-modal-tools button{display:inline-grid;align-items:center;justify-content:center;color:var(--ink);background:#ffffffeb;border:1px solid #d8dee8;border-radius:7px;box-shadow:0 8px 18px #26334d24}.image-actions button{width:30px;height:30px}.image-actions button:hover,.image-modal-tools button:hover{color:var(--blue);background:var(--blue-soft);border-color:#b7c8ff}.generated-image{box-shadow:0 16px 34px #26334d24}.node-agent{display:flex;flex-direction:column;padding:10px;background:#ffffffeb;border:2px solid var(--line);border-radius:8px;box-shadow:0 12px 26px #26334d1f}.node-agent.processing{border-color:var(--blue)}.agent-head{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:26px}.node-port{position:absolute;top:50%;z-index:4;width:12px;height:12px;background:#fff;border:2px solid var(--blue);border-radius:50%;box-shadow:0 4px 10px #2864f042;cursor:crosshair;opacity:0;transform:translateY(-50%);transition:opacity .12s ease,transform .12s ease}.node-port-in{left:-7px}.node-port-out{right:-7px}.canvas-node:hover .node-port,.canvas-node.selected .node-port{opacity:1}.node-port:hover{transform:translateY(-50%) scale(1.18)}.agent-label{display:inline-flex;align-items:center;gap:7px;height:24px;min-width:74px;color:var(--ink);font-size:13px;font-weight:750}.agent-controls{position:relative;display:inline-flex;align-items:center;gap:6px}.agent-icon-button,.agent-ratio-button{display:inline-grid;height:28px;place-items:center;color:var(--ink);background:#fff;border:1px solid #d8dee8;border-radius:7px}.agent-icon-button{width:30px}.agent-ratio-button{min-width:44px;padding:0 8px;font-size:12px;font-weight:760}.agent-icon-button:hover,.agent-icon-button.active,.agent-ratio-button:hover,.agent-ratio-button.active{color:var(--blue);background:var(--blue-soft);border-color:#b7c8ff}.ratio-popover{position:absolute;top:34px;right:0;z-index:34;display:grid;gap:4px;padding:6px;background:#fffffffa;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 16px 38px #26334d2e}.ratio-popover{width:116px}.ratio-popover button{display:grid;grid-template-columns:38px minmax(0,1fr);min-height:32px;align-items:center;padding:0 8px;text-align:left;background:transparent;border:0;border-radius:6px}.ratio-popover button:hover,.ratio-popover button.selected{background:var(--blue-soft)}.ratio-popover span{color:var(--ink);font-size:12px;font-weight:800}.ratio-popover small{color:var(--muted);font-size:11px}.node-agent textarea{flex:1;width:100%;min-height:86px;margin:6px 0 0;padding:0;resize:none;color:var(--ink);background:transparent;border:0;outline:0;font-size:13px;line-height:20px}.mention-popover{position:absolute;left:10px;top:82px;z-index:32;display:grid;width:min(210px,calc(100% - 20px));gap:4px;padding:6px;background:#fffffffa;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 16px 38px #26334d2e}.mention-popover button{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;min-height:32px;align-items:center;padding:0 8px;text-align:left;background:transparent;border:0;border-radius:6px}.mention-popover button:hover,.mention-popover button.selected{background:var(--blue-soft)}.mention-popover span{color:var(--blue);font-size:12px;font-weight:800}.mention-popover small{overflow:hidden;color:var(--muted);font-size:11px;text-overflow:ellipsis;white-space:nowrap}.mention-empty{min-height:30px;padding:7px 8px;color:var(--muted);font-size:12px}.agent-run{position:absolute;right:10px;bottom:10px;display:grid;width:34px;height:34px;place-items:center;color:#fff;background:var(--blue);border:0;border-radius:8px}.agent-run:disabled{cursor:wait;opacity:.72}.agent-processing{position:absolute;right:52px;bottom:22px;width:8px;height:8px;background:var(--blue);border-radius:999px;box-shadow:0 0 0 5px #2864f029}.agent-error{position:absolute;right:52px;bottom:17px;display:inline-flex;height:20px;align-items:center;padding:0 7px;color:var(--red);background:#fff3f3;border:1px solid #ffd2d2;border-radius:999px;font-size:12px;font-weight:700}.resize-handle{position:absolute;right:-6px;bottom:-6px;z-index:5;width:16px;height:16px;background:#fff;border:2px solid var(--blue);border-radius:5px;box-shadow:0 6px 14px #2864f03d;cursor:nwse-resize;opacity:0;transition:opacity .12s ease}.canvas-node:hover .resize-handle,.canvas-node.selected .resize-handle{opacity:1}.upload-input{display:none}.floating-toolbar{position:fixed;left:18px;bottom:18px;z-index:36;display:inline-flex;align-items:center;gap:7px;padding:7px;background:#ffffffeb;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 16px 38px #26334d24;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.floating-toolbar button{display:grid;width:34px;height:34px;place-items:center;color:var(--ink);background:#fff;border:1px solid #d8dee8;border-radius:7px}.floating-toolbar button:hover,.floating-toolbar button.active{color:var(--blue);background:var(--blue-soft);border-color:#b7c8ff}.camera-popover{position:absolute;top:34px;right:0;z-index:38;display:grid;width:176px;gap:4px;padding:6px;background:#fffffffa;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 18px 44px #26334d2e}.camera-popover button{display:grid;grid-template-columns:18px 38px minmax(0,1fr);width:100%;height:34px;align-items:center;gap:6px;padding:0 8px;text-align:left;background:transparent;border:0;border-radius:6px}.camera-popover button:hover{background:var(--blue-soft)}.camera-popover span{color:var(--ink);font-size:12px;font-weight:780}.camera-popover small{overflow:hidden;color:var(--muted);font-size:11px;white-space:nowrap;text-overflow:ellipsis}.context-menu{position:fixed;z-index:40;display:flex;width:122px;flex-direction:column;gap:4px;padding:6px;background:#fffffff5;border:1px solid #d8dee8;border-radius:8px;box-shadow:0 18px 44px #26334d2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.context-menu button{display:flex;align-items:center;gap:8px;width:100%;min-height:32px;padding:0 10px;color:var(--ink);text-align:left;background:transparent;border:0;border-radius:6px;font-size:13px}.context-menu button svg{flex:0 0 auto}.context-menu button span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.context-menu button:hover{background:var(--blue-soft)}.context-menu button.danger{color:var(--red)}.context-divider{display:block;height:1px;margin:3px 2px;background:#e5e9f0}.image-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:42px;background:#0f172a94;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.image-modal-panel{position:relative;display:grid;max-width:min(86vw,980px);max-height:86vh;place-items:center}.image-modal-panel img{display:block;max-width:min(86vw,980px);max-height:86vh;object-fit:contain;background:#fff;border-radius:8px;box-shadow:0 26px 72px #00000047}.image-modal-tools{position:absolute;top:10px;right:10px;z-index:2;display:flex;gap:8px}.image-modal-tools button{width:36px;min-width:36px;height:36px;padding:0}@keyframes spin{to{transform:rotate(360deg)}}
