@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
:root{--bg-primary:#fff;--bg-secondary:#f0fdf4;--bg-tertiary:#dcfce7;--border-color:#bbf7d0;--text-primary:#14532d;--text-secondary:#166534;--accent-primary:#22c55e;--accent-hover:#16a34a;--accent-text:#fff;--shadow-color:rgba(20,83,45,.1)}[data-theme=dark]{--bg-primary:#020617;--bg-secondary:#0f0a1e;--bg-tertiary:#1e1b2e;--border-color:#3b0764;--text-primary:#e9d5ff;--text-secondary:#d8b4fe;--accent-primary:#9333ea;--accent-hover:#7e22ce;--accent-text:#fff;--shadow-color:rgba(0,0,0,.5)}body{background:var(--bg-primary);color:var(--text-primary);font-family:Arial,Helvetica,sans-serif}html,body{height:100%}body{margin:0}#root,body>div:first-of-type{height:100%}.app{background:var(--bg-primary);flex-direction:column;height:100vh;display:flex;overflow:hidden}.toolbar{background:var(--bg-secondary);color:var(--text-primary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex}.toolbar .status{font-size:.95rem}.toolbar .actions{gap:.75rem;display:flex}.toolbar button{background:var(--accent-primary);color:var(--accent-text);cursor:pointer;border:none;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:transform .2s,box-shadow .2s,background .2s}.toolbar button:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.65;box-shadow:none;transform:none}.toolbar button:not(:disabled):hover{background:var(--accent-hover);box-shadow:0 4px 12px var(--shadow-color);transform:translateY(-1px)}.workspace{background:var(--bg-primary);border-top:1px solid var(--border-color);flex:1;gap:0;display:flex;position:relative;overflow:hidden}.diagram-wrapper{flex:1;min-width:0;display:flex;position:relative}.placeholder{background:var(--bg-secondary);box-shadow:0 12px 32px var(--shadow-color);color:var(--text-secondary);margin:auto;padding:1rem 1.5rem;font-size:1rem}.diagram{background:var(--bg-primary);width:100%;height:100%;box-shadow:inset 0 0 0 1px var(--border-color);cursor:grab;flex:1;min-height:0}.diagram:active{cursor:grabbing}.edge{pointer-events:visibleStroke}.edge .handle{pointer-events:all;fill:#fff;stroke:#4a5568;stroke-width:1.5px;opacity:0;transition:opacity .15s}.edge .handle.active,.edge:hover .handle,.edge:focus-within .handle{opacity:1}.edge.selected line,.edge.selected polyline{stroke:#f472b6}.edge-label{fill:#2d3748;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:13px}.edge-label-handle{pointer-events:auto;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.edge-label-handle .edge-label{pointer-events:all}.edge-label-handle-active,.edge-label-handle:active{cursor:grabbing}.edge-label-group{pointer-events:none}.edge-label-group rect,.edge-label-handle rect{filter:drop-shadow(0 6px 16px rgba(15,23,42,.18))}.node rect,.node ellipse,.node polygon,.node path,.node line{stroke-width:2px;filter:drop-shadow(0 6px 18px rgba(15,23,42,.08));transition:stroke .2s,filter .2s}.node.selected rect,.node.selected ellipse,.node.selected polygon,.node.selected path,.node.selected line{stroke:#f472b6;filter:drop-shadow(0 16px 30px rgba(236,72,153,.2))}.node:hover rect,.node:hover ellipse,.node:hover polygon,.node:hover path,.node:hover line{stroke:#38b2ac;filter:drop-shadow(0 16px 30px rgba(59,130,246,.2))}.node text{fill:var(--node-text,#1a202c);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:.95rem;font-weight:600}[data-theme=dark] .node rect,[data-theme=dark] .node ellipse,[data-theme=dark] .node polygon,[data-theme=dark] .node path,[data-theme=dark] .node line{stroke:#94a3b8}[data-theme=dark] .edge path,[data-theme=dark] .edge polygon{stroke:#94a3b8;fill:#94a3b8}[data-theme=dark] .edge text{fill:#e2e8f0}.source-panel{background:var(--bg-secondary);border-left:1px solid var(--border-color);width:380px;max-width:42%;box-shadow:inset 0 0 0 1px var(--border-color);flex-direction:column;display:flex;position:relative}.style-panel{background:var(--bg-secondary);border-right:1px solid var(--border-color);width:280px;max-width:30%;box-shadow:inset 0 0 0 1px var(--border-color);flex-direction:column;display:flex;position:relative}.style-panel .panel-header{border-bottom:1px solid var(--border-color);flex-direction:row;align-items:center;gap:.65rem;padding:.9rem 1.1rem .4rem;display:flex}.style-panel .panel-title{text-transform:none;letter-spacing:normal;color:var(--text-primary);font-size:1rem;font-weight:600}.style-panel .panel-caption{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:500;overflow:hidden}.style-panel .panel-caption span{display:inline}.style-panel .panel-body{flex-direction:column;gap:0;padding:1rem 1.1rem 1.25rem;display:flex;overflow-y:auto}.style-section{border:none;border-top:1px solid var(--border-color);background:0 0;flex-direction:column;gap:.85rem;padding:1rem 0;display:flex}.style-section:first-of-type{border-top:none}.style-section+.style-section{margin-top:.5rem}.section-heading{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.section-heading h3{letter-spacing:normal;text-transform:none;color:var(--text-primary);margin:0;font-size:.95rem}.section-caption{color:var(--text-secondary);font-size:.8rem;font-weight:600}.section-caption.muted{color:var(--text-secondary);opacity:.7;font-style:italic}.style-controls{flex-direction:column;gap:.75rem;display:flex}.style-color-row{flex-wrap:wrap;gap:.35rem;display:flex}.style-color-row .style-control{flex:none;min-width:72px;max-width:90px}.style-color-row .style-control span{text-align:left}.style-control{color:var(--text-secondary);flex-direction:column;gap:.25rem;font-size:.8rem;display:flex}.style-control span{color:var(--text-primary);font-size:.75rem;font-weight:600}.style-control input[type=color]{border:1px solid var(--border-color);background:var(--bg-primary);cursor:pointer;border-radius:.35rem;align-self:flex-start;width:2.5rem;height:2.5rem;padding:0}.style-control input[type=color]::-webkit-color-swatch-wrapper{padding:0}.style-control input[type=color]::-webkit-color-swatch{border:none}.style-control select{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);cursor:pointer;padding:.3rem .5rem;font-size:.85rem}.style-control.image-control{width:100%}.image-control-actions{flex-wrap:wrap;gap:.5rem;display:flex}.image-control-actions button{color:#1f2937;cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;padding:.4rem .75rem;font-size:.8rem;font-weight:600;transition:background .15s,transform .15s}.image-control-actions button:disabled{opacity:.55;cursor:not-allowed;transform:none}.image-control-actions button:not(:disabled):hover{background:#e2e8f0;transform:translateY(-1px)}.image-control-actions button:not(:disabled):active{transform:translateY(0)}.image-control-meta{color:var(--text-secondary);font-size:.75rem}.image-control-meta.muted{color:var(--text-secondary);opacity:.7;font-style:italic}.style-control input[type=color]:disabled,.style-control select:disabled{opacity:.6;cursor:not-allowed}.style-reset{background:var(--bg-tertiary);color:var(--accent-primary);cursor:pointer;border:none;align-self:flex-start;padding:.45rem .9rem;font-size:.85rem;font-weight:700;transition:background .15s,transform .15s}.style-reset:disabled{background:var(--bg-primary);color:var(--text-secondary);cursor:not-allowed;transform:none}.style-reset:not(:disabled):hover{background:var(--border-color);transform:translateY(-1px)}.style-reset:not(:disabled):active{transform:translateY(0)}.editor-link-actions{gap:.5rem;display:flex}.editor-link-button{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;padding:.45rem .9rem;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s,background .15s}.editor-link-button:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.editor-link-button:disabled{opacity:.6;cursor:not-allowed}.source-panel .panel-header{border-bottom:1px solid var(--border-color);flex-direction:column;gap:.35rem;padding:.9rem 1.1rem .4rem;display:flex}.source-panel .panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-size:.85rem;font-weight:700}.source-panel .panel-path{color:var(--text-primary);word-break:break-all;font-size:.9rem;font-weight:600}.source-editor{resize:none;background:var(--bg-primary);width:100%;color:var(--text-primary);border:none;border-bottom:1px solid var(--border-color);white-space:pre;overflow-wrap:normal;word-break:normal;outline:none;flex:1;padding:1rem 1.1rem;font-family:JetBrains Mono,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9rem;line-height:1.5}.source-editor:focus{box-shadow:inset 0 0 0 2px var(--border-color)}.source-panel .panel-footer{justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1.1rem 1rem;display:flex}.selection-label{color:var(--text-secondary);text-align:right;font-size:.8rem}.source-status{color:var(--text-secondary);font-size:.85rem}.source-status.saving{color:#0f766e}.source-status.error{color:#b91c1c}.source-status.pending{color:#b45309}.source-status.synced{color:#2563eb}.error{color:#822727;background:#fed7d7;border-top:1px solid rgba(185,28,28,.35);padding:.75rem 1.5rem}.context-menu{background:var(--bg-secondary);min-width:140px;color:var(--text-primary);box-shadow:0 12px 24px var(--shadow-color);z-index:20;border:1px solid var(--border-color);flex-direction:column;gap:.25rem;padding:.35rem;display:flex;position:absolute}.context-menu button{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;text-align:left;cursor:pointer;background:0 0;border:none;padding:.4rem .6rem;font-size:.85rem;transition:background .15s}.context-menu button:hover{background:var(--bg-tertiary);outline:none}.context-menu button:focus-visible{background:var(--bg-tertiary);outline:none}.context-menu-separator{background:var(--border-color);height:1px;margin:.25rem 0}.alignment-guide{stroke:var(--accent-primary);stroke-width:1.5px;stroke-dasharray:6 6;pointer-events:none}.alignment-guide-center{stroke:var(--accent-hover)}.code-panel{background:var(--bg-secondary);border-left:1px solid var(--border-color);width:500px;max-width:50%;box-shadow:inset 0 0 0 1px var(--border-color);flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.code-panel.empty{justify-content:center;align-items:center}.code-panel .panel-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:.35rem;padding:.9rem 1.1rem .4rem;display:flex}.code-panel .panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-size:.85rem;font-weight:700}.code-panel .panel-path{color:var(--text-primary);word-break:break-all;flex:1;margin-left:1rem;font-size:.9rem;font-weight:600}.code-panel .close-button{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.code-panel .close-button:hover{color:var(--text-primary)}.code-content{background:var(--bg-primary);color:var(--text-primary);flex:1;padding:1rem;overflow:auto}.code-content pre{margin:0}.code-content code{font-family:JetBrains Mono,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.85rem;line-height:1.5;display:block}.code-line{gap:1rem;width:100%;display:flex}.code-line.highlighted{background-color:var(--bg-tertiary)}.line-number{color:var(--text-secondary);-webkit-user-select:none;-moz-user-select:none;user-select:none;text-align:right;min-width:2rem}.line-text{white-space:pre-wrap;word-break:break-all}.code-line-row{width:100%}.code-line-row.highlighted{background:rgba(253,230,138,.25)}.code-line-row [class*=language-]{width:100%;display:block;background:0 0!important}.code-line-row .token{background:0 0!important}.resize-handle{transition:background .2s}.resize-handle:hover,.resize-handle:active{background:var(--accent-primary)}.zoom-controls{background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow-color);gap:.5rem;padding:.5rem;display:flex;position:absolute;bottom:1.5rem;right:1.5rem}.zoom-controls button{background:var(--bg-primary);border:1px solid var(--border-color);min-width:2.2rem;height:2.2rem;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;padding:0 .5rem;font-size:1rem;line-height:1;transition:all .2s;display:flex}.zoom-controls button:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.zoom-controls .zoom-display{min-width:4rem;font-weight:600}.collapse-button{background:var(--bg-secondary);border:1px solid var(--border-color);width:1.5rem;height:3rem;color:var(--text-secondary);cursor:pointer;z-index:20;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.collapse-button:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.collapse-button.left{border-left:none;right:-1.5rem}.collapse-button.right{border-right:none;left:-1.5rem}.collapse-button.collapsed-left{border-left:none;left:0}.collapse-button.collapsed-right{border-right:none;right:0}.panel-actions{align-items:center;gap:.5rem;display:flex}.panel-actions button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem .5rem;font-size:.85rem}.panel-actions button:hover{color:var(--text-primary);background:var(--bg-tertiary)}.panel-actions button.active{color:var(--accent-primary);background:var(--bg-tertiary);font-weight:600}
