.sidebar{width:360px;min-width:360px;max-width:360px;background-color:var(--white);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;padding:10px;box-sizing:border-box}.sidebar-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;width:100%;min-width:0;margin-bottom:10px;overflow:hidden}.sidebar-tab{width:100%;min-width:0;max-width:100%;border-radius:0;padding:0;box-sizing:border-box}.sidebar-tab:first-child{border-top-left-radius:999px;border-bottom-left-radius:999px}.sidebar-tab:last-child{border-top-right-radius:999px;border-bottom-right-radius:999px}.sidebar-tabs button{width:100%;min-width:0;max-width:100%;height:40px;padding:0 4px;border:1.5px solid #3a3836;color:#1e1c1a;border-radius:0;background:#fff;font-weight:600;font-size:11px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.sidebar-tabs button:hover{background:#f2f0ec;border-color:#2f2b27}.sidebar-tabs button.active,.sidebar-tab.active{background:#2f2b27;color:#fff;border-color:#2f2b27}.sidebar-content{flex:1;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding:.75rem 10px 0 0}.form-group{margin-bottom:.85rem}.form-group label{display:block;margin-bottom:.25rem;font-weight:500;font-size:.9rem}.form-group input,.form-group select{width:100%;max-width:100%;padding:9px 10px;font-size:14px;border:1px solid #ccc;border-radius:6px;box-sizing:border-box}.sidebar button{padding:9px 10px;font-size:14px;border-radius:6px;cursor:pointer;box-sizing:border-box;max-width:100%}.sidebar input,.sidebar select,.sidebar textarea,.sidebar button{max-width:100%}@keyframes cautionPulseHard{0%{box-shadow:0 0 #f000;transform:translate(0)}35%{box-shadow:0 0 26px #ff000073}50%{transform:translate(-2px)}65%{transform:translate(2px)}to{box-shadow:0 0 #f000;transform:translate(0)}}.rebuild-warning--sticky{position:sticky;top:0;z-index:50}.rebuild-warning{border:3px solid rgba(200,0,0,.95);background:#ffdcdcfa;padding:14px 12px;border-radius:12px;margin:10px 0 14px;animation:cautionPulseHard .75s infinite}.rebuild-warning__title{font-weight:900;font-size:.95rem;letter-spacing:.4px;margin-bottom:10px;text-transform:uppercase}.rebuild-warning__actions{display:flex;gap:10px}.rebuild-warning__danger{flex:1;border:2px solid rgba(200,0,0,.95);background:#c800002e;font-weight:800}.rebuild-warning__cancel{flex:1;border:2px solid #777;background:#f2f2f2;font-weight:700}.rebuild-dimmed{opacity:.45!important;filter:grayscale(.15)!important;pointer-events:none!important}.rebuild-dimmed *{pointer-events:none!important}@media (max-width: 768px){.sidebar{width:100%;max-height:300px}}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 520px){.form-row{grid-template-columns:1fr}}.sidebar-tabs .sidebar-tab.active{background:#2f2b27!important;color:#fff!important;border-color:#2f2b27!important}.sidebar-content input,.sidebar-content select,.sidebar-content textarea{background:#fff;border:1.5px solid #3a3836;color:#1e1c1a;border-radius:6px;padding:6px 8px;font-weight:500;transition:border-color .15s ease,box-shadow .15s ease}.sidebar-content input:focus,.sidebar-content select:focus,.sidebar-content textarea:focus{border-color:#2f2b27;outline:none;box-shadow:0 0 0 2px #2f2b2726}#width,#height{border:1.5px solid #3a3836!important;background:#fff!important;color:#1e1c1a!important;font-weight:500;border-radius:6px;padding:6px 8px}.grid-size-box{padding:10px 12px;border:1.5px solid #3a3836;border-radius:8px;font-size:14px;background:#fff;box-sizing:border-box;color:#1e1c1a}.palette-item{display:flex;align-items:center;gap:.5rem;width:100%;min-width:0;max-width:100%;padding:.5rem;margin-bottom:.5rem;background:#fff;border:1.5px solid #3a3836;border-radius:8px;cursor:pointer;overflow:hidden;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.palette-text{flex:1 1 auto;min-width:0;overflow:hidden}.palette-code,.palette-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.palette-remove,.palette-add{flex-shrink:0}.palette-item:hover{background:#f2f0ec;border-color:#2f2b27}.palette-item.active{border-color:#2f2b27;box-shadow:0 0 0 2px #2f2b272e}.palette-item .color-swatch{width:30px;height:30px;border-radius:6px;border:1.5px solid #3a3836;flex-shrink:0}.palette-text{flex:1 1 auto;min-width:0;max-width:100%;display:flex;flex-direction:column;line-height:1.1;overflow:hidden}.palette-code,.palette-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-code{font-weight:700;color:#1e1c1a;font-size:.9rem}.palette-name{font-size:.8rem;color:#555453}.palette-search-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;min-width:0;width:100%}.palette-search{flex:1 1 auto;width:auto;min-width:0;max-width:100%;padding:8px 10px;border-radius:6px;border:1.5px solid #3a3836;margin-bottom:0;font-size:14px;background:#fff;color:#1e1c1a}.palette-search-row>*{min-width:0}.palette-clear,.palette-add,.palette-remove,.linklike{flex-shrink:0}.palette-section-title{margin:12px 0 8px;font-size:14px;font-weight:800;color:#2f2b27}.palette-hint{margin:6px 0 10px;font-size:13px;color:#555453}.palette-clear{padding:8px 12px;font-size:13px}.palette-empty{font-size:13px;color:#555453;margin:6px 0 10px}.linklike{background:none;border:none;padding:0;margin:0;color:#2f2b27;font-weight:700;cursor:pointer;text-decoration:underline}.palette-add,.palette-remove{padding:6px 10px;font-size:12px}.palette-add,.palette-remove,.palette-clear,.recent-thread-chip,.thread-setting-select{flex-shrink:0;max-width:100%}.palette-results{display:flex;flex-wrap:wrap;gap:8px 12px;margin-bottom:10px;font-size:12px;color:#555453;min-width:0}.color-palette,.active-thread,.thread-settings,.palette-list,.palette-search-row,.recent-threads-list{width:100%;min-width:0;max-width:100%}.palette-item,.active-thread,.thread-settings,.yardage-settings-note,.grid-size-box{width:100%;max-width:100%}.yardage-note{margin-top:8px;font-size:12px;color:#555453}.yardage-calculator h2{margin-bottom:8px}.yardage-calculator p{margin:6px 0}.yardage-calculator div{margin-bottom:4px}.yardage-calculator{font-size:14px}.yardage-calculator h2{font-size:16px;font-weight:700}.yardage-calculator .color-swatch,.yardage-calculator .yardage-swatch{width:28px;height:28px;border-radius:6px;border:1.5px solid #3a3836;flex-shrink:0}.sidebar-tabs button.active,.sidebar-tabs .sidebar-tab.active{background:#2f2b27!important;color:#fff!important;border-color:#2f2b27!important}.sidebar-tabs button,.sidebar-tabs .sidebar-tab{border-width:1.5px!important;border-style:solid!important;border-color:#3a3836!important}.active-thread{margin-bottom:30px!important;padding:10px;border:1.5px solid #3a3836;border-radius:8px;background:#fff}.active-thread-label{font-size:12px;font-weight:600;margin-bottom:8px;color:#555453}.active-thread-display{display:flex;align-items:center;gap:10px}.active-color-box{width:34px;height:34px;border-radius:6px;border:1.5px solid #3a3836;flex-shrink:0}.active-color-info{display:flex;flex-direction:column;line-height:1.2}.active-color-code{font-size:12px;font-weight:600;color:#4d4c4c}.active-color-name{font-size:12px;color:#666}.palette-item.active{outline:2px solid #497fd2;outline-offset:0;transform:none;border-radius:8px}.palette-item{transition:outline .15s ease,box-shadow .15s ease,border-color .15s ease}.recent-threads-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;border:none}.recent-thread-chip{display:flex;align-items:center;gap:6px;padding:6px 8px;-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1px solid #8f8f8f;border-radius:999px;background:#fff;cursor:pointer;font-size:12px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.recent-thread-chip:hover{transform:translateY(-1px);border-color:#497fd2;box-shadow:0 1px 4px #00000014}.recent-thread-swatch{width:12px;height:12px;border-radius:50%;border:1px solid #cfcfcf;flex-shrink:0}.recent-thread-code{color:#4d4c4c;font-weight:600}.thread-settings{margin-bottom:12px;padding:10px;border:1.5px solid #3a3836;border-radius:8px;background:#fff}.thread-settings-title{font-size:12px;font-weight:600;margin-bottom:8px;color:#555453}.thread-type-group{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.thread-radio{display:flex;align-items:center;gap:6px;font-size:12px;color:#4d4c4c}.thread-setting-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.active-thread-display,.thread-setting-row{min-width:0;width:100%}.active-color-info,.thread-setting-row>*{min-width:0}.thread-setting-label{font-size:12px;font-weight:600;color:#4d4c4c}.thread-setting-select{min-width:72px;padding:4px 6px;border:1.5px solid #3a3836;border-radius:6px;background:#fff;font-size:12px;color:#4d4c4c}.yardage-settings-note{margin:16px 0!important;padding:12px 14px!important;border:1.5px solid #3a3836!important;border-radius:8px!important;background:#fff!important;font-size:14px!important;line-height:1.5!important;color:#4d4c4c!important}.yardage-settings-note div{margin-bottom:3px}.sidebar *,.sidebar *:before,.sidebar *:after{box-sizing:border-box}.sidebar-content>*{min-width:0;max-width:100%}.sidebar .form-group,.sidebar .section,.sidebar .card,.sidebar .panel,.sidebar .palette-section,.sidebar .yardage-section,.sidebar .project-section,.sidebar .row,.sidebar .form-row,.sidebar .input-row,.sidebar .palette-row,.sidebar .controls-row{min-width:0;max-width:100%}.sidebar .row>*,.sidebar .form-row>*,.sidebar .input-row>*,.sidebar .palette-row>*,.sidebar .controls-row>*{min-width:0;max-width:100%}.sidebar-tabs,.sidebar-content,.form-group,.form-row,.palette-search-row,.palette-results,.palette-item,.active-thread,.thread-settings,.yardage-settings-note,.grid-size-box,.rebuild-warning{width:100%;max-width:100%;min-width:0}.form-row>*,.palette-search-row>*,.palette-results>*{min-width:0;max-width:100%}.palette-list,.yardage-calculator{width:100%;max-width:100%;min-width:0;padding-right:2px;overflow-x:hidden}.palette-list{width:100%;max-width:100%;min-width:0;overflow-x:hidden}.palette-item{width:100%;max-width:100%;min-width:0;padding-right:4px}.palette-text{flex:1 1 auto;min-width:0;max-width:100%;overflow:hidden}.palette-code,.palette-name{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-search-row,.palette-results{width:100%;max-width:100%;min-width:0;overflow:hidden}.palette-list,.active-thread,.thread-settings,.recent-threads-list,.yardage-calculator{width:100%;max-width:100%;min-width:0;overflow-x:hidden}.palette-search-row,.active-thread-display,.thread-setting-row{display:flex;align-items:center;gap:8px;width:100%;max-width:100%;min-width:0;overflow:hidden}.palette-search,.palette-text,.active-color-info{flex:1 1 0%;min-width:0;max-width:100%;overflow:hidden}.palette-item{display:flex;align-items:center;gap:8px;width:100%;max-width:100%;min-width:0;overflow:hidden}.palette-code,.palette-name,.active-color-code,.active-color-name{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-add,.palette-remove,.palette-clear,.linklike,.recent-thread-chip,.thread-setting-select{flex:0 0 auto;max-width:92px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.palette-add,.palette-remove,.palette-clear,.recent-thread-chip,.thread-setting-select{max-width:100%;min-width:0;flex-shrink:1}.recent-thread-chip{padding:4px 6px;font-size:11px}.thread-setting-select{min-width:0;width:auto;max-width:88px;padding:4px;font-size:11px}.palette-add,.palette-remove,.palette-clear{padding:4px 6px;font-size:11px}.sidebar-panel{width:100%;max-width:100%;min-width:0;overflow-x:hidden}.palette-search-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;width:100%}.active-thread-display{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;width:100%}.thread-setting-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;width:100%}.palette-item{display:grid;grid-template-columns:30px minmax(0,1fr) auto;align-items:center;gap:8px;width:100%}.palette-text,.active-color-info{min-width:0;overflow:hidden}.palette-code,.palette-name,.active-color-code,.active-color-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-threads-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:8px;width:100%}.recent-thread-chip{width:100%;min-width:0;justify-content:center}.sidebar-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;width:100%;min-width:0;overflow:hidden}.sidebar-tab,.sidebar-tabs button{width:100%;min-width:0;max-width:100%}.sidebar-tabs button{display:flex;align-items:center;justify-content:center;padding:0 4px;font-size:13px}.grid-cell{position:relative;overflow:visible;width:11px;min-width:11px;max-width:11px;height:18px;min-height:18px;max-height:18px;flex:0 0 11px}.stitch-shape{position:absolute;left:50%;top:50%;width:16px;height:20px;transform:translate(-50%,-50%);border-radius:999px;pointer-events:none}.stitch-shape.loop-short{width:16px;height:17px}.stitch-shape.loop-medium{width:16px;height:20px}.stitch-shape.loop-tall{width:15px;height:23px}.stitch-shape.dir-up{transform:translate(-50%,-50%) rotate(0)}.stitch-shape.dir-down{transform:translate(-50%,-50%) rotate(180deg)}.stitch-shape.dir-left{transform:translate(-50%,-50%) rotate(-90deg)}.stitch-shape.dir-right{transform:translate(-50%,-50%) rotate(90deg)}.stitch-shape.dir-up-left{transform:translate(-50%,-50%) rotate(-45deg)}.stitch-shape.dir-up-right{transform:translate(-50%,-50%) rotate(45deg)}.stitch-shape.dir-down-left{transform:translate(-50%,-50%) rotate(-135deg)}.stitch-shape.dir-down-right{transform:translate(-50%,-50%) rotate(135deg)}.grid-cell.selected .grid-stitch,.grid-cell.selected .cell-stitch,.grid-cell.selected .stitch,.grid-cell.selected .stitch-shape{box-shadow:0 0 0 2px #497fd2,0 0 14px #497fd2f2,0 0 26px #497fd2d9,0 0 36px #497fd28c;filter:brightness(1.14)}.cell-stitch.dragging{opacity:.25;filter:blur(.3px)}.canvas-container{flex:1;overflow:auto;background-color:#f5f5f5;padding:1rem;position:relative;min-height:0}.canvas-wrapper{transform-origin:top left;width:max-content;height:max-content;display:inline-block;transition:transform .2s ease}.design-canvas{position:relative}.free-stitch-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:20;overflow:visible}.canvas-row{display:flex;flex-direction:row;align-items:flex-start;height:18px;min-height:18px}.grid-overlay{pointer-events:none}.grid-cell:before{content:"";position:absolute;left:50%;top:50%;width:78;height:82%;transform:translate(-50%,-50%);transform-origin:center;border-radius:65% 35% 60% 40%/45% 55%;background:inherit;box-shadow:inset 0 1px 1px #ffffff6b,inset 0 -1px 2px #00000038,0 0 1px #00000014;pointer-events:none}.grid-cell:after{content:"";position:absolute;left:50%;top:50%;width:26%;height:34%;transform:translate(-50%,-95%);border-radius:999px;background:#ffffff2e;pointer-events:none}.grid-cell.empty:before,.grid-cell.empty:after{display:none}.grid-cell.loop-short:before{width:44%;height:68%}.grid-cell.loop-medium:before{width:50%;height:82%}.grid-cell.loop-tall:before{width:56%;height:94%}.grid-cell.dir-up:before{transform:translate(-50%,-50%) rotate(0) skewY(-6deg)}.grid-cell.dir-down:before{transform:translate(-50%,-50%) rotate(180deg) skewY(-6deg)}.grid-cell.dir-right:before{transform:translate(-50%,-50%) rotate(90deg) skewY(-8deg)}.grid-cell.dir-left:before{transform:translate(-50%,-50%) rotate(-90deg) skewY(-8deg)}.grid-cell.dir-up-right:before{transform:translate(-50%,-50%) rotate(45deg) skewY(-7deg)}.grid-cell.dir-up-left:before{transform:translate(-50%,-50%) rotate(-45deg) skewY(-7deg)}.grid-cell.dir-down-right:before{transform:translate(-50%,-50%) rotate(135deg) skewY(-7deg)}.grid-cell.dir-down-left:before{transform:translate(-50%,-50%) rotate(-135deg) skewY(-7deg)}.canvas-placeholder{display:flex;justify-content:center;align-items:center;height:400px;background-color:var(--white);border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.mode-toggle{display:flex;background:#efeae2;border-radius:999px;padding:4px;box-shadow:0 2px 6px #00000014}.canvas-toolbar{width:100%;align-self:stretch;display:flex;justify-content:flex-end;margin-bottom:12px}.mode-toggle button{border:1.5px solid #3a3836;background:#fff;padding:8px 14px;border-radius:999px;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none;color:#1e1c1a;font-weight:500;transition:all .2s ease}.mode-toggle button:hover{background:#f2f0ec;border-color:#2f2b27}.mode-toggle button.active{background:#2f2b27;color:#fff;border-color:#2f2b27}.tool-status{display:flex;align-items:center}.status-pill{display:inline-flex;align-items:center;gap:12px;height:44px;padding:0 16px;font-size:14px;border-radius:999px;background:#fff;border:1.5px solid #3a3836;color:#1e1c1a;font-weight:600}.status-pill .color-swatch,.status-pill .color-dot{width:34px;height:34px;border-radius:50%;border:2px solid #2f2b27;flex-shrink:0}.color-swatch{width:12px;height:12px;min-width:12px;min-height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.15);box-shadow:inset 0 1px 1px #fff6}.color-swatch{display:inline-block;width:12px;height:12px;min-width:12px;min-height:12px;border-radius:50%;margin-right:6px;border:1px solid rgba(0,0,0,.15);box-shadow:inset 0 1px 1px #fff6}@media (max-width: 768px){.canvas-container{padding:1rem}}.ruler-frame{display:grid;align-items:start;justify-items:start;width:max-content}.ruler-corner{width:28px;height:28px;background:#fff;border-right:1px solid #3a3836;border-bottom:1px solid #3a3836;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-size:8px;color:#3a3836}.top-ruler{position:relative;height:28px;background:#fff;border-bottom:1px solid #3a3836;box-sizing:border-box}.left-ruler{position:relative;width:28px;background:#fff;border-right:1px solid #3a3836;box-sizing:border-box}.bottom-ruler{position:relative;height:28px;background:#fff;border-top:1px solid #3a3836;box-sizing:border-box}.right-ruler{position:relative;width:28px;background:#fff;border-left:1px solid #3a3836;box-sizing:border-box}.ruler-tick{position:absolute;color:#3a3836;font-size:8px}.ruler-tick.top{top:0;transform:translate(-50%)}.ruler-tick.left{left:0;transform:translateY(-50%)}.ruler-tick.bottom{bottom:0;transform:translate(-50%)}.ruler-tick.right{right:0;transform:translateY(-50%)}.ruler-tick.top:after,.ruler-tick.bottom:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:1px;background:#3a3836}.ruler-tick.left:after,.ruler-tick.right:after{content:"";position:absolute;top:50%;transform:translateY(-50%);height:1px;background:#3a3836}.ruler-tick.top:after{bottom:0}.ruler-tick.bottom:after{top:0}.ruler-tick.left:after{right:0}.ruler-tick.right:after{left:0}.ruler-tick.top.minor:after,.ruler-tick.bottom.minor:after{height:4px}.ruler-tick.top.mid:after,.ruler-tick.bottom.mid:after{height:7px}.ruler-tick.top.major:after,.ruler-tick.bottom.major:after{height:10px;background:#000}.ruler-tick.left.minor:after,.ruler-tick.right.minor:after{width:4px}.ruler-tick.left.mid:after,.ruler-tick.right.mid:after{width:7px}.ruler-tick.left.major:after,.ruler-tick.right.major:after{width:10px;background:#000}.ruler-tick.top .ruler-label{position:absolute;top:2px;left:50%;transform:translate(-50%);white-space:nowrap}.ruler-tick.bottom .ruler-label{position:absolute;bottom:2px;left:50%;transform:translate(-50%);white-space:nowrap}.ruler-tick.left .ruler-label{position:absolute;top:50%;left:2px;transform:translateY(-50%);white-space:nowrap}.ruler-tick.right .ruler-label{position:absolute;top:50%;right:2px;transform:translateY(-50%);white-space:nowrap}.canvas-container.hand-mode{cursor:grab}.canvas-container.hand-mode.is-panning,.canvas-container.hand-mode:active{cursor:grabbing}.view-reset-button{border:1px solid #a8a8a8;border-radius:999px;padding:.5rem .9rem;font-size:.9rem;font-weight:600;cursor:pointer;background:#fff;color:#333;box-shadow:0 1px 3px #0000001f;transition:background .2s ease,transform .2s ease}.view-reset-button:hover{background:#f2f2f2;border-color:#888}.view-reset-button:active{transform:translateY(1px)}.mini-map-panel{position:absolute;top:90px;right:30px;width:170px;background:#fff;border:1px solid #d8d8d8;border-radius:10px;box-shadow:0 8px 18px #00000014;padding:10px;z-index:50}.mini-map-title{padding:.6rem .85rem;font-size:.9rem;font-weight:700;border-bottom:1px solid #e3e3e3;background:#f8f8f8}.mini-map-body{padding:1rem;font-size:.85rem;color:#555;min-height:120px;display:flex;align-items:center;justify-content:center}.mini-map-grid{display:grid;gap:1px;justify-content:center;align-content:center}.mini-map-cell{border-radius:1px;background:transparent}.mini-map-stage{position:relative;display:inline-block}.mini-map-grid{position:relative;z-index:1}.mini-map-viewport{position:absolute;border:2px solid #4d7cff;background:#4d7cff1f;border-radius:4px;box-sizing:border-box;pointer-events:none;z-index:2}@keyframes erasePulse{0%{opacity:.45}50%{opacity:.85}to{opacity:.45}}.erase-preview-pulse{animation:erasePulse .9s ease-in-out infinite}.brush-size-badge.pulse{animation:badgePulse .28s ease-out}@keyframes badgePulse{0%{transform:scale(1);box-shadow:0 0 #0000}40%{transform:scale(1.28);box-shadow:0 0 14px #00000052}to{transform:scale(1);box-shadow:0 0 #0000}}.canvas-zoom-ui{position:absolute;right:16px;bottom:16px;display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fffffff5;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 6px 18px #0000001f;z-index:30}.canvas-zoom-ui button{min-width:34px;height:34px;border-radius:8px;border:1px solid var(--border-color);background:var(--white);cursor:pointer;font-weight:600}.canvas-zoom-ui span{min-width:52px;text-align:center;font-size:13px;font-weight:600}.design-canvas.fabric-preview-mode{background:transparent!important}.ruler-frame.fabric-preview-mode{display:block!important}.fabric-preview-mode .top-ruler,.fabric-preview-mode .bottom-ruler,.fabric-preview-mode .left-ruler,.fabric-preview-mode .right-ruler,.fabric-preview-mode .ruler-corner{display:none!important}.free-stitch{position:absolute;display:block;width:12px;height:20px;border-radius:999px;transform:translate(-50%,-50%);pointer-events:none;z-index:20}.floating-stitch-overlay{position:absolute;z-index:200;pointer-events:none;opacity:1}.floating-stitch-shape{width:13px;border-radius:999px;box-shadow:0 1px 1px #0000002e}.floating-stitch-overlay{pointer-events:none}.floating-stitch-shape{border-radius:999px;box-shadow:0 6px 14px #00000040;transform:scale(1.08);transition:transform .08s ease,box-shadow .08s ease}.stitch-action-pad{position:absolute;z-index:1400;display:flex;flex-direction:column;gap:4px;padding:6px;min-width:154px;border-radius:12px;background:#fffffffa;border:1.5px solid rgba(73,127,210,.95);box-shadow:0 10px 24px #0000002e,0 0 10px #497fd2a6,0 0 22px #497fd273;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto}.stitch-action-pad:hover{box-shadow:0 12px 28px #00000038,0 0 14px #497fd2bf,0 0 28px #497fd28c}.stitch-pad-grab-handle{height:10px;border-radius:999px;background:#00000029;cursor:grab;pointer-events:auto;flex:0 0 auto}.stitch-pad-grab-handle:hover{background:#0000003d}.stitch-pad-grab-handle:active{cursor:grabbing;background:#0000004d}.stitch-pad-row.utility{display:flex;align-items:center;justify-content:space-between;gap:6px}.stitch-pad-grid{display:flex;flex-direction:column;gap:6px}.stitch-pad-grid.horizontal-layout{flex-direction:row;align-items:stretch;gap:10px;pointer-events:auto}.stitch-pad-column{display:flex;flex-direction:column;gap:6px;flex:0 0 auto}.stitch-pad-section-label{font-size:9px;font-weight:800;letter-spacing:.8px;text-align:center;color:#1f2937}.stitch-pad-section-label.duplicate-label{color:#1f2937}.stitch-pad-divider{height:1px;background:#3a38362e;margin:2px 0}.stitch-pad-divider.vertical{width:1px;height:auto;align-self:stretch;margin:0;background:#3a38362e}.stitch-pad-cell{display:flex;justify-content:center;align-items:center;gap:6px}.stitch-pad-cell.horizontal{justify-content:center}.stitch-pad-btn{width:30px;height:30px;min-width:30px;min-height:30px;padding:0;border:1px solid rgba(58,56,54,.8);border-radius:8px;background:#fff;color:#000;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;cursor:pointer;line-height:1;transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-color .14s ease}.stitch-pad-btn.duplicate{background:#f3f4f6;border-color:#6b7280;color:#000}.stitch-pad-btn.wide{width:auto;min-width:56px;padding:0 8px;font-size:10px;font-weight:700;letter-spacing:.3px}.stitch-pad-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #00000029;background:#fffdf9}.stitch-pad-btn.duplicate:hover{background:#e5e7eb;border-color:#4b5563}.stitch-pad-btn:active{transform:translateY(0)}.stitch-pad-btn.danger:hover{background:#fff3f3;border-color:#b64949;color:#8b2e2e}.stitch-pad-icon{width:15px;height:15px;display:block;stroke:#000;stroke-width:2.35;stroke-linecap:round;stroke-linejoin:round;fill:none;pointer-events:none}.toolbar{background-color:var(--white);border-bottom:1px solid #3a3836;padding:8px 10px;display:flex;flex-direction:column;gap:8px}.toolbar-main{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;width:100%}.toolbar-section{display:flex;flex-direction:column;gap:3px;min-width:220px}.toolbar-label{width:100%;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#5a5652;margin-bottom:4px}.tool-buttons{display:grid;grid-template-columns:repeat(2,minmax(96px,1fr));gap:10px;width:100%}.tool-buttons button{width:100%;display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 10px;background:linear-gradient(to bottom,#fff,#f7f4ef);color:#2f2d2b;border:1px solid #3a3836;border-radius:10px;text-align:center;font-weight:600;font-size:13px;line-height:1;cursor:pointer;gap:6px;box-shadow:0 1px #ffffffd9 inset,0 1px 2px #00000014;transition:transform .12s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease,color .16s ease}.tool-buttons button:hover:not(:disabled):not(.active){transform:translateY(-1px);background:linear-gradient(to bottom,#fff,#f2ede6);box-shadow:0 1px #ffffffe6 inset,0 4px 10px #0000001f}.tool-buttons button:active:not(:disabled){transform:translateY(0);background:linear-gradient(to bottom,#efe9e1,#f8f5f0);box-shadow:0 1px 2px #0000001a inset}.tool-buttons button.active{background:linear-gradient(to bottom,#4b4946,#353331);color:#fff;border-color:#2e2c2a;box-shadow:0 1px #ffffff1a inset,0 4px 10px #0000002e}.tool-buttons button.active:hover:not(:disabled){background:linear-gradient(to bottom,#55524f,#3b3937)}.tool-buttons button:disabled{opacity:.55;cursor:not-allowed}.toolbar-subpanel{z-index:2000;display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;padding-top:10px;background:#fff;border:1px solid rgba(0,0,0,.08);border-top:4px solid rgba(176,48,48,.92);border-radius:12px;box-shadow:0 1px 2px #0000000a,0 6px 14px #00000014,0 14px 28px #0000000f}.toolbar-subpanel:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:8px solid red;z-index:9999}.toolbar-subgroup{display:flex;flex-direction:column;gap:3px;min-width:0}.direction-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.direction-buttons button{min-width:42px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;color:#2f2d2b;border-radius:10px;border:1px solid #3a3836;background:linear-gradient(to bottom,#fff,#f7f4ef);cursor:pointer;line-height:1;box-shadow:0 1px #ffffffd9 inset,0 1px 2px #00000014;transition:transform .12s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease,color .16s ease}.direction-buttons button:hover:not(.active){background:linear-gradient(to bottom,#fff,#f0f0f0);border-color:#0000002e;box-shadow:inset 0 1px #ffffffbf,0 6px 12px #00000014;transform:translateY(-1px)}.direction-buttons button:hover:not(:disabled):not(.active){transform:translateY(-1px);background:linear-gradient(to bottom,#fff,#f2ede6);box-shadow:0 1px #ffffffe6 inset,0 4px 10px #0000001f}.direction-buttons button:active{transform:scale(.985)}.direction-buttons button:active:not(:disabled){transform:translateY(0);background:linear-gradient(to bottom,#efe9e1,#f8f5f0);box-shadow:0 1px 2px #0000001a inset}.direction-buttons button.active{background:linear-gradient(to bottom,#3c3631,#241f1c);color:#fff;border-color:#1f1b18;box-shadow:inset 0 1px #ffffff1a,0 8px 16px #0003;transform:translateY(1px)}.direction-buttons button.active{background:linear-gradient(to bottom,#4b4946,#353331);color:#fff;border-color:#2e2c2a;box-shadow:0 1px #ffffff1a inset,0 4px 10px #0000002e}.view-controls{display:flex;flex-direction:column;gap:6px}.zoom-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.zoom-controls button{width:auto;height:30px;padding:0 10px;background:#fff;border:1.5px solid #3a3836;color:#1e1c1a;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s ease;line-height:1}.zoom-controls button:hover{background:#f2f0ec;border-color:#2f2b27}.zoom-controls input[type=range]{width:120px}.preview-controls{display:flex;flex-direction:column;gap:6px}.preview-controls button{min-height:30px;padding:0 12px;white-space:nowrap}.preview-controls button.active{background-color:var(--primary-color);color:var(--white);border-color:var(--primary-color)}button:disabled{opacity:.5;cursor:not-allowed}.brush-size{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border-color);border-radius:10px;background:var(--white)}.brush-size__label{font-weight:700;opacity:.8;margin-right:4px}.brush-size__btn{border:1px solid var(--border-color);background:var(--background-color);height:30px;padding:0 10px;border-radius:8px;cursor:pointer;font-weight:700}.brush-size__btn.active{background:#2f2b27;color:#fff;border-color:#2f2b27}.ui-control{background:#fff;border:1.5px solid #3a3836;color:#1e1c1a;font-weight:500;border-radius:8px;height:30px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;min-width:0;max-width:100%;flex-shrink:1;box-sizing:border-box;transition:all .15s ease;line-height:1}.ui-control:hover{border-color:#1e1c1a;background:#f2f0ec}.loop-height-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:2px}.loop-height-buttons button{min-width:72px;height:36px;padding:0 12px;font-size:13px;font-weight:600;letter-spacing:.01em;color:#2f2d2b;border-radius:10px;border:1px solid #3a3836;background:linear-gradient(to bottom,#fff,#f7f4ef);cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 1px #ffffffd9 inset,0 1px 2px #00000014;transition:transform .12s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease,color .16s ease}.loop-height-buttons button:hover:not(:disabled):not(.active){transform:translateY(-1px);background:linear-gradient(to bottom,#fff,#f2ede6);box-shadow:0 1px #ffffffe6 inset,0 4px 10px #0000001f}.loop-height-buttons button:active:not(:disabled){transform:translateY(0);background:linear-gradient(to bottom,#efe9e1,#f8f5f0);box-shadow:0 1px 2px #0000001a inset}.loop-height-buttons button.active{background:linear-gradient(to bottom,#4b4946,#353331);color:#fff;border-color:#2e2c2a;box-shadow:0 1px #ffffff1a inset,0 4px 10px #0000002e}.loop-height-buttons button.active:hover:not(:disabled){background:linear-gradient(to bottom,#55524f,#3b3937)}.sidebar-toggle{height:30px;padding:0 12px;border:1.5px solid #3a3836;border-radius:8px;background:#fff;color:#2f2b27;font-weight:600;cursor:pointer;line-height:1}.sidebar-toggle:hover{border-color:#000}.sidebar-toggle.active{background:#2f2b27;color:#fff;border-color:#000}@media (max-width: 768px){.toolbar{padding:8px;gap:8px}.toolbar-main{gap:10px}.toolbar-section{min-width:100%}.tool-buttons{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbar-subpanel{align-items:stretch}.toolbar-subpanel{position:fixed;overflow:visible}}.toolbar-history button{height:30px;padding:0 10px;font-size:13px;font-weight:600;border-radius:8px;line-height:1}.toolbar-history{min-width:150px}.toolbar-history>*:last-child{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.anchored-subpanel{position:fixed;z-index:1000;min-width:200px;max-width:calc(100vw - 24px);background:#fff;border:1px solid rgba(0,0,0,.06);border-top:4px solid rgba(176,48,48,.92);border-radius:12px;padding:10px 10px 12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 0 0 1px #b0303038,0 0 18px #b0303059,0 10px 24px #0000001a,0 22px 40px #00000014;animation:panelFadeIn .14s ease-out;transform-origin:top left;transform:translateY(2px);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow:hidden;isolation:isolate}@keyframes panelFadeIn{0%{opacity:0;transform:scale(.985) translateY(-6px)}60%{opacity:1;transform:scale(1.002) translateY(1px)}to{opacity:1;transform:scale(1) translateY(0)}}.toolbar-subpanel.anchored-subpanel{background:#fff;border:1px solid rgba(0,0,0,.08);border-top:3px solid rgba(176,48,48,.8);border-radius:14px;box-shadow:0 0 24px #b0303080,0 0 42px #b0303033,0 12px 28px #0000001f,0 26px 46px #0000001a;transition:box-shadow .22s ease,transform .18s ease,border-color .18s ease}.toolbar-subpanel.anchored-subpanel:hover{box-shadow:0 0 28px #b0303094,0 0 46px #b030303d,0 14px 30px #00000021,0 28px 48px #0000001c}.toolbar-subpanel.anchored-subpanel .toolbar-subgroup{display:flex;flex-direction:column}.toolbar-subpanel.anchored-subpanel .toolbar-label{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#0000008c;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(0,0,0,.06)}.toolbar-subpanel.anchored-subpanel .direction-buttons,.toolbar-subpanel.anchored-subpanel .loop-height-buttons{margin-top:2px}.direction-buttons button{color:#000000bf}.direction-buttons button.active{color:#fff}.direction-buttons button:focus,.loop-height-buttons button:focus,.tool-buttons button:focus{outline:none}.direction-buttons button:focus:not(.active),.loop-height-buttons button:focus:not(.active),.tool-buttons button:focus:not(.active){box-shadow:0 0 0 2px #497fd259,0 1px #ffffffd9 inset,0 1px 2px #00000014}.direction-buttons button.active:focus,.loop-height-buttons button.active:focus,.tool-buttons button.active:focus{box-shadow:0 0 0 2px #497fd24d,0 1px #ffffff1a inset,0 4px 10px #0000002e}.palette-list,.yardage-calculator{width:100%;max-width:100%;min-width:0;box-sizing:border-box;overflow-x:hidden}.undo-redo-buttons{display:flex;align-items:center;gap:10px;margin-top:4px}.undo-redo-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:104px;height:40px;padding:0 14px;border:1.5px solid #3a3836;border-radius:12px;background:linear-gradient(to bottom,#fff,#f3efe9);color:#1f1f1f;font-size:14px;font-weight:700;letter-spacing:.2px;cursor:pointer;box-shadow:0 2px #0000002e,0 6px 14px #00000014;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,opacity .12s ease}.undo-redo-btn:not(:disabled){background:linear-gradient(to bottom,#fff,#e8e2d8)}.undo-redo-btn:active:not(:disabled){background:#000;color:#fff;transform:translateY(1px);box-shadow:0 1px #0003,0 2px 6px #0000001f}.undo-redo-btn:active:not(:disabled) .undo-redo-icon,.undo-redo-btn:active:not(:disabled) .undo-redo-label{color:#fff}.undo-redo-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px #0000002e,0 0 0 3px #497fd22e,0 10px 18px #0000001f;background:linear-gradient(to bottom,#fff,#ece6dc)}.undo-redo-btn:active:not(:disabled){background:#000!important;color:#fff!important;transform:translateY(1px);box-shadow:0 1px #0003,0 2px 6px #0000001f!important}.undo-redo-btn:active:not(:disabled) .undo-redo-icon,.undo-redo-btn:active:not(:disabled) .undo-redo-label{color:#fff!important}.undo-redo-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 1px #00000014,0 2px 6px #0000000a}.undo-redo-icon{font-size:17px;line-height:1}.undo-redo-label{line-height:1;white-space:nowrap}.undo-button:not(:disabled):hover{box-shadow:0 3px #0000002e,0 0 0 3px #497fd224,0 10px 18px #0000001f}.redo-button:not(:disabled):hover{box-shadow:0 3px #0000002e,0 0 0 3px #497fd224,0 10px 18px #0000001f}.toolbar-subpanel,.anchored-subpanel{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.toolbar-subpanel button,.anchored-subpanel button{min-width:44px;padding:8px 10px;border:1.5px solid #3a3836;border-radius:8px;background:#fff;color:#222;cursor:pointer}.toolbar-subpanel button.active,.anchored-subpanel button.active{background:#000;color:#fff;border-color:#000}.toolbar-subpanel.anchored-subpanel{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;min-width:180px;width:auto}.toolbar-subpanel.anchored-subpanel button{flex:0 0 auto;width:auto}.toolbar-subpanel.anchored-subpanel button span{font-size:20px;display:inline-block;line-height:1}.toolbar-subpanel.anchored-subpanel button{min-width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:13px}.toolbar-subpanel.anchored-subpanel{display:grid;grid-template-columns:repeat(3,48px);justify-content:center;gap:6px}.toolbar-subpanel.anchored-subpanel button{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.direction-subpanel{display:grid;grid-template-columns:repeat(3,48px);grid-template-areas:"up-left up up-right" "left none right" "down-left down down-right";justify-content:center;gap:6px;min-width:auto}.direction-subpanel button{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.direction-subpanel button svg{width:28px;height:28px;display:block}.direction-subpanel button:nth-child(1){grid-area:none}.direction-subpanel button:nth-child(2){grid-area:up}.direction-subpanel button:nth-child(3){grid-area:down}.direction-subpanel button:nth-child(4){grid-area:left}.direction-subpanel button:nth-child(5){grid-area:right}.direction-subpanel button:nth-child(6){grid-area:up-right}.direction-subpanel button:nth-child(7){grid-area:up-left}.direction-subpanel button:nth-child(8){grid-area:down-right}.direction-subpanel button:nth-child(9){grid-area:down-left}.height-subpanel{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:center;gap:6px;min-width:auto}.height-subpanel button{min-width:72px;height:42px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center}.toolbar-subpanel.anchored-subpanel.height-subpanel{display:grid;grid-template-columns:repeat(2,72px);gap:6px;justify-content:center;align-items:center;min-width:auto;width:auto}.toolbar-subpanel.anchored-subpanel.height-subpanel button{width:72px;min-width:72px;height:42px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;flex:none}:root{--pmd-page: #FDFAF7;--pmd-canvas: #F1EDE9;--pmd-text: #555453;--pmd-ui: #4D4C4C;--pmd-border: #E6E0DA;--pmd-card: #FFFDFC}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--pmd-page);color:var(--pmd-text);font-family:League Spartan,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100%;background:transparent}button{font-family:inherit}.yardage-calculator h2{margin:0 0 8px!important}.yardage-calculator p{margin:6px 0!important}.yardage-calculator *{margin:0!important;padding:0!important}.yardage-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:14px;color:#1e1c1a}.yardage-swatch{width:30px;height:30px;border-radius:6px;border:1.5px solid #3a3836;flex-shrink:0}.yardage-color{font-size:15px;font-weight:700;color:#1e1c1a}.yardage-details{font-size:14px;line-height:1.5;color:#444}
