*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;width:100%;height:100%;overflow:hidden;font-family:system-ui,-apple-system,sans-serif;user-select:none;-webkit-user-select:none}input,textarea{user-select:text;-webkit-user-select:text}.projects-page{display:flex;flex-direction:column;width:100%;height:100%;overflow:auto;background:#f3f4f6}.projects-page__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 32px;background:#fff;border-bottom:1px solid #e5e7eb}.projects-page__title{margin:0;font-size:1.5rem;font-weight:700;color:#111827}.projects-page__add{padding:8px 16px;font-size:.875rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:6px;cursor:pointer}.projects-page__add:hover:not(:disabled){background:#1d4ed8}.projects-page__add:disabled{opacity:.6;cursor:not-allowed}.projects-page__error{margin:16px 32px 0;padding:12px 16px;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.projects-page__status{margin:32px;color:#6b7280}.projects-page__list{list-style:none;margin:24px 32px 32px;padding:0;display:flex;flex-direction:column;gap:12px}.projects-page__item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:background-color .15s ease}.projects-page__item:hover{background:#eff6ff;border-color:#bfdbfe}.projects-page__item:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.projects-page__item-main{display:flex;flex-direction:column;gap:4px;min-width:0}.projects-page__item-title{font-size:1rem;font-weight:600;color:#111827}.projects-page__item-meta{font-size:.8125rem;color:#6b7280}.projects-page__delete{flex-shrink:0;padding:6px 14px;font-size:.875rem;font-weight:600;color:#b91c1c;background:#fff;border:1px solid #fecaca;border-radius:6px;cursor:pointer}.projects-page__delete:hover:not(:disabled){background:#fef2f2}.projects-page__delete:disabled{opacity:.6;cursor:not-allowed}.editor-page{width:100%;height:100%}.editor-page--invalid{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%}.diagram-app{display:flex;flex-direction:column;width:100%;height:100%}.diagram-app--loading,.diagram-app--error{align-items:center;justify-content:center}.diagram-app__status{margin:0;color:#6b7280;font-size:1rem}.diagram-app__workspace{display:flex;flex:1;min-height:0;min-width:0}.toolbar__button--active{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.io-sidebar{display:flex;flex-direction:column;flex-shrink:0;width:min(280px,28vw);border-right:1px solid #d1d5db;background:#fff;z-index:25}.io-sidebar__header{flex-shrink:0;padding:10px 12px;border-bottom:1px solid #e5e7eb}.io-sidebar__title{margin:0;font-size:.8125rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#374151}.io-sidebar__content{flex:1;min-height:0;overflow:auto;padding:12px 14px 16px}.io-sidebar__empty{margin:0;font-size:.8125rem;line-height:1.5;color:#6b7280}.io-sidebar__element{margin-bottom:20px}.io-sidebar__element:last-child{margin-bottom:0}.io-sidebar__element-name{margin:0 0 8px;font-size:.9375rem;font-weight:700;color:#111827;line-height:1.3}.io-sidebar__divider{margin:0 0 10px;border:none;border-top:1px solid #d1d5db}.io-sidebar__group{margin-bottom:10px}.io-sidebar__group:last-child{margin-bottom:0}.io-sidebar__group-label{font-size:.6875rem;font-weight:700;letter-spacing:.06em;color:#6b7280;margin-bottom:4px}.io-sidebar__list{margin:0;padding:0 0 0 1rem;font-size:.8125rem;line-height:1.5;color:#111827}.io-sidebar__list li{margin-bottom:2px}.json-panel{display:flex;flex-direction:column;flex-shrink:0;width:min(420px,40vw);border-left:1px solid #d1d5db;background:#fff;z-index:25}.json-panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;padding:10px 12px;border-bottom:1px solid #e5e7eb}.json-panel__title{margin:0;font-size:.8125rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#374151}.json-panel__close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#374151;font-size:16px;line-height:1;cursor:pointer}.json-panel__close:hover{background:#f3f4f6;border-color:#9ca3af}.json-panel__content{flex:1;min-height:0;margin:0;padding:12px 14px 16px;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.5;color:#111827;white-space:pre;word-break:break-word;user-select:text;-webkit-user-select:text}.toolbar{display:flex;flex-direction:column;flex-shrink:0;border-bottom:1px solid #d1d5db;background:#fff;z-index:20}.toolbar__top{display:flex;align-items:center;gap:16px;padding:12px 20px 8px}.toolbar__back{flex-shrink:0;padding:6px 12px;font-size:.8125rem;font-weight:600;color:#374151;text-decoration:none;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px}.toolbar__back:hover{background:#e5e7eb}.toolbar__title{flex:1;min-width:0;margin:0;padding:4px 0;border:none;background:transparent;color:#111827;font-size:1.75rem;font-weight:700;line-height:1.2;letter-spacing:-.02em}.toolbar__title:focus{outline:none}.toolbar__title::placeholder{color:#9ca3af}.toolbar__button{flex-shrink:0;padding:8px 14px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827;font-size:.75rem;font-weight:700;letter-spacing:.04em;cursor:pointer}.toolbar__button:hover{background:#f9fafb;border-color:#9ca3af}.toolbar__elements{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;padding:10px 20px 12px;background:#e5e7eb}.toolbar__shape-btn{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827;font-size:.8125rem;cursor:pointer}.toolbar__shape-btn:hover{background:#f3f4f6;border-color:#9ca3af}.toolbar__shape-label{white-space:nowrap}.toolbar__menu-icon{flex-shrink:0;display:block;width:22px;height:18px;overflow:visible}.canvas{position:relative;flex:1;min-height:0;min-width:0;width:100%;background:linear-gradient(#e8ecf1 1px,transparent 1px),linear-gradient(90deg,#e8ecf1 1px,transparent 1px);background-size:20px 20px;background-color:#f4f6f9}.box{position:absolute;z-index:5;border:none;background:transparent;color:#1e3a8a;-webkit-user-select:none;user-select:none;touch-action:none;cursor:grab}.box__surface{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;box-sizing:border-box;border:2px solid #2563eb;border-radius:6px;background:#fff;pointer-events:none}.box__surface--stroke-dotted{border-style:dotted}.box__surface--stroke-dashed{border-style:dashed}.box__surface--stroke-double{outline:2px solid var(--element-stroke, #2563eb);outline-offset:2px}.box__label{position:absolute;top:8px;right:12px;bottom:8px;left:12px;z-index:0;display:flex;align-items:center;justify-content:center;font-weight:600;line-height:1.25;text-align:center;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;overflow:hidden;pointer-events:none}.box__label--empty{opacity:.3}.box--shape-triangle .box__label,.box--shape-triangle .connection-label__box-text-hit{inset:auto;top:calc(8px + 40%);right:12px;bottom:8px;left:12px}.box--selected{z-index:6}.box--selected .box__surface--rect,.box--selected .box__surface-svg{filter:drop-shadow(0 0 0 1px rgba(37,99,235,.35))}.box--dragging{z-index:7;cursor:grabbing}.box--dragging .box__surface--rect,.box--dragging .box__surface-svg{opacity:.75;filter:drop-shadow(0 8px 24px rgba(37,99,235,.25))}.box__surface-svg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;display:block;width:100%;height:100%;overflow:visible;pointer-events:none;border:none;background:transparent}.box__cloud-bounds{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;box-sizing:border-box;padding:5px;overflow:hidden;pointer-events:none}.box__surface-svg--cloud{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.box--shape-hexagon .connection-bubble--n{top:-11px}.box--shape-hexagon .connection-bubble--s{bottom:-11px}.box--shape-hexagon .connection-bubble--e{right:-11px}.box--shape-hexagon .connection-bubble--w{left:-11px}.box__side-actions{position:absolute;left:calc(100% + 20px);top:3px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:auto}.box__copy-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#374151;cursor:pointer;box-shadow:0 1px 4px #0000001f}.box__copy-btn:hover{background:#eff6ff;border-color:#60a5fa;color:#2563eb}.box__copy-icon{display:block}.resize-handle{position:absolute;z-index:2;width:10px;height:10px;border:2px solid #fff;border-radius:2px;background:#2563eb;touch-action:none}.resize-handle--nw{top:-5px;left:-5px}.resize-handle--n{top:-5px;left:50%;transform:translate(-50%)}.resize-handle--ne{top:-5px;right:-5px}.resize-handle--e{top:50%;right:-5px;transform:translateY(-50%)}.resize-handle--se{right:-5px;bottom:-5px}.resize-handle--s{bottom:-5px;left:50%;transform:translate(-50%)}.resize-handle--sw{bottom:-5px;left:-5px}.resize-handle--w{top:50%;left:-5px;transform:translateY(-50%)}.selection-surface{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:auto}.selection-marquee{position:absolute;z-index:15;border:1px solid #2563eb;background:#2563eb14;pointer-events:none}.connections-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.connections-layer--visual{z-index:2;pointer-events:none}.connections-layer--hits{z-index:4;pointer-events:none}.connections-hits,.connection-group{pointer-events:visibleStroke}.connections-lines{pointer-events:none}.connections-lines .connection-group{pointer-events:visibleStroke}.connections-labels{pointer-events:none}.connection-line-hit{stroke:transparent;stroke-width:16;fill:none;cursor:pointer}.connection-line{stroke:var(--connection-color, #374151);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.connection-line--arrows{stroke:transparent;stroke-width:2}.connection-line--selection-outline{stroke:#f0f;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.connection-line--selection-outline--double{stroke-width:5}.connection-line--dotted{stroke-dasharray:2 5}.connection-line--dashed{stroke-dasharray:8 5}.connection-line--double-outer{stroke-width:4}.connection-line--double-gap{stroke:#f4f6f9;stroke-width:1}.connection-line--draft{stroke-dasharray:6 4;opacity:.7}.connection-label{position:absolute;z-index:19;transform:translate(-50%,-50%);pointer-events:auto}.connection-label--on-line{max-width:160px;padding:4px 8px;border:2px solid #374151;border-radius:4px;background:#fff;color:#111827;font-size:12px;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 4px #0000001a;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.connection-label--on-line-dragging{cursor:grabbing;box-shadow:0 2px 8px #2563eb40}.connection-label--draggable{cursor:grab;touch-action:none}.connection-label--draggable .connection-label__input{cursor:text}.connection-label__input{min-width:72px;max-width:160px;padding:4px 8px;border:2px solid #374151;border-radius:4px;background:#fff;color:#111827;font-size:12px;line-height:1.2;text-align:center;box-shadow:0 1px 4px #0000001a}.connection-label__input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.connection-label__input::placeholder{color:#9ca3af}.connection-label--box-inset{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;transform:none}.connection-label__box-frame{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid rgba(37,99,235,.2);border-radius:6px;pointer-events:none}.connection-label__box-text-hit{position:absolute;top:8px;right:12px;bottom:8px;left:12px;z-index:1;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden}.connection-label__textarea--box{display:block;width:100%;min-width:0;max-width:100%;pointer-events:auto;height:auto;min-height:1.25em;padding:0;margin:0;border:none;border-radius:0;background:transparent;font:inherit;font-weight:600;line-height:1.25;text-align:center;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;resize:none;overflow-x:hidden;box-shadow:none;cursor:text;box-sizing:border-box}.connection-label__textarea--box:focus{outline:none}.connection-label__textarea--box::placeholder{color:currentColor;opacity:.3}.connection-label-foreign{overflow:visible;pointer-events:none}.connection-label-foreign .connection-label--display{width:100%;height:100%;max-width:none;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.connection-label--display{max-width:160px;padding:4px 8px;border:2px solid #374151;border-radius:4px;background:#fff;color:#111827;font-size:12px;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 4px #0000001a;pointer-events:none}.element-stroke-controls{display:flex;flex-direction:column;align-items:center;gap:4px}.box__side-actions .connection-control-color__menu{top:calc(100% + 4px);bottom:auto;left:auto;right:0;transform:none}.connection-controls{position:absolute;z-index:20;display:flex;align-items:center;gap:4px;transform:translate(-50%,-50%);pointer-events:auto}.connection-controls--above-label{transform:translate(-50%,calc(-50% - 32px))}.connection-controls__count{min-width:18px;height:24px;padding:0 6px;border:1px solid #d1d5db;border-radius:4px;background:#eff6ff;color:#1d4ed8;font-size:11px;font-weight:700;line-height:24px;text-align:center;box-shadow:0 1px 4px #0000001f}.connection-control-btn{width:24px;height:24px;padding:0;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#374151;font-size:11px;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 1px 4px #0000001f}.connection-control-btn:hover{background:#f3f4f6;border-color:#9ca3af}.connection-control-btn--delete{font-size:16px}.connection-control-btn--label,.connection-control-btn--text-color{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:Georgia,Times New Roman,serif;font-size:13px;font-weight:700}.connection-control-btn--text-color-letter{line-height:1}.connection-control-btn--text-color-bar{display:block;width:14px;height:3px;border-radius:1px}.connection-control-btn--label-on{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.connection-control-btn--delete:hover{background:#fef2f2;border-color:#f87171;color:#dc2626}.connection-control-btn--duplicate,.connection-control-btn--line-style{display:flex;align-items:center;justify-content:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.connection-control-color{position:relative;display:flex;align-items:center;height:24px}.connection-control-color__trigger{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;box-shadow:0 1px 4px #0000001f}.connection-control-color__trigger:hover{border-color:#9ca3af}.connection-control-color__swatch{display:block;width:16px;height:16px;border-radius:2px;border:1px solid rgba(15,23,42,.12)}.connection-control-color__swatch--stroke{width:14px;height:5px;border-radius:1px}.connection-control-color__menu{position:absolute;top:calc(100% + 4px);left:50%;z-index:30;display:flex;flex-direction:row;gap:4px;margin:0;padding:4px;list-style:none;border:1px solid #d1d5db;border-radius:6px;background:#fff;box-shadow:0 8px 24px #0f172a1f;transform:translate(-50%)}.connection-control-color__option{display:block;width:20px;height:20px;padding:0;border:1px solid rgba(15,23,42,.15);border-radius:3px;cursor:pointer}.connection-control-color__option:hover{transform:scale(1.08)}.connection-control-color__option--selected{outline:2px solid #2563eb;outline-offset:1px}.connection-control-btn--duplicate:hover{background:#eff6ff;border-color:#60a5fa;color:#2563eb}.connection-control-icon{display:block}.connection-bubble{position:absolute;z-index:2;width:12px;height:12px;padding:0;border:2px solid #2563eb;border-radius:50%;background:#fff;cursor:crosshair;touch-action:none;pointer-events:auto}.connection-bubble:hover,.connection-bubble--target{background:#dbeafe;border-color:#1d4ed8;transform:scale(1.15)}.connection-bubble--n{top:-16px;left:50%;transform:translate(-50%)}.connection-bubble--n:hover,.connection-bubble--n.connection-bubble--target{transform:translate(-50%) scale(1.15)}.connection-bubble--s{bottom:-16px;left:50%;transform:translate(-50%)}.connection-bubble--s:hover,.connection-bubble--s.connection-bubble--target{transform:translate(-50%) scale(1.15)}.connection-bubble--e{top:50%;right:-16px;transform:translateY(-50%)}.connection-bubble--e:hover,.connection-bubble--e.connection-bubble--target{transform:translateY(-50%) scale(1.15)}.connection-bubble--w{top:50%;left:-16px;transform:translateY(-50%)}.connection-bubble--w:hover,.connection-bubble--w.connection-bubble--target{transform:translateY(-50%) scale(1.15)}.snap-guides{position:absolute;top:0;right:0;bottom:0;left:0;overflow:visible;pointer-events:none;z-index:10}.snap-guide{position:absolute;pointer-events:none;background:#f43f5e;box-shadow:0 0 0 1px #f43f5e59}.snap-guide--vertical{top:0;bottom:0;width:2px;margin-left:-1px}.snap-guide--horizontal{left:0;right:0;height:2px;margin-top:-1px}
