:root{--bg: #ebe9e3;--panel: #fcfbf8;--panelAlt: #f4f2ec;--border: rgba(30, 26, 18, .1);--borderStrong: rgba(30, 26, 18, .2);--text: #1f1c16;--textDim: #6b6760;--textFaint: #6c6962;--accent: #3a5dbe;--accentInk: #ffffff;--accentSoft: rgba(58, 93, 190, .12);--danger: #b3261e;--dangerBorder: rgba(179, 38, 30, .35);--dangerSoft: rgba(179, 38, 30, .08);--dangerHover: rgba(179, 38, 30, .12);--grid: rgba(30, 26, 18, .05);--gridStrong: rgba(30, 26, 18, .13);--fabric: #fdfcf8;--thread: #3a5dbe;--needle: #d97757;--threadOutline: #11224a;--footBody: #c9c4ba;--footStroke: #5b554a;--footSlot: #2a261f;--rulerBg: rgba(252, 251, 248, .85);--rulerCornerBg: rgba(252, 251, 248, .95);--overlay-soft: rgba(0, 0, 0, .03);--overlay: rgba(0, 0, 0, .04);--overlay-strong: rgba(0, 0, 0, .06);--space-1: 2px;--space-2: 4px;--space-3: 6px;--space-4: 8px;--space-5: 12px;--space-6: 16px;--space-7: 24px;--radius-sm: 6px;--radius-md: 10px;--radius-pill: 999px;--font-2xs: 9px;--font-xs: 10px;--font-sm: 11.5px;--font-md: 12.5px;--font-lg: 14px;--font-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--shadow-md: 0 8px 24px rgba(0, 0, 0, .2);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .25);--z-sticky: 2;--z-overlay: 3;--z-toast: 1000;--z-modal: 1100}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}[hidden]{display:none!important}.app-root{display:grid;grid-template-columns:240px 1fr 240px;height:100%;width:100%}.main{display:flex;min-width:0;height:100%}.main-single{display:flex;flex-direction:column;min-width:0;height:100%}.pane{flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.pane-full{flex:1;min-height:0}.sb-section-h,.sl-header,.ed-tlbl,.pv-meta-lbl,.ed-insp-lbl{font-size:var(--font-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim)}.app-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:transparent;color:var(--text);border-radius:var(--radius-md);font-family:inherit;font-size:12px;font-weight:500;padding:var(--space-3) var(--space-5);cursor:pointer}input[type=range]{-moz-appearance:none;appearance:none;-webkit-appearance:none;height:3px;background:#7d7d7d40;border-radius:var(--radius-pill);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:var(--panel);border:1px solid rgba(0,0,0,.2);box-shadow:var(--shadow-sm);cursor:pointer}input[type=range]::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:var(--panel);border:1px solid rgba(0,0,0,.2);cursor:pointer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--borderStrong)}.ed-canvas-wrap{flex:1;position:relative;overflow:hidden;cursor:crosshair;background:var(--bg)}.ed-canvas-wrap[data-tool=pan]{cursor:grab}.ed-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.ed-hoop{fill:var(--fabric);stroke:var(--borderStrong);stroke-width:1;rx:4}.ed-grid line.grid-fine-x,.ed-grid line.grid-fine-y{stroke:var(--grid);stroke-width:.5;stroke-opacity:.6}.ed-grid line.grid-minor-x,.ed-grid line.grid-minor-y{stroke:var(--gridStrong);stroke-width:.7}.ed-grid line.grid-major-x,.ed-grid line.grid-major-y{stroke:var(--text);stroke-width:1;stroke-opacity:.22}.ed-grid line.grid-axis-x,.ed-grid line.grid-axis-y{stroke:var(--accent);stroke-width:1;stroke-opacity:.55}.ed-bg{cursor:move}.ed-bg.ed-bg-locked{cursor:inherit}.ed-segment.kind-straight{stroke:var(--thread);stroke-width:1.6;fill:none;cursor:pointer}.ed-segment.kind-straight.selected{stroke:var(--accent);stroke-width:2.5}.ed-segment.kind-straight.last:not(.selected){stroke:var(--thread);stroke-width:2;stroke-dasharray:4 2}.ed-segment.kind-satin .satin-cone{fill:var(--thread);fill-opacity:.18;stroke:var(--thread);stroke-opacity:.4;stroke-width:.8}.ed-segment.kind-satin.selected .satin-cone{stroke:var(--accent);stroke-opacity:1;stroke-width:1.4}.ed-segment.kind-satin.last:not(.selected) .satin-cone{stroke-opacity:.7;stroke-width:1.1;stroke-dasharray:4 2}.ed-segment.kind-satin .satin-spine{stroke:var(--thread);stroke-opacity:.4;stroke-width:1;stroke-dasharray:2 2;cursor:pointer}.ed-segment.kind-satin .satin-stitch{stroke:var(--thread);stroke-opacity:.55;stroke-width:.6;stroke-linecap:round;pointer-events:none}.ed-segment.kind-satin.selected .satin-stitch{stroke:var(--accent);stroke-opacity:.85}.ed-point .start-disc{fill:var(--accent)}.ed-point .start-halo{stroke:var(--accent);stroke-opacity:.3;stroke-width:1.2;stroke-dasharray:2 2}.ed-point .point-disc{fill:var(--fabric);stroke:var(--borderStrong);stroke-width:1.5}.ed-point.selected .point-disc{stroke:var(--accent);stroke-width:2}.ed-point .point-dot{fill:var(--text);opacity:.8}.hover-crosshair .hover-line{stroke:var(--accent);stroke-opacity:.25;stroke-width:1;stroke-dasharray:2 3;pointer-events:none}.hover-crosshair .hover-target{fill:none;stroke:var(--accent);stroke-width:1.4;pointer-events:none}.hover-crosshair .hover-target-dot{fill:var(--accent);pointer-events:none}.ed-ruler-top{position:absolute;left:34px;right:0;top:0;height:22px;background:var(--rulerBg);border-bottom:1px solid var(--border);pointer-events:none;z-index:var(--z-sticky);font-size:9.5px;color:var(--textFaint)}.ed-ruler-left{position:absolute;left:0;top:22px;bottom:0;width:34px;background:var(--rulerBg);border-right:1px solid var(--border);pointer-events:none;z-index:var(--z-sticky);font-size:9.5px;color:var(--textFaint)}.ed-ruler-corner{position:absolute;left:0;top:0;width:34px;height:22px;background:var(--rulerCornerBg);border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:var(--font-2xs);font-weight:600;color:var(--textFaint);letter-spacing:.08em;text-transform:uppercase;z-index:var(--z-overlay);pointer-events:none}.ed-ruler line.axis-tick,.ed-ruler text.axis-tick{stroke:var(--accent);fill:var(--accent);font-weight:600}.ed-ruler .hover-tick line{stroke:var(--accent);stroke-width:1.2}.ed-ruler .hover-tick text{fill:var(--accent);font-weight:600}.pv-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);flex:0 0 auto;background:var(--panel);border-bottom:1px solid var(--border);font-size:12px}.pv-canvas-wrap{flex:1;position:relative;overflow:hidden;background:var(--bg)}.pv-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.pv-canvas .x-axis{stroke:var(--accent);stroke-opacity:.18;stroke-width:1;stroke-dasharray:3 4}.pv-canvas .pv-x-limit-line{stroke:var(--needle);stroke-opacity:.5;stroke-width:1;stroke-dasharray:3 3}.pv-canvas .start-halo{stroke:var(--accent);stroke-opacity:.5;stroke-width:1}.pv-canvas .needle-marker .needle-pulse{stroke:var(--needle);stroke-opacity:.4;stroke-width:1}.pv-canvas .needle-marker .needle-shaft{stroke:var(--needle);stroke-linecap:round}.pv-canvas .needle-marker .needle-tip,.pv-canvas .needle-marker .needle-dot{fill:var(--needle)}.pv-canvas .thread-outline{stroke:var(--threadOutlineColor, var(--threadOutline));fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .real-thread{stroke:var(--threadColor, var(--thread));fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .real-highlight{stroke:#ffffff8c;fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .presser-foot .foot-body{fill:var(--footBody);stroke:var(--footStroke);stroke-width:1.2;fill-opacity:.92}.pv-canvas .presser-foot .foot-slot{fill:var(--footSlot);fill-opacity:.7}.pv-empty{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center}.pv-transport{padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);flex:0 0 auto;background:var(--panel);border-top:1px solid var(--border)}.pv-tx-row{display:flex;align-items:center;gap:var(--space-4)}.pv-tx-meta{font-size:10.5px}.pv-tx-btn{width:30px;height:30px;background:var(--panelAlt);display:inline-flex;align-items:center;justify-content:center}.pv-tx-play{background:var(--accent);color:var(--accentInk);border-color:var(--accent);width:40px}.pv-tx-zoom{width:30px;margin-left:var(--space-1)}.pv-tx-row input[type=range]{flex:1;min-width:80px}.pv-tx-color{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:24px;height:22px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer}.pv-tx-color::-webkit-color-swatch-wrapper{padding:0}.pv-tx-color::-webkit-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 1px)}.pv-tx-color::-moz-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 1px)}.pv-tx-pct,.pv-tx-xy{color:var(--textDim);font-size:11px;font-variant-numeric:tabular-nums;min-width:40px;text-align:right}.sb-root{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:var(--panel);border-right:1px solid var(--border)}.sb-brand{padding:var(--space-6);border-bottom:1px solid var(--border)}.sb-brand-title{font-size:var(--font-md);font-weight:600}.sb-brand-sub{font-size:var(--font-xs);color:var(--textFaint);letter-spacing:.04em;text-transform:uppercase;margin-top:var(--space-1)}.sb-debug-link{display:flex;align-items:center;min-height:24px;padding:var(--space-2) 0;margin-top:var(--space-3);font-size:11px;color:var(--textDim);text-decoration:none}.sb-debug-link:hover{color:var(--accent)}.sb-info-link{display:flex;align-items:center;min-height:24px;margin-top:var(--space-1);padding:var(--space-2) 0;border:0;background:transparent;font:inherit;font-size:11px;color:var(--textDim);text-align:left;cursor:pointer}.sb-info-link:hover{color:var(--accent)}.sb-actions{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.sb-act-row{display:flex;gap:var(--space-3)}.sb-btn-primary{background:var(--accent);color:var(--accentInk);border-color:var(--accent);font-weight:600;width:100%;padding:var(--space-4) var(--space-5)}.sb-btn-ghost{flex:1;font-size:var(--font-sm)}.sb-section{padding:var(--space-5);border-top:1px solid var(--border)}.sb-section-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.sb-list{display:flex;flex-direction:column;gap:var(--space-1);max-height:320px;overflow-y:auto}.sb-empty{font-size:var(--font-sm);color:var(--textFaint)}.sb-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-sm);cursor:pointer;border-left:2px solid transparent;color:var(--textDim)}.sb-item:hover{background:var(--overlay)}.sb-item.active{background:var(--panelAlt);border-left-color:var(--accent);color:var(--text)}.sb-item-main{flex:1;min-width:0}.sb-item-name{font-size:var(--font-md);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-item-name-input{width:100%;font:inherit;font-size:var(--font-md);font-weight:500;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);margin:calc(-1 * var(--space-1)) calc(-1 * var(--space-2));color:inherit}.sb-item-name-input:hover{border-color:var(--border)}.sb-item-name-input:focus{outline:none;border-color:var(--accent);background:var(--panelAlt)}.sb-item-meta{font-size:10.5px;color:var(--textFaint);margin-top:var(--space-1)}.sb-item-del{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;font-size:11px;cursor:pointer;padding:var(--space-2);color:var(--textFaint)}.sb-item-del:hover{color:var(--danger)}.sb-stitch-controls,.sb-bg-controls{display:flex;flex-direction:column;gap:var(--space-4)}.sb-bg-row{display:flex;flex-direction:column;gap:var(--space-2)}.sb-bg-lbl{font-size:10.5px;color:var(--textDim)}.sb-bg-row input[type=range]{width:100%;min-height:24px}.sb-bg-row>input[type=number]{width:100%;min-height:24px;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panelAlt);font:inherit;font-size:11px;color:var(--text);box-sizing:border-box}.sb-bg-pos{display:flex;gap:var(--space-3)}.sb-bg-num{flex:1;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--panelAlt);font-size:11px}.sb-bg-num input{flex:1;border:0;background:transparent;font-family:inherit;text-align:right;outline:none;width:100%;color:var(--text)}.sb-bg-hint{font-size:10.5px;color:var(--textFaint);margin-top:var(--space-3);line-height:1.4}.sb-bg-lock{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);font-size:11px;color:var(--textDim);cursor:pointer;-webkit-user-select:none;user-select:none}.sb-preview-controls{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4) var(--space-5)}.sb-color{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:32px;height:22px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer}.sb-color::-webkit-color-swatch-wrapper{padding:0}.sb-color::-webkit-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 1px)}.sb-color::-moz-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 1px)}.sb-btn-toggle{padding:2px 10px;font-size:11px;background:var(--panelAlt)}.sb-btn-toggle[aria-pressed=true]{background:var(--accent);color:var(--accentInk);border-color:var(--accent)}.ms-bar{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:var(--space-4) var(--space-5);background:var(--bg);border-bottom:1px solid var(--border)}.ms-wrap{position:relative;display:inline-flex;padding:var(--space-1);border-radius:var(--radius-pill);background:var(--overlay);border:1px solid var(--border)}.ms-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:var(--space-2) var(--space-6);border-radius:var(--radius-pill);font-family:inherit;font-size:var(--font-sm);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-3);letter-spacing:.02em;color:var(--textDim);transition:color .15s,background .15s}.ms-btn[data-active=true]{background:var(--accent);color:var(--accentInk)}.ms-kbd{font-size:var(--font-2xs);font-weight:500;padding:1px var(--space-2);border-radius:var(--radius-sm);background:var(--overlay-strong)}.ms-btn[data-active=true] .ms-kbd{background:#fff3}.ed-toolbar{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-5);flex:0 0 auto;background:var(--panel);border-bottom:1px solid var(--border)}.ed-toolgroup{display:flex;align-items:center;gap:var(--space-3)}.ed-right{margin-left:auto}.ed-tool-btn[data-active=true],.ed-stitch-btn[data-active=true]{background:var(--accent);color:var(--accentInk);border-color:var(--accent)}.ed-zoom-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--panelAlt);color:var(--text);border-radius:var(--radius-sm);padding:var(--space-2) 0;width:28px;font-size:var(--font-xl);line-height:1;cursor:pointer}.ed-zoom-btn:hover{background:var(--panel)}.ed-zoom-btn:active{background:var(--accent);color:var(--accentInk)}.ed-toolbar select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--panelAlt);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-4);font-family:inherit;font-size:11px;cursor:pointer;outline:none}.ed-inspector{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-6);flex:0 0 auto;background:var(--panel);border-top:1px solid var(--border);font-size:var(--font-sm);min-height:40px}.ed-insp-meta,.ed-insp-row{display:flex;align-items:center;gap:var(--space-4)}.ed-insp-id{font-weight:500;font-family:ui-monospace,monospace}.ed-insp-len,.ed-insp-imported{color:var(--textFaint)}.ed-insp-imported{font-style:italic}.ed-insp-row select,.ed-insp-row input[type=range]{font-family:inherit}.ed-insp-val{font-variant-numeric:tabular-nums;font-size:11px;min-width:46px;text-align:right}.ed-insp-btn{padding:var(--space-2) var(--space-5);background:var(--panel);border-radius:var(--radius-sm)}.ed-insp-btn:hover{background:var(--overlay)}.ed-insp-btn-danger{color:var(--danger);border-color:var(--dangerBorder)}.ed-insp-btn-danger:hover{background:var(--dangerSoft)}.sl-root{display:flex;flex-direction:column;height:100%;background:var(--panel);border-left:1px solid var(--border);overflow:hidden}.sl-header{padding:var(--space-6);border-bottom:1px solid var(--border)}.sl-list{margin:0;padding:0;list-style:none;overflow-y:auto;font-family:ui-monospace,monospace;font-size:11px}.sl-list li{padding:var(--space-2) var(--space-5);border-bottom:1px solid var(--overlay);cursor:pointer;white-space:nowrap;color:var(--textDim);display:flex;align-items:center;gap:var(--space-3)}.sl-list .sl-row-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.sl-list .sl-row-delete{font:inherit;font-size:var(--font-lg);line-height:1;width:18px;height:18px;padding:0;border:none;background:transparent;color:var(--textFaint);border-radius:var(--radius-sm);cursor:pointer;opacity:0}.sl-list li:hover .sl-row-delete,.sl-list .sl-row-delete:focus-visible{opacity:1}.sl-list .sl-row-delete:hover{background:var(--dangerHover);color:var(--danger)}.sl-list li:hover{background:var(--overlay-soft)}.sl-list li.done{color:var(--accent)}.sl-list li.current{background:var(--accentSoft);color:var(--accent);font-weight:600}.sl-list li.future{color:var(--textFaint)}.sl-list li.kind-last:not(.current){border-left:3px solid var(--accent);padding-left:9px}.sl-empty{padding:var(--space-6);text-align:center;color:var(--textFaint);font-style:italic}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:var(--space-5) var(--space-6);border-radius:var(--radius-md);font-size:var(--font-md);font-weight:500;background:var(--text);color:var(--bg);box-shadow:var(--shadow-md);z-index:var(--z-toast);animation:toastIn .3s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.info-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1a1273;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:infoIn .2s ease;padding:var(--space-7)}.info-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-7);max-width:480px;width:100%;box-shadow:var(--shadow-lg)}.info-title{margin:0 0 var(--space-5) 0;font-size:var(--font-xl);font-weight:600;color:var(--text)}.info-body{font-size:13px;line-height:1.55;color:var(--textDim)}.info-body p{margin:0 0 var(--space-5) 0}.info-body p:last-child{margin-bottom:0}.info-actions{display:flex;justify-content:flex-end;margin-top:18px}.info-btn-primary{border-color:var(--accent);background:var(--accent);color:var(--accentInk);font-size:var(--font-md);font-weight:600;padding:var(--space-4) var(--space-6)}.info-btn-primary:hover{filter:brightness(1.05)}@keyframes infoIn{0%{opacity:0}to{opacity:1}}
