html,body,#root{width:100%;height:100%;margin:0}body{overflow:hidden;background:#e9edf1;color:#172033;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}button{min-height:40px;padding:8px 11px;border:1px solid #b7c3d1;border-radius:6px;background:#fff;color:#172033;cursor:pointer;line-height:1.2;white-space:normal}button:hover{border-color:#57748f;background:#f6f8fa}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.block-node:focus-visible,.collapsed-group:focus-visible,.expanded-group:focus-visible,.expanded-edge-group:focus-visible,.edge-hit:focus-visible,.bus-group:focus-visible{outline:3px solid #f0b429;outline-offset:3px}input,textarea,select{min-width:0;border:1px solid #b7c3d1;border-radius:6px;background:#fff;color:#172033;box-sizing:border-box}input,select{min-height:40px;padding:6px 8px}textarea{width:100%;padding:8px;resize:vertical;font-size:16px;line-height:1.4}.app-shell{display:grid;grid-template-columns:340px minmax(480px,1fr) 360px;width:100%;height:100vh;overflow:hidden}.left-rail,.right-rail{overflow:auto;background:#f9fafb;border-color:#cfd8e3;box-sizing:border-box}.left-rail{border-right:1px solid #cfd8e3}.right-rail{border-left:1px solid #cfd8e3}.brand{padding:18px 16px 12px;border-bottom:1px solid #d8e0e8;background:#fff}.brand h1{margin:0;font-size:20px;line-height:1.2}.brand p{margin:5px 0 0;color:#5c6b7a;font-size:13px}.panel-section{padding:14px 16px;border-bottom:1px solid #d8e0e8}.section-label{display:block;margin:0 0 8px;color:#405266;font-size:13px;font-weight:700;letter-spacing:0;text-transform:none}.brief-input{min-height:142px;margin-bottom:10px}.draft-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.draft-options .field{margin-bottom:10px}.row{display:flex;gap:8px;align-items:center}.row>select{flex:1}.row.wrap{flex-wrap:wrap}.primary-button{border-color:#137a7f;background:#0f8b8d;color:#fff;font-weight:700}.primary-button:hover{border-color:#0b6063;background:#0b7779}.wide-button{width:100%}.chat-log{display:grid;gap:8px}.chat-message{padding:9px 10px;border-radius:7px;font-size:14px;line-height:1.4}.chat-message.assistant{border:1px solid #bdd5d5;background:#eef9f8}.chat-message.user{border:1px solid #d7c59b;background:#fff7df}.button-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.estimate{display:grid;grid-template-columns:1fr 1fr;gap:10px}.estimate div{padding:10px;border:1px solid #d5dde6;border-radius:7px;background:#fff}.estimate span{display:block;color:#5c6b7a;font-size:13px}.estimate strong{display:block;margin-top:4px;font-size:18px}.workspace-viewport{position:relative;overflow:hidden;background:linear-gradient(#dce4ec 1px,transparent 1px),linear-gradient(90deg,#dce4ec 1px,transparent 1px),#eef2f5;background-size:28px 28px;cursor:default;touch-action:none}.workspace-world{position:absolute;left:0;top:0;transform-origin:0 0}.edge-layer{position:absolute;inset:0;overflow:visible;pointer-events:none;z-index:20}.edge-hit,.bus-group{pointer-events:auto;cursor:pointer}.flow-path,.flow-line{fill:none;stroke:#334155;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;pointer-events:stroke;vector-effect:non-scaling-stroke}.flow-path.design-dependency{stroke:#64748b;stroke-dasharray:7 6;stroke-width:1.8;opacity:.78}.flow-hit-path{fill:none;stroke:transparent;stroke-width:18;stroke-linecap:round;stroke-linejoin:round;pointer-events:stroke;vector-effect:non-scaling-stroke}.flow-path.selected,.flow-line.selected{stroke:#d45b22;opacity:1;stroke-width:4}.bus-line{stroke:#0f8b8d;stroke-width:7;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:stroke;vector-effect:non-scaling-stroke}.bus-line.bundle{stroke-width:8.5}.bus-hit-line{stroke:transparent;stroke-width:26;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:stroke;vector-effect:non-scaling-stroke}.bus-hit-line.bundle{stroke-width:30}.bus-branch{fill:none;stroke:#0f8b8d;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:.88;pointer-events:none;vector-effect:non-scaling-stroke}.bus-line.selected{stroke:#d45b22;stroke-width:9}.bus-junction,.bus-port{fill:#0f8b8d;stroke:#fff;stroke-width:2;vector-effect:non-scaling-stroke}.edge-label{fill:#172033;font-size:12px;font-weight:650;pointer-events:none;text-anchor:middle;dominant-baseline:middle;paint-order:stroke;stroke:#eef2f5;stroke-width:4px;vector-effect:non-scaling-stroke}.edge-label.design-dependency{fill:#475569;font-weight:600}.bus-label{fill:#0d6266}.connect-line{stroke:#d45b22;stroke-width:2.5;stroke-dasharray:7 5;vector-effect:non-scaling-stroke}.expanded-group,.expanded-edge-group,.collapsed-group,.block-node,.marquee{position:absolute;box-sizing:border-box}.expanded-group{border:2px dashed #8191a6;border-radius:8px;background:#ffffff61;z-index:4}.expanded-edge-group{border:2px dashed #0f8b8d;border-radius:8px;background:#0f8b8d14;color:#0d6266;cursor:pointer;pointer-events:none;z-index:26}.expanded-group.selected,.expanded-edge-group.selected{border-color:#d45b22;box-shadow:0 0 0 4px #d45b221f}.expanded-group span{position:absolute;left:10px;top:7px;color:#405266;font-size:12px;font-weight:700}.expanded-edge-group span{position:absolute;left:10px;top:7px;cursor:pointer;font-size:12px;font-weight:750;pointer-events:auto}.expanded-edge-group small{position:absolute;right:10px;top:7px;cursor:pointer;font-size:11px;font-weight:650;pointer-events:auto}.group-collapse-button{position:absolute;right:8px;bottom:8px;min-width:28px;min-height:28px;padding:0;border-radius:999px;font-size:16px;font-weight:800;line-height:1;pointer-events:auto}.collapsed-group{display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed #72839a;border-radius:8px;background:#fffffff5;color:#172033;cursor:grab;z-index:42;touch-action:none}.collapsed-group.selected{border-color:#d45b22;box-shadow:0 0 0 4px #d45b2224}.collapsed-group span{margin-top:4px;color:#5c6b7a;font-size:12px}.block-node{display:flex;flex-direction:column;justify-content:center;border:1px solid #b8c4d2;border-radius:8px;background:#fff;box-shadow:0 8px 20px #17203314;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:32}.block-node.selected{border-color:#d45b22;box-shadow:0 0 0 4px #d45b2229,0 8px 20px #17203314}.node-role{position:absolute;left:10px;top:8px;max-width:calc(100% - 20px);overflow:hidden;color:#607086;font-size:11px;font-weight:700;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.node-label{padding:0 16px;overflow:hidden;font-size:16px;font-weight:750;text-align:center;text-overflow:ellipsis;white-space:nowrap}.node-component{padding:4px 16px 0;overflow:hidden;color:#5c6b7a;font-size:12px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.node-meta{position:absolute;right:9px;bottom:8px;display:flex;gap:5px}.node-meta span{padding:2px 5px;border-radius:5px;background:#edf1f5;color:#405266;font-size:11px;font-weight:700}.node-port{position:absolute;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:22px;height:22px;min-width:22px;min-height:22px;padding:0;border:2px solid #41546c;border-radius:999px;background:#fff;color:#172033;cursor:crosshair;font-size:0;line-height:0;touch-action:none;z-index:60}.node-port:before{width:8px;height:8px;flex:0 0 8px;border-radius:999px;background:#0f8b8d;content:""}.node-port.top:before{background:#d4a017}.node-port.bottom:before{background:#5b77c6}.node-port span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.marquee{border:1px solid #2f6fbb;background:#2f6fbb1f;pointer-events:none;z-index:200}.right-rail{padding:16px}.inspector h2{margin:0 0 14px;font-size:18px}.field{display:grid;gap:6px;margin-bottom:12px;color:#405266;font-size:13px;font-weight:700}.field.inline{display:flex;align-items:center;color:#172033;font-size:13px;font-weight:600}.field.full-width{grid-column:1 / -1}.part-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px;margin-bottom:14px;padding:10px;border:1px solid #d5dde6;border-radius:7px;background:#f8fafc}.part-editor .field{margin-bottom:0}.param-list,.port-list{display:grid;gap:8px;margin-bottom:10px}.param-row{display:grid;grid-template-columns:minmax(96px,.8fr) minmax(120px,1.2fr);gap:7px}.port-editor{display:grid;gap:7px;padding:9px;border:1px solid #d5dde6;border-radius:7px;background:#fff}.checkbox-row{display:flex;flex-wrap:wrap;gap:8px;color:#405266;font-size:13px}.checkbox-row label{display:flex;gap:4px;align-items:center;min-height:34px}.code-box{min-height:230px;font-family:Cascadia Code,Consolas,monospace;font-size:12px}.source-file-list{display:grid;gap:8px}.source-file{border:1px solid #d5dde6;border-radius:7px;background:#fff}.source-file summary{padding:10px 12px;color:#172033;cursor:pointer;font-size:13px;font-weight:700}.source-file .code-box{min-height:150px;border-right:0;border-bottom:0;border-left:0;border-radius:0 0 7px 7px}.muted-id{margin-top:12px;color:#5c6b7a;font-size:13px;word-break:break-all}.selection-counts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.selection-counts span{padding:10px 8px;border:1px solid #d5dde6;border-radius:7px;background:#fff;color:#405266;font-size:13px;text-align:center}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;background:#17203370;z-index:999}.modal{width:min(900px,calc(100vw - 40px));max-height:calc(100vh - 60px);padding:16px;overflow:auto;border-radius:8px;background:#fff;box-shadow:0 22px 70px #1720334d}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.modal-header h2{margin:0;font-size:18px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}@media (max-width: 1120px){.app-shell{grid-template-rows:minmax(0,1fr) minmax(250px,34vh);grid-template-columns:300px minmax(420px,1fr)}.right-rail{grid-column:1 / -1;border-top:1px solid #cfd8e3;border-left:0}}@media (max-width: 760px){body{overflow:auto}.app-shell{height:auto;min-height:100vh;overflow:visible;grid-template-rows:auto minmax(420px,56vh) auto;grid-template-columns:1fr}.left-rail{max-height:none;border-right:0;border-bottom:1px solid #cfd8e3}.workspace-viewport{min-height:420px}.right-rail{grid-column:auto;max-height:none;border-top:1px solid #cfd8e3}.row{align-items:stretch;flex-direction:column}.button-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (prefers-reduced-motion: reduce){button:active{transform:none}}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:#f8fafc;color:#0f172a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.h-screen{display:flex;flex-direction:column;height:100vh}header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff;border-bottom:1px solid #e6eef6;box-shadow:0 0 #0000}header h1{margin:0;font-size:18px}.h-screen>header+div{display:flex;flex:1;overflow:hidden}.h-screen>header+div>aside:first-child{width:300px;min-width:240px;max-width:360px;background:#fff;border-right:1px solid #e6eef6;padding:12px;box-sizing:border-box;overflow:auto}main{flex:1;position:relative;overflow:auto;min-height:0}.h-screen>header+div>aside:last-child{width:360px;min-width:280px;background:#fff;border-left:1px solid #e6eef6;padding:12px;box-sizing:border-box;overflow:auto}footer{padding:8px 12px;font-size:12px;background:#fff;border-top:1px solid #e6eef6}.absolute{position:absolute}.rounded{border-radius:8px}.shadow-sm{box-shadow:0 1px 2px #0206170f}.border{border:1px solid #e6eef6}.bg-white{background:#fff}.bg-slate-50{background:#f8fafc}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.text-sm{font-size:13px}.text-xs{font-size:12px;color:#475569}button{cursor:pointer;border-radius:6px;border:1px solid #cbd5e1;background:#f8fafc;padding:6px 10px;font-size:13px}button:active{transform:translateY(1px)}.motion-div,.node-card{box-sizing:border-box}.absolute[style]{position:absolute!important;box-sizing:border-box}main svg{width:100%;height:100%;position:absolute;inset:0;pointer-events:none}textarea,input[type=text],input[type=number]{font-size:13px;padding:6px 8px;border:1px solid #e6eef6;border-radius:6px;width:100%;box-sizing:border-box}aside .grid{display:grid;gap:8px}aside .flex{display:flex;gap:8px;align-items:center}@media (max-width: 900px){.h-screen>header+div>aside:first-child,.h-screen>header+div>aside:last-child{display:none}}
