:root{--bg: #ebe9e3;--panel: #fcfbf8;--panelAlt: #f4f2ec;--border: rgba(30, 26, 18, .1);--borderStrong: rgba(30, 26, 18, .2);--text: #1f1c16;--textDim: #6b6760;--textFaint: #a09c93;--accent: #3a5dbe;--accentInk: #ffffff;--grid: rgba(30, 26, 18, .05);--gridStrong: rgba(30, 26, 18, .13);--fabric: #fdfcf8;--thread: #3a5dbe;--needle: #d97757;--radius: 10px}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}.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}[hidden]{display:none!important}.ms-bar{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:8px 12px;background:var(--bg);border-bottom:1px solid var(--border)}.ms-wrap{position:relative;display:inline-flex;padding:3px;border-radius:999px;background:#0000000a;border:1px solid var(--border)}.ms-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:5px 14px;border-radius:999px;font-family:inherit;font-size:11.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;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:9px;font-weight:500;padding:1px 5px;border-radius:3px;background:#0000000f}.ms-btn[data-active=true] .ms-kbd{background:#fff3}.sb-root{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:var(--panel);border-right:1px solid var(--border)}.sb-brand{padding:16px;border-bottom:1px solid var(--border)}.sb-brand-title{font-size:12.5px;font-weight:600}.sb-brand-sub{font-size:10px;color:var(--textFaint);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.sb-debug-link{display:inline-block;margin-top:8px;font-size:11px;color:var(--textDim);text-decoration:none}.sb-debug-link:hover{color:var(--accent)}.sb-actions{padding:12px;display:flex;flex-direction:column;gap:6px}.sb-act-row{display:flex;gap:6px}.sb-btn-primary,.sb-btn-ghost,.ed-tool-btn,.ed-stitch-btn,.pv-tx-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:transparent;color:var(--text);border-radius:var(--radius);font-family:inherit;font-size:12px;font-weight:500;padding:6px 10px;cursor:pointer}.sb-btn-primary{background:var(--accent);color:var(--accentInk);border-color:var(--accent);font-weight:600;width:100%;padding:8px 10px}.sb-btn-ghost{flex:1;font-size:11.5px}.sb-section{padding:12px;border-top:1px solid var(--border)}.sb-section-h{display:flex;justify-content:space-between;align-items:center;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim);margin-bottom:8px}.sb-list{display:flex;flex-direction:column;gap:2px;max-height:320px;overflow-y:auto}.sb-empty{font-size:11.5px;color:var(--textFaint)}.sb-item{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:4px;cursor:pointer;border-left:2px solid transparent;color:var(--textDim)}.sb-item:hover{background:#0000000a}.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:12.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-item-meta{font-size:10.5px;color:var(--textFaint);margin-top:2px}.sb-item-del{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;font-size:11px;cursor:pointer;padding:4px;color:var(--textFaint)}.sb-item-del:hover{color:#e74c3c}.sb-bg-controls{display:flex;flex-direction:column;gap:8px}.sb-bg-row{display:flex;flex-direction:column;gap:3px}.sb-bg-lbl{font-size:10.5px;color:var(--textDim)}.sb-bg-row input[type=range]{width:100%}.sb-bg-pos{display:flex;gap:6px}.sb-bg-num{flex:1;display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);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:6px;line-height:1.4}.ed-toolbar{display:flex;align-items:center;gap:14px;padding:8px 12px;flex:0 0 auto;background:var(--panel);border-bottom:1px solid var(--border)}.ed-toolgroup{display:flex;align-items:center;gap:6px}.ed-right{margin-left:auto}.ed-tlbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim)}.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:6px;padding:4px 0;width:28px;font-size:16px;line-height:1;cursor:pointer}.ed-zoom-btn:hover{background:var(--panel)}.ed-zoom-btn:active{background:var(--accent);color:var(--accentInk)}.pv-tx-zoom{width:30px;margin-left:2px}.ed-toolbar select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--panelAlt);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:11px;cursor:pointer;outline:none}.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-minor-x,.ed-grid line.grid-minor-y{stroke:var(--grid);stroke-width:.5}.ed-grid line.grid-major-x,.ed-grid line.grid-major-y{stroke:var(--gridStrong);stroke-width:1}.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}.sb-bg-lock{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:11px;color:var(--textDim);cursor:pointer;-webkit-user-select:none;user-select:none}.x-limit-guides .x-limit-zone{fill:var(--text);fill-opacity:.04}.x-limit-guides .x-limit-line{stroke:var(--needle);stroke-opacity:.6;stroke-width:1;stroke-dasharray:3 3}.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-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 .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}.ed-ruler-top{position:absolute;left:34px;right:0;top:0;height:22px;background:#fcfbf8d9;border-bottom:1px solid var(--border);pointer-events:none;z-index:2;font-size:9.5px;color:var(--textFaint)}.ed-ruler-left{position:absolute;left:0;top:22px;bottom:0;width:34px;background:#fcfbf8d9;border-right:1px solid var(--border);pointer-events:none;z-index:2;font-size:9.5px;color:var(--textFaint)}.ed-ruler-corner{position:absolute;left:0;top:0;width:34px;height:22px;background:#fcfbf8f2;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:var(--textFaint);letter-spacing:.08em;text-transform:uppercase;z-index:3;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}.ed-inspector{display:flex;align-items:center;gap:14px;padding:8px 14px;flex:0 0 auto;background:var(--panel);border-top:1px solid var(--border);font-size:11.5px;min-height:40px}.ed-insp-meta,.ed-insp-row{display:flex;align-items:center;gap:8px}.ed-insp-lbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim)}.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}.pv-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;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 .ghost-path{stroke:var(--thread);stroke-opacity:.18;stroke-width:1;fill:none;stroke-dasharray:2 3}.pv-canvas .thread-path{stroke:var(--thread);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .drop{fill:var(--thread);opacity:.9}.pv-canvas .drop.kind-start{fill:var(--accent)}.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-width:1.5;stroke-linecap:round}.pv-canvas .needle-marker .needle-tip,.pv-canvas .needle-marker .needle-dot{fill:var(--needle)}.pv-canvas .real-shadow{stroke:#00000040;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .real-thread{stroke:var(--thread);stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-canvas .real-highlight{stroke:#fff6;stroke-width:.7;fill:none;stroke-linecap:round;stroke-linejoin:round}.pv-empty{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center}.pv-transport{padding:10px 14px;display:flex;flex-direction:column;gap:8px;flex:0 0 auto;background:var(--panel);border-top:1px solid var(--border)}.pv-tx-row{display:flex;align-items:center;gap:8px}.pv-tx-meta{font-size:10.5px}.pv-meta-lbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim)}.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-row input[type=range]{flex:1;min-width:80px}.pv-tx-pct,.pv-tx-xy{color:var(--textDim);font-size:11px;font-variant-numeric:tabular-nums;min-width:40px;text-align:right}.sl-root{display:flex;flex-direction:column;height:100%;background:var(--panel);border-left:1px solid var(--border);overflow:hidden}.sl-header{padding:14px 16px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--textDim);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:4px 12px;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer;white-space:nowrap;color:var(--textDim)}.sl-list li:hover{background:#00000008}.sl-list li.done{color:var(--accent)}.sl-list li.current{background:#3a5dbe1f;color:var(--accent);font-weight:600}.sl-list li.future{color:var(--textFaint)}.sl-empty{padding:16px;text-align:center;color:var(--textFaint);font-style:italic}input[type=range]{-moz-appearance:none;appearance:none;-webkit-appearance:none;height:3px;background:#7d7d7d40;border-radius:999px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.2);box-shadow:0 1px 2px #00000040;cursor:pointer}input[type=range]::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.2);cursor:pointer}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:10px 16px;border-radius:8px;font-size:12.5px;font-weight:500;background:var(--text);color:var(--bg);box-shadow:0 8px 24px #0003;z-index:1000;animation:toastIn .3s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7d7d7d4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#7d7d7d80}
