.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{--page-bg: #f8fafc;--panel-bg: #ffffff;--panel-border: #e2e8f0;--panel-ink: #0f172a;--panel-soft: #64748b;--canvas-bg: #fafafa;--canvas-border: #e2e8f0;--canvas-grid: #f1f5f9;--edge: #cbd5e1;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--interactive-bg: #f1f5f9;--interactive-hover: #e2e8f0;--pill-bg: #ffffff;--pill-border: #e2e8f0;--icon-bg: #ffffff;--icon-border: #e2e8f0;--primary: #3b82f6;--ring: rgba(59, 130, 246, .2);--input-bg: #fbfcfe;--input-border: #c6d1e4;--btn-bg: #f7faff;--btn-border: #aec2e7;--btn-ink: #24468f;--btn-hover: #edf3fd;--node-fallback-bg: #f8fafc;--canvas-area-bg: #fafafa;--canvas-gradient: none;--edge-color: #94a3b8;--edge-selected: #3b82f6;--edge-text: #64748b;--header-text: #1e293b;--overlay-bg: #ffffff;--overlay-border: #e2e8f0;--overlay-text: #475569;--overlay-shadow: 0 1px 2px rgba(0,0,0,.05);--node-text: #1e293b;--node-caption: #64748b;--handle-bg: #cbd5e1;--node-fallback-border: #e2e8f0;--group-default-border: rgba(148, 163, 184, .5);--group-default-bg: rgba(241, 245, 249, .6);--group-label-bg: #ffffff;--group-label-color: #334155;--group-shadow: inset 0 0 0 1px rgba(0, 0, 0, .04)}[data-theme=dark]{--page-bg: #0b1120;--panel-bg: #1e293b;--panel-border: #334155;--panel-ink: #f8fafc;--panel-soft: #94a3b8;--canvas-bg: #0f172a;--canvas-border: #334155;--canvas-grid: #1e293b;--edge: #475569;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .3);--interactive-bg: #334155;--interactive-hover: #475569;--pill-bg: #1e293b;--pill-border: #334155;--icon-bg: #1e293b;--icon-border: #334155;--primary: #60a5fa;--ring: rgba(96, 165, 250, .3);--input-bg: #0f172a;--input-border: #334155;--btn-bg: #334155;--btn-border: #475569;--btn-ink: #f8fafc;--btn-hover: #475569;--node-fallback-bg: #1e293b;--canvas-area-bg: #141414;--canvas-gradient: radial-gradient(circle at top right, rgba(103, 86, 55, .1), transparent 28%), linear-gradient(180deg, #171717 0%, #121212 100%);--edge-color: #f8fafc;--edge-selected: #fbbf24;--edge-text: #e5e7eb;--header-text: #f8fafc;--overlay-bg: rgba(17, 17, 17, .95);--overlay-border: rgba(196, 154, 80, .35);--overlay-text: #e5e7eb;--overlay-shadow: 0 1px 3px rgba(0,0,0,.3);--node-text: #f8fafc;--node-caption: #a1a1aa;--handle-bg: #f8fafc;--node-fallback-bg: rgba(255, 255, 255, .06);--node-fallback-border: rgba(255, 255, 255, .14);--group-default-border: rgba(196, 154, 80, .72);--group-default-bg: rgba(66, 54, 33, .3);--group-label-bg: rgba(17, 17, 17, .96);--group-label-color: #f8fafc;--group-shadow: inset 0 0 0 1px rgba(255, 255, 255, .04)}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;font-family:Inter,Avenir Next,Segoe UI,sans-serif;color:var(--panel-ink);background:var(--page-bg)}input,textarea,button,select{font:inherit}.app-shell{display:flex;width:100vw;height:100vh;overflow:hidden;background:var(--page-bg);padding:16px;gap:16px}.panel{position:relative;z-index:10;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;box-shadow:0 4px 8px -2px #0000000d,0 12px 24px -6px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column}.panel.left{width:320px;min-width:320px;flex-shrink:0;padding:24px 20px}.panel.left.collapsed{width:64px;min-width:64px;padding:16px 8px;display:flex;flex-direction:column;align-items:center;overflow:visible}.panel.right{width:320px;min-width:320px;flex-shrink:0;padding:24px 20px;transform:translate(0);opacity:1}.app-shell.right-hidden .panel.right{display:none}.panel-toggle{width:32px;height:32px;border-radius:8px;background:transparent;color:var(--panel-soft);display:flex;justify-content:center;align-items:center;cursor:pointer;font-size:14px;margin-bottom:24px;align-self:flex-end;border:none;flex-shrink:0;transition:background .2s}.panel-toggle:hover{background:var(--interactive-bg)}.panel.left.collapsed .panel-toggle{align-self:center;margin-bottom:24px}.tool-section{display:flex;flex-direction:column;gap:4px;margin-bottom:20px}.tool-section-title{font-size:11px;font-weight:700;color:var(--panel-soft);text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px 4px}.panel.left.collapsed .tool-section-title{display:none}.panel.left.collapsed .tool-section{align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--panel-border);width:100%}.panel.left.collapsed .tool-section:last-child{border-bottom:none;padding-bottom:0}.button-grid{display:flex;flex-direction:column;gap:8px;width:100%}.panel.left.collapsed .button-grid{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:0}.panel.left.collapsed .button-grid button{width:40px;height:40px;padding:0;display:flex;justify-content:center;align-items:center;border:none;background:transparent;font-size:18px;border-radius:8px;box-shadow:none;margin:0 auto}.panel.left.collapsed .button-grid button:hover{background:var(--interactive-bg)}.panel.left.collapsed .button-grid button svg{width:20px;height:20px;stroke:var(--panel-soft);stroke-width:2}.panel.left.collapsed .button-grid button:hover svg{stroke:var(--panel-ink)}.panel.left.collapsed .button-grid button{position:relative}.panel.left.collapsed .button-grid button:after{content:attr(data-title);position:absolute;left:100%;margin-left:8px;padding:6px 10px;background:var(--panel-ink);color:var(--page-bg);border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap;opacity:0;pointer-events:none;transform:translate(-5px);transition:all .2s ease;z-index:100}.panel.left.collapsed .button-grid button:hover:after{opacity:1;transform:translate(0)}.canvas-area{flex:1;position:relative;display:flex;z-index:1;background:var(--canvas-area-bg);border:1px solid var(--canvas-border);border-radius:12px;overflow:hidden}.diagram-export-surface{width:100%;height:100%;min-height:0}.diagram-export-surface .react-flow{width:100%;height:100%}.canvas-area .react-flow{background:var(--canvas-gradient)}.panel-hero{margin-bottom:12px}.eyebrow{margin:0 0 6px;font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:#7183a4}h1,h2{margin:0;font-weight:800;letter-spacing:-.03em}h1{font-size:1.92rem;color:var(--panel-ink)}h2{font-size:1rem;color:var(--panel-ink)}.field-label{display:block;margin:14px 0 6px;color:#566b92;font-size:12px;font-weight:700}input,textarea,.field-select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--panel-ink);outline:none;transition:border-color .2s,box-shadow .2s}input:focus,textarea:focus,.field-select:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}input[type=color]{min-width:44px;padding:4px;border-radius:10px}textarea{min-height:150px;resize:vertical}.button-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}.button-grid.small{grid-template-columns:1fr;gap:10px}button{padding:14px;border-radius:12px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-ink);font-size:.98rem;font-weight:800;cursor:pointer;transition:background .2s}button:hover{background:var(--btn-hover)}button:disabled{opacity:.58;cursor:not-allowed}.status{margin-top:18px;color:var(--panel-soft);font-size:13px}.canvas-header{position:absolute;top:24px;left:24px;right:24px;z-index:5;display:flex;gap:16px;align-items:flex-start;pointer-events:none}.canvas-header>*{pointer-events:auto}.canvas-header h2,.canvas-header .eyebrow{color:var(--header-text)}.canvas-pill{padding:8px 14px;border-radius:999px;border:1px solid var(--overlay-border);background:var(--overlay-bg);color:var(--overlay-text);font-size:12px;font-weight:700;box-shadow:var(--overlay-shadow)}.diagram-minimap{border-radius:12px;border:1px solid var(--overlay-border);background:var(--overlay-bg)}.empty-state{padding:18px;border-radius:22px;background:#eef3fb;border:1px solid #c7d3e6}.empty-state p{margin:0 0 8px;font-weight:800}.empty-state span{color:var(--panel-soft);line-height:1.45}.icon-results{display:grid;gap:8px;margin-top:12px}.icon-option{display:flex;justify-content:space-between;align-items:center;gap:10px;text-align:left}.icon-option small{color:var(--panel-soft)}.inspector-section{display:flex;flex-direction:column;gap:10px}.inspector-section--divided{margin-top:16px;padding-top:14px;border-top:1px solid var(--panel-border)}.inspector-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.inspector-actions{display:flex;align-items:center;gap:12px}.property-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.property-field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;color:var(--panel-soft)}.property-field--inline{flex-direction:row;justify-content:space-between;align-items:center}.text-button{padding:0;border:none;background:transparent;color:var(--primary);font-size:12px;font-weight:700;cursor:pointer}.text-button:hover{background:transparent;color:var(--btn-ink)}.inspector-note,.inspector-caption{display:flex;flex-direction:column;gap:4px;margin-top:10px;font-size:12px;line-height:1.45;color:var(--panel-soft)}.inspector-note strong{color:var(--panel-ink)}.react-flow__controls{border:1px solid var(--overlay-border);border-radius:12px;overflow:hidden;background:var(--overlay-bg);box-shadow:var(--overlay-shadow)}.react-flow__controls-button{background:transparent;border-bottom:1px solid var(--overlay-border)}.react-flow__controls-button svg{fill:var(--overlay-text)}.react-flow__attribution{display:none}.react-flow__edge-path{stroke-linecap:round;stroke-linejoin:round}.react-flow__node-group{background:transparent;border:none}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--edge-selected);stroke-width:2.8}.board-edge__control-point{border-radius:999px;background:color-mix(in srgb,var(--panel-bg) 86%,transparent);border:1px solid color-mix(in srgb,var(--edge-selected) 72%,var(--panel-border));box-shadow:0 4px 10px #0f172a1f;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.board-edge__control-point:hover{background:color-mix(in srgb,var(--edge-selected) 22%,var(--panel-bg));box-shadow:0 0 0 5px color-mix(in srgb,var(--edge-selected) 14%,transparent)}.board-edge__control-point--curve{width:18px;height:18px;background:var(--edge-selected);border-color:var(--panel-bg)}.board-edge__control-point--corner{width:14px;height:14px}.react-flow__node-architecture,.react-flow__node-group{background:transparent!important;border:none!important;box-shadow:none!important}.arch-node{position:relative;width:100%;height:100%;min-width:84px;min-height:132px;border:none;background:transparent;color:var(--node-text);box-shadow:none}.arch-node__block{position:relative;width:100%;height:100%;min-width:84px;min-height:132px;display:flex;flex-direction:column;align-items:center;overflow:hidden}.arch-node__icon{display:grid;place-items:center;width:72px;height:72px;margin:0 auto;background:transparent;border:none;box-shadow:none}.arch-node__icon svg,.icon-glyph__image{width:50px;height:50px;object-fit:contain}.icon-glyph__fallback{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--node-fallback-bg);border:1px solid var(--node-fallback-border);color:var(--node-text);font-size:12px;font-weight:700}.arch-node__copy{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;padding-top:4px;flex:1}.arch-node__label{font-size:14px;font-weight:500;text-align:center;white-space:pre-line;word-break:break-word;line-height:1.2;max-width:180px;color:var(--node-text);cursor:text;text-shadow:0 1px 2px rgba(0,0,0,.15)}.arch-node__caption{font-size:11px;color:var(--node-caption);font-weight:500;text-transform:capitalize;text-align:center;max-width:160px}.arch-node__description{font-size:10px;color:var(--node-caption);background:var(--interactive-bg);padding:4px 6px;border-radius:6px;margin-top:6px;text-align:center;width:90%;white-space:pre-wrap;word-break:break-word;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.arch-node__input{width:120px;padding:4px 6px;border-radius:8px;border:1px solid var(--primary);background:var(--panel-bg);color:var(--panel-ink);font-size:13px;font-weight:600;text-align:center;outline:none}.arch-node--selected{outline:none;box-shadow:none}.arch-node--selected .arch-node__icon{transform:scale(1.03)}.arch-handle{width:28px;height:28px;background:transparent;border:none;opacity:0;transition:opacity .2s;border-radius:999px}.arch-handle:after{content:"";position:absolute;top:50%;left:50%;width:10px;height:10px;transform:translate(-50%,-50%);border-radius:999px;background:var(--handle-bg);box-shadow:0 0 0 8px color-mix(in srgb,var(--primary) 16%,transparent)}.arch-handle--left{left:-14px}.arch-handle--right{right:-14px}.arch-handle--top{top:-14px}.arch-handle--bottom{bottom:-14px}.arch-node:hover .arch-handle,.arch-node--selected .arch-handle{opacity:1}.diagram-group{position:relative;width:100%;height:100%;border-radius:18px;border:1.5px solid var(--group-default-border);background:var(--group-default-bg);box-shadow:var(--group-shadow)}.diagram-group--runtime,.diagram-group--runtime-core{--group-default-border: rgba(86, 149, 255, .78);--group-default-bg: rgba(25, 41, 72, .24)}.diagram-group--safety{--group-default-border: rgba(198, 88, 78, .82);--group-default-bg: rgba(88, 29, 27, .14)}.diagram-group--ai{--group-default-border: rgba(196, 154, 80, .84);--group-default-bg: rgba(66, 54, 33, .2)}.diagram-group--storage{--group-default-border: rgba(196, 154, 80, .84);--group-default-bg: rgba(59, 47, 28, .2)}.diagram-group--client,.diagram-group--auth,.diagram-group--ci,.diagram-group--observability{--group-default-border: rgba(196, 154, 80, .68);--group-default-bg: rgba(52, 45, 32, .2)}.diagram-group__label{position:absolute;top:12px;left:14px;display:inline-flex;align-items:center;max-width:calc(100% - 28px);padding:5px 10px;border-radius:10px;border:1px solid var(--group-default-border);background:var(--group-label-bg);color:var(--group-label-color);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;line-height:1.25}@media(max-width:1280px){.app-shell{grid-template-columns:300px 1fr;grid-template-rows:1fr 260px}.panel.right{grid-column:1 / -1}}@media(max-width:860px){.app-shell{display:flex;flex-direction:column;height:auto;min-height:100%}.canvas-area{height:60vh}}.app-shell{--shell-gap: 12px;--rail-width: 64px;--drawer-width: 252px;position:relative;gap:var(--shell-gap);padding:var(--shell-gap)}.panel{border-radius:16px;box-shadow:0 10px 28px -18px #00000073}.left-rail{width:var(--rail-width);min-width:var(--rail-width);padding:10px 8px;flex-shrink:0;align-items:center;gap:10px;overflow:visible}.left-drawer{position:absolute;top:var(--shell-gap);bottom:var(--shell-gap);left:calc(var(--shell-gap) + var(--rail-width) + 8px);width:min(var(--drawer-width),calc(100vw - 128px));padding:18px 16px 14px;z-index:24}.left-drawer__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.left-drawer__body{flex:1;min-height:0;overflow-y:auto;padding-right:2px}.tool-rail{display:flex;flex:1;flex-direction:column;align-items:center;gap:12px;width:100%}.tool-rail-section,.tool-rail-footer{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.tool-rail-section{padding-bottom:10px;border-bottom:1px solid var(--panel-border)}.tool-rail-section:last-of-type{border-bottom:none;padding-bottom:0}.tool-rail-footer{padding-top:2px}.tool-rail-button,.rail-toggle,.drawer-close{position:relative;width:40px;min-width:40px;height:40px;min-height:40px;padding:0;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;color:var(--panel-soft);box-shadow:none}.rail-toggle,.drawer-close{background:var(--interactive-bg);border-color:var(--panel-border);color:var(--panel-ink)}.tool-rail-button svg,.rail-toggle svg,.drawer-close svg{width:18px;height:18px;stroke-width:2}.tool-rail-button:hover,.rail-toggle:hover,.drawer-close:hover{background:var(--interactive-bg);color:var(--panel-ink)}.tool-rail-button:after,.rail-toggle:after{content:attr(data-title);position:absolute;left:calc(100% + 10px);top:50%;transform:translate(-4px,-50%);opacity:0;pointer-events:none;white-space:nowrap;padding:6px 10px;border-radius:8px;background:var(--panel-ink);color:var(--page-bg);font-size:11px;font-weight:700;transition:opacity .16s ease,transform .16s ease;z-index:40}.tool-rail-button:hover:after,.tool-rail-button:focus-visible:after,.rail-toggle:hover:after,.rail-toggle:focus-visible:after{opacity:1;transform:translateY(-50%)}.panel-hero{margin-bottom:0}.panel-hero .eyebrow{margin-bottom:4px}h1{font-size:1.48rem}h2{font-size:.96rem}.field-label{margin:10px 0 5px;font-size:11px}input,textarea,.field-select{padding:10px 12px;border-radius:10px}textarea{min-height:120px}.left-drawer textarea{min-height:88px}.button-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}.button-grid.button-grid--stacked,.button-grid.small{grid-template-columns:1fr}button{min-height:40px;padding:10px 12px;border-radius:10px;font-size:.9rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}button:focus-visible,input:focus-visible,textarea:focus-visible,.field-select:focus-visible,.tool-rail-button:focus-visible,.rail-toggle:focus-visible,.drawer-close:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.tool-section{gap:6px;margin-bottom:16px}.tool-section-title{margin:0 0 4px;font-size:10px}.status{margin-top:12px;font-size:12px}.canvas-area{min-width:0}.canvas-header{top:18px;left:18px;right:18px;gap:12px;align-items:center;justify-content:space-between}.canvas-header__main{min-width:0}.canvas-header__main h2{font-size:.98rem;line-height:1.15}.canvas-header__actions{display:inline-flex;align-items:center;gap:8px;margin-left:auto}.canvas-pill{padding:7px 12px;font-size:11px}.canvas-chip-button{min-height:34px;padding:8px 12px;border-radius:999px;background:var(--pill-bg);border:1px solid var(--pill-border);color:var(--panel-soft);font-size:12px;font-weight:700;box-shadow:var(--overlay-shadow)}.inspector-panel{width:clamp(280px,22vw,296px);min-width:280px;padding:18px 16px}.inspector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.inspector-header h2{margin:0}.inspector-section--divided{margin-top:14px;padding-top:12px}.property-grid{gap:8px}.property-field{gap:5px;font-size:11px}.inspector-note,.inspector-caption{margin-top:8px;font-size:11px}.empty-state{padding:14px;border-radius:16px}.code-panel{display:flex;flex-direction:column;height:calc(100% - 12px);gap:10px}.code-panel__eyebrow{margin-top:0}.code-panel__editor{flex:1;min-height:320px;font-family:Fira Code,monospace;font-size:11px;resize:none}.diagram-minimap,.react-flow__controls{border-radius:10px}@media(max-width:1280px){.app-shell{--shell-gap: 10px}.inspector-panel{position:absolute;top:var(--shell-gap);right:var(--shell-gap);bottom:var(--shell-gap);width:min(296px,calc(100vw - 108px));min-width:0;z-index:22}}@media(max-width:980px){.app-shell{--rail-width: 56px}.left-drawer{width:min(248px,calc(100vw - 96px))}.canvas-header{align-items:flex-start;flex-wrap:wrap}.canvas-header__actions{margin-left:0}}@media(max-width:860px){.app-shell{display:flex;flex-direction:row;height:100vh;min-height:100vh;padding:8px;gap:8px}.left-drawer,.inspector-panel{top:8px;bottom:8px}.left-drawer{left:calc(8px + var(--rail-width) + 8px);width:min(240px,calc(100vw - 88px))}.inspector-panel{right:8px;width:min(288px,calc(100vw - 88px))}.canvas-area{height:100%}}
