.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,0.5);--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:rgba(240,240,240,0.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,0.25);--xy-node-boxshadow-hover-default:0 1px 4px 1px rgba(0,0,0,0.08);--xy-node-boxshadow-selected-default:0 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,0.08);--xy-selection-border-default:1px dotted rgba(0,89,220,0.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,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,0.25);--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:rgba(60,60,60,0.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,0.25);--xy-node-boxshadow-hover-default:0 1px 4px 1px rgba(255,255,255,0.08);--xy-node-boxshadow-selected-default:0 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,0.08);--xy-selection-border-default:1px dotted rgba(200,200,220,0.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,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;touch-action:none}.react-flow__pane.draggable{cursor:-webkit-grab;cursor:grab}.react-flow__pane.dragging{cursor:-webkit-grabbing;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.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path,.react-flow__edge.selected .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:-webkit-grab;cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:-webkit-grabbing;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:-webkit-grab;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.bottom.center,.react-flow__panel.top.center{left:50%;transform:translateX(-15px) translateX(-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{pointer-events:none}.react-flow__edgelabel-renderer,.react-flow__viewport-portal{position:absolute;width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top: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{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-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{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-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.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.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{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.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.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.bottom,.react-flow__resize-control.line.top{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))}@import url("https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600&family=Geist+Mono:wght@400;500;600&display=swap");:root{--font-sans:"Geist",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;--font-mono:"Geist Mono",ui-monospace,"SF Mono",Menlo,monospace;--accent:#3b82f6;--accent-soft:rgba(59,130,246,0.14);--accent-ring:rgba(59,130,246,0.30);--t-client:#9aa1ab;--t-gateway:#9aa1ab;--t-service:#6366f1;--t-api:#06b6d4;--t-cache:#10b981;--t-datastore:#f97316;--t-queue:#8b5cf6;--r-sm:6px;--r-md:9px;--r-lg:13px;--ease:cubic-bezier(0.22,0.61,0.36,1)}:root,:root[data-theme=light]{--bg:#f6f7f9;--bg-dots:rgba(15,20,30,0.055);--chrome:#ffffff;--chrome-2:#fbfbfc;--surface:#ffffff;--surface-2:#f3f4f6;--surface-hover:#f7f8fa;--border:rgba(17,24,39,0.10);--border-strong:rgba(17,24,39,0.16);--text:#14161a;--text-dim:#5b6370;--text-faint:#9aa1ad;--edge:#b3b9c2;--edge-label-bg:#f6f7f9;--shadow-pop:0 10px 34px -8px rgba(15,23,42,0.20),0 2px 8px -2px rgba(15,23,42,0.10);--shadow-block:0 1px 2px rgba(15,23,42,0.05)}:root[data-theme=dark]{--bg:#1a1c1f;--bg-dots:rgba(255,255,255,0.045);--chrome:#101113;--chrome-2:#141517;--surface:#202327;--surface-2:#181a1d;--surface-hover:#25282d;--border:rgba(255,255,255,0.085);--border-strong:rgba(255,255,255,0.16);--text:#e8eaed;--text-dim:#8d929b;--text-faint:#5f646d;--edge:#41454c;--edge-label-bg:#1a1c1f;--shadow-pop:0 14px 40px -10px rgba(0,0,0,0.55),0 2px 10px -2px rgba(0,0,0,0.40);--shadow-block:0 1px 2px rgba(0,0,0,0.30)}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%;background:var(--chrome);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}html.home,html.home body{overflow:auto;height:auto;min-height:100%}html.home body{background:var(--bg)}#__next,body>div{height:100%}button{font-family:inherit;cursor:pointer}::selection{background:var(--accent-soft)}.mono{font-family:var(--font-mono);font-feature-settings:"ss01","cv01"}.rufo-app{height:100vh;display:grid;grid-template-rows:auto 1fr;background:var(--chrome)}.workspace{display:grid;grid-template-columns:1fr 420px;min-height:0;position:relative;overflow:hidden}.workspace.with-sidebar{grid-template-columns:256px 1fr 420px}.problembar{display:flex;align-items:center;gap:16px;padding:14px 22px;border-bottom:1px solid var(--border);background:var(--chrome);z-index:10}.pb-glyph{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--border-strong);display:grid;place-items:center;color:var(--text-dim);flex:none}.pb-main{display:flex;flex-direction:column;gap:3px;min-width:0}.pb-title{font-size:19px;font-weight:600;letter-spacing:-.012em;line-height:1.1}.pb-constraints{font-size:12.5px;color:var(--text-dim);letter-spacing:.01em}.pb-constraints b{color:var(--text);font-weight:500}.pb-spacer{flex:1 1}.pb-timer{font-size:16px;color:var(--text-dim);letter-spacing:.04em;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.pb-timer.low{color:var(--t-datastore)}.iconbtn{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-dim);display:grid;place-items:center;transition:all .15s var(--ease)}.iconbtn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.canvas-wrap{position:relative;overflow:hidden;background:radial-gradient(var(--bg-dots) 1.1px,transparent 1.1px);background-color:var(--bg);background-size:22px 22px}.canvas-wrap .react-flow__renderer{background:transparent}.canvas-wrap .react-flow__background{display:none}.canvas-wrap .react-flow__pane{cursor:default}.canvas-wrap .react-flow__pane.draggable{cursor:-webkit-grab;cursor:grab}.canvas-wrap .react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.canvas-wrap .react-flow__edge-path{stroke:var(--edge);stroke-width:1.6}.canvas-wrap .react-flow__edge.selected .react-flow__edge-path,.canvas-wrap .react-flow__edge:focus .react-flow__edge-path{stroke:var(--accent);stroke-width:2}.canvas-wrap .react-flow__edge:hover .react-flow__edge-path{stroke:var(--text-dim)}.canvas-wrap .react-flow__edge-text{font-family:var(--font-mono);font-size:11.5px;fill:var(--text-faint)}.canvas-wrap .react-flow__arrowhead polyline{stroke:var(--edge);fill:var(--edge)}.canvas-wrap .react-flow__controls,.canvas-wrap .react-flow__minimap{display:none}.canvas-wrap .react-flow__connection-line{stroke:var(--accent);stroke-dasharray:5 4;stroke-width:2}.block-node{width:212px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-block);padding:13px 15px;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:box-shadow .15s var(--ease),border-color .15s var(--ease)}.block-node:hover{border-color:var(--border-strong)}.block-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.block-node.dragging{cursor:-webkit-grabbing;cursor:grabbing;box-shadow:var(--shadow-pop)}.block-node.pulsing{animation:nodePulse 1.1s var(--ease)}@keyframes nodePulse{0%{box-shadow:0 0 0 0 var(--accent-ring)}40%{box-shadow:0 0 0 7px rgba(59,130,246,0)}to{box-shadow:var(--shadow-block)}}.block-node.style-filled:before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);background:var(--type-tint,transparent);opacity:.5;pointer-events:none}.block-node.style-minimal{background:transparent;border-color:transparent;box-shadow:none}.block-node.style-minimal:hover{background:var(--surface);border-color:var(--border)}.block-node.style-minimal.selected{background:var(--surface)}.node-head{display:flex;align-items:center;gap:8px}.node-dot{width:8px;height:8px;border-radius:50%;flex:none}.node-type{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);letter-spacing:.01em}.node-name{line-height:1.15}.node-name,.node-name-input{margin-top:7px;font-size:18px;font-weight:500;letter-spacing:-.01em}.node-name-input{width:100%;font-family:var(--font-sans);background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--r-sm);padding:3px 7px;color:var(--text);outline:none}.canvas-wrap .react-flow__handle{width:11px;height:11px;border-radius:50%;background:var(--chrome);border:2px solid var(--accent);opacity:0;transition:opacity .12s var(--ease),transform .12s var(--ease)}.canvas-wrap .react-flow__handle[data-handletype=target]{opacity:0!important;pointer-events:none}.block-node.selected .react-flow__handle[data-handletype=source],.block-node:hover .react-flow__handle[data-handletype=source]{opacity:1}.canvas-wrap .react-flow__handle:hover{transform:scale(1.35)}.canvas-wrap .react-flow__handle-top{top:-6px}.canvas-wrap .react-flow__handle-bottom{bottom:-6px}.canvas-wrap .react-flow__handle-left{left:-6px}.canvas-wrap .react-flow__handle-right{right:-6px}.node-body{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}.pill{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.03em;padding:2px 6px;border-radius:5px;line-height:1.3}.pill.method{text-transform:uppercase}.pill.engine{color:var(--text-dim);border:1px solid var(--border);text-transform:lowercase}.pill.engine,.pill.muted{background:var(--surface-2)}.pill.muted{color:var(--text-faint)}.group-node{width:214px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:5px 5px 0 -1px var(--bg),5px 5px 0 0 var(--border),var(--shadow-block);padding:13px 15px;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.group-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.group-node.pulsing{animation:nodePulse 1.1s var(--ease)}.group-dots{display:flex;align-items:center;gap:4px;margin-top:9px;flex-wrap:wrap}.gn-count{font-size:10px;color:var(--text-faint);margin-left:4px;font-family:var(--font-mono)}.group-expand-btn{margin-left:auto;width:20px;height:20px;border:none;background:transparent;color:var(--text-dim);border-radius:5px;display:grid;place-items:center;transition:background .12s var(--ease),color .12s var(--ease);cursor:pointer}.group-expand-btn:hover{background:var(--surface-hover);color:var(--text)}.group-container{border:1.4px dashed var(--border-strong);border-radius:18px;background:rgba(125,135,150,.055);position:relative}.group-container.selected{border-style:solid;border-color:var(--accent);background:var(--accent-soft)}.group-pill{position:absolute;top:9px;left:11px;display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 7px 0 4px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-block);cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:10}.group-chevron{width:22px;height:22px;flex:none;display:grid;place-items:center;border:none;background:transparent;color:var(--text-dim);border-radius:5px;transition:background .12s var(--ease),color .12s var(--ease);cursor:pointer}.group-chevron:hover{background:var(--surface-hover);color:var(--text)}.group-name,.group-name-input{font-size:13px;font-weight:500;letter-spacing:-.01em;color:var(--text)}.group-name-input{border:1px solid var(--accent);padding:2px 6px;outline:none;width:130px}.group-count,.group-name-input{background:var(--surface-2);border-radius:5px}.group-count{padding:1px 6px;font-family:var(--font-mono)}.group-count,.group-ungroup{font-size:10.5px;color:var(--text-faint)}.group-ungroup{background:none;border:none;padding:2px 4px;opacity:0;transition:opacity .12s var(--ease),color .12s var(--ease);cursor:pointer}.group-pill:hover .group-ungroup{opacity:1}.group-ungroup:hover{color:var(--t-datastore)}.ctx-overlay{position:fixed;z-index:100;width:272px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);padding:13px 15px;font-size:13px;max-height:calc(100vh - 24px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.ctx-overlay::-webkit-scrollbar{width:7px}.ctx-overlay::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.ctx-head{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11.5px;color:var(--text-dim);margin-bottom:9px}.ctx-head .node-dot{width:7px;height:7px}.ctx-head .sep{color:var(--text-faint)}.ctx-meta{display:flex;flex-direction:column;gap:6px}.ctx-line{font-family:var(--font-mono);font-size:12.5px;color:var(--text-dim);letter-spacing:.005em;line-height:1.4}.ctx-divider{height:1px;background:var(--border);margin:11px -15px}.hovercard-overlay{pointer-events:none;opacity:.98}.hovercard-overlay .ctx-line{color:var(--text-dim)}.route-line{display:flex;align-items:center;gap:8px}.method-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;color:#fff;border-radius:3px;padding:2px 5px;flex-shrink:0;letter-spacing:.05em;min-width:48px;text-align:center}.route-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-dim)}.ins-field{display:flex;flex-direction:column;gap:4px;margin-bottom:9px}.ins-label{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);text-transform:lowercase;letter-spacing:.04em}.ins-input,.ins-select{font-family:var(--font-mono);font-size:12.5px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:5px 8px;color:var(--text);outline:none;transition:border-color .12s var(--ease)}.ins-input:focus,.ins-select:focus{border-color:var(--accent)}.ins-row2{display:grid;grid-template-columns:1fr 1fr;grid-gap:9px;gap:9px}.ins-lines{display:flex;flex-direction:column;gap:5px}.ins-line-row{display:flex;gap:6px;align-items:center}.ins-line-row .ins-input{flex:1 1}.ctx-actions{display:flex;gap:8px;margin-top:12px}.ctx-btn{flex:1 1;font-family:var(--font-mono);font-size:12px;padding:7px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);transition:all .12s var(--ease)}.ctx-btn:hover{color:var(--text);border-color:var(--border-strong)}.ctx-btn.danger:hover{color:var(--t-datastore);border-color:var(--t-datastore);background:transparent}.ctx-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ctx-btn.primary:hover{filter:brightness(1.08)}.tinybtn{width:24px;height:28px;flex:none;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-faint);display:grid;place-items:center;font-size:14px}.tinybtn:hover{color:var(--t-datastore);border-color:var(--border-strong)}.addline{font-family:var(--font-mono);font-size:11.5px;color:var(--accent);background:none;border:none;padding:2px 0;text-align:left;align-self:flex-start}.addline:hover{text-decoration:underline}.ins-static{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--r-sm);padding:5px 8px;display:inline-flex;align-items:center;gap:7px}.ins-static .tag{color:var(--t-api);font-weight:500}.route-row{display:flex;gap:6px;align-items:center}.route-row .m-select{width:78px;flex:none;font-family:var(--font-mono);font-size:11px;font-weight:600;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:5px 4px;color:var(--text);outline:none}.route-row .m-select:focus{border-color:var(--accent)}.err-row{display:flex;gap:7px;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:5px 8px}.err-code{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--t-datastore);flex:none;min-width:30px}.err-msg{font-size:12px;color:var(--text-dim);flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.err-x{color:var(--text-faint);cursor:pointer;background:none;border:none;font-size:14px;padding:0 2px}.err-x:hover{color:var(--t-datastore)}.err-add{display:grid;grid-template-columns:64px 1fr auto;grid-gap:6px;gap:6px;align-items:center;margin-top:6px}.err-add .ins-input{font-size:12px}.err-add .add-btn{font-family:var(--font-mono);font-size:11.5px;color:var(--accent);background:var(--accent-soft);border:1px solid transparent;border-radius:var(--r-sm);padding:6px 10px;transition:all .12s var(--ease)}.err-add .add-btn:hover{border-color:var(--accent)}.err-add .add-btn:disabled{opacity:.4;cursor:default}.seg{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px}.seg button{flex:1 1;font-family:var(--font-mono);font-size:12px;padding:6px 8px;border-radius:5px;border:none;background:transparent;color:var(--text-dim);transition:all .12s var(--ease);text-transform:lowercase}.seg button.on,.seg button:hover{color:var(--text)}.seg button.on{background:var(--surface);box-shadow:var(--shadow-block)}.canvas-toolbar{position:absolute;left:16px;bottom:16px;z-index:40;display:flex;align-items:center;gap:4px;background:var(--chrome);border:1px solid var(--border);border-radius:var(--r-md);padding:5px;box-shadow:var(--shadow-pop);pointer-events:all}.tb-btn{height:32px;min-width:32px;padding:0 8px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-dim);display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font-mono);font-size:12px;transition:all .12s var(--ease)}.tb-btn:hover{background:var(--surface-hover);color:var(--text)}.tb-btn.active{background:var(--accent-soft);color:var(--accent)}.tb-sep{width:1px;height:20px;background:var(--border);margin:0 3px}.tb-zoom{font-family:var(--font-mono);font-size:12px;color:var(--text-faint);min-width:42px;text-align:center}.sel-bar{position:absolute;transform:translateX(-50%);z-index:45;display:inline-flex;align-items:center;gap:9px;background:var(--chrome);border:1px solid var(--border-strong);border-radius:9px;padding:5px 6px 5px 12px;box-shadow:var(--shadow-pop);white-space:nowrap;animation:msgIn .18s var(--ease) both;pointer-events:all}.sel-count{font-size:11.5px;color:var(--text-dim);font-family:var(--font-mono)}.sel-group-btn{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:#fff;background:var(--accent);border:none;border-radius:6px;padding:6px 11px;transition:filter .12s var(--ease);cursor:pointer}.sel-group-btn:hover{filter:brightness(1.08)}.Agent{display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--chrome);min-height:0}.iv-head{display:flex;align-items:center;gap:9px;padding:12px 16px 10px;font-size:14px;color:var(--text);font-weight:500;border-bottom:1px solid var(--border)}.iv-head .glyph{width:17px;height:17px;color:var(--text-dim)}.iv-head-actions{margin-left:auto;display:flex;align-items:center;gap:2px}.iv-tabs{display:flex;gap:2px;padding:6px 12px 0;border-bottom:1px solid var(--border)}.iv-tab{padding:5px 12px;border-radius:var(--r-sm) var(--r-sm) 0 0;font-size:12px;font-family:var(--font-mono);color:var(--text-faint);border:1px solid transparent;background:transparent;cursor:pointer;transition:all .12s var(--ease);white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.iv-tab:hover{color:var(--text-dim);background:var(--surface-hover)}.iv-tab.active{color:var(--text);background:var(--chrome);border-color:var(--border) var(--border) transparent;margin-bottom:-1px}.iv-history-wrap{position:relative}.iv-history-popover{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--chrome-2);border:1px solid var(--border);border-radius:var(--r-md);padding:6px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:50}.iv-history-label{font-size:10.5px;font-family:var(--font-mono);color:var(--text-faint);padding:2px 8px 6px;letter-spacing:.04em;text-transform:uppercase}.iv-history-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border-radius:var(--r-sm);font-size:13px;color:var(--text-dim);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .1s var(--ease)}.iv-history-item:hover{background:var(--surface-hover);color:var(--text)}.iv-history-item.active{color:var(--text);font-weight:500}.iv-history-dot{width:6px;height:6px;border-radius:50%;flex:none;background:var(--text-faint)}.iv-history-item.active .iv-history-dot{background:var(--accent)}.iv-history-count{margin-left:auto;font-size:11px;font-family:var(--font-mono);color:var(--text-faint);background:var(--surface-2);padding:1px 5px;border-radius:8px}.iconbtn.active{color:var(--accent)}.iv-feed{flex:1 1;overflow-y:auto;padding:6px 20px 20px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.iv-feed::-webkit-scrollbar{width:8px}.iv-feed::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.msg{border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;background:var(--chrome-2);animation:msgIn .35s var(--ease) both}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.msg.probe{cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease)}.msg.probe:hover{border-color:var(--border-strong)}.msg.probe.linked-active{border-color:var(--accent);background:var(--accent-soft)}.msg-meta{font-family:var(--font-mono);font-size:11.5px;color:var(--text-dim);margin-bottom:9px;display:flex;align-items:center;gap:6px}.msg-meta .sep{color:var(--text-faint)}.msg.probe .msg-body{font-size:15.5px;line-height:1.45;letter-spacing:-.006em;color:var(--text);font-weight:450}.msg.you{position:relative;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}.msg.you .msg-meta{color:var(--text-faint)}.msg.you .msg-body{font-size:14px;line-height:1.5;color:var(--text-dim)}.msg.you.ok{border-color:#16a34a;box-shadow:inset 0 0 0 1px #16a34a}.msg.you.error{border-color:#dc2626;box-shadow:inset 0 0 0 1px #dc2626}.msg-check{position:absolute;top:-7px;right:-7px;line-height:0;color:#16a34a;background:var(--chrome-2);border-radius:50%;animation:checkPop .3s var(--ease) both}@keyframes checkPop{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:none}}.iv-typing{display:flex;gap:4px;padding:4px 2px}.iv-typing span{width:5px;height:5px;border-radius:50%;background:var(--text-faint);animation:typing 1.2s var(--ease) infinite}.iv-typing span:nth-child(2){animation-delay:.18s}.iv-typing span:nth-child(3){animation-delay:.36s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.iv-composer{padding:14px 20px 18px;border-top:1px solid var(--border)}.iv-inputwrap{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:13px 14px;transition:border-color .15s var(--ease)}.iv-inputwrap:focus-within{border-color:var(--accent)}.iv-input{flex:1 1;border:none;background:none;outline:none;resize:none;font-family:var(--font-sans);font-size:14px;color:var(--text);line-height:1.4;max-height:96px}.iv-input::placeholder{color:var(--text-faint)}.iv-send{width:28px;height:28px;flex:none;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);display:grid;place-items:center;transition:all .12s var(--ease)}.iv-send:hover{color:var(--accent);border-color:var(--accent)}.iv-send:disabled{opacity:.4;cursor:default}.sidebar{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--chrome);min-height:0;overflow:hidden}.sb-head{display:flex;align-items:center;gap:8px;padding:16px 16px 12px;font-size:14px;font-weight:500;color:var(--text)}.sb-head .glyph{width:16px;height:16px;color:var(--text-dim)}.sb-head .sb-collapse{margin-left:auto;width:26px;height:26px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;color:var(--text-faint);display:grid;place-items:center;transition:all .12s var(--ease)}.sb-head .sb-collapse:hover{background:var(--surface-hover);color:var(--text)}.sb-body{flex:1 1;overflow-y:auto;padding:4px 12px 18px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}.sb-body::-webkit-scrollbar{width:7px}.sb-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.sb-section-label{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);text-transform:lowercase;letter-spacing:.06em;padding:14px 6px 7px}.lib-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);text-align:left;color:var(--text);margin-bottom:6px;cursor:-webkit-grab;cursor:grab;transition:border-color .12s var(--ease),background .12s var(--ease);box-shadow:var(--shadow-block)}.lib-item:hover{border-color:var(--border-strong);background:var(--surface-hover)}.lib-item:active{cursor:-webkit-grabbing;cursor:grabbing}.lib-item.ghosting{opacity:.4}.lib-dot{width:9px;height:9px;border-radius:50%;flex:none}.lib-text{min-width:0;display:flex;flex-direction:column;gap:1px}.lib-name{font-size:13px;font-weight:450;letter-spacing:-.005em}.lib-desc{font-family:var(--font-mono);font-size:10.5px}.lib-desc,.lib-plus{color:var(--text-faint)}.lib-plus{margin-left:auto;font-size:15px;line-height:1;opacity:0;transition:opacity .12s var(--ease)}.lib-item:hover .lib-plus{opacity:1}.sb-open{position:absolute;left:16px;top:16px;z-index:42;display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--chrome);color:var(--text-dim);font-family:var(--font-mono);font-size:12px;box-shadow:var(--shadow-pop);transition:all .12s var(--ease)}.sb-open:hover{color:var(--text);border-color:var(--border-strong)}.lib-ghost{position:fixed;z-index:999;pointer-events:none;display:flex;align-items:center;gap:9px;padding:9px 13px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--accent);box-shadow:var(--shadow-pop);font-size:13px;color:var(--text);transform:translate(-50%,-50%)}.sg-view{display:grid;grid-template-rows:auto 1fr;min-height:0;height:100%}.sg-breadcrumb{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--chrome)}.sg-back-btn{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);font-size:12px;transition:all .12s var(--ease)}.sg-back-btn:hover{color:var(--text);border-color:var(--border-strong)}.sg-breadcrumb-path{display:flex;align-items:center;gap:7px;font-size:13px}.sg-bc-item{color:var(--text-dim);font-size:12px;cursor:pointer;transition:color .12s}.sg-bc-active,.sg-bc-item:hover{color:var(--text)}.sg-bc-active{font-weight:500;cursor:default}.sg-bc-sep,.sg-breadcrumb-meta{color:var(--text-faint);font-size:11px}.sg-breadcrumb-meta{margin-left:auto}.sg-canvas-area{position:relative;min-height:0}.sg-node{width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-block);padding:11px 13px;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;background-image:linear-gradient(135deg,var(--type-tint,transparent) 0,transparent 60%);transition:box-shadow .15s var(--ease),border-color .15s var(--ease)}.sg-node:hover{border-color:var(--border-strong)}.sg-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.sg-node-head{display:flex;align-items:center;gap:7px}.sg-level-badge{font-size:9px;font-weight:600;color:var(--text-faint);background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 4px;letter-spacing:.04em}.sg-node-name{margin-top:6px;font-size:16px;font-weight:500;letter-spacing:-.01em}.sg-fields{display:flex;flex-direction:column;gap:3px;margin-top:8px;padding-top:6px;border-top:1px solid var(--border)}.sg-fields-out{margin-top:4px;padding-top:4px;border-top:1px dashed var(--border)}.sg-field-row{display:flex;align-items:baseline;gap:6px;font-size:11px;line-height:1.3}.sg-field-dir{font-family:var(--font-mono);font-size:9px;font-weight:600;padding:1px 4px;border-radius:3px;flex:none;letter-spacing:.04em}.sg-dir-in{color:#10b981;background:rgba(16,185,129,.12)}.sg-dir-out{color:#3b82f6;background:rgba(59,130,246,.12)}.sg-field-name{font-family:var(--font-mono);font-size:11px;color:var(--text)}.sg-field-type{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}.sg-indicator{display:flex;align-items:center;gap:5px;margin-top:9px;padding:4px 8px;border:1px dashed var(--border-strong);border-radius:var(--r-sm);background:transparent;color:var(--text-faint);font-size:11px;width:100%;transition:all .12s var(--ease)}.sg-indicator:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.sg-indicator svg{flex:none;color:currentColor}.sg-label-params{color:#10b981!important}.sg-label-outputs{color:#3b82f6!important}.sg-field-edit-row{grid-template-columns:90px 80px 1fr 28px;grid-gap:5px;margin-bottom:4px}.sg-field-add-row,.sg-field-edit-row{display:grid;gap:5px;align-items:center}.sg-field-add-row{grid-template-columns:90px 80px auto;grid-gap:5px;margin-top:4px}.sg-field-input-name{font-size:11.5px!important}.sg-field-input-type{font-size:11px!important}.sg-field-input-desc{font-size:11.5px!important}.sg-toolbar{bottom:16px;left:16px}.sg-node .react-flow__handle{width:9px;height:9px;border-radius:50%;background:var(--chrome);border:2px solid var(--accent);opacity:0;transition:opacity .12s var(--ease)}.sg-node.selected .react-flow__handle[data-handletype=source],.sg-node:hover .react-flow__handle[data-handletype=source]{opacity:1}.sg-node .react-flow__handle[data-handletype=target]{opacity:0!important;pointer-events:none}.iv-tease{margin:auto 0;padding:14px 16px;border:1px dashed var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:8px}.iv-tease-label{font-size:10px;letter-spacing:.07em;color:var(--text-faint);text-transform:lowercase}.iv-tease-text{font-size:12.5px;line-height:1.55;color:var(--text-faint);font-style:italic}.brief-trigger{position:absolute;top:14px;left:14px;z-index:10;display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px 0 8px;border-radius:var(--r-md);border:1px solid var(--border);background:color-mix(in srgb,var(--chrome) 85%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text-dim);font-family:var(--font-mono);font-size:11px;letter-spacing:.02em;box-shadow:var(--shadow-block);cursor:pointer;transition:border-color .15s var(--ease),color .15s var(--ease),background .15s var(--ease)}.brief-trigger:hover{border-color:var(--border-strong);color:var(--text);background:var(--chrome)}.qip-wrap{position:absolute;top:0;left:0;bottom:0;width:300px;z-index:20;transform:translateX(-100%);opacity:0;pointer-events:none;transition:transform .22s var(--ease),opacity .18s var(--ease)}.qip-wrap.open{transform:translateX(0);opacity:1;pointer-events:auto}.qip-panel{position:absolute;inset:10px auto 10px 10px;width:288px;display:flex;flex-direction:column;background:var(--chrome);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);overflow:hidden}.qip-header{display:flex;align-items:center;gap:8px;padding:10px 12px 10px 14px;border-bottom:1px solid var(--border);flex:none}.qip-title{font-size:11px;letter-spacing:.06em;color:var(--text-faint);text-transform:lowercase}.qip-role-badge{font-size:10px;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-ring);padding:1px 7px;border-radius:999px}.qip-close{margin-left:auto;width:24px;height:24px;display:grid;place-items:center;border:none;background:transparent;color:var(--text-faint);border-radius:var(--r-sm);cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease)}.qip-close:hover{background:var(--surface-hover);color:var(--text)}.qip-body{flex:1 1;overflow:hidden;display:flex;flex-direction:column}.qip-editor{flex:1 1;resize:none;border:none;outline:none;background:transparent;padding:14px;font-family:var(--font-sans);font-size:13px;line-height:1.6;color:var(--text);min-height:0}.qip-editor::placeholder{color:var(--text-faint)}.qip-reader{flex:1 1;padding:14px;font-size:13px;line-height:1.6;color:var(--text-dim);white-space:pre-wrap;overflow-y:auto}.qip-empty{flex:1 1;padding:14px;font-size:11.5px}.qip-empty,.qip-footer{color:var(--text-faint)}.qip-footer{padding:7px 14px;font-size:10.5px;border-top:1px solid var(--border);letter-spacing:.03em;flex:none}