:root,[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-deep:#0c0e16;--bg-panel:#131825;--bg-card:#1a2236;--bg-input:#0f1524;--bg-canvas:#0a0d14;--bg-integration:#1a2838;--accent-primary:#6ee7d7;--accent-secondary:#e9b4f8;--accent-tertiary:#b4a7f8;--text-primary:#e8edf7;--text-muted:#94a3b8;--border-soft:#2d3a55;--btn-bg:#1e2a42;--btn-hover:#243352;--btn-primary-bg:#1a3d38;--arrow-inherit:#6ee7d7;--arrow-implement:#b4a7f8;--arrow-use:#94a3b8;--glow:0 0 18px 2px #6ee7d740;--radius:12px;--font:"Segoe UI", Inter, system-ui, sans-serif}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg-deep:#f4f6fb;--bg-panel:#fff;--bg-card:#f8fafc;--bg-input:#fff;--bg-canvas:#eef2f8;--bg-integration:#f0f4ff;--accent-primary:#0d9488;--accent-secondary:#9333ea;--accent-tertiary:#6366f1;--text-primary:#1e293b;--text-muted:#64748b;--border-soft:#cbd5e1;--btn-bg:#f1f5f9;--btn-hover:#e2e8f0;--btn-primary-bg:#ccfbf1;--arrow-inherit:#0d9488;--arrow-implement:#6366f1;--arrow-use:#64748b;--glow:0 2px 12px #00000014}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg-deep);color:var(--text-primary);overflow:hidden}button,input,select,textarea{font:inherit;color:var(--text-primary)}select,.input-control{background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-soft);cursor:pointer;appearance:auto;border-radius:8px;padding:6px 10px}select:focus,.input-control:focus{outline:2px solid var(--accent-primary);outline-offset:1px}select option{background-color:var(--bg-panel);color:var(--text-primary)}.app-shell{grid-template-rows:auto 1fr auto;height:100%;display:grid}.app-header{background:var(--bg-panel);border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;padding:10px 16px;display:flex}.app-header h1{background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.1rem;font-weight:700}.app-header .tagline{color:var(--text-muted);font-size:.8rem}.app-main{grid-template-columns:minmax(200px,240px) 1fr minmax(260px,320px);min-height:0;display:grid;overflow:hidden}.panel{background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:var(--radius);padding:12px;overflow:auto}.panel-left{flex-direction:column;gap:10px;margin:8px 0 8px 8px;display:flex}.panel-right{flex-direction:column;min-height:0;margin:8px 8px 8px 0;display:flex}.canvas-wrap{border-radius:var(--radius);border:1px solid var(--border-soft);background:var(--bg-canvas);cursor:grab;flex:1;min-height:0;margin:8px 0;position:relative;overflow:hidden}.canvas-wrap.panning{cursor:grabbing}.canvas-controls{background:var(--bg-panel);border:1px solid var(--border-soft);box-shadow:var(--glow);z-index:10;border-radius:10px;align-items:center;gap:6px;padding:6px 8px;display:flex;position:absolute;bottom:12px;right:12px}.canvas-controls .zoom-label{color:var(--text-primary);text-align:center;min-width:42px;font-size:.8rem}.app-main>.canvas-wrap{flex-direction:column;min-height:0;display:flex}.diagram-svg{touch-action:none;width:100%;height:100%;display:block}.status-bar{color:var(--text-muted);background:var(--bg-panel);border-top:1px solid var(--border-soft);padding:6px 16px;font-size:.8rem}.btn{border:1px solid var(--border-soft);background:var(--btn-bg);cursor:pointer;border-radius:8px;padding:6px 12px;transition:background .15s}.btn:hover{background:var(--btn-hover)}.btn-primary{background:var(--btn-primary-bg);border-color:var(--accent-primary);color:var(--accent-primary)}.btn-compact{padding:4px 8px;font-size:.8rem}a.btn{color:inherit;align-items:center;text-decoration:none;display:inline-flex}.field{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.field label{color:var(--text-muted);font-size:.75rem}.field input,.field select,.field textarea{background:var(--bg-input);border:1px solid var(--border-soft);border-radius:8px;padding:6px 8px}.section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent-primary);margin:8px 0 4px;font-size:.75rem}.tabs{gap:4px;margin-bottom:8px;display:flex}.tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:6px}.tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.code-preview{background:var(--bg-input);border:1px solid var(--border-soft);white-space:pre;border-radius:8px;flex:1;min-height:0;padding:10px;font-family:Cascadia Code,Consolas,monospace;font-size:.75rem;line-height:1.45;overflow:auto}.pattern-desc{color:var(--text-muted);max-height:72px;font-size:.78rem;overflow:auto}.relation-picker{z-index:100;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:var(--radius);box-shadow:var(--glow);min-width:180px;padding:8px;position:absolute}.relation-picker button{text-align:left;width:100%;margin:2px 0;display:block}.modal-backdrop{z-index:100;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:var(--radius);width:90%;max-width:520px;max-height:80vh;padding:20px;overflow:auto}.modal h2{margin-top:0}.help-content p{margin:.5em 0;font-size:.9rem;line-height:1.5}.inspector-scroll{flex:1;min-height:0;padding-right:4px;overflow:auto}.flags-row{flex-wrap:wrap;gap:8px;flex-direction:row!important}.member-block{border:1px solid var(--border-soft);border-radius:8px;margin-bottom:8px;padding:0 8px 8px}.member-summary{cursor:pointer;align-items:center;gap:8px;padding:8px 0;list-style:none;display:flex}.member-summary::-webkit-details-marker{display:none}.member-kind-badge{text-transform:uppercase;color:var(--accent-primary);background:var(--btn-bg);border-radius:4px;padding:2px 6px;font-size:.65rem}.member-fields{flex-direction:column;gap:6px;display:flex}.field-row{grid-template-columns:72px 1fr;align-items:center;gap:6px;display:grid}.field-row label{color:var(--text-muted);font-size:.7rem}.member-flags{flex-wrap:wrap;gap:10px;font-size:.75rem;display:flex}.param-row{grid-template-columns:1fr 1fr .8fr auto;gap:4px;margin-bottom:4px;display:grid}.member-actions{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.btn-icon{min-width:28px;margin-left:auto}.nav-list{max-height:160px;margin:0;padding:0;list-style:none;overflow:auto}.nav-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:.8rem;display:flex}.nav-item:hover{background:var(--btn-hover)}.nav-icon{border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:inline-flex}.nav-icon.class{background:var(--btn-primary-bg);color:var(--accent-primary)}.nav-icon.service{color:var(--accent-tertiary);background:#b4a7f833}.snap-toggle{color:var(--text-muted);align-items:center;gap:8px;font-size:.75rem;display:flex}.btn-row{flex-wrap:wrap;gap:4px;display:flex}.app-header{flex-wrap:wrap}@media (width<=1100px){.app-main{grid-template-columns:200px 1fr 260px}}@media (width<=900px){.app-main{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}.panel-left,.panel-right{max-height:min(220px,35vh);margin:4px 8px}.canvas-wrap{min-height:50vh}.app-header h1{font-size:1rem}.app-header .tagline{display:none}}@media (width<=520px){.app-header input.input-control{max-width:120px!important}}.class-card-hit,.integration-card .class-card-hit,.class-card.is-selected .class-card-hit,.integration-card.is-selected .class-card-hit{cursor:grab}.canvas-wrap.linking,.canvas-wrap.linking .class-card-hit,.link-port{cursor:crosshair}.link-port-dot{fill:var(--accent-primary);stroke:var(--bg-canvas);stroke-width:2px;pointer-events:none;transition:r .12s}.link-port-dot--service{fill:var(--accent-tertiary)}.link-port:hover .link-port-dot{r:8;filter:drop-shadow(0 0 6px var(--accent-primary))}.link-draft-layer{pointer-events:none}.link-hint-banner{background:var(--bg-panel);border:1px solid var(--accent-primary);color:var(--accent-primary);box-shadow:var(--glow);z-index:20;pointer-events:none;white-space:nowrap;text-align:center;border-radius:10px;max-width:90%;padding:8px 14px;font-size:.78rem;position:absolute;top:12px;left:50%;transform:translate(-50%)}.context-menu{z-index:200;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:var(--radius);min-width:200px;box-shadow:var(--glow);padding:6px;position:fixed}.context-menu-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 10px;font-size:.85rem;display:block}.context-menu-item:hover:not(:disabled){background:var(--btn-hover)}.context-menu-item:disabled{opacity:.45;cursor:not-allowed}.relations path[markerEnd]{color:var(--accent-primary)}.btn-compact:disabled{opacity:.4;cursor:not-allowed}.export-menu-wrap{position:relative}.export-menu{z-index:100;background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:var(--radius);min-width:220px;padding:4px;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 8px 24px #00000059}.export-menu-item{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 10px;font-size:.82rem;display:block}.export-menu-item:hover{background:var(--btn-hover)}.export-crop-overlay{z-index:300;cursor:crosshair;-webkit-user-select:none;user-select:none;position:fixed;inset:0}.export-crop-dim{background:#0000004d;position:absolute;inset:0}.export-crop-selection{border:2px dashed var(--accent-primary);position:absolute;box-shadow:0 0 0 9999px #00000073}.export-crop-hint{background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--glow);z-index:301;align-items:center;gap:12px;padding:10px 16px;font-size:.85rem;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%)}.export-crop-esc{color:var(--text-muted);font-size:.75rem}.canvas-wrap.selecting{cursor:crosshair}.selection-marquee{border:1.5px dashed var(--accent-primary);pointer-events:none;z-index:18;background:#6ee7d71f;position:absolute;box-shadow:0 0 0 1px #6ee7d740}.selection-count-badge{z-index:18;color:var(--accent-primary);background:var(--bg-panel);border:1px solid var(--accent-primary);pointer-events:none;border-radius:8px;padding:6px 10px;font-size:.78rem;position:absolute;bottom:52px;left:12px}.smart-guides-overlay{pointer-events:none;z-index:15;width:100%;height:100%;position:absolute;inset:0}
