.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.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 .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.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:-webkit-grab;cursor:grab}.react-flow__node.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:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.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.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@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}.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-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.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,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.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{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.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:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform: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:#3367d9;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%}:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,input,textarea,select{font:inherit}button{border:1px solid var(--line);background:var(--button);color:var(--text);border-radius:6px;min-width:36px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:border-color .14s cubic-bezier(.22,1,.36,1),color .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1)}button:hover{border-color:var(--accent);color:var(--accent)}button:active{background:var(--panel-2)}button:disabled{cursor:wait;opacity:.58}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{--bg: #0b1020;--panel: #101827;--panel-2: #151f32;--line: #26344e;--muted: #8ea0bc;--text: #e7edf7;--button: #121c2d;--canvas-dot: #25334a;--accent: #49d6a6;--accent-2: #5ea2ff;--warn: #f7bd5c;--danger: #ff7b7b;--node-entry: #49d6a6;--node-server: #5ea2ff;--node-route: #e066ff;--node-upstream: #5ea2ff;--node-target: #f7bd5c;--node-variable: #ff8f70;--syntax-comment: #6c7f9c;--syntax-block: #5ea2ff;--syntax-directive: #49d6a6;--syntax-variable: #f7bd5c;--syntax-target: #ff8f70;--syntax-punct: #9aa9c0;--edge-default: #6f83a6;--edge-rewrite: #e066ff;--edge-dimmed: #566277;height:100vh;display:grid;grid-template-columns:var(--left-panel-width, 340px) minmax(0,1fr) 320px;grid-template-rows:48px minmax(0,1fr);background:var(--bg);color:var(--text)}.app-shell.panel-collapsed{grid-template-columns:52px minmax(0,1fr) 320px}.app-shell.canvas-focused{grid-template-columns:minmax(0,1fr)}.canvas-focused .left-panel,.canvas-focused .right-panel{display:none}.canvas-focused .canvas{grid-column:1}.app-shell.light{--bg: #f7f8fb;--panel: #ffffff;--panel-2: #f0f3f8;--line: #d8e0ec;--muted: #65758c;--text: #172033;--button: #ffffff;--canvas-dot: #cfd8e5;--accent: #138a68;--accent-2: #2368d4;--warn: #a66104;--danger: #b82e39;--node-entry: #087052;--node-server: #1859a9;--node-route: #7a3fa0;--node-upstream: #1859a9;--node-target: #805000;--node-variable: #9d351f;--syntax-comment: #53657f;--syntax-block: #1859a9;--syntax-directive: #087052;--syntax-variable: #805000;--syntax-target: #9d351f;--syntax-punct: #495970;--edge-default: #526783;--edge-rewrite: #7a3fa0;--edge-dimmed: #748196;color-scheme:light}.topbar{grid-column:1 / -1;grid-row:1;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--line);background:var(--panel);z-index:5}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;white-space:nowrap}.brand-mark{width:26px;height:26px;display:inline-grid;place-items:center;border-radius:6px;color:#06130f;background:var(--accent)}.menu{display:flex;align-items:center;gap:8px;flex:0 0 auto}.menu button,.menu a{padding:0 8px}.menu a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;color:var(--muted);transition:color .14s cubic-bezier(.22,1,.36,1)}.menu a:hover{color:var(--accent)}.menu .language-button{width:72px;min-width:72px;flex:0 0 72px;padding:0 9px;font-size:12px;font-weight:650}.menu-action-label{font-size:12px;line-height:1;white-space:nowrap}.fullscreen-button{width:112px;min-width:112px;flex:0 0 112px;padding:0 12px!important}.fullscreen-button span{font-size:12px;white-space:nowrap}.left-panel,.right-panel{min-height:0;font-size:14px;background:var(--panel);border-color:var(--line);overflow:hidden}.left-panel{grid-column:1;grid-row:2;border-right:1px solid var(--line);padding:10px;display:grid;grid-template-rows:auto minmax(0,1fr);gap:10px;position:relative}.panel-resize-handle{position:absolute;inset-block:0;inset-inline-end:-7px;z-index:2;width:14px;min-width:14px;height:100%;min-height:0;padding:0;border:0;border-radius:0;background:transparent;cursor:col-resize;touch-action:none}.panel-resize-handle span{display:block;width:2px;height:48px;border-radius:999px;opacity:.34;background:linear-gradient(180deg,transparent,var(--accent-2),transparent);transition:opacity .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1)}.panel-resize-handle:hover span{opacity:1}.panel-collapsed .panel-resize-handle{display:none}.panel-collapsed .left-panel{padding:8px}.right-panel{grid-column:3;grid-row:2;border-left:1px solid var(--line);padding:18px;overflow-y:auto}.collapse-button{width:36px;height:36px;min-width:36px;min-height:36px;justify-self:end}.panel-collapsed .collapse-button{justify-self:center}.panel-content{min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:10px}.panel-collapsed .panel-content{display:none}.panel-tools{min-width:0;display:grid;grid-template-columns:auto auto minmax(0,1fr);gap:8px}.icon-upload,.panel-tool-button{height:34px;border:1px solid var(--line);border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 9px;color:var(--text);background:var(--button)}.icon-upload{width:auto;cursor:pointer;position:relative;transition:border-color .14s cubic-bezier(.22,1,.36,1),color .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1)}.icon-upload:hover,.panel-tool-button:hover{border-color:var(--accent);color:var(--accent)}.tool-label{font-size:12px;line-height:1;white-space:nowrap}.icon-upload input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.search-box{height:40px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:6px;padding:0 10px;background:var(--button)}.search-box input{width:100%;min-width:0;border:0;outline:0;color:var(--text);background:transparent}.search-box input::placeholder{color:var(--muted);opacity:1}.status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.panel-meta{min-height:0;display:grid;gap:10px}.status-grid div{height:58px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-2);display:grid;grid-template-rows:20px 18px;align-content:center}.status-grid strong,.status-grid span{display:block;line-height:18px}.status-grid strong{font-variant-numeric:tabular-nums}.status-grid span{color:var(--muted);font-size:13px;margin-top:2px}.issues{--issue-color: var(--muted);height:112px;overflow:hidden;border:1px solid var(--line);border-radius:8px;display:grid;grid-template-rows:auto minmax(0,1fr) auto;padding:0;color:var(--text);background:var(--panel)}.issues p{margin:0 0 6px;font-size:13px;line-height:1.35}.issues p:last-child{margin-bottom:0}.issues-header{min-height:38px;padding:9px 10px 8px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:8px;background:color-mix(in srgb,var(--panel) 88%,var(--panel-2))}.issues-header strong{color:var(--text);font-size:12px}.issues-header span{color:var(--muted);font-size:11px}.issues-scroll{min-height:0;overflow:auto}.issues-list{padding:8px 10px 10px;display:grid;gap:8px}.issues-hint{max-width:62ch;color:var(--muted);font-size:11px;line-height:1.4}.issue-item{--issue-color: var(--muted);--issue-bg: color-mix(in srgb, var(--panel-2) 58%, transparent);width:100%;min-width:0;min-height:0;padding:8px 9px;border:1px solid color-mix(in srgb,var(--line) 84%,var(--issue-color));border-radius:8px;display:block;text-align:left;background:var(--issue-bg);color:var(--text);transition:border-color .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1),color .14s cubic-bezier(.22,1,.36,1)}.issue-item--error{--issue-color: var(--danger);--issue-bg: color-mix(in srgb, var(--panel-2) 88%, var(--danger) 12%)}.issue-item--warning{--issue-color: var(--warn);--issue-bg: color-mix(in srgb, var(--panel-2) 90%, var(--warn) 10%)}.issue-item--info{--issue-color: var(--accent-2);--issue-bg: color-mix(in srgb, var(--panel-2) 92%, var(--accent-2) 8%)}.issue-item:hover,.issue-item:focus-visible{border-color:color-mix(in srgb,var(--issue-color) 78%,var(--line));color:var(--text);outline:none;background:color-mix(in srgb,var(--panel-2) 82%,var(--issue-color) 18%)}.issue-item__message{display:block;color:var(--text);font-size:13px;line-height:1.4}.issue-item__message strong{color:var(--issue-color);font-weight:700}.issue-item__suggestion{display:block;margin-top:3px;color:color-mix(in srgb,var(--text) 72%,var(--muted));font-size:12px;line-height:1.4}.issues-resize-handle:focus-visible{outline:1px solid var(--accent);outline-offset:-2px}.issues-resize-handle{position:relative;width:100%;height:18px;border-top:1px solid var(--line);cursor:ns-resize;touch-action:none;background:var(--panel)}.issues-resize-bar{position:absolute;inset-inline:14px;top:7px;height:3px;border-radius:999px;background:color-mix(in srgb,var(--accent-2) 28%,var(--line))}.issues-resize-helper{position:absolute;right:10px;top:-18px;color:var(--muted);font-size:11px;pointer-events:none}.config-textarea-area{min-height:0;height:100%}.code-editor{position:relative;width:100%;height:100%;min-height:0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#080d18}.light .code-editor{background:#fbfcff}.code-gutter,.code-editor textarea,.code-highlight{position:absolute;margin:0;overflow:auto;white-space:pre;-moz-tab-size:2;tab-size:2;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.55}.code-gutter{inset:0 auto 0 0;width:52px;padding:12px 8px 12px 10px;border-right:1px solid var(--line);color:var(--muted);background:color-mix(in srgb,var(--panel) 74%,transparent);text-align:right;overflow:hidden;z-index:1;-webkit-user-select:none;user-select:none}.code-editor textarea,.code-highlight{top:0;right:0;bottom:0;left:52px;padding:12px}.code-editor textarea{resize:none;border:0;outline:0;color:transparent;caret-color:var(--text);background:transparent;z-index:2}.code-editor textarea::selection{background:color-mix(in srgb,var(--accent-2) 38%,transparent)}.code-highlight{pointer-events:none;color:var(--text);z-index:2}.code-highlight code{display:block;min-width:max-content;min-height:100%}.code-line{display:block;margin:0 -4px;padding:0 4px;border-radius:4px}.code-gutter-line{display:block;padding:0 2px;border-radius:4px}.code-line-active{background:color-mix(in srgb,var(--accent-2) 24%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent-2) 40%,transparent)}.code-gutter-line-active{color:var(--text);background:color-mix(in srgb,var(--accent-2) 24%,transparent)}.tok-comment{color:var(--syntax-comment)}.tok-block{color:var(--syntax-block);font-weight:700}.tok-directive{color:var(--syntax-directive)}.tok-variable{color:var(--syntax-variable)}.tok-target{color:var(--syntax-target)}.tok-punct{color:var(--syntax-punct)}.canvas{grid-column:2;grid-row:2;min-width:0;min-height:0;background:var(--bg);position:relative}.react-flow{background:var(--bg)}.react-flow__background{color:var(--canvas-dot)}.react-flow__controls,.react-flow__minimap{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}.react-flow__controls-button{background:color-mix(in srgb,var(--panel-2) 72%,var(--panel));border-bottom:1px solid var(--line);color:var(--text)}.react-flow__controls-button svg{fill:currentColor}.react-flow__controls-button:hover{background:var(--panel-2);color:var(--accent)}.react-flow__controls-button:focus-visible{outline:1px solid var(--accent);outline-offset:-2px}.react-flow__edge-path{stroke:var(--edge-default)}.custom-flow-edge{fill:none}.custom-flow-edge:not(.dimmed-edge){stroke-dasharray:9;animation:flowDash .85s linear infinite}.custom-flow-edge.flow-edge{stroke:var(--accent-2)}.custom-flow-edge.dynamic-edge,.custom-flow-edge.map-edge{stroke:var(--warn)}.custom-flow-edge.rewrite-edge{stroke:var(--edge-rewrite)}.custom-flow-edge.selected-edge,.custom-flow-edge.search-edge,.custom-flow-edge.simulation-edge{stroke:var(--accent)}.custom-flow-edge.dimmed-edge{stroke:var(--edge-dimmed);stroke-dasharray:none}@keyframes flowDash{to{stroke-dashoffset:-18}}.react-flow__edge-textbg{fill:var(--panel)}.react-flow__edge-text{fill:var(--text);font-size:11px}.react-flow__node-laneGroup{pointer-events:none}.react-flow__node.dragging{transition:transform .12s linear}.edge-label{position:absolute;z-index:3;padding:2px 6px;border:1px solid var(--line);border-radius:999px;color:var(--text);background:var(--panel);font-size:11px;pointer-events:none;white-space:nowrap}.canvas-actions{display:flex;gap:8px}.request-simulator{width:min(608px,calc(100vw - 44px));min-height:112px;display:grid;grid-template-columns:104px 136px 132px 72px 62px 32px;align-items:end;gap:7px;padding:7px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--panel) 94%,var(--bg));box-shadow:0 4px 8px #0003}.simulator-title{height:30px;width:104px;display:inline-flex;align-items:center;padding-inline:2px 6px;color:var(--text);font-size:11px;font-weight:700;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.request-simulator label{display:grid;gap:3px;min-width:0;color:var(--muted);font-size:10px;line-height:1.2}.request-simulator input,.request-simulator select{height:30px;min-width:0;border:1px solid var(--line);border-radius:6px;padding:0 8px;outline:0;color:var(--text);background:var(--button);transition:border-color .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1)}.request-simulator input::placeholder{color:color-mix(in srgb,var(--muted) 82%,var(--text))}.request-simulator input:hover,.request-simulator select:hover{border-color:color-mix(in srgb,var(--accent-2) 48%,var(--line));background:color-mix(in srgb,var(--button) 82%,var(--panel-2))}.request-simulator input:focus,.request-simulator select:focus{border-color:var(--accent);background:var(--panel-2)}.request-simulator label:nth-of-type(1) input{width:100%}.request-simulator label:nth-of-type(2) input{width:100%}.request-simulator select,.request-simulator .simulator-port input{width:100%}.simulator-live-toggle{width:32px;min-width:32px;height:30px;padding:0!important;display:inline-flex;align-items:center;justify-content:center}.simulator-live-toggle[aria-pressed=true]{border-color:color-mix(in srgb,var(--accent) 70%,var(--line));color:var(--accent);background:color-mix(in srgb,var(--panel-2) 84%,var(--accent) 16%)}.simulator-live-toggle[aria-pressed=false]{color:var(--muted);background:var(--button)}.simulation-outcome{grid-column:1 / -1;min-width:0;padding:8px 9px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--panel-2) 86%,var(--bg))}.simulation-outcome__label{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:11px;line-height:1.25}.simulation-outcome__label strong{color:var(--text);font-size:11px;font-weight:650;white-space:nowrap}.simulation-outcome p{margin:5px 0 0;color:var(--text);font-size:12px;line-height:1.35;overflow-wrap:anywhere}.simulation-outcome__meta{margin-top:4px;display:flex;flex-wrap:wrap;gap:6px 10px;color:var(--muted);font-size:11px;line-height:1.3}.simulation-outcome--matched{border-color:color-mix(in srgb,var(--accent) 38%,var(--line))}.simulation-outcome--no-server,.simulation-outcome--no-location,.simulation-outcome.confidence-low{border-color:color-mix(in srgb,var(--warn) 44%,var(--line))}.app-shell.light .request-simulator{background:color-mix(in srgb,var(--panel) 96%,var(--panel-2));box-shadow:0 4px 8px #1720331a}.topology-progress{position:absolute;inset-inline-start:50%;inset-block-start:12px;z-index:4;transform:translate(-50%);width:154px;padding:5px 9px;border-radius:999px;background:var(--panel);color:var(--muted);font-size:12px;text-align:center;white-space:nowrap;pointer-events:none}.lane-group{position:relative;width:100%;height:100%;border-radius:20px}.nginx-node{--node-color: var(--node-server);width:216px;min-height:78px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--panel) 92%,#000);color:var(--text);transition:opacity .14s cubic-bezier(.22,1,.36,1),border-color .14s cubic-bezier(.22,1,.36,1),background-color .14s cubic-bezier(.22,1,.36,1)}.nginx-node.entry{--node-color: var(--node-entry)}.nginx-node.server,.nginx-node.upstream{--node-color: var(--node-server)}.nginx-node.route{--node-color: var(--node-route)}.nginx-node.target{--node-color: var(--node-target)}.nginx-node.variable{--node-color: var(--node-variable)}.nginx-node.selected,.nginx-node.matches,.nginx-node.related{outline:1px solid var(--accent);outline-offset:1px}.nginx-node.corner-trace{position:relative;overflow:hidden;background:linear-gradient(225deg,color-mix(in srgb,var(--node-color) 8%,var(--panel)) 0%,var(--panel) 50%)}.nginx-node.corner-trace:before,.nginx-node.corner-trace:after{content:"";position:absolute;pointer-events:none}.nginx-node.corner-trace:before{inset:0 0 auto 0;height:1px;background:linear-gradient(270deg,color-mix(in srgb,var(--node-color) 78%,transparent),color-mix(in srgb,var(--node-color) 22%,transparent) 68%,transparent)}.nginx-node.corner-trace:after{inset:0 0 0 auto;width:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--node-color) 78%,transparent),transparent 78%)}.nginx-node.dimmed{opacity:.34}.node-topline{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:11px;text-transform:uppercase}.node-icon{display:inline-flex;color:var(--node-server)}.nginx-node.entry .node-icon{color:var(--node-entry)}.nginx-node.route .node-icon{color:var(--node-route)}.nginx-node.upstream .node-icon{color:var(--node-upstream)}.nginx-node.target .node-icon{color:var(--node-target)}.nginx-node.variable .node-icon{color:var(--node-variable)}.node-type{overflow:hidden;text-overflow:ellipsis}.confidence{margin-left:auto;text-transform:lowercase;color:var(--warn)}.node-label{margin-top:8px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.node-subtitle{margin-top:5px;color:var(--muted);font-size:12px;overflow-wrap:anywhere}.empty-detail h2,.detail-content h2{margin:0;min-height:25px;font-size:20px;line-height:1.25}.empty-detail p{min-height:66px}.empty-detail p,.detail-content p,.detail-content li{color:var(--muted);line-height:1.55;font-size:14px}.detail-kind{display:inline-flex;margin-bottom:10px;color:var(--accent);font-size:13px;text-transform:uppercase}.subtitle,.line,.confidence-note{margin:8px 0;min-height:22px}.confidence-note--high{color:color-mix(in srgb,var(--text) 82%,var(--accent))!important}.confidence-note--medium,.confidence-note--low{color:color-mix(in srgb,var(--text) 78%,var(--warn))!important}.detail-content pre{white-space:pre-wrap;overflow-wrap:anywhere;border:1px solid var(--line);border-radius:8px;padding:10px;color:var(--text);background:var(--panel-2);font-size:13px;line-height:1.45}.detail-content h3{margin:18px 0 8px;min-height:22px;font-size:14px;line-height:22px}.detail-content ul{margin:0;padding-left:18px}.detail-content li.localized-explanation{min-height:44px}.simulation-summary{margin:14px 0;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-2)}.simulation-summary.compact{margin:10px 0 12px}.simulation-summary__top{display:grid;gap:4px}.simulation-summary strong{color:var(--text);font-size:13px;line-height:1.45}.simulation-summary span{color:var(--muted);font-size:12px}.simulation-summary__note{margin:7px 0 0;color:color-mix(in srgb,var(--text) 70%,var(--muted));font-size:12px;line-height:1.45}.simulation-summary ul{margin:9px 0 0;padding-left:18px}@media (max-width: 1100px){.app-shell{grid-template-columns:min(var(--left-panel-width, 300px),42vw) minmax(0,1fr);grid-template-rows:48px minmax(0,1fr) minmax(180px,28vh)}.app-shell.panel-collapsed{grid-template-columns:52px minmax(0,1fr)}.right-panel{display:block;grid-column:1 / -1;grid-row:3;border-left:0;border-top:1px solid var(--line);padding:14px 18px}.app-shell.canvas-focused{grid-template-columns:minmax(0,1fr);grid-template-rows:48px minmax(0,1fr)}.canvas-focused .canvas{grid-row:2}.request-simulator{width:min(608px,calc(100vw - 28px));align-items:end}.menu-action-label{display:none}}@media (max-width: 760px){body{overflow:auto}.app-shell{height:auto;min-height:100vh;grid-template-columns:1fr;grid-template-rows:auto auto 72vh auto}.topbar,.left-panel,.canvas{grid-column:1}.topbar{position:sticky;top:0;gap:10px}.menu{overflow-x:auto;padding-bottom:2px}.fullscreen-button span{display:none}.fullscreen-button{width:36px;min-width:36px;flex-basis:36px;padding:0!important}.left-panel{grid-row:2;border-right:0;border-bottom:1px solid var(--line);grid-template-rows:auto minmax(0,1fr);min-height:360px}.panel-collapsed .left-panel{min-height:52px}.canvas{grid-row:3}.right-panel{grid-column:1;grid-row:4;min-height:220px;max-height:none}.panel-resize-handle{display:none}.app-shell.canvas-focused{height:100vh;min-height:0;grid-template-rows:auto minmax(0,1fr)}.canvas-focused .canvas{grid-row:2;min-height:0}.request-simulator{inset-inline:8px auto;width:calc(100vw - 32px);min-height:166px;grid-template-columns:104px minmax(0,1fr) 72px 62px 32px;grid-template-rows:45px 45px auto}.simulator-title{grid-column:1;grid-row:1}.request-simulator label:nth-of-type(1){grid-column:2;grid-row:1}.request-simulator label:nth-of-type(2){grid-column:1 / -1;grid-row:2}.request-simulator label:nth-of-type(3){grid-column:3;grid-row:1}.request-simulator label:nth-of-type(4){grid-column:4;grid-row:1}.simulator-live-toggle{grid-column:5;grid-row:1}.request-simulator label:nth-of-type(1) input,.request-simulator label:nth-of-type(2) input{width:100%}}@media (max-width: 520px){.tool-label{display:none}.panel-tools{grid-template-columns:36px 36px minmax(0,1fr)}.icon-upload,.panel-tool-button{width:36px;padding:0}}@media (pointer: coarse){button,.icon-upload,.collapse-button{min-width:44px;min-height:44px}.panel-tools{grid-template-columns:auto auto minmax(0,1fr)}.fullscreen-button{min-width:44px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:0ms!important;animation-duration:0ms!important;animation-iteration-count:1!important}.custom-flow-edge:not(.dimmed-edge){animation:none;stroke-dasharray:0}}
