:root{--bg-canvas: #E8DFC8;--bg-canvas-2: #DFD4B8;--bg-panel: #6E4626;--bg-panel-light: #8B5E3A;--bg-panel-deep: #4E3018;--bg-paper: #FBF6E9;--bg-paper-2: #F4ECD4;--bg-metal-top: #DFD7C5;--bg-metal-bot: #B8AC95;--bg-metal-edge: #8A7A5C;--ink-primary: #2A1F14;--ink-secondary: rgba(42, 31, 20, .72);--ink-tertiary: rgba(42, 31, 20, .54);--ink-onwood: #F5EAD8;--ink-onwood-soft: rgba(245, 234, 216, .65);--ink-onwood-faint: rgba(245, 234, 216, .35);--accent-thread: #9B2C3F;--accent-thread-deep: #7A1F30;--accent-thread-soft: #C97A87;--accent-thread-tint: rgba(155, 44, 63, .12);--shadow-warm-1: 0 1px 2px rgba(60, 30, 10, .18);--shadow-warm-2: 0 2px 6px rgba(60, 30, 10, .22);--shadow-warm-3: 0 10px 30px rgba(60, 30, 10, .28), 0 2px 8px rgba(60, 30, 10, .18);--shadow-warm-deep: 0 24px 60px rgba(40, 20, 6, .38), 0 6px 18px rgba(40, 20, 6, .24);--hl-warm: rgba(255, 248, 230, .55);--hl-warm-strong: rgba(255, 248, 230, .8);--bevel-dark: rgba(40, 22, 8, .55);--font-ui: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-display: "Libre Caslon Display", "EB Garamond", "Playfair Display", Georgia, serif;--font-mono: "JetBrains Mono", "Berkeley Mono", "SF Mono", ui-monospace, Menlo, monospace;--fs-display: 32px;--lh-display: 40px;--fs-h1: 24px;--lh-h1: 32px;--fs-h2: 18px;--lh-h2: 26px;--fs-h3: 14px;--lh-h3: 20px;--fs-body: 13px;--lh-body: 20px;--fs-caption: 11px;--lh-caption: 16px;--fs-mono: 12px;--lh-mono: 16px;--r-2: 4px;--r-3: 6px;--r-4: 8px;--r-5: 10px;--r-6: 14px;--ease-default: cubic-bezier(.22, 1, .36, 1);--ease-elastic: cubic-bezier(.34, 1.42, .64, 1)}:root[data-theme=dark]{--bg-canvas: #2A2620;--bg-canvas-2: #221E18;--bg-panel: #3D2817;--bg-panel-light: #533720;--bg-panel-deep: #261607;--bg-paper: #3A332A;--bg-paper-2: #2F2920;--bg-metal-top: #5A5247;--bg-metal-bot: #3D362E;--bg-metal-edge: #1F1A14;--ink-primary: #E8DFC8;--ink-secondary: rgba(232, 223, 200, .72);--ink-tertiary: rgba(232, 223, 200, .5);--ink-onwood: #F5EAD8;--ink-onwood-soft: rgba(245, 234, 216, .6);--ink-onwood-faint: rgba(245, 234, 216, .3);--accent-thread: #D14A5F;--accent-thread-deep: #A8334A;--accent-thread-soft: #C97A87;--accent-thread-tint: rgba(209, 74, 95, .18);--hl-warm: rgba(255, 230, 180, .18);--hl-warm-strong: rgba(255, 230, 180, .32)}:root[data-wood=walnut]{--bg-panel: #6E4626;--bg-panel-light: #8B5E3A;--bg-panel-deep: #4E3018}:root[data-wood=oak]{--bg-panel: #A07842;--bg-panel-light: #BC9056;--bg-panel-deep: #7C5728}:root[data-wood=mahogany]{--bg-panel: #6B2F22;--bg-panel-light: #8A4232;--bg-panel-deep: #491A12}:root[data-theme=dark][data-wood=walnut]{--bg-panel: #3D2817;--bg-panel-light: #533720;--bg-panel-deep: #261607}:root[data-theme=dark][data-wood=oak]{--bg-panel: #5A4222;--bg-panel-light: #715228;--bg-panel-deep: #3A2914}:root[data-theme=dark][data-wood=mahogany]{--bg-panel: #3F1B12;--bg-panel-light: #59281D;--bg-panel-deep: #270E08}:root[data-accent=red]{--accent-thread: #9B2C3F;--accent-thread-deep: #7A1F30;--accent-thread-soft: #C97A87;--accent-thread-tint: rgba(155, 44, 63, .12)}:root[data-accent=indigo]{--accent-thread: #2E437A;--accent-thread-deep: #1E2F5C;--accent-thread-soft: #7B8AB5;--accent-thread-tint: rgba(46, 67, 122, .12)}:root[data-accent=moss]{--accent-thread: #3B6334;--accent-thread-deep: #284621;--accent-thread-soft: #8AAA7E;--accent-thread-tint: rgba(59, 99, 52, .12)}:root[data-theme=dark][data-accent=red]{--accent-thread: #D14A5F;--accent-thread-deep: #A8334A;--accent-thread-soft: #C97A87;--accent-thread-tint: rgba(209, 74, 95, .18)}:root[data-theme=dark][data-accent=indigo]{--accent-thread: #6D85C2;--accent-thread-deep: #475E94;--accent-thread-soft: #8FA0C9;--accent-thread-tint: rgba(109, 133, 194, .2)}:root[data-theme=dark][data-accent=moss]{--accent-thread: #8AB47A;--accent-thread-deep: #5A8048;--accent-thread-soft: #A5BF9A;--accent-thread-tint: rgba(138, 180, 122, .2)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.tex-linen{background-color:var(--bg-canvas);background-image:repeating-linear-gradient(0deg,rgba(80,55,25,.055) 0 1px,transparent 1px 3px),repeating-linear-gradient(90deg,rgba(80,55,25,.045) 0 1px,transparent 1px 3px),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.6' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.35  0 0 0 0 0.22  0 0 0 0 0.08  0 0 0 0.08 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");background-size:3px 3px,3px 3px,240px 240px}.tex-aida{background-color:var(--bg-canvas);background-image:repeating-linear-gradient(0deg,rgba(80,55,25,.09) 0 1px,transparent 1px 5px),repeating-linear-gradient(90deg,rgba(80,55,25,.09) 0 1px,transparent 1px 5px),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='2.0' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.35  0 0 0 0 0.22  0 0 0 0 0.08  0 0 0 0.1 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");background-size:5px 5px,5px 5px,240px 240px}.tex-walnut{background-color:var(--bg-panel);background-image:linear-gradient(180deg,rgba(255,230,190,.07) 0%,transparent 18%,transparent 80%,rgba(0,0,0,.22) 100%),repeating-linear-gradient(90deg,rgba(0,0,0,.08) 0px,rgba(0,0,0,.08) 1px,transparent 1px,transparent 3px,rgba(255,220,180,.04) 3px,rgba(255,220,180,.04) 4px,transparent 4px,transparent 7px),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='420' height='200'><filter id='g'><feTurbulence type='turbulence' baseFrequency='0.012 0.9' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.18  0 0 0 0 0.08  0 0 0 0 0.02  0 0 0 0.45 0'/></filter><rect width='420' height='200' filter='url(%23g)'/></svg>");background-size:100% 100%,7px 100%,420px 200px;background-repeat:no-repeat,repeat,repeat}.tex-walnut-h{background-color:var(--bg-panel);background-image:linear-gradient(180deg,rgba(255,230,190,.16) 0%,rgba(255,230,190,.04) 30%,transparent 60%,rgba(0,0,0,.28) 100%),repeating-linear-gradient(0deg,rgba(0,0,0,.08) 0px,rgba(0,0,0,.08) 1px,transparent 1px,transparent 3px,rgba(255,220,180,.05) 3px,rgba(255,220,180,.05) 4px,transparent 4px,transparent 7px),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='420'><filter id='g'><feTurbulence type='turbulence' baseFrequency='0.9 0.012' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.18  0 0 0 0 0.08  0 0 0 0 0.02  0 0 0 0.45 0'/></filter><rect width='200' height='420' filter='url(%23g)'/></svg>");background-size:100% 100%,100% 7px,200px 420px;background-repeat:no-repeat,repeat,repeat}.tex-paper{background-color:var(--bg-paper);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.4  0 0 0 0 0.28  0 0 0 0 0.1  0 0 0 0.06 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>")}.tex-metal{background-color:var(--bg-metal-top);background-image:linear-gradient(180deg,#e5ddc9,#d2c8b0 45%,#b6a98d),repeating-linear-gradient(0deg,rgba(0,0,0,.025) 0 1px,transparent 1px 2px);background-blend-mode:normal,multiply}.bevel-up{box-shadow:inset 0 1px 0 var(--hl-warm-strong),inset 0 -1px 0 var(--bevel-dark),var(--shadow-warm-1)}.bevel-down{box-shadow:inset 0 1px 2px #28160866,inset 0 -1px 0 var(--hl-warm)}.groove{background:linear-gradient(180deg,#00000040,#0000000d);box-shadow:inset 0 1px 2px #0000008c,inset 0 -1px #ffdcb42e}html,body,#app{margin:0;padding:0;width:100%;height:100%;font-family:var(--font-ui);font-size:var(--fs-body);line-height:var(--lh-body);color:var(--ink-primary);background:var(--bg-canvas);overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit}.btn-metal{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 14px;border-radius:var(--r-3);border:1px solid var(--bg-metal-edge);background:linear-gradient(180deg,#dfd7c5,#c2b89e,#a89b7f);color:#2a1f14;font-size:12px;font-weight:600;cursor:pointer;box-shadow:inset 0 1px #fff8e6a6,inset 0 -1px #0000000f,0 1px 2px #3c1e0a40;text-shadow:0 1px 0 rgba(255,255,255,.4);transition:all .1s var(--ease-default)}.btn-metal:hover{background:linear-gradient(180deg,#ece4d2,#cdc3a9,#b3a687)}.btn-metal:active{background:linear-gradient(180deg,#a89b7f,#c2b89e,#dfd7c5);transform:translateY(.5px)}.btn-metal:disabled{opacity:.45;pointer-events:none}.btn-primary{background:linear-gradient(180deg,var(--accent-thread-soft) 0%,var(--accent-thread) 60%,var(--accent-thread-deep) 100%);color:#fbf0dc;border-color:var(--accent-thread-deep);text-shadow:0 1px 0 rgba(0,0,0,.3);box-shadow:inset 0 1px #ffdcd2a6,inset 0 -1px #0000002e,0 1px 2px #3c1e0a4d}.btn-primary:hover{background:linear-gradient(180deg,#D88A95 0%,#B23E50 60%,var(--accent-thread-deep) 100%)}.btn-primary:active{background:linear-gradient(180deg,var(--accent-thread-deep) 0%,var(--accent-thread) 60%,var(--accent-thread-soft) 100%)}.select-mini{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'><path d='M0 0l4 5 4-5z' fill='%23332'/></svg>") no-repeat right 8px center,linear-gradient(180deg,#e5ddc9,#c2b89e);background-size:8px auto,100% 100%;border:1px solid var(--bg-metal-edge);color:#2a1f14;font-family:var(--font-ui);font-size:12px;padding:5px 22px 5px 10px;border-radius:4px;box-shadow:inset 0 1px #fff8e699,0 1px 1px #3c1e0a33;cursor:pointer}.select-mini option{color:#2a1f14;background:#fbf6e9}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:12px;cursor:pointer}.checkbox-row input{accent-color:var(--accent-thread)}.toggle{position:relative;width:38px;height:22px;border-radius:12px;background:#0006;box-shadow:inset 0 1px 2px #000000b3;cursor:pointer;transition:background .2s;border:none;padding:0}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fcf7e8,#d9cfb8 50%,#9c8f73);box-shadow:inset 0 1px #ffffffb3,0 1px 2px #0006;transition:left .2s var(--ease-default)}.toggle[aria-pressed=true]{background:linear-gradient(180deg,var(--accent-thread-deep),var(--accent-thread));box-shadow:inset 0 1px 2px #0006}.toggle[aria-pressed=true] .toggle-knob{left:18px}.welcome-shell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:auto;padding:40px 20px}.welcome-shell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(20,10,4,.45) 100%)}.welcome-card{position:relative;z-index:1;max-width:680px;width:100%;background:var(--bg-paper);border-radius:var(--r-6);padding:48px 56px 40px;box-shadow:var(--shadow-warm-deep);text-align:center;border:1px solid rgba(60,30,10,.2)}.welcome-ornament{display:flex;align-items:center;justify-content:center;gap:6px;color:var(--accent-thread);margin-bottom:12px}.welcome-ornament span{width:4px;height:4px;background:currentColor;border-radius:50%}.welcome-ornament .bar{width:18px;height:2px;border-radius:1px}.welcome-ornament .vbar{width:2px;height:12px;border-radius:1px}.welcome-title{font-family:var(--font-display);font-size:48px;line-height:1.1;color:var(--ink-primary);margin:0 0 8px}.welcome-tagline{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--ink-secondary);margin:0 0 10px}.welcome-lede{font-size:13px;color:var(--ink-secondary);max-width:480px;margin:0 auto 28px}.welcome-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.welcome-busy{display:flex;align-items:center;justify-content:center;min-height:116px;margin-bottom:18px}.welcome-action{background:var(--bg-paper-2);border:1px solid rgba(60,30,10,.15);border-radius:var(--r-4);padding:22px 18px;text-align:center;cursor:pointer;transition:all .15s var(--ease-default);font-family:inherit}.welcome-action:hover{transform:translateY(-1px);box-shadow:var(--shadow-warm-2);border-color:var(--accent-thread-soft)}.welcome-action svg{width:64px;height:64px}.welcome-action h3{font-size:15px;font-weight:600;margin:10px 0 4px;color:var(--ink-primary)}.welcome-action p{font-size:11px;color:var(--ink-tertiary);margin:0}.welcome-drop{border:2px dashed rgba(60,30,10,.3);border-radius:var(--r-4);padding:20px;font-size:13px;color:var(--ink-secondary);margin-bottom:18px;transition:all .15s var(--ease-default)}.welcome-drop.dragover{border-color:var(--accent-thread);background:var(--accent-thread-tint);color:var(--accent-thread-deep)}.welcome-footer{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-onwood-faint);font-family:var(--font-mono)}.editor-shell{width:100%;height:100%;display:grid;grid-template-rows:52px 1fr 28px;grid-template-columns:280px 1fr 320px;grid-template-areas:"toolbar toolbar toolbar" "left    canvas  right" "status  status  status"}.toolbar{grid-area:toolbar;position:relative;z-index:10}.panel-left{grid-area:left;position:relative;overflow:hidden}.panel-right{grid-area:right;position:relative;overflow:hidden}.canvas-area{grid-area:canvas;position:relative;overflow:hidden}.status-bar{grid-area:status;position:relative;z-index:5}.toolbar{display:flex;align-items:center;padding:0 12px;gap:10px;border-bottom:1px solid var(--bg-panel-deep);box-shadow:0 2px #0000002e,0 6px 18px #00000026}.app-title{font-family:var(--font-display);font-size:16px;letter-spacing:.02em;color:var(--ink-onwood);text-shadow:0 1px 0 rgba(0,0,0,.4);padding:0 12px 0 4px;border-right:1px solid var(--bevel-dark);box-shadow:1px 0 0 var(--hl-warm);margin-right:6px;height:28px;display:flex;align-items:center;gap:8px;white-space:nowrap}.toolbar-group{display:flex;align-items:center;gap:2px;padding:0 6px;height:28px;position:relative}.toolbar-group+.toolbar-group:before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:1px;background:var(--bevel-dark);box-shadow:1px 0 0 var(--hl-warm)}.tool-btn{background:transparent;border:none;width:36px;height:32px;border-radius:var(--r-3);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-onwood);transition:all .12s var(--ease-default)}.tool-btn:hover{background:var(--hl-warm);color:var(--ink-primary);box-shadow:inset 0 1px 0 var(--hl-warm-strong),inset 0 -1px 0 var(--bevel-dark)}.tool-btn:active,.tool-btn[aria-pressed=true]{background:#00000047;box-shadow:inset 0 1px 3px #00000073;color:var(--ink-onwood)}.tool-btn svg{width:22px;height:22px;display:block}.tabs{display:inline-flex;align-items:stretch;height:30px;border-radius:var(--r-3);box-shadow:inset 0 1px 2px #0006,0 1px 0 var(--hl-warm);background:#00000038;padding:2px;gap:2px}.tab{background:transparent;border:none;padding:0 12px;font-size:12px;font-weight:500;color:var(--ink-onwood-soft);cursor:pointer;display:flex;align-items:center;gap:6px;border-radius:4px;transition:all .12s var(--ease-default)}.tab:hover:not([aria-pressed=true]){color:var(--ink-onwood);background:#ffffff0f}.tab[aria-pressed=true]{background:linear-gradient(180deg,#e5ddc9,#b6a98d);color:var(--ink-primary);font-weight:600;box-shadow:inset 0 1px 0 var(--hl-warm-strong),inset 0 -1px #0000002e,0 1px 2px #00000038;text-shadow:0 1px 0 rgba(255,255,255,.4)}.tab svg{width:16px;height:16px}.toolbar-spacer{flex:1 1 auto}.panel-left{border-right:1px solid var(--bg-panel-deep);box-shadow:inset -1px 0 #fff8e614,2px 0 6px #00000026}.panel-right{border-left:1px solid var(--bg-panel-deep);box-shadow:inset 1px 0 #fff8e614,-2px 0 6px #00000026}.panel-content{height:100%;overflow-y:auto;padding:0;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.3) transparent}.panel-content::-webkit-scrollbar{width:8px}.panel-content::-webkit-scrollbar-thumb{background:#0000004d;border-radius:4px}.section{border-bottom:1px solid var(--bg-panel-deep);box-shadow:0 1px #fff8e60f}.section-header{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(180deg,#fff8e60f,#00000014);border:none;width:100%;font-size:12px;font-weight:600;color:var(--ink-onwood);letter-spacing:.02em;text-transform:uppercase;transition:background .12s;text-align:left}.section-header:hover{background:linear-gradient(180deg,#fff8e61a,#0000000a)}.disclosure{width:10px;height:10px;display:inline-block;transition:transform .2s var(--ease-default);color:var(--ink-onwood-soft)}.disclosure.open{transform:rotate(90deg);color:var(--ink-onwood)}.section-body{padding:12px 14px 16px;display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field-label{display:flex;justify-content:space-between;align-items:baseline;font-size:11px;font-weight:500;color:var(--ink-onwood-soft);letter-spacing:.04em;text-transform:uppercase}.field-hint{text-transform:none;font-weight:400;font-size:9px;letter-spacing:.02em;color:var(--ink-onwood-faint);font-family:var(--font-mono)}.field-value{font-family:var(--font-mono);font-size:11px;color:var(--ink-onwood);background:#00000040;padding:1px 6px;border-radius:3px;box-shadow:inset 0 1px 2px #0006;white-space:nowrap}.slider{position:relative;height:24px;width:100%;display:flex;align-items:center;--pct: 50%}.slider-rail,.slider-fill,.slider-thumb{pointer-events:none}.slider-rail{position:absolute;top:10px;right:8px;bottom:10px;left:8px;height:5px;border-radius:3px;background:linear-gradient(180deg,#0000008c,#0003);box-shadow:inset 0 1px 2px #000000bf,inset 0 -1px #ffdcb41f,0 1px #ffdcb42e}.slider-fill{position:absolute;left:8px;top:10px;height:5px;width:calc(var(--pct) - 8px);max-width:calc(100% - 16px);border-radius:3px;background:linear-gradient(180deg,var(--accent-thread-soft),var(--accent-thread));box-shadow:inset 0 1px #ffdcd280,0 0 6px var(--accent-thread-tint)}.slider-thumb{position:absolute;left:calc(var(--pct) - 9px);top:3px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fcf7e8,#d9cfb8 40%,#9c8f73 75%,#7a6e55);box-shadow:inset 0 1px #ffffffb3,0 1px 2px #0006,0 2px 4px #00000040;border:1px solid #5A4F38}.slider:hover .slider-thumb{transform:scale(1.05)}input[type=range].slider-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:grab;margin:0;padding:0;z-index:3}input[type=range].slider-input:active{cursor:grabbing}.status-bar{display:flex;align-items:center;padding:0 14px;gap:16px;font-family:var(--font-mono);font-size:11px;color:var(--ink-onwood);border-top:1px solid var(--bg-panel-deep);box-shadow:inset 0 1px 0 var(--hl-warm),0 -2px 6px #00000026}.status-bar .sep{width:1px;height:12px;background:var(--bevel-dark);box-shadow:1px 0 #fff8e61a}.status-bar .stale{margin-left:auto;display:flex;align-items:center;gap:6px;color:var(--accent-thread-soft);font-family:var(--font-ui)}.stale-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-thread);box-shadow:0 0 6px var(--accent-thread),inset 0 1px #fff6;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.canvas-area{background-color:var(--bg-canvas);display:flex;flex-direction:column}.canvas-rulers{display:flex;align-items:center;height:22px;padding:0 8px;background:var(--bg-paper-2);border-bottom:1px solid rgba(80,55,25,.18);box-shadow:inset 0 -1px #fff8e680;font-family:var(--font-mono);font-size:10px;color:var(--ink-secondary);gap:12px}.canvas-viewport{flex:1 1 auto;position:relative;overflow:auto;display:grid;place-items:center;padding:32px;cursor:grab;user-select:none;-webkit-user-select:none}.canvas-viewport.panning{cursor:grabbing}.canvas-viewport.placing-text,.canvas-viewport.placing-text *{cursor:crosshair!important}.canvas-viewport.hovering-text{cursor:move}.canvas-viewport.dragging-text{cursor:grabbing}.text-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.text-sel{fill:none;stroke:var(--accent-thread);stroke-width:1.5;stroke-dasharray:4 3;vector-effect:non-scaling-stroke}.text-hover{fill:var(--accent-thread-tint);fill-opacity:.18;stroke:none}body.sc-panning,body.sc-panning *{cursor:grabbing!important;user-select:none!important;-webkit-user-select:none!important}.canvas-frame{position:relative;background:var(--bg-canvas);box-shadow:0 30px 60px #3c1e0a59,0 8px 20px #3c1e0a38,0 0 0 8px #6e462880,0 0 0 9px #281406e6,inset 0 0 80px #3c1e0a1f;border-radius:var(--r-3)}.stitch-canvas{display:block;image-rendering:pixelated;image-rendering:crisp-edges}.zoom-hud{position:absolute;right:16px;bottom:16px;display:flex;align-items:stretch;background:var(--bg-paper);border-radius:6px;box-shadow:0 4px 12px #3c1e0a40,0 0 0 1px #3c1e0a2e;font-family:var(--font-mono);font-size:11px;overflow:hidden;z-index:5}.zoom-hud button{background:linear-gradient(180deg,#dfd7c5,#b6a98d);border:none;color:var(--ink-primary);width:28px;height:28px;cursor:pointer;font-size:14px;font-weight:700;border-right:1px solid var(--bg-metal-edge)}.zoom-hud button:last-child{border-right:none}.zoom-hud button:hover{background:linear-gradient(180deg,#ece4d2,#bfb298)}.zoom-hud .zoom-val{padding:0 10px;display:flex;align-items:center;background:var(--bg-paper);font-weight:500;color:var(--ink-primary);min-width:56px;justify-content:center}.legend-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 8px;font-size:11px;font-weight:600;color:var(--ink-onwood);text-transform:uppercase;letter-spacing:.04em}.legend-header .legend-count{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-onwood-soft);text-transform:none;letter-spacing:0}.thread-row{display:grid;grid-template-columns:28px 28px 1fr auto;align-items:center;gap:10px;padding:7px 14px;cursor:pointer;transition:background .1s;position:relative;border-bottom:1px solid rgba(0,0,0,.18);box-shadow:0 1px #fff8e60d;border-left:none;border-right:none;border-top:none;background:transparent;width:100%;text-align:left}.thread-row:hover{background:#fff8e614}.thread-row[aria-pressed=true]{background:var(--accent-thread-tint);box-shadow:inset 0 0 0 1px var(--accent-thread-soft)}.thread-symbol{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--ink-onwood);background:#0000004d;border-radius:3px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fff8e61a,inset 0 -1px #0006}.thread-swatch{width:24px;height:24px;border-radius:4px;position:relative;box-shadow:inset 0 1px #fff6,inset 0 -1px #0000004d,0 1px 2px #0006}.thread-swatch:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.35),transparent 60%)}.thread-meta{display:flex;flex-direction:column;gap:1px;min-width:0}.thread-code{font-family:var(--font-mono);font-size:11px;color:var(--ink-onwood);font-weight:600}.thread-name{font-size:11px;color:var(--ink-onwood-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-count{font-family:var(--font-mono);font-size:11px;color:var(--ink-onwood-soft);text-align:right;font-variant-numeric:tabular-nums}.export-shell{width:100%;height:100%;display:grid;grid-template-rows:40px 1fr}.export-titlebar{display:flex;align-items:center;padding:0 16px;color:var(--ink-onwood);font-family:var(--font-display);font-size:14px;border-bottom:1px solid var(--bg-panel-deep)}.export-body{display:grid;grid-template-columns:320px 1fr;overflow:hidden}.export-controls{padding:24px 22px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.export-controls h2{font-family:var(--font-display);font-size:22px;margin:0 0 4px}.export-controls .lede{font-family:var(--font-display);font-style:italic;font-size:13px;color:var(--ink-secondary);margin:0 0 8px}.export-row{display:flex;flex-direction:column;gap:4px}.export-row label{font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-tertiary)}.export-actions{margin-top:auto;display:flex;gap:8px;justify-content:flex-end;padding-top:16px;border-top:1px dashed rgba(60,30,10,.2)}.export-preview{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px}.book{display:grid;grid-template-columns:1fr 1fr;gap:0;width:min(720px,100%);aspect-ratio:3 / 2;background:var(--bg-paper);border-radius:var(--r-4);box-shadow:var(--shadow-warm-deep),inset 0 0 0 1px #3c1e0a33;overflow:hidden;position:relative}.book:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:14px;transform:translate(-50%);background:linear-gradient(90deg,rgba(0,0,0,.18),transparent 50%,rgba(0,0,0,.18));pointer-events:none}.book-page{padding:24px;font-family:var(--font-display);color:var(--ink-primary)}.book-page h3{margin:0 0 4px;font-size:18px}.book-page p{font-size:11px;color:var(--ink-tertiary);margin:0 0 12px;font-family:var(--font-ui)}.book-legend-row{display:grid;grid-template-columns:16px 1fr 40px;gap:6px;font-size:10px;font-family:var(--font-mono);align-items:center;border-bottom:1px dotted rgba(60,30,10,.2);padding:2px 0}.book-legend-swatch{width:12px;height:12px;border-radius:2px}.book-legend-sym{font-size:11px;text-align:center;min-width:14px;display:inline-block}.book-legend-row{grid-template-columns:14px 14px 1fr 40px}.book-page-empty{background:linear-gradient(180deg,var(--bg-paper-2),var(--bg-paper))}.tile-grid{display:grid;grid-template-columns:repeat(var(--tile-w),1fr);grid-template-rows:repeat(var(--tile-h),1fr);width:100%;aspect-ratio:var(--tile-w) / var(--tile-h);gap:0;border:1px solid rgba(60,30,10,.4);background:var(--bg-paper);margin-top:6px}.tile-cell{display:flex;align-items:center;justify-content:center;border:.4px solid rgba(60,30,10,.15);font-family:var(--font-mono);font-size:clamp(4px,calc(100%/max(var(--tile-w),var(--tile-h))*.6),10px);line-height:1}.tile-cell-empty{background:transparent;border-color:#3c1e0a14}.tile-sym{color:#000000d9;text-shadow:0 0 1px rgba(255,255,255,.6);pointer-events:none}.book-check-row{display:grid;grid-template-columns:14px 14px 14px 1fr 40px;gap:6px;font-size:10px;font-family:var(--font-mono);align-items:center;border-bottom:1px dotted rgba(60,30,10,.2);padding:2px 0}.book-check-box{width:11px;height:11px;border:1px solid rgba(60,30,10,.6);border-radius:2px;background:var(--bg-paper)}.cover-thumb-hint{margin-top:12px;padding:6px 10px;font-size:10px;font-family:var(--font-mono);color:var(--ink-tertiary);background:#3c1e0a0f;border-radius:4px;display:inline-block}.pager button:disabled{opacity:.3;cursor:not-allowed}.pager{display:inline-flex;align-items:center;background:var(--bg-paper);border-radius:999px;padding:4px 10px;gap:10px;font-family:var(--font-mono);font-size:11px;box-shadow:var(--shadow-warm-2),0 0 0 1px #3c1e0a26}.pager button{border:none;background:transparent;color:var(--ink-primary);cursor:pointer;font-size:14px;line-height:1}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;font-family:var(--font-ui);font-size:var(--fs-body);color:var(--ink-primary);background:var(--bg-canvas);overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.mat-shell{width:100%;height:100vh;display:grid;grid-template-rows:44px 1fr;grid-template-columns:360px 1fr;grid-template-areas:"titlebar titlebar" "rail     paper"}.mat-titlebar{grid-area:titlebar;min-width:0}.mat-rail{grid-area:rail;position:relative;overflow:hidden;min-height:0;min-width:0}.mat-paper-area{grid-area:paper;overflow:hidden;position:relative;min-height:0;min-width:0}.mat-titlebar{display:flex;align-items:center;padding:0 14px;gap:12px;border-bottom:1px solid var(--bg-panel-deep);box-shadow:0 2px 6px #0003;z-index:5;position:relative}.mat-traffic{display:flex;gap:6px}.mat-traffic span{width:11px;height:11px;border-radius:50%;box-shadow:inset 0 1px #ffffff80,inset 0 -1px #0000004d}.mat-traffic span:nth-child(1){background:#e25141}.mat-traffic span:nth-child(2){background:#daa21e}.mat-traffic span:nth-child(3){background:#1bac4a}.mat-titlebar-title{font-family:var(--font-display);font-size:14px;color:var(--ink-onwood);text-shadow:0 1px 0 rgba(0,0,0,.4);margin-left:6px}.mat-titlebar-sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-onwood-faint);margin-left:4px}.mat-rail{border-right:1px solid var(--bg-panel-deep);box-shadow:inset -1px 0 #fff8e60f,2px 0 8px #0000002e}.mat-rail-scroll{height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.3) transparent}.mat-rail-scroll::-webkit-scrollbar{width:8px}.mat-rail-scroll::-webkit-scrollbar-thumb{background:#0000004d;border-radius:4px}.mat-rail-header{padding:18px 18px 14px;border-bottom:1px solid var(--bg-panel-deep);box-shadow:0 1px #fff8e60f}.mat-rail-header h1{font-family:var(--font-display);font-size:22px;line-height:1.1;margin:0;color:var(--ink-onwood);text-shadow:0 1px 0 rgba(0,0,0,.4);letter-spacing:.005em}.mat-rail-header p{font-family:var(--font-display);font-style:italic;font-size:12px;margin:4px 0 0;color:var(--ink-onwood-soft)}.mat-section{border-bottom:1px solid var(--bg-panel-deep);box-shadow:0 1px #fff8e60d;padding:14px 18px 16px}.mat-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-onwood-soft);margin:0 0 10px;display:flex;justify-content:space-between;align-items:baseline}.mat-section-title .badge{font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--ink-onwood);background:#00000047;padding:1px 6px;border-radius:3px;box-shadow:inset 0 1px 2px #00000080;text-transform:none;letter-spacing:0}.mat-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.mat-field:last-child{margin-bottom:0}.mat-field-label{font-size:11px;font-weight:500;color:var(--ink-onwood-soft);display:flex;justify-content:space-between;align-items:baseline}.mat-field-label .v{font-family:var(--font-mono);color:var(--ink-onwood);background:#00000047;padding:1px 6px;border-radius:3px;box-shadow:inset 0 1px 2px #00000080;font-size:10px}.mat-seg{display:grid;gap:4px;padding:3px;background:#00000047;border-radius:6px;box-shadow:inset 0 1px 2px #00000080,0 1px #fff8e614}.mat-seg.col-3{grid-template-columns:1fr 1fr 1fr}.mat-seg.col-4{grid-template-columns:1fr 1fr 1fr 1fr}.mat-seg.col-2{grid-template-columns:1fr 1fr}.mat-seg.stack{grid-template-columns:1fr;gap:4px}.mat-seg-btn{background:transparent;border:none;font-family:var(--font-ui);font-size:11px;font-weight:500;color:var(--ink-onwood-soft);padding:6px 8px;border-radius:4px;cursor:pointer;transition:background .1s;display:flex;flex-direction:column;align-items:center;gap:2px;line-height:1.2}.mat-seg-btn:hover{color:var(--ink-onwood);background:#fff8e60f}.mat-seg-btn[aria-pressed=true]{background:linear-gradient(180deg,#e5ddc9,#b6a98d);color:var(--ink-primary);font-weight:600;box-shadow:inset 0 1px 0 var(--hl-warm-strong),inset 0 -1px #0000002e,0 1px 2px #00000038;text-shadow:0 1px 0 rgba(255,255,255,.4)}.mat-seg-btn .pct{font-family:var(--font-mono);font-size:13px;font-weight:600}.mat-seg-btn .sub{font-size:9px;opacity:.7;letter-spacing:.02em}.mat-seg-btn[aria-pressed=true] .sub{opacity:.85;color:var(--ink-secondary)}.mat-seg-btn.row{flex-direction:row;justify-content:space-between;padding:7px 10px;text-align:left}.mat-seg-btn.row .meta{font-family:var(--font-mono);font-size:10px;opacity:.7}.mat-stepper{display:inline-flex;align-items:stretch;background:#00000047;border-radius:4px;box-shadow:inset 0 1px 2px #00000080;height:26px}.mat-stepper button{background:linear-gradient(180deg,#dfd7c5,#b6a98d);border:1px solid var(--bg-metal-edge);color:var(--ink-primary);width:22px;font-weight:700;font-size:13px;cursor:pointer;box-shadow:inset 0 1px #fff8e68c,0 1px 1px #3c1e0a2e;margin:2px;border-radius:3px}.mat-stepper button:disabled{opacity:.4;cursor:not-allowed}.mat-stepper .v{font-family:var(--font-mono);font-size:12px;color:var(--ink-onwood);display:flex;align-items:center;justify-content:center;min-width:36px;padding:0 6px}.strand-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:6px 0;border-bottom:1px dashed rgba(255,248,230,.1)}.strand-row:last-child{border-bottom:none}.strand-row .lbl{font-size:11px;color:var(--ink-onwood-soft)}.strand-row .lbl small{display:block;font-size:9px;color:var(--ink-onwood-faint);margin-top:1px;font-family:var(--font-mono);letter-spacing:0}.pat-extras{display:flex;flex-direction:column;gap:6px}.pat-extras .row{display:grid;grid-template-columns:18px 18px 1fr auto;gap:6px;align-items:center;padding:4px 6px;background:#0000002e;border-radius:4px;box-shadow:inset 0 1px 1px #0000004d}.pat-extras .sym{font-family:var(--font-mono);font-weight:700;font-size:11px;color:var(--ink-onwood);text-align:center}.pat-extras .sw{width:14px;height:14px;border-radius:3px;box-shadow:inset 0 1px #fff6,inset 0 -1px #0000004d}.pat-extras .code{font-family:var(--font-mono);font-size:10px;color:var(--ink-onwood)}.pat-extras .ext{font-family:var(--font-mono);font-size:10px;color:var(--ink-onwood-soft);display:flex;gap:8px}.pat-extras .ext b{color:var(--accent-thread-soft);font-weight:600}.mat-actions{padding:16px 18px 20px;display:flex;flex-direction:column;gap:8px}.mat-paper-area{background:radial-gradient(ellipse at 50% 30%,#3c1e0a0d,#3c1e0a33),var(--bg-canvas);padding:28px 36px 28px 28px;overflow-y:auto;display:block;scrollbar-width:thin;scrollbar-color:rgba(60,30,10,.4) transparent}.mat-paper-area::-webkit-scrollbar{width:10px}.mat-paper-area::-webkit-scrollbar-thumb{background:#3c1e0a66;border-radius:5px}.mat-paper{position:relative;width:100%;background:var(--bg-paper);border-radius:2px;box-shadow:0 28px 60px #28140652,0 8px 18px #2814062e,0 0 0 1px #3c1e0a2e}.mat-paper:before{content:"";position:absolute;left:0;right:0;top:0;height:6px;background:radial-gradient(circle at 6px 0,transparent 4px,var(--bg-paper) 4.5px),radial-gradient(circle at 18px 0,transparent 4px,var(--bg-paper) 4.5px);background-size:12px 12px;background-repeat:repeat-x;pointer-events:none}.mat-paper-scroll{padding:36px 48px 60px;background-image:repeating-linear-gradient(0deg,transparent 0 21px,rgba(60,30,10,.025) 21px 22px)}.paper-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;border-bottom:1.5px solid rgba(60,30,10,.42);padding-bottom:12px;margin-bottom:24px}.paper-head-main{flex:1 1 0;min-width:0}.paper-head h2{font-family:var(--font-display);font-size:30px;margin:0;color:var(--ink-primary);letter-spacing:.005em;line-height:1.05}.paper-head .lede{font-family:var(--font-display);font-style:italic;font-size:13px;color:var(--ink-secondary);margin:4px 0 0}.paper-head .stamp{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;font-family:var(--font-mono);font-size:10px;color:var(--ink-secondary);line-height:1.5}.paper-head .stamp .big{font-family:var(--font-display);font-size:14px;color:var(--ink-primary);letter-spacing:.04em}.paper-section{margin-top:28px}.paper-section:first-of-type{margin-top:0}.paper-section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:12px}.paper-section-head h3{font-family:var(--font-display);font-size:18px;margin:0;color:var(--ink-primary);letter-spacing:.01em}.paper-section-head .num{font-family:var(--font-display);font-style:italic;font-size:12px;color:var(--accent-thread);font-weight:600;letter-spacing:.06em}.paper-section-head .meta{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-tertiary)}.pattern-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;background:#3c1e0a0a;border:.5px solid rgba(60,30,10,.18);border-radius:4px;padding:14px 18px}.pattern-summary .cell{display:flex;flex-direction:column;gap:2px}.pattern-summary .k{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-tertiary);font-weight:600}.pattern-summary .v{font-family:var(--font-display);font-size:18px;color:var(--ink-primary)}.pattern-summary .v .unit{font-family:var(--font-ui);font-size:11px;color:var(--ink-secondary);font-weight:500;margin-left:2px}.fabric-card{display:grid;grid-template-columns:96px 1fr auto;gap:18px;align-items:center;border:.5px solid rgba(60,30,10,.22);background:#fff8e680;padding:14px 16px;border-radius:4px}.fabric-swatch{width:96px;height:64px;border-radius:3px;box-shadow:inset 0 0 0 1px #3c1e0a4d,0 1px 2px #3c1e0a33;position:relative;overflow:hidden}.fabric-info .name{font-family:var(--font-display);font-size:16px;color:var(--ink-primary)}.fabric-info .sub{font-size:11px;color:var(--ink-secondary);margin-top:2px;font-family:var(--font-mono)}.fabric-cut{text-align:right;font-family:var(--font-mono)}.fabric-cut .lbl{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-tertiary);font-weight:600}.fabric-cut .val{font-family:var(--font-display);font-size:20px;color:var(--ink-primary);margin-top:2px}.fabric-cut .with{font-size:10px;color:var(--ink-tertiary);font-family:var(--font-mono);margin-top:2px}.thread-table{width:100%;border-collapse:collapse;font-size:12px}.thread-table thead th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-tertiary);text-align:left;padding:8px 6px;border-bottom:1px solid rgba(60,30,10,.32);cursor:pointer;-webkit-user-select:none;user-select:none}.thread-table thead th.num{text-align:right}.thread-table thead th .arr{display:inline-block;width:8px;color:var(--accent-thread);font-size:10px}.thread-table tbody tr{border-bottom:1px dotted rgba(60,30,10,.2)}.thread-table tbody tr:hover{background:#9b2c3f0a}.thread-table td{padding:8px 6px;color:var(--ink-primary);vertical-align:middle}.thread-table td.num{text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.thread-table .sw{width:22px;height:22px;border-radius:3px;display:inline-block;vertical-align:middle;box-shadow:inset 0 1px #ffffff80,inset 0 -1px #00000040,0 1px 2px #0000002e;position:relative}.thread-table .sw:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.35),transparent 60%)}.thread-table .sym{display:inline-block;font-family:var(--font-mono);font-weight:700;font-size:12px;width:18px;text-align:center;color:var(--ink-secondary)}.thread-table .code{font-family:var(--font-mono);font-weight:600;color:var(--ink-primary)}.thread-table .name{color:var(--ink-secondary);font-size:11px;font-family:var(--font-ui)}.thread-table td .stitches-cell{display:inline-flex;gap:6px;flex-wrap:wrap;font-family:var(--font-mono);font-size:10px;color:var(--ink-secondary)}.thread-table td .stitches-cell .tag{display:inline-block;padding:1px 4px;border-radius:2px;background:#3c1e0a14}.thread-table td .stitches-cell .tag.bs{background:#2e437a1f;color:#2e437a}.thread-table td .stitches-cell .tag.fk{background:#9b2c3f1f;color:var(--accent-thread)}.thread-table td .stitches-cell .tag.main{background:transparent;color:var(--ink-primary);font-weight:600;padding-left:0}.skein-cell{display:inline-flex;flex-direction:column;align-items:flex-end;gap:2px}.skein-cell .top{font-family:var(--font-display);font-size:16px;color:var(--ink-primary);line-height:1}.skein-cell .top .x{font-family:var(--font-ui);font-size:10px;color:var(--ink-tertiary);margin-left:2px;font-weight:500}.skein-cell .bar{width:56px;height:5px;background:#3c1e0a26;border-radius:2px;overflow:hidden;box-shadow:inset 0 1px 1px #3c1e0a33;margin-top:2px}.skein-cell .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent-thread-soft),var(--accent-thread))}.skein-cell .exact{font-size:9px;color:var(--ink-tertiary);font-family:var(--font-mono)}.thread-table tfoot td{border-top:1.5px solid rgba(60,30,10,.42);padding:14px 6px 4px;font-family:var(--font-display);font-size:14px;color:var(--ink-primary)}.thread-table tfoot td.num{text-align:right}.thread-table tfoot td.total-cost{font-size:22px;color:var(--accent-thread);font-weight:700}.needle-list{display:flex;flex-direction:column;gap:8px}.needle-item{display:grid;grid-template-columns:48px 1fr auto;gap:14px;align-items:center;padding:8px 14px;border:.5px solid rgba(60,30,10,.2);border-radius:4px;background:#fff8e666}.needle-item svg{width:48px;height:18px;display:block}.needle-item .info .n{font-family:var(--font-display);font-size:14px;color:var(--ink-primary)}.needle-item .info .purpose{font-size:11px;color:var(--ink-secondary);font-family:var(--font-mono)}.needle-item .tag{font-size:9px;text-transform:uppercase;letter-spacing:.1em;padding:3px 7px;background:#3c1e0a1f;color:var(--ink-secondary);border-radius:2px}.needle-item .tag.opt{background:#2e437a1f;color:#2e437a}.also-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}.also-list li{display:grid;grid-template-columns:18px 1fr;gap:8px;align-items:flex-start;font-size:12px;color:var(--ink-primary);padding:4px 0}.also-list li .box{width:14px;height:14px;margin-top:1px;border:1px solid rgba(60,30,10,.55);border-radius:2px;background:#fff8e666;box-shadow:inset 0 1px 1px #3c1e0a1a}.also-list li .desc{color:var(--ink-secondary);font-size:10px;margin-top:1px}.warn-list{display:flex;flex-direction:column;gap:8px}.warn{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:flex-start;font-size:12px;padding:10px 14px;background:#daa21e1a;border:.5px solid rgba(218,162,30,.45);border-radius:4px;color:var(--ink-primary);line-height:1.45}.warn.info{background:#2e437a12;border-color:#2e437a4d}.warn .glyph{font-family:var(--font-display);font-style:italic;font-size:14px;line-height:1;color:#daa21e}.warn.info .glyph{color:#2e437a}.warn b{color:var(--ink-primary);font-weight:600}.paper-foot{margin-top:32px;padding-top:14px;border-top:.5px dashed rgba(60,30,10,.3);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--ink-tertiary)}.paper-foot .seal{font-family:var(--font-display);font-style:italic;color:var(--accent-thread)}:root[data-theme=dark] .mat-paper{box-shadow:0 28px 60px #00000080,0 8px 18px #00000052,0 0 0 1px #0006}:root[data-theme=dark] .paper-head,:root[data-theme=dark] .thread-table tfoot td,:root[data-theme=dark] .thread-table thead th{border-color:#f5ead84d}:root[data-theme=dark] .thread-table tbody tr{border-color:#f5ead81f}:root[data-theme=dark] .pattern-summary,:root[data-theme=dark] .fabric-card,:root[data-theme=dark] .needle-item{background:#0000002e}:root[data-theme=dark] .also-list li .box{background:#0003;border-color:#f5ead859}@media print{body,html,.mat-shell{background:#fff!important}.mat-titlebar,.mat-rail,.mat-actions{display:none!important}.mat-shell{display:block!important;height:auto!important;overflow:visible!important}.mat-paper-area{overflow:visible!important;padding:0!important;background:#fff!important}.mat-paper{box-shadow:none!important;background:#fff!important;border-radius:0!important}.mat-paper:before{display:none!important}.mat-paper-scroll{padding:20px!important;background-image:none!important}.paper-head,.thread-table tfoot td,.thread-table thead th{border-color:#444!important}.thread-table tbody tr{border-color:#999!important}.fabric-card,.pattern-summary,.needle-item{background:#fff!important;border-color:#888!important}.warn{background:#fff8e1!important;border-color:#d4a017!important}.thread-table tr,.needle-item,.also-list li,.paper-section{page-break-inside:avoid}@page{margin:12mm}}.price-input{background:var(--bg-paper);color:var(--ink-primary);border:1px solid rgba(0,0,0,.4);border-radius:3px;font-family:var(--font-mono);font-size:13px;padding:6px 10px;box-shadow:inset 0 1px 2px #0000004d;outline:none}.price-input:focus{border-color:var(--accent-thread);box-shadow:inset 0 1px 2px #0000004d,0 0 0 2px var(--accent-thread-tint)}.loading-needle.svelte-1qop83j{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-paper);border-radius:999px;box-shadow:0 6px 18px #3c1e0a47,0 1px 2px #3c1e0a2e,0 0 0 1px #3c1e0a26;color:var(--ink-primary);font-size:12px;font-weight:500;letter-spacing:.01em}.loading-needle.inline.svelte-1qop83j{padding:4px 10px;font-size:11px;gap:6px}.loading-needle.inline.svelte-1qop83j svg:where(.svelte-1qop83j){width:18px;height:18px}.loading-label.svelte-1qop83j{font-family:var(--font-display);font-style:italic}.needle-spin.svelte-1qop83j{transform-origin:24px 24px;animation:svelte-1qop83j-needle-rotate 1.6s cubic-bezier(.4,0,.6,1) infinite}@keyframes svelte-1qop83j-needle-rotate{0%{transform:rotate(0)}50%{transform:rotate(20deg)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.needle-spin.svelte-1qop83j{animation:none}}.sc-logo.svelte-1l8nvlt{display:block;-webkit-user-select:none;user-select:none}.welcome-logo.svelte-1krhhra{display:flex;justify-content:center;margin-bottom:8px}.welcome-actions--quad.svelte-1krhhra{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.welcome-actions--quad.svelte-1krhhra .welcome-action:where(.svelte-1krhhra){flex:0 0 auto}.blank-backdrop.svelte-1krhhra{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#140a028c;display:flex;align-items:center;justify-content:center;padding:24px}.blank-dialog.svelte-1krhhra{width:min(440px,100%);background:var(--bg-paper, #f7efdd);color:var(--ink-primary, #2b2419);border-radius:10px;box-shadow:0 12px 32px #00000073;padding:22px 24px 18px;display:flex;flex-direction:column;gap:12px}.blank-dialog.svelte-1krhhra h2:where(.svelte-1krhhra){margin:0;font-family:var(--font-display, serif);font-size:22px}.blank-sub.svelte-1krhhra{margin:0 0 4px;font-size:12px;color:var(--ink-secondary, #5c4d3a);font-style:italic}.blank-field.svelte-1krhhra{display:flex;flex-direction:column;gap:5px}.blank-field-label.svelte-1krhhra{display:flex;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-secondary, #5c4d3a)}.blank-field.svelte-1krhhra input[type=range]:where(.svelte-1krhhra){width:100%}.blank-chips.svelte-1krhhra{display:flex;flex-wrap:wrap;gap:4px}.blank-chip.svelte-1krhhra{background:#3c1e0a0f;border:.5px solid rgba(60,30,10,.25);color:var(--ink-secondary, #5c4d3a);border-radius:14px;padding:4px 10px;font-size:11px;cursor:pointer}.blank-chip.svelte-1krhhra:hover{background:#3c1e0a1f}.blank-chip[aria-pressed=true].svelte-1krhhra{background:var(--accent-thread, #9b2c3f);border-color:var(--accent-thread, #9b2c3f);color:#fff}.blank-actions.svelte-1krhhra{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.blank-btn.svelte-1krhhra{background:linear-gradient(180deg,#dfd7c5,#b6a98d);border:1px solid rgba(60,30,10,.4);border-radius:4px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--ink-primary, #2b2419);cursor:pointer}.blank-btn-primary.svelte-1krhhra{background:linear-gradient(180deg,#c54a5b,#9b2c3f);color:#fff;border-color:#7a1f30}.welcome-demos-lede.svelte-1krhhra{margin:18px 0 6px;text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-secondary, #6d5e4a)}.welcome-demos.svelte-1krhhra{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:10px}.demo-card.svelte-1krhhra{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px 10px;background:#ffffff73;border:1px solid rgba(0,0,0,.12);border-radius:8px;cursor:pointer;font:inherit;color:inherit;transition:background .12s,transform .12s}.demo-card.svelte-1krhhra:hover{background:#ffffffbf;transform:translateY(-1px)}.demo-thumb.svelte-1krhhra{display:block;width:48px;height:48px;border-radius:4px;background-size:cover;background-position:center;image-rendering:pixelated}.demo-thumb--heart.svelte-1krhhra{background:radial-gradient(circle at 35% 35%,#ffd7d7,#c72b3b 60%,#7a1525);clip-path:path("M24 44C24 44 4 30 4 17C4 8 11 4 16 4C20 4 24 8 24 12C24 8 28 4 32 4C37 4 44 8 44 17C44 30 24 44 24 44Z");background-color:transparent}.demo-thumb--pixel.svelte-1krhhra{background:linear-gradient(45deg,transparent 25%,#ffd7d7 25% 50%,transparent 50% 75%,#ffd7d7 75%) 0 0/12px 12px,#c72b3b;border:2px solid #281616}.demo-title.svelte-1krhhra{font-size:12px;font-weight:600;line-height:1.15;text-align:center}.demo-sub.svelte-1krhhra{font-size:10px;line-height:1.25;color:var(--ink-tertiary, #8a7a64);text-align:center}.step-tabs.svelte-1ld6r3r .tab:where(.svelte-1ld6r3r){gap:6px}.step-num.svelte-1ld6r3r{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#00000052;color:var(--ink-onwood-soft);font-size:10px;font-weight:700}.step-tabs.svelte-1ld6r3r .tab[aria-pressed=true]:where(.svelte-1ld6r3r) .step-num:where(.svelte-1ld6r3r){background:var(--accent-thread);color:#fff}.apply-group.svelte-1ld6r3r{gap:6px}.auto-toggle.svelte-1ld6r3r{background:#00000038;border:none;color:var(--ink-onwood-soft);display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border-radius:999px;cursor:pointer;font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;box-shadow:inset 0 1px 2px #0006,0 1px 0 var(--hl-warm);transition:all .12s var(--ease-default)}.auto-toggle.svelte-1ld6r3r:hover{color:var(--ink-onwood)}.auto-toggle[aria-pressed=true].svelte-1ld6r3r{background:var(--accent-thread-tint);color:var(--ink-onwood);box-shadow:inset 0 0 0 1px var(--accent-thread-soft)}.auto-dot.svelte-1ld6r3r{width:7px;height:7px;border-radius:50%;background:#fff3;box-shadow:inset 0 1px #ffffff4d,0 0 4px #0006}.auto-dot.on.svelte-1ld6r3r{background:var(--accent-thread);box-shadow:0 0 6px var(--accent-thread),inset 0 1px #fff6}.apply-btn.svelte-1ld6r3r{height:28px;padding:0 12px}.text-tool.svelte-b8fcrz{display:flex;flex-direction:column;gap:8px}.field-row.svelte-b8fcrz{display:grid;grid-template-columns:1fr 1fr;gap:8px}.text-toolbar.svelte-b8fcrz{display:flex;align-items:center;gap:10px}.text-new.svelte-b8fcrz{flex:1 1 auto}.text-clear.svelte-b8fcrz{background:none;border:none;color:var(--accent-thread);cursor:pointer;font-size:10px;text-decoration:underline;padding:0;white-space:nowrap}.text-empty-list.svelte-b8fcrz{font-size:10px;font-style:italic;color:var(--ink-onwood-faint);text-align:center;padding:6px 0}.text-list.svelte-b8fcrz{display:flex;flex-direction:column;gap:4px}.text-list-row.svelte-b8fcrz{display:grid;grid-template-columns:1fr auto 18px;gap:6px;align-items:center;padding:6px 8px;font-size:11px;color:var(--ink-onwood);cursor:pointer;border-left:3px solid transparent;border-radius:0 3px 3px 0;background:#0000001a;transition:background .12s var(--ease-default),border-color .12s}.text-list-row.svelte-b8fcrz:hover{background:#0000002e}.text-list-row.active.svelte-b8fcrz{background:var(--accent-thread-tint);border-left-color:var(--accent-thread);border-bottom-left-radius:0;border-bottom-right-radius:0}.text-list-row.svelte-b8fcrz:focus-visible{outline:2px solid var(--accent-thread);outline-offset:-2px}.text-list-content.svelte-b8fcrz{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-list-meta.svelte-b8fcrz{font-family:var(--font-mono);font-size:9px;color:var(--ink-onwood-soft)}.text-list-x.svelte-b8fcrz{background:#00000038;border:none;color:var(--ink-onwood-soft);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;padding:0}.text-list-x.svelte-b8fcrz:hover{color:var(--ink-onwood);background:#00000059}.text-editor.svelte-b8fcrz{background:#0000002e;border-left:3px solid var(--accent-thread);border-radius:0 3px 3px;padding:10px 10px 12px 12px;margin-bottom:4px;display:flex;flex-direction:column;gap:8px;box-shadow:inset 0 1px 4px #0000004d}.text-input.svelte-b8fcrz{background:var(--bg-paper);color:var(--ink-primary);border:1px solid rgba(0,0,0,.4);border-radius:3px;font-family:var(--font-mono);font-size:12px;padding:4px 8px;box-shadow:inset 0 1px 2px #0000004d;outline:none}.text-input-area.svelte-b8fcrz{resize:vertical;min-height:48px;line-height:1.35}.text-input.svelte-b8fcrz:focus{border-color:var(--accent-thread);box-shadow:inset 0 1px 2px #0000004d,0 0 0 2px var(--accent-thread-tint)}.align-group.svelte-b8fcrz{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#00000038;border-radius:4px;padding:2px}.align-btn.svelte-b8fcrz{background:transparent;border:none;color:var(--ink-onwood-soft);font-size:14px;padding:4px 0;border-radius:2px;cursor:pointer;transition:all .1s var(--ease-default)}.align-btn.svelte-b8fcrz:hover{color:var(--ink-onwood);background:#0000002e}.align-btn.active.svelte-b8fcrz{background:var(--accent-thread-tint);color:var(--ink-onwood);box-shadow:inset 0 0 0 1px var(--accent-thread-soft)}.text-colors.svelte-b8fcrz{display:grid;grid-template-columns:repeat(auto-fill,minmax(16px,1fr));gap:3px}.text-color-swatch.svelte-b8fcrz{width:100%;aspect-ratio:1;border:1px solid rgba(0,0,0,.4);border-radius:2px;padding:0;cursor:pointer;box-shadow:inset 0 1px #ffffff4d,0 1px 1px #0000004d;transition:transform .1s var(--ease-default)}.text-color-swatch.svelte-b8fcrz:hover{transform:scale(1.15);z-index:1}.text-color-swatch.active.svelte-b8fcrz{box-shadow:0 0 0 2px var(--accent-thread),0 2px 4px #0006;transform:scale(1.1);z-index:1}.text-empty.svelte-b8fcrz{font-size:10px;font-style:italic;color:var(--ink-onwood-soft)}.text-preview.svelte-b8fcrz{background:var(--bg-paper);color:var(--ink-primary);padding:10px;border-radius:4px;box-shadow:inset 0 1px 2px #0000004d;overflow:hidden;max-height:72px;overflow-y:auto;white-space:pre-wrap}.text-actions.svelte-b8fcrz{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}.text-action-delete.svelte-b8fcrz{background:linear-gradient(180deg,#8a2a2e,#5e1c1f);color:#fff}.text-action-delete.svelte-b8fcrz:hover{filter:brightness(1.1)}.symbol-tool.svelte-1dk2asm{display:flex;flex-direction:column;gap:8px}.symbol-toolbar.svelte-1dk2asm{display:flex;align-items:center;gap:10px}.symbol-new.svelte-1dk2asm{flex:1 1 auto}.symbol-clear.svelte-1dk2asm{background:none;border:none;color:var(--accent-thread);cursor:pointer;font-size:10px;text-decoration:underline;padding:0;white-space:nowrap}.symbol-picker.svelte-1dk2asm{background:#00000038;border-radius:4px;padding:8px;display:flex;flex-direction:column;gap:6px;box-shadow:inset 0 1px 4px #0000004d}.symbol-picker-head.svelte-1dk2asm{display:flex;align-items:center;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-onwood-soft)}.symbol-picker-x.svelte-1dk2asm{background:transparent;border:0;color:var(--ink-onwood-soft);cursor:pointer;font-size:16px;line-height:1}.symbol-picker-x.svelte-1dk2asm:hover{color:var(--ink-onwood)}.symbol-picker-tabs.svelte-1dk2asm{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.symbol-picker-tab.svelte-1dk2asm{background:#ffffff0f;border:0;border-radius:3px;padding:4px 0 3px;cursor:pointer;color:var(--ink-onwood-soft);display:flex;flex-direction:column;align-items:center;gap:0;transition:background .1s}.symbol-picker-tab.svelte-1dk2asm:hover{background:#ffffff1f}.symbol-picker-tab.active.svelte-1dk2asm{background:var(--accent-thread);color:#fff}.symbol-picker-tab-g.svelte-1dk2asm{font-size:14px;line-height:1}.symbol-picker-tab-c.svelte-1dk2asm{font-family:var(--font-mono);font-size:8px;opacity:.75}.symbol-picker-search.svelte-1dk2asm{background:var(--bg-paper);color:var(--ink-primary);border:1px solid rgba(0,0,0,.4);border-radius:3px;font-size:11px;padding:3px 7px;outline:none}.symbol-picker-search.svelte-1dk2asm:focus{border-color:var(--accent-thread);box-shadow:0 0 0 2px var(--accent-thread-tint)}.symbol-picker-grid.svelte-1dk2asm{display:grid;grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:4px;max-height:200px;overflow-y:auto;padding-right:2px}.symbol-picker-tile.svelte-1dk2asm{background:#fffcf0d9;border:.5px solid rgba(0,0,0,.2);border-radius:3px;padding:4px;cursor:pointer;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.symbol-picker-tile.svelte-1dk2asm svg{width:100%;height:100%;image-rendering:pixelated}.symbol-picker-tile.svelte-1dk2asm:hover{transform:translateY(-1px);box-shadow:0 4px 10px #3c1e0a33}.symbol-empty-list.svelte-1dk2asm{font-size:10px;font-style:italic;color:var(--ink-onwood-faint);text-align:center;padding:6px 0}.symbol-empty.svelte-1dk2asm{font-size:10px;font-style:italic;color:var(--ink-onwood-soft)}.symbol-list.svelte-1dk2asm{display:flex;flex-direction:column;gap:4px}.symbol-row.svelte-1dk2asm{display:grid;grid-template-columns:24px 1fr auto 18px;gap:6px;align-items:center;padding:5px 8px;font-size:11px;color:var(--ink-onwood);cursor:pointer;border-left:3px solid transparent;border-radius:0 3px 3px 0;background:#0000001a;transition:background .12s var(--ease-default),border-color .12s}.symbol-row.svelte-1dk2asm:hover{background:#0000002e}.symbol-row.active.svelte-1dk2asm{background:var(--accent-thread-tint);border-left-color:var(--accent-thread);border-bottom-left-radius:0;border-bottom-right-radius:0}.symbol-row-glyph.svelte-1dk2asm{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--bg-paper);border-radius:2px}.symbol-row-glyph.svelte-1dk2asm svg{width:100%;height:100%;image-rendering:pixelated}.symbol-row-name.svelte-1dk2asm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.symbol-row-meta.svelte-1dk2asm{font-family:var(--font-mono);font-size:9px;color:var(--ink-onwood-soft)}.symbol-row-x.svelte-1dk2asm{background:#00000038;border:none;color:var(--ink-onwood-soft);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;padding:0}.symbol-row-x.svelte-1dk2asm:hover{color:var(--ink-onwood);background:#00000059}.symbol-editor.svelte-1dk2asm{background:#0000002e;border-left:3px solid var(--accent-thread);border-radius:0 3px 3px;padding:10px 10px 12px 12px;margin-bottom:4px;display:flex;flex-direction:column;gap:8px;box-shadow:inset 0 1px 4px #0000004d}.symbol-current.svelte-1dk2asm{display:grid;grid-template-columns:28px 1fr auto auto;align-items:center;gap:8px;background:var(--bg-paper);color:var(--ink-primary);border:1px solid rgba(0,0,0,.4);border-radius:3px;padding:6px 10px;cursor:pointer;text-align:left;font:inherit}.symbol-current.svelte-1dk2asm:hover{border-color:var(--accent-thread);box-shadow:0 0 0 2px var(--accent-thread-tint)}.symbol-current-glyph.svelte-1dk2asm{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.symbol-current-glyph.svelte-1dk2asm svg{width:100%;height:100%;image-rendering:pixelated}.symbol-current-name.svelte-1dk2asm{font-size:12px}.symbol-current-dim.svelte-1dk2asm{font-family:var(--font-mono);font-size:10px;color:var(--ink-tertiary, #8a7a64)}.symbol-current-cta.svelte-1dk2asm{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-thread)}.symbol-colors.svelte-1dk2asm{display:grid;grid-template-columns:repeat(auto-fill,minmax(16px,1fr));gap:3px}.symbol-color.svelte-1dk2asm{width:100%;aspect-ratio:1;border:1px solid rgba(0,0,0,.4);border-radius:2px;padding:0;cursor:pointer;box-shadow:inset 0 1px #ffffff4d,0 1px 1px #0000004d;transition:transform .1s var(--ease-default)}.symbol-color.svelte-1dk2asm:hover{transform:scale(1.15);z-index:1}.symbol-color.active.svelte-1dk2asm{box-shadow:0 0 0 2px var(--accent-thread),0 2px 4px #0006;transform:scale(1.1);z-index:1}.symbol-actions.svelte-1dk2asm{display:flex;justify-content:flex-end;gap:6px}.symbol-delete.svelte-1dk2asm{background:linear-gradient(180deg,#8a2a2e,#5e1c1f);color:#fff}.symbol-delete.svelte-1dk2asm:hover{filter:brightness(1.1)}.paint-tool.svelte-b96z42{display:flex;flex-direction:column;gap:8px}.paint-toolbar.svelte-b96z42{display:grid;grid-template-columns:1fr 1fr;gap:6px}.paint-btn.svelte-b96z42{display:flex;align-items:center;justify-content:center;gap:6px;background:#0000002e;border:1px solid rgba(0,0,0,.35);color:var(--ink-onwood);border-radius:4px;padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:background .1s}.paint-btn.svelte-b96z42:hover{background:#00000047}.paint-btn[aria-pressed=true].svelte-b96z42{background:var(--accent-thread, #9b2c3f);color:#fff;border-color:var(--accent-thread, #9b2c3f)}.paint-btn[disabled].svelte-b96z42{opacity:.5;cursor:not-allowed}.paint-btn-icon.svelte-b96z42{font-size:14px;line-height:1}.paint-active.svelte-b96z42{font-size:11px;color:var(--ink-onwood);background:#0000002e;border-left:3px solid var(--accent-thread);padding:6px 10px;border-radius:0 3px 3px 0;display:flex;gap:6px;align-items:center;flex-wrap:wrap}.paint-active.svelte-b96z42 strong:where(.svelte-b96z42){font-family:var(--font-mono)}.paint-active-name.svelte-b96z42{color:var(--ink-onwood-soft);font-size:10.5px}.paint-active-erase.svelte-b96z42{border-left-color:var(--ink-onwood-soft)}.paint-section-label.svelte-b96z42{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-onwood-soft);margin-top:2px}.paint-colors.svelte-b96z42{display:grid;grid-template-columns:repeat(auto-fill,minmax(16px,1fr));gap:3px}.paint-color.svelte-b96z42{width:100%;aspect-ratio:1;border:1px solid rgba(0,0,0,.4);border-radius:2px;padding:0;cursor:pointer;box-shadow:inset 0 1px #ffffff4d,0 1px 1px #0000004d;transition:transform .1s var(--ease-default)}.paint-color.svelte-b96z42:hover{transform:scale(1.15);z-index:1}.paint-color.active.svelte-b96z42{box-shadow:0 0 0 2px var(--accent-thread),0 2px 4px #0006;transform:scale(1.1);z-index:1}.paint-empty.svelte-b96z42{font-size:10px;font-style:italic;color:var(--ink-onwood-faint);text-align:center;padding:6px 0}.paint-footer.svelte-b96z42{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:10px;color:var(--ink-onwood-soft);padding-top:4px;border-top:.5px dashed rgba(0,0,0,.25)}.paint-clear.svelte-b96z42{background:none;border:none;color:var(--accent-thread);cursor:pointer;font-size:10px;text-decoration:underline;padding:0}.mode-row.svelte-u7b2b9{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid rgba(0,0,0,.25);background:#0000002e}.mode-label.svelte-u7b2b9{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-onwood-soft);margin-right:4px}.mode-btn.svelte-u7b2b9{flex:1;background:transparent;color:var(--ink-onwood);border:1px solid rgba(0,0,0,.35);border-radius:4px;padding:5px 8px;font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}.mode-btn.svelte-u7b2b9:hover{background:#0000002e}.mode-btn[aria-pressed=true].svelte-u7b2b9{background:var(--accent-thread, #c72b3b);border-color:var(--accent-thread, #c72b3b);color:#fff}.size-header.svelte-u7b2b9{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}.size-source.svelte-u7b2b9{font-family:var(--font-mono);font-size:10px;color:var(--ink-onwood-soft)}.aspect-lock.svelte-u7b2b9{display:inline-flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-onwood-soft);padding:3px 6px;border-radius:3px;background:#0000002e;transition:all .12s var(--ease-default)}.aspect-lock.svelte-u7b2b9:hover{background:#0000004d}.aspect-lock.svelte-u7b2b9 input:where(.svelte-u7b2b9){display:none}.aspect-lock-icon.svelte-u7b2b9{font-size:12px;line-height:1}.aspect-lock.svelte-u7b2b9:has(input:where(.svelte-u7b2b9):checked){background:var(--accent-thread-tint);color:var(--ink-onwood);box-shadow:inset 0 0 0 1px var(--accent-thread-soft)}.transform-row.svelte-u7b2b9{display:flex;gap:4px;align-items:center;padding:4px 0}.transform-sep.svelte-u7b2b9{width:1px;height:18px;background:#0006;margin:0 4px;box-shadow:1px 0 #fff8e614}.transform-btn.svelte-u7b2b9{width:30px;height:28px;background:linear-gradient(180deg,#dfd7c5,#b6a98d);border:1px solid var(--bg-metal-edge);color:#2a1f14;border-radius:var(--r-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fff8e6a6,inset 0 -1px #0000000f,0 1px 2px #3c1e0a40;transition:all .1s var(--ease-default)}.transform-btn.svelte-u7b2b9:hover:not(:disabled){background:linear-gradient(180deg,#ece4d2,#bfb298)}.transform-btn.svelte-u7b2b9:active:not(:disabled){background:linear-gradient(180deg,#b6a98d,#dfd7c5);transform:translateY(.5px)}.transform-btn.svelte-u7b2b9:disabled{opacity:.4;cursor:not-allowed}.adjust-actions.svelte-u7b2b9{display:flex;justify-content:flex-end;padding:4px 0 0}.adjust-reset.svelte-u7b2b9{background:#00000038;border:none;color:var(--ink-onwood-soft);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:999px;cursor:pointer;box-shadow:inset 0 1px 2px #0006,0 1px 0 var(--hl-warm);transition:all .12s var(--ease-default)}.adjust-reset.svelte-u7b2b9:hover:not(:disabled){color:var(--ink-onwood);background:var(--accent-thread-tint);box-shadow:inset 0 0 0 1px var(--accent-thread-soft),inset 0 1px 2px #0000004d}.adjust-reset.svelte-u7b2b9:disabled{opacity:.35;cursor:not-allowed}.thread-row.svelte-1en6eyb{cursor:pointer;outline:none}.thread-row.svelte-1en6eyb:focus-visible{box-shadow:inset 0 0 0 2px var(--accent-thread-soft)}.thread-symbol.svelte-1en6eyb{border:none;cursor:pointer;font:inherit;color:inherit;transition:transform .1s var(--ease-default),box-shadow .1s;padding:0}.thread-symbol.svelte-1en6eyb:hover{transform:scale(1.12);box-shadow:inset 0 1px #fff8e633,inset 0 -1px #00000073,0 0 0 2px var(--accent-thread-tint)}.thread-equiv.svelte-1en6eyb{grid-column:1 / -1;font-family:var(--font-mono);font-size:9px;color:var(--ink-onwood-soft);margin-top:2px;letter-spacing:.02em;cursor:help}.thread-equiv-brand.svelte-1en6eyb{color:var(--accent-thread);font-weight:700;margin-right:1px}.thread-equiv-sep.svelte-1en6eyb{margin:0 4px;color:var(--ink-onwood-faint)}.thread-replace.svelte-1en6eyb{padding:8px 14px 12px;background:#0000002e;border-bottom:1px solid rgba(0,0,0,.25);box-shadow:inset 0 1px 4px #00000059}.thread-replace-header.svelte-1en6eyb{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-onwood-soft)}.symbol-hint.svelte-1en6eyb{font-size:9px;letter-spacing:.02em;text-transform:none;color:var(--ink-onwood-faint);font-style:italic}.thread-replace-filter.svelte-1en6eyb{flex:1;background:var(--bg-paper);color:var(--ink-primary);border:1px solid rgba(0,0,0,.4);border-radius:3px;font-family:var(--font-mono);font-size:11px;padding:3px 6px;box-shadow:inset 0 1px 2px #0000004d;outline:none}.thread-replace-filter.svelte-1en6eyb:focus{border-color:var(--accent-thread);box-shadow:inset 0 1px 2px #0000004d,0 0 0 2px var(--accent-thread-tint)}.thread-replace-grid.svelte-1en6eyb{display:grid;grid-template-columns:repeat(auto-fill,minmax(20px,1fr));gap:4px}.thread-replace-swatch.svelte-1en6eyb{width:100%;aspect-ratio:1;border:1px solid rgba(0,0,0,.5);border-radius:3px;cursor:pointer;padding:0;box-shadow:inset 0 1px #ffffff4d,0 1px 1px #0000004d;transition:transform .1s var(--ease-default)}.thread-replace-swatch.svelte-1en6eyb:hover{transform:scale(1.18);z-index:1;border-color:var(--accent-thread);box-shadow:0 0 0 2px var(--accent-thread-tint),0 2px 4px #0006}.thread-replace-empty.svelte-1en6eyb,.thread-replace-more.svelte-1en6eyb{font-size:10px;color:var(--ink-onwood-soft);font-style:italic;padding:4px 0}.symbol-grid.svelte-1en6eyb{display:grid;grid-template-columns:repeat(auto-fill,minmax(24px,1fr));gap:3px;max-height:220px;overflow-y:auto;padding:2px}.symbol-grid.svelte-1en6eyb::-webkit-scrollbar{width:6px}.symbol-grid.svelte-1en6eyb::-webkit-scrollbar-thumb{background:#0000004d;border-radius:3px}.symbol-cell.svelte-1en6eyb{border:1px solid rgba(0,0,0,.4);background:#0000002e;color:var(--ink-onwood);font-family:var(--font-mono);font-size:14px;font-weight:700;aspect-ratio:1;border-radius:3px;cursor:pointer;padding:0;transition:all .1s var(--ease-default);box-shadow:inset 0 1px #fff8e60f,inset 0 -1px #0006}.symbol-cell.svelte-1en6eyb:hover{background:#fff8e62e;color:var(--ink-onwood);border-color:var(--accent-thread);transform:scale(1.15);z-index:1}.symbol-cell.in-use.svelte-1en6eyb{color:var(--ink-onwood-faint);opacity:.55}.symbol-cell.current.svelte-1en6eyb{background:var(--accent-thread-tint);border-color:var(--accent-thread);color:var(--ink-onwood);opacity:1}.canvas-viewport.painting.svelte-1ebrlgr{cursor:crosshair}.canvas-empty.svelte-1ebrlgr{color:var(--ink-secondary);font-family:var(--font-display);font-style:italic}.canvas-frame.dimmed.svelte-1ebrlgr{transition:filter .15s var(--ease-default);filter:brightness(.88) saturate(.9)}.canvas-regen-pill.svelte-1ebrlgr{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:6;pointer-events:none}.status-toast.svelte-1piydef{margin-left:auto;padding:2px 10px;border-radius:999px;background:var(--accent-thread-tint);color:var(--ink-onwood);font-family:var(--font-mono);font-size:10px;letter-spacing:.02em;box-shadow:inset 0 0 0 1px var(--accent-thread-soft);animation:svelte-1piydef-toast-in .2s var(--ease-default)}@keyframes svelte-1piydef-toast-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}
