*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f8f6f3;--surface: #ffffff;--border: #e2ddd5;--text: #2c2420;--text-secondary: #6b5e54;--primary: #8b6f5e;--primary-hover: #725a4a;--accent: #c4956a;--danger: #c45e5e}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.app{max-width:1400px;margin:0 auto;padding:24px}.app-header{text-align:center;margin-bottom:32px}.app-header h1{font-size:28px;font-weight:700;color:var(--primary);margin-bottom:4px}.app-header p{color:var(--text-secondary);font-size:15px}.upload-zone{border:2px dashed var(--border);border-radius:16px;padding:64px 32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface);max-width:600px;margin:0 auto}.upload-zone:hover{border-color:var(--primary);background:#faf8f5}.upload-icon{font-size:48px;margin-bottom:16px}.upload-text{font-size:16px;font-weight:500;margin-bottom:8px}.upload-hint{font-size:13px;color:var(--text-secondary)}.status-message{text-align:center;padding:80px 32px}.status-message p{font-size:17px;font-weight:500;margin-top:16px}.status-hint{color:var(--text-secondary);font-size:14px!important;font-weight:400!important;margin-top:4px!important}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;margin:0 auto;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{max-width:500px;margin:40px auto}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:24px;text-align:center}.error-message p{color:var(--danger);margin-bottom:16px}.editor-layout{display:flex;gap:24px;align-items:flex-start}.editor-main{flex:1;min-width:0}.pattern-desc{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;font-size:14px;color:var(--text-secondary);margin-bottom:16px;font-style:italic}.canvas-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;overflow:hidden}.quilt-canvas{width:100%;height:auto;display:block;border-radius:8px}.editor-actions{display:flex;gap:12px;margin-top:16px;justify-content:flex-end}.btn-primary,.btn-secondary,.btn-reset-all,.btn-reset{border:none;border-radius:8px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:var(--primary);color:#fff;padding:10px 20px}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.4;cursor:default}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);padding:10px 20px}.btn-secondary:hover{background:var(--bg)}.sidebar{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 140px);overflow-y:auto}.palette-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.palette-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.palette-header h3{font-size:16px;font-weight:600}.btn-reset-all{background:none;color:var(--danger);padding:4px 10px;font-size:12px}.btn-reset-all:hover{background:#fef2f2}.palette-list{display:flex;flex-direction:column;gap:8px}.palette-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;border:1px solid transparent;transition:all .15s}.palette-item:hover{background:var(--bg);border-color:var(--border)}.palette-item.changed{background:#faf5f0;border-color:var(--accent)}.color-swatches{display:flex;align-items:center;gap:4px;flex-shrink:0}.swatch{width:32px;height:32px;border-radius:6px;border:2px solid var(--border)}.swatch-label{position:relative;cursor:pointer}.color-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.arrow{color:var(--text-secondary);font-size:14px}.color-info{display:flex;flex-direction:column;min-width:0;flex:1}.color-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.color-hex{font-size:11px;color:var(--text-secondary);font-family:monospace}.color-desc{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-reset{background:none;color:var(--text-secondary);padding:4px 6px;font-size:16px;flex-shrink:0}.btn-reset:hover{color:var(--danger)}.canvas-container.select-mode{cursor:crosshair;position:relative}.canvas-container.select-mode .quilt-canvas{pointer-events:none}.selection-rect{position:absolute;border:2px solid #4285f4;background:#4285f426;pointer-events:none;z-index:2}.selection-picker{position:absolute;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px;box-shadow:0 4px 16px #00000026;z-index:10;min-width:180px;max-width:280px}.selection-picker-label{font-size:12px;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.selection-picker-colors{display:flex;flex-wrap:wrap;gap:4px}.selection-color-btn{width:28px;height:28px;border-radius:6px;border:2px solid var(--border);padding:0;cursor:pointer;overflow:hidden;transition:all .12s}.selection-color-btn:hover{border-color:var(--primary);transform:scale(1.15)}.selection-color-swatch{display:block;width:100%;height:100%;border-radius:4px}.selection-color-fabric{width:100%;height:100%;object-fit:cover;display:block}.selection-cancel{display:block;width:100%;margin-top:8px;padding:4px;background:none;border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:inherit;cursor:pointer;color:var(--text-secondary)}.selection-cancel:hover{background:var(--bg)}.btn-secondary.active{background:var(--primary);color:#fff;border-color:var(--primary)}.merge-banner{background:#e8f0fe;border:1px solid #a8c7fa;border-radius:8px;padding:8px 12px;font-size:13px;margin-bottom:8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.merge-banner strong{color:var(--primary)}.merge-banner button{margin-left:auto;background:none;border:1px solid var(--border);border-radius:6px;padding:4px 12px;font-size:12px;font-family:inherit;cursor:pointer;color:var(--text-secondary)}.merge-banner button:hover{background:var(--surface)}.palette-item.merge-source{opacity:.5;pointer-events:none}.palette-item.merge-target{cursor:pointer}.palette-item.merge-target:hover{border-color:#4285f4;box-shadow:0 0 0 2px #4285f433}.btn-merge{background:none;border:none;color:var(--text-secondary);padding:4px 6px;font-size:16px;flex-shrink:0;cursor:pointer;opacity:0;transition:opacity .15s}.palette-item:hover .btn-merge{opacity:1}.btn-merge:hover{color:var(--primary)}.palette-item.fabric-target{cursor:pointer}.palette-item.fabric-target:hover{border-color:var(--primary);box-shadow:0 0 0 2px #8b6f5e33}.swatch.fabric-applied{overflow:hidden;padding:0}.swatch-fabric-img{width:100%;height:100%;object-fit:cover;border-radius:4px}.fabric-mode-banner{background:#f0ebe5;border:1px solid var(--accent);border-radius:8px;padding:10px 16px;font-size:13px;margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.fabric-mode-banner strong{color:var(--primary)}.fabric-mode-banner button{margin-left:auto;background:none;border:1px solid var(--border);border-radius:6px;padding:4px 12px;font-size:12px;font-family:inherit;cursor:pointer;color:var(--text-secondary)}.fabric-mode-banner button:hover{background:var(--surface)}.fabric-library{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.fabric-header{margin-bottom:12px}.fabric-header h3{font-size:16px;font-weight:600;margin-bottom:2px}.fabric-hint{font-size:11px;color:var(--text-secondary)}.fabric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.fabric-swatch{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:all .15s}.fabric-swatch:hover{border-color:var(--primary)}.fabric-swatch.active{border-color:var(--primary);box-shadow:0 0 0 3px #8b6f5e4d}.fabric-thumb{width:100%;height:100%;object-fit:cover;display:block}.fabric-color-dot{position:absolute;bottom:4px;right:4px;width:16px;height:16px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px #0000004d}.fabric-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:14px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.fabric-swatch:hover .fabric-remove{opacity:1}.fabric-add{aspect-ratio:1;border-radius:8px;border:2px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;gap:2px}.fabric-add:hover{border-color:var(--primary);background:var(--bg)}.fabric-add-icon{font-size:20px;color:var(--text-secondary);line-height:1}.fabric-add-text{font-size:10px;color:var(--text-secondary)}.calculator-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.calc-header h3{font-size:16px;font-weight:600;margin-bottom:12px}.calc-inputs{margin-bottom:16px}.calc-dimensions{display:flex;align-items:flex-end;gap:8px}.calc-dimensions label{display:flex;flex-direction:column;gap:4px;flex:1}.calc-dimensions label span{font-size:11px;color:var(--text-secondary);font-weight:500}.calc-dimensions input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:var(--bg)}.calc-dimensions input:focus{outline:none;border-color:var(--primary)}.calc-x{font-size:16px;color:var(--text-secondary);padding-bottom:6px}.calc-unit-toggle{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.calc-unit-toggle button{padding:6px 10px;border:none;background:var(--bg);font-size:12px;font-family:inherit;cursor:pointer;color:var(--text-secondary);transition:all .15s}.calc-unit-toggle button.active{background:var(--primary);color:#fff}.calc-note{font-size:11px;color:var(--text-secondary);margin-top:8px}.calc-table{font-size:13px}.calc-table-header{display:flex;gap:4px;padding:6px 0;border-bottom:1px solid var(--border);font-weight:600;font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.calc-table-row{display:flex;gap:4px;padding:6px 0;border-bottom:1px solid #f0ebe5;align-items:center}.calc-table-total{display:flex;gap:4px;padding:8px 0 0;font-weight:600}.calc-col-color{flex:1;min-width:0;display:flex;align-items:center;gap:6px}.calc-col-pct{width:36px;text-align:right;flex-shrink:0}.calc-col-area,.calc-col-yards{width:56px;text-align:right;flex-shrink:0}.calc-swatch{width:16px;height:16px;border-radius:4px;border:1px solid var(--border);flex-shrink:0}.calc-color-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:900px){.editor-layout{flex-direction:column}.sidebar{width:100%;max-height:none}}
