:root{font-family:system-ui,sans-serif}body{margin:0;background:#0f172a;color:#e2e8f0}header{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;padding:1rem 1.5rem;border-bottom:1px solid #1e293b}header h1{margin:0;font-size:1.4rem}.floor-switch{display:flex;gap:.4rem}.floor-btn{background:#1e293b;color:#cbd5e1;border:1px solid #334155;border-radius:8px;padding:.35rem .8rem;cursor:pointer;font-size:.9rem}.floor-btn.active{background:#334155;border-color:#64748b;color:#fff}.legend{display:flex;gap:.9rem;flex-wrap:wrap;color:#94a3b8;font-size:.8rem}.legend-item{display:inline-flex;align-items:center;gap:.35rem}.legend-item i{width:11px;height:11px;border-radius:50%;display:inline-block}#stage{padding:1.5rem}.zoom-ctrls{display:flex;gap:.3rem;margin-left:auto}.zoom-ctrls button{width:34px;height:34px;border-radius:8px;cursor:pointer;background:#1e293b;color:#cbd5e1;border:1px solid #334155;font-size:1.1rem;line-height:1}.floor-layer{display:none;height:calc(100vh - 160px)}.floor-layer.active{display:block}.floor-svg{width:100%;height:100%}.hl-node{cursor:pointer}.hl-node:hover rect,.hl-node:hover{filter:brightness(.95)}[data-node]{cursor:pointer}.conn{transition:opacity .12s ease,stroke .12s ease,stroke-width .12s ease}.conn.lit{stroke:#93c5fd;stroke-width:2.5;opacity:1}.group-box.lit{stroke:#93c5fd;stroke-width:2.5}.reveal-line{opacity:0;pointer-events:none;transition:opacity .12s ease}.reveal-line.lit{opacity:1;stroke:#93c5fd;stroke-width:2.5}.lit .ring{stroke:#93c5fd;stroke-width:3}.gen-error{white-space:pre-wrap;color:#fca5a5;background:#2a1313;border:1px solid #7f1d1d;border-radius:8px;padding:1rem 1.25rem}#panel{position:fixed;inset:0;pointer-events:none;display:none;justify-content:flex-end}#panel.open{display:flex}#panel-inner{pointer-events:auto;width:min(420px,90vw);background:#0f172a;color:#e2e8f0;height:100%;border-left:1px solid #1e293b;padding:1.5rem;overflow-y:auto;box-shadow:-4px 0 16px #0006}#panel h2{margin-bottom:.25rem}.panel-dead{display:inline-block;margin-bottom:.4rem;padding:.15rem .5rem;border-radius:4px;background:#7f1d1d;color:#fecaca;font-size:.8rem;font-weight:600;letter-spacing:.03em}.panel-meta{display:flex;flex-wrap:wrap;gap:.25rem 1rem;color:#94a3b8;font-size:.9rem;font-family:ui-monospace,monospace}.panel-meta a{color:#38bdf8;text-decoration:none}.panel-meta a:hover{text-decoration:underline}#panel img{max-width:100%;max-height:400px;object-fit:contain;border-radius:8px;margin:.5rem 0 1rem;background:#f8fafc}#panel table{width:100%;border-collapse:collapse}#panel th{text-align:left;padding:4px 8px 4px 0;color:#94a3b8;width:40%;vertical-align:top}#panel td{padding:4px 0}#panel-close{float:right;border:0;background:none;color:#cbd5e1;font-size:1.5rem;cursor:pointer}.panel-chain{margin:1rem 0}.panel-chain svg{display:block;width:100%;max-width:300px;height:auto;margin:0 auto}.panel-chain [data-host],.panel-chain [data-url]{cursor:pointer}.panel-chain [data-host]:hover .ring,.panel-chain [data-url]:hover{filter:brightness(1.15)}.panel-btn{display:block;text-align:center;margin-top:1rem;padding:.55rem 1rem;border-radius:8px;background:#0ea5e9;color:#fff;font-weight:600;text-decoration:none}.panel-btn:hover{background:#0284c7}.panel-btn.disabled{background:#1e293b;color:#475569;cursor:not-allowed}.drill-btn:hover circle{fill:#38bdf8}.drill-btn:hover line{stroke:#0f172a}.flow-back:hover rect{stroke:#38bdf8}.flow-node{cursor:default}.hl-svc.flow-node{cursor:pointer}.editor-toolbar{display:flex;align-items:center;gap:.5rem}#edit-toggle[aria-pressed=true]{background:#0284c7;color:#fff}.edit-status{color:#94a3b8;font-size:.85rem;font-family:ui-monospace,monospace}.editing [data-edit-path]{cursor:grab}.editing [data-edit-path].is-selected .ring,.editing rect.is-selected{stroke:#f59e0b!important;stroke-width:3}.editing text.is-selected{fill:#f59e0b!important}.edit-point{fill:#38bdf8;stroke:#0f172a;stroke-width:1}.editing .edit-point.is-selected{fill:#f59e0b}.edit-handle{fill:#f59e0b;stroke:#0f172a;stroke-width:1}.editing rect[data-edit-path]{pointer-events:all}.edit-handle[data-handle=n],.edit-handle[data-handle=s]{cursor:ns-resize}.edit-handle[data-handle=e],.edit-handle[data-handle=w]{cursor:ew-resize}.edit-handle[data-handle=ne],.edit-handle[data-handle=sw]{cursor:nesw-resize}.edit-handle[data-handle=nw],.edit-handle[data-handle=se]{cursor:nwse-resize}.edit-form{position:fixed;top:64px;right:12px;width:280px;max-height:80vh;overflow:auto;background:#0f172a;border:1px solid #334155;border-radius:8px;padding:14px;display:none;z-index:50}.edit-form.open{display:block}.edit-form h2{margin:0 0 8px;font-size:1rem;color:#e2e8f0}.edit-form h3{margin:12px 0 4px;font-size:.8rem;color:#94a3b8;text-transform:uppercase;letter-spacing:1px}.edit-kind{font-size:.7rem;color:#64748b;font-weight:400}.edit-field{display:flex;flex-direction:column;gap:3px;margin:6px 0;font-size:.82rem;color:#cbd5e1}.edit-field .ef-label{color:#94a3b8}.edit-field input[type=text],.edit-field input[type=number],.edit-field select{width:100%;box-sizing:border-box;background:#1e293b;border:1px solid #475569;border-radius:4px;color:#e2e8f0;padding:4px 6px;font:inherit}.edit-field .req{color:#f59e0b}.run-chips{display:flex;flex-wrap:wrap;gap:4px}.run-chip{background:#1e293b;border:1px solid #475569;border-radius:4px;color:#cbd5e1;padding:3px 8px;font-size:.78rem;cursor:pointer}.run-chip:hover{border-color:#38bdf8}.add-menu{display:none;background:#1e293b;border:1px solid #475569;border-radius:4px;color:#e2e8f0;padding:4px 6px;font:inherit}body.editing .add-menu{display:inline-block}.edit-del{float:right;background:transparent;border:none;color:#f87171;cursor:pointer;font-size:.9rem;line-height:1}.edit-del:hover{color:#ef4444}.child-add{display:flex;gap:6px;margin-top:10px}.add-btn{background:#1e293b;border:1px dashed #475569;border-radius:4px;color:#94a3b8;padding:3px 8px;font-size:.78rem;cursor:pointer}.add-btn:hover{border-color:#38bdf8;color:#cbd5e1}
