:root{--font-size-base: 16px;--color-primary: #5b7fa5;--color-primary-hover: #4a6b8c;--color-accent: #e8a87c;--color-danger: #d9534f;--color-bg: #fafafa;--color-surface: #ffffff;--color-border: #ddd;--color-text: #333;--color-text-muted: #888;--color-selected: #2196f3;--radius: 8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:var(--font-size-base);line-height:1.5;color:var(--color-text);background:var(--color-bg);min-height:100vh}#root{width:100%}h1,h2,h3{font-weight:600}button{font-family:inherit;font-size:var(--font-size-base);padding:8px 16px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;min-height:44px;min-width:44px;transition:background .15s,border-color .15s}button:hover:not(:disabled){background:#f0f0f0;border-color:#bbb}button:disabled{opacity:.4;cursor:not-allowed}button:focus-visible{outline:3px solid var(--color-selected);outline-offset:2px}select{font-family:inherit;font-size:var(--font-size-base);padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);min-height:44px;cursor:pointer}select:focus-visible{outline:3px solid var(--color-selected);outline-offset:2px}.plus-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;background:linear-gradient(135deg,#c2714f,#d4a853);color:#fff;letter-spacing:.5px;vertical-align:middle;margin-left:4px}.update-banner{display:flex;align-items:center;gap:12px;padding:8px 24px;background:#e8f4fd;border-bottom:1px solid #b8daef;font-size:14px;color:#1a5276}.update-banner.update-error{background:#fdecea;border-color:#f5c6cb;color:#721c24}.update-banner button{min-height:30px;padding:4px 12px;font-size:12px}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:baseline;gap:16px;padding:16px 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.app-header h1{font-size:24px;color:var(--color-primary)}.tagline{font-size:14px;color:var(--color-text-muted);font-style:italic}.auth-section{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:8px}.user-avatar{width:28px;height:28px;border-radius:50%}.user-name{font-size:13px;color:var(--color-text-muted)}.btn-sm{padding:4px 10px;font-size:12px}.project-manager{position:relative;margin-left:auto}.project-dropdown{position:absolute;top:100%;right:0;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #00000026;padding:12px;width:320px;margin-top:8px}.project-save-row{display:flex;gap:6px;margin-bottom:8px}.project-name-input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px}.project-actions-row{display:flex;gap:6px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.project-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:8px}.project-tab{flex:1;padding:6px 12px;font-size:13px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--color-text-muted)}.project-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.project-list-header{font-size:12px;font-weight:600;color:var(--color-text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.project-list{max-height:300px;overflow-y:auto}.project-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:var(--radius);cursor:pointer;transition:background .1s}.project-item:hover{background:#f5f5f5}.project-item.active{background:#e3f2fd}.project-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.project-item-name{font-size:14px;font-weight:500}.project-item-meta,.project-item-date{font-size:11px;color:var(--color-text-muted)}.project-delete-btn{width:24px;height:24px;min-width:24px;min-height:24px;padding:0;border:none;background:none;color:var(--color-text-muted);font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.project-delete-btn:hover{background:#fdf0f0;color:var(--color-danger)}.toolbar{display:flex;align-items:center;gap:16px;padding:8px 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-wrap:wrap}.mode-tabs{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;flex-shrink:0}.mode-tab{padding:8px 20px;font-size:14px;font-weight:600;border:none;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s;min-height:36px}.mode-tab:hover{background:#f0f0f0}.mode-tab.active{background:var(--color-primary);color:#fff}.mode-tab+.mode-tab{border-left:1px solid var(--color-border)}.toolbar-right{margin-left:auto;display:flex;gap:8px;align-items:center}.toolbar-group{display:flex;align-items:center;gap:8px}.toolbar-group label{font-weight:600;font-size:14px;color:var(--color-text-muted)}.size-controls{display:flex;align-items:center;gap:4px}.size-display{padding:0 12px;font-weight:600;min-width:60px;text-align:center}.block-actions{display:flex;gap:4px}.block-context-bar{padding:8px 12px;background:#e3f2fd;border-bottom:1px solid #bbdefb;display:flex;flex-direction:column;gap:6px}.context-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#1565c0}.context-actions{display:flex;flex-wrap:wrap;gap:4px}.context-actions button{font-size:12px;padding:4px 10px;min-height:28px}.finish-panel{padding:0;display:flex;flex-direction:column}.finish-section{padding:12px 14px;border-bottom:1px solid var(--color-border)}.finish-section h4{margin:0;font-size:15px;font-weight:700;color:var(--color-text)}.finish-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.finish-section-body{display:flex;flex-direction:column;gap:6px}.finish-section-body label{font-weight:600;font-size:13px;color:var(--color-text-muted);margin-top:2px}.finish-section-body select{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;width:100%}.finish-hint{font-size:13px;color:var(--color-text-muted);line-height:1.5;margin:0}.finish-tools-grid{display:flex;flex-direction:column;gap:6px;margin-top:8px}.finish-tool-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fafafa;cursor:pointer;font-size:14px;font-weight:500;text-align:left;transition:border-color .15s,background .15s;min-height:44px}.finish-tool-btn:hover{border-color:var(--color-primary);background:#f5f0eb}.finish-tool-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}.applique-mode-hint{font-size:13px;color:var(--color-text-muted);line-height:1.5;margin:0}.btn-danger{color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#fdf0f0}.btn-undo,.btn-redo{font-weight:600}.btn-redo{font-size:12px}.main-layout{display:flex;flex:1;overflow:hidden}.left-panel{width:280px;min-width:280px;overflow-y:auto;border-right:1px solid var(--color-border);background:var(--color-surface);display:flex;flex-direction:column}.left-panel-top{padding:12px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px}.unified-search{display:flex;flex-direction:column;gap:6px}.search-toggle{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.search-toggle-btn{flex:1;padding:5px 0;font-size:12px;font-weight:600;border:none;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;min-height:28px;min-width:auto}.search-toggle-btn:hover{background:#f0f0f0}.search-toggle-btn.active{background:var(--color-primary);color:#fff}.center-panel{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;align-items:center;min-height:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border)}.panel-header h2{font-size:16px}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.panel-search{padding:8px 12px}.search-input{width:100%;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;background:var(--color-bg)}.search-input:focus{outline:none;border-color:var(--color-primary)}.count-badge{background:var(--color-border);color:var(--color-text-muted);font-size:12px;padding:1px 8px;border-radius:10px;font-weight:600}.category-tabs{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;border-bottom:1px solid var(--color-border)}.category-tab{font-size:12px;padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;display:flex;align-items:center;gap:4px;min-height:28px;min-width:auto}.category-tab:hover{background:#f0f0f0}.category-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tab-count{font-size:10px;opacity:.7}.block-picker{border-bottom:1px solid var(--color-border)}.block-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}.expand-blocks-btn{width:calc(100% - 24px);margin:0 12px 12px;font-size:13px;color:var(--color-primary);border:1px dashed var(--color-primary);background:transparent;padding:6px;border-radius:var(--radius);cursor:pointer}.expand-blocks-btn:hover{background:#4c6f4014}.wildcard-section{margin-top:12px;padding:12px;border:2px dashed #b0bec5;border-radius:10px;background:linear-gradient(135deg,#f8f9fa,#eef1f5)}.wildcard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.wildcard-label{font-weight:700;font-size:14px;color:#4a6741;letter-spacing:.5px}.wildcard-preview{display:flex;flex-direction:column;gap:8px}.wildcard-card{border-color:#4a6741!important;background:#fff}.wildcard-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.wildcard-hint{font-size:12px;color:#888;margin:0}.block-card{display:flex;flex-direction:column;align-items:center;padding:8px;border:2px solid transparent;border-radius:var(--radius);cursor:grab;transition:border-color .15s,background .15s}.block-card:active{cursor:grabbing}.block-card:hover{background:#f5f5f5}.block-card.selected{border-color:var(--color-selected);background:#e3f2fd}.block-preview-svg{width:80px;height:80px}.block-name{font-size:12px;margin-top:4px;text-align:center}.fabric-library{flex:1}.empty-hint{padding:16px;color:var(--color-text-muted);font-size:14px;text-align:center}.fabric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}.fabric-swatch{position:relative;border:2px solid transparent;border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .15s;aspect-ratio:1}.fabric-swatch:hover{border-color:#bbb}.fabric-swatch.selected{border-color:var(--color-selected);box-shadow:0 0 0 2px var(--color-selected)}.fabric-swatch img{width:100%;height:100%;object-fit:cover}.fabric-name{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#fff;font-size:11px;padding:2px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remove-btn{position:absolute;top:2px;right:2px;width:28px;height:28px;min-width:28px;min-height:28px;padding:0;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:.6;cursor:pointer;z-index:2}.remove-btn:hover{opacity:1;background:#dc3545d9}.color-filter-row{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;border-bottom:1px solid var(--color-border)}.color-filter-btn{width:28px;height:28px;min-width:28px;min-height:28px;padding:0;border:2px solid transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;background:none}.color-filter-btn:hover{border-color:#aaa}.color-filter-btn.active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.color-dot{display:block;width:18px;height:18px;border-radius:50%;border:1px solid rgba(0,0,0,.15)}.color-dot-all{font-size:10px;font-weight:700;color:var(--color-text-muted)}.fabric-name-edit{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;font-size:11px;padding:2px 6px;border:none;outline:1px solid var(--color-primary);width:100%;box-sizing:border-box}.fabric-color-badge{position:absolute;top:4px;left:4px;width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.8);box-shadow:0 1px 2px #0000004d}.fabric-color-select{position:absolute;bottom:18px;right:2px;width:20px;height:20px;min-width:20px;min-height:20px;opacity:0;cursor:pointer;font-size:11px;padding:0;border:none;background:none}.fabric-swatch:hover .fabric-color-select{opacity:.7}.design-wall-canvas{display:flex;justify-content:center;align-items:center;padding:16px;flex:1;min-height:0;width:100%}.wall-grid{background:#e0d8d0;padding:8px;border-radius:var(--radius);box-shadow:inset 0 2px 8px #0000001a}.wall-cell{background:#f5f0eb;border:1px dashed #ccc;display:flex;align-items:center;justify-content:center;transition:background .15s}.wall-cell.can-place{cursor:copy;background:#e8f4e8;transition:background .12s}.wall-cell.can-place:hover{background:#c3e6c3;box-shadow:inset 0 0 0 2px #4caf50}.wall-cell.can-place .empty-cell{font-size:20px;color:#4caf50;font-weight:700}.wall-cell.drag-over{background:#e3f2fd;border-color:var(--color-selected);border-style:solid}.empty-cell{color:#bbb;font-size:24px;font-weight:300;-webkit-user-select:none;user-select:none}.cell-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#333;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:20;pointer-events:none;animation:tooltipFade .2s ease}.cell-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#333}@keyframes tooltipFade{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.quick-picker{position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:8px;z-index:30;animation:tooltipFade .15s ease}.quick-picker-title{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;padding:2px 4px 6px}.quick-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.quick-picker-item{background:#f5f0eb;border:1px solid #ddd;border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:48px;min-height:48px}.quick-picker-item:hover{background:#e8f4e8;border-color:var(--color-primary)}.quilt-block{cursor:pointer;transition:transform .2s}.quilt-block:hover{filter:brightness(1.02)}.quilt-block.selected{filter:brightness(1.05)}.block-region:hover{filter:brightness(.92)}.block-region.fabric-target{cursor:pointer;transition:filter .1s,stroke .1s}.block-region.fabric-target:hover{filter:brightness(.8) saturate(.5);stroke:#4caf50!important;stroke-width:3!important}.zoom-controls{display:flex;align-items:center;gap:8px;margin-bottom:12px;background:var(--color-surface);padding:8px 16px;border-radius:var(--radius);border:1px solid var(--color-border)}.zoom-slider{width:120px;cursor:pointer}.zoom-label{font-size:13px;font-weight:600;color:var(--color-text-muted);min-width:40px;text-align:center}.zoom-container{transition:transform .15s ease}.hint-banner{background:#fff3cd;color:#856404;padding:10px 20px;border-radius:var(--radius);margin-bottom:12px;font-size:14px;text-align:center;width:100%;max-width:600px;display:flex;align-items:center;justify-content:center;gap:8px}.hint-placement{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.placement-indicator{width:10px;height:10px;border-radius:50%;background:#4caf50;animation:pulse 1.2s infinite;flex-shrink:0}.panel-backdrop{display:none}.gpicker-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.gpicker-modal{background:var(--color-surface);border-radius:12px;box-shadow:0 8px 32px #00000040;width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.gpicker-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.gpicker-header h2{font-size:18px;margin:0}.gpicker-close{width:36px;height:36px;min-width:36px;min-height:36px;border:none;background:none;font-size:24px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.gpicker-close:hover{background:#f0f0f0}.gpicker-setup,.gpicker-signin{padding:40px 20px;text-align:center;color:var(--color-text-muted)}.gpicker-setup code{background:#f0f0f0;padding:2px 6px;border-radius:3px;font-size:13px}.gpicker-signin-btn{margin-top:16px;padding:12px 32px;font-size:16px}.gpicker-error{padding:12px 20px;background:#fdf0f0;color:var(--color-danger);font-size:14px}.gpicker-toolbar{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--color-border)}.gpicker-count{font-size:14px;color:var(--color-text-muted);margin-right:auto}.gpicker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:16px;overflow-y:auto;flex:1}.gpicker-item{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;cursor:pointer;border:3px solid transparent;transition:border-color .15s}.gpicker-item:hover{border-color:#bbb}.gpicker-item.selected{border-color:var(--color-primary)}.gpicker-item img{width:100%;height:100%;object-fit:cover}.gpicker-check{position:absolute;top:6px;right:6px;width:28px;height:28px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.gpicker-filename{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#fff;font-size:10px;padding:2px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gpicker-loading,.gpicker-empty{grid-column:1 / -1;text-align:center;padding:40px;color:var(--color-text-muted);font-size:14px}.gpicker-load-more{padding:12px 20px;text-align:center;border-top:1px solid var(--color-border)}.add-fabric-dropdown-wrap{position:relative}.btn-add-fabric{width:100%;padding:10px;font-size:15px;font-weight:600}.add-fabric-menu{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 12px #0000001f;margin-top:4px;overflow:hidden}.add-fabric-option{display:flex;flex-direction:column;width:100%;padding:12px 14px;border:none;background:none;text-align:left;cursor:pointer;font-size:14px;font-weight:500;min-height:44px}.add-fabric-option:hover{background:#f5f5f5}.add-fabric-option+.add-fabric-option{border-top:1px solid var(--color-border)}.add-fabric-option-desc{font-size:12px;color:var(--color-text-muted);font-weight:400;margin-top:2px}.sashing-cell{border:none}.yardage-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.yardage-modal{background:var(--color-surface);border-radius:12px;box-shadow:0 8px 32px #00000040;width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.yardage-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.yardage-header h2{font-size:18px;margin:0}.yardage-summary{display:flex;gap:24px;padding:16px 20px;background:#f8f6f3;border-bottom:1px solid var(--color-border)}.yardage-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.yardage-stat-value{font-size:18px;font-weight:700;color:var(--color-primary)}.yardage-stat-label{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.yardage-note{padding:8px 20px;font-size:11px;color:var(--color-text-muted);font-style:italic;border-bottom:1px solid var(--color-border)}.yardage-table{flex:1;overflow-y:auto;padding:8px 0}.yardage-row{display:grid;grid-template-columns:1fr 60px 80px;align-items:center;padding:8px 20px;gap:8px}.yardage-row-header{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);padding-bottom:8px}.yardage-row:hover:not(.yardage-row-header){background:#f5f5f5}.yardage-fabric-info{display:flex;align-items:center;gap:8px;min-width:0}.yardage-fabric-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover;flex-shrink:0}.yardage-fabric-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.yardage-pieces{text-align:center;font-size:13px;color:var(--color-text-muted)}.yardage-yards{text-align:right;font-size:14px;font-weight:600}.yardage-empty{padding:24px 20px;text-align:center;color:var(--color-text-muted);font-size:14px}.block-tab-tools{padding:8px 12px;border-top:1px solid var(--color-border)}.btn-trace-pattern{width:100%;padding:8px 12px;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:6px;cursor:pointer;font-size:14px;color:var(--color-text);transition:background .15s,border-color .15s}.btn-trace-pattern:hover{background:#f0f7f0;border-color:var(--color-primary);color:var(--color-primary)}.scrappy-controls{padding:8px 12px;border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;align-items:center;gap:6px}.btn-scrappy{font-size:12px;padding:5px 12px}.scrappy-hint{font-size:12px;color:var(--color-text-muted);font-weight:600}.scrappy-instructions{display:flex;flex-direction:column;gap:4px;padding:4px 0}.scrappy-step{font-size:12px;color:var(--color-primary);font-weight:500}.fabric-swatch.scrappy-selected{border-color:#ff9800;box-shadow:0 0 0 2px #ff9800}.panel-toggle{display:none;position:fixed;bottom:16px;left:16px;z-index:60;padding:8px 16px;font-size:13px;font-weight:600;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;box-shadow:0 2px 8px #0003}.left-panel-hidden{display:none!important}.btn-coach{padding:6px 14px;font-size:13px;font-weight:600;border:1px solid #e0c97f;border-radius:var(--radius);background:#fdf8e8;color:#8b6914;cursor:pointer;transition:background .15s,border-color .15s}.btn-coach:hover{background:#faf0d0;border-color:#d4a843}.btn-coach-active{background:#f5e6a3;border-color:#c9a227;color:#6b4f00}.coach-tips{position:fixed;top:140px;left:296px;z-index:50;display:flex;flex-direction:column;gap:0;max-width:340px;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px #0000001f;border:1px solid #e0d5b8}.coach-tips-header{background:#f5e6a3;padding:6px 14px;display:flex;align-items:center;gap:8px}.coach-tips-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#7a6210}.coach-tip{padding:10px 14px;font-size:13px;line-height:1.45;display:flex;align-items:flex-start;gap:8px;border-top:1px solid #ede4c8}.coach-tip-content{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.coach-tip-message{display:block}.coach-action-btn{align-self:flex-start;padding:5px 12px;font-size:12px;font-weight:600;border:1px solid #b8a44a;border-radius:var(--radius);background:#f5e6a3;color:#6b4f00;cursor:pointer;transition:background .15s;white-space:nowrap;min-height:28px}.coach-action-btn:hover{background:#edd84e;border-color:#9a8530}.coach-tip-tip{background:#fdfaf0;color:#5a4a1a}.coach-tip-suggestion{background:#f0f7ed;color:#2d5016}.coach-tip-heads-up{background:#fef5e7;color:#7a4a0a}.warning-dismiss{margin-left:auto;background:none;border:none;font-size:18px;cursor:pointer;opacity:.4;padding:0 4px;line-height:1;min-width:24px;min-height:24px;flex-shrink:0}.warning-dismiss:hover{opacity:1}.snapshot-save-row{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--color-border)}.snapshot-list{flex:1;overflow-y:auto;padding:8px 0}.snapshot-item{display:flex;align-items:center;gap:8px;padding:10px 20px}.snapshot-item.active{background:#e3f2fd}.snapshot-item:hover{background:#f5f5f5}.snapshot-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.compare-panel{position:fixed;top:0;right:0;width:50%;height:100vh;background:var(--color-surface);border-left:3px solid var(--color-primary);box-shadow:-4px 0 16px #00000026;z-index:100;display:flex;flex-direction:column;overflow:auto}.compare-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--color-border);background:#f8f6f3}.compare-canvas{flex:1;overflow:auto;display:flex;justify-content:center;padding:16px}@media(max-width:900px){.panel-toggle{display:block}.left-panel{position:fixed;top:0;left:0;z-index:80;height:100vh;box-shadow:4px 0 16px #0003;transition:transform .25s ease}.left-panel-hidden{display:flex!important;transform:translate(-100%);pointer-events:none}.panel-backdrop{display:block;position:fixed;inset:0;background:#0000004d;z-index:79}.toolbar{gap:8px;padding:8px 12px;font-size:12px;flex-wrap:wrap}.toolbar-group{gap:4px}.toolbar-group label{font-size:11px}.toolbar-group select{font-size:12px;padding:4px 6px;max-width:110px}.toolbar-group button{font-size:11px;padding:4px 8px}.toolbar-right{gap:4px}.app-header{padding:8px 12px;flex-wrap:wrap;gap:6px}.app-header h1{font-size:18px}.tagline{display:none}.center-panel{padding:8px}.compare-panel{width:100%}.mode-tab{padding:6px 12px;font-size:12px}.applique-piece-bar{position:fixed!important;bottom:12px;left:50%;top:auto!important;transform:translate(-50%)}}@media(max-width:600px){.toolbar{gap:4px;padding:6px 8px}.toolbar-group,.size-controls,.block-actions{flex-wrap:wrap}.zoom-controls{gap:4px;padding:4px 8px}.zoom-slider{width:60px}.zoom-label{display:none}.hint-banner{font-size:12px;padding:6px 10px}.block-context-bar{flex-direction:column;align-items:flex-start;gap:4px}.context-actions{flex-wrap:wrap;gap:4px}.context-actions button{font-size:11px;padding:3px 8px}}.fabric-swatch.scrappy-selected:after{content:"S";position:absolute;top:4px;right:4px;width:20px;height:20px;background:#ff9800;color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:3}.block-designer-modal{background:var(--color-surface);border-radius:var(--radius);width:90vw;max-width:900px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.designer-layout{display:flex;gap:20px;padding:16px 20px 20px}.designer-canvas-area{flex:1;min-width:0}.designer-toolbar{display:flex;gap:8px;margin-bottom:12px}.designer-svg{width:100%;max-width:400px;aspect-ratio:1;border:2px solid var(--color-border);border-radius:var(--radius);cursor:crosshair;background:#fafafa}.designer-hint{font-size:12px;color:var(--color-text-muted);margin-top:8px;line-height:1.4}.designer-sidebar{width:220px;display:flex;flex-direction:column;gap:8px}.designer-sidebar label{font-weight:600;font-size:13px;color:var(--color-text-muted)}.designer-select{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px}.designer-region-list{flex:1;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius);padding:8px;min-height:100px}.designer-region-list h3{margin:0 0 8px;font-size:13px}.designer-region-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:3px 0}.designer-region-swatch{width:16px;height:16px;border-radius:3px;flex-shrink:0}.designer-actions{display:flex;gap:8px;margin-top:8px}.cutting-modal{max-width:700px}.cutting-summary{padding:8px 16px;background:#f5f0eb;border-bottom:1px solid var(--color-border);font-size:14px}.cutting-summary p{margin:0}.cutting-groups{padding:16px;display:flex;flex-direction:column;gap:16px;max-height:50vh;overflow-y:auto}.cutting-group-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.cutting-group-header h3{margin:0;font-size:15px}.cutting-fabric-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover}.cutting-table{width:100%;border-collapse:collapse;font-size:14px}.cutting-table th{text-align:left;padding:4px 8px;border-bottom:2px solid var(--color-border);font-size:12px;color:var(--color-text-muted);text-transform:uppercase}.cutting-table td{padding:4px 8px;border-bottom:1px solid #eee}.cutting-extras{padding:16px;border-top:1px solid var(--color-border)}.cutting-extras h3{margin:0 0 8px;font-size:14px}.cutting-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--color-border)}.starter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:16px;max-height:60vh;overflow-y:auto}.starter-card{background:#f9f6f2;border:2px solid var(--color-border);border-radius:var(--radius);padding:16px;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}.starter-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.starter-name{font-weight:700;font-size:15px;margin-bottom:4px;color:var(--color-text)}.starter-desc{font-size:12px;color:var(--color-text-muted);line-height:1.3;margin-bottom:6px}.starter-size{font-size:11px;color:var(--color-primary);font-weight:600}.block-fill-actions{display:flex;flex-direction:column;gap:4px;padding:0 8px}.bulk-ops{padding:8px;background:#f5f0eb;border-radius:var(--radius);margin:4px 8px;display:flex;flex-direction:column;gap:6px}.bulk-ops-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.bulk-ops-label{font-size:11px;font-weight:600;color:var(--color-text-muted);min-width:90px}.bulk-ops .btn-sm{font-size:11px;padding:2px 6px}.applique-overlay{pointer-events:auto}.applique-piece{transition:box-shadow .15s}.applique-selected{outline:2px dashed #2196F3;outline-offset:2px}.applique-panel{position:fixed;right:16px;top:100px;width:260px;max-height:calc(100vh - 130px);overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #00000026;padding:12px;z-index:60}.applique-panel h3{margin:0 0 10px;font-size:16px;color:var(--color-text)}.applique-sidebar-panel{padding:12px;border-bottom:1px solid var(--color-border)}.applique-sidebar-panel h4{margin:0 0 8px;font-size:14px;color:var(--color-text)}.applique-piece-bar{display:flex;gap:4px;padding:4px 8px;background:#fffffff2;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 2px 8px #00000026;z-index:100;white-space:nowrap}.applique-cat-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.applique-cat-tabs .btn-sm{font-size:11px;padding:2px 8px}.applique-shape-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:10px;max-height:200px;overflow-y:auto}.applique-shape-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fafafa;cursor:pointer;transition:border-color .15s}.applique-shape-btn:hover{border-color:var(--color-primary);background:#f5f0eb}.applique-shape-name{font-size:9px;color:var(--color-text-muted);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.applique-letter-preview{font-size:28px;font-weight:700;font-family:serif;color:#d4a574;line-height:1}.applique-import{margin-bottom:10px}.applique-piece-controls{border-top:1px solid var(--color-border);padding-top:10px}.applique-piece-controls h4{margin:0 0 8px;font-size:14px}.applique-control-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:12px}.applique-control-row label{font-weight:600;color:var(--color-text-muted);min-width:45px;font-size:12px}.applique-control-row input[type=range]{flex:1;min-width:0}.applique-control-row span{font-size:11px;min-width:30px;text-align:right}.applique-hint{font-size:12px;color:var(--color-text-muted);line-height:1.4;margin:8px 0 0}.quilt-with-applique{position:relative}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}@media print{.toolbar,.left-panel,.app-header,.zoom-controls,.coach-tips,.panel-toggle,.applique-panel{display:none!important}.center-panel{padding:0!important}.cutting-modal{max-width:100%;max-height:none;box-shadow:none}.yardage-overlay{position:static;background:none}}.pattern-tracer-overlay{position:fixed;inset:0;background:#0009;z-index:1000;display:flex;align-items:center;justify-content:center}.pattern-tracer{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:480px;width:90%;overflow:hidden}.pattern-tracer-active{max-width:960px;width:95%;max-height:90vh;display:flex;flex-direction:column}.pattern-tracer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e0e0e0;background:#f8f6f3}.pattern-tracer-header h3{margin:0;font-size:16px;color:#5d4037}.pattern-tracer-header-actions{display:flex;align-items:center;gap:8px}.pattern-name-input{padding:4px 8px;border:1px solid #ccc;border-radius:4px;font-size:14px;width:160px}.pattern-tracer-upload{padding:40px 24px;text-align:center}.pattern-tracer-upload p{margin:0 0 20px;color:#666;font-size:15px;line-height:1.5}.pattern-tracer-body{display:flex;flex:1;min-height:0;overflow:hidden}.pattern-tracer-canvas{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px;overflow:auto;background:#f0ece6}.pattern-tracer-instructions{font-size:13px;color:#666;margin-bottom:8px;text-align:center;line-height:1.4}.pattern-tracer-svg{border:2px solid #8b7355;border-radius:4px;background:#fff;-webkit-user-select:none;user-select:none}.pattern-tracer-sidebar{width:220px;border-left:1px solid #e0e0e0;padding:12px;overflow-y:auto;background:#faf8f5}.pattern-tracer-sidebar h4{margin:0 0 10px;font-size:14px;color:#5d4037}.tracer-hint{font-size:13px;color:#999;font-style:italic}.tracer-region-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;cursor:pointer;margin-bottom:4px;font-size:13px;transition:background .15s}.tracer-region-item:hover{background:#e8e4dd}.tracer-region-item.selected{background:#e3f2fd;outline:2px solid #2196F3}.tracer-region-active{color:#ff5722;font-style:italic;cursor:default}.tracer-region-dot{width:10px;height:10px;border-radius:50%;background:#4caf50;flex-shrink:0}.tracer-region-dot.active-dot{background:#ff5722;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.tracer-region-name{flex:1;border:1px solid transparent;background:transparent;padding:2px 4px;border-radius:3px;font-size:13px;min-width:0}.tracer-region-name:focus{border-color:#8b7355;background:#fff;outline:none}.tracer-delete-btn{background:none;border:none;color:#999;font-size:18px;cursor:pointer;padding:0 2px;line-height:1}.tracer-delete-btn:hover{color:#e53935}.tracer-fabric-toggle{display:flex;align-items:center;gap:4px;font-size:12px;color:#666;cursor:pointer;white-space:nowrap}.tracer-fabric-toggle input{cursor:pointer}.auto-detect-section{padding-bottom:10px}.auto-detect-section h4{margin:0 0 6px;font-size:14px;color:#5d4037}.auto-detect-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.auto-detect-label{display:flex;align-items:center;gap:6px;font-size:12px;color:#555;flex-wrap:wrap}.auto-detect-slider{flex:1;min-width:60px;cursor:pointer}.auto-detect-value{font-size:11px;color:#888;min-width:28px;text-align:right}.auto-detect-btn{width:100%;font-size:14px}.tracer-divider{height:1px;background:#e0e0e0;margin:12px 0}.btn-clear-regions{margin-bottom:8px;width:100%;color:#999;font-size:12px}.recolor-analyzing{padding:40px 24px;text-align:center;color:#666;font-size:15px}.recolor-sidebar{width:260px;min-width:260px}.recolor-mode-toggle{display:flex;background:#e8e4dd;border-radius:6px;padding:2px}.recolor-mode-toggle .search-toggle-btn{font-size:12px;padding:4px 10px}.recolor-tolerance-label{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}.recolor-tolerance{width:80px;cursor:pointer}.recolor-palette{display:flex;flex-direction:column;gap:3px;margin-bottom:12px;max-height:280px;overflow-y:auto}.recolor-swatch{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:4px;cursor:pointer;transition:background .12s;position:relative}.recolor-swatch:hover,.recolor-swatch-hover{background:#e8e4dd}.recolor-swatch-color{width:24px;height:24px;border-radius:4px;border:1px solid rgba(0,0,0,.15);flex-shrink:0}.recolor-swatch-fabric{width:24px;height:24px;border-radius:4px;border:2px solid #4CAF50;flex-shrink:0;background-size:cover;background-position:center}.recolor-swatch-info{flex:1;min-width:0;display:flex;flex-direction:column}.recolor-swatch-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recolor-swatch-pct{font-size:10px;color:#999}.recolor-swatch-clear{background:none;border:none;color:#999;font-size:16px;cursor:pointer;padding:0 2px;line-height:1}.recolor-swatch-clear:hover{color:#e53935}.recolor-fabrics{border-top:1px solid #e0e0e0;padding-top:10px}.recolor-fabrics h4{margin:0 0 8px;font-size:13px;color:#5d4037}.recolor-fabric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;max-height:200px;overflow-y:auto}.recolor-fabric-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;border:2px solid transparent;border-radius:4px;background:none;cursor:pointer;transition:border-color .12s}.recolor-fabric-btn:hover{border-color:#ccc}.recolor-fabric-btn.selected{border-color:#4caf50;background:#e8f5e9}.recolor-fabric-btn img{width:48px;height:48px;object-fit:cover;border-radius:3px}.recolor-fabric-btn span{font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60px}.account-intro{color:#666;font-size:14px;line-height:1.5;margin:0 0 16px}.account-social-buttons{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.btn-social{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid #ddd;transition:background .15s}.btn-google{background:#fff;color:#333}.btn-google:hover{background:#f5f5f5}.btn-facebook{background:#1877f2;color:#fff;border-color:#1877f2}.btn-facebook:hover{background:#166fe5}.account-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:#999;font-size:12px}.account-divider:before,.account-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.account-email-form{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.account-input{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.account-input:focus{border-color:#8b7355;outline:none}.account-submit{padding:10px;font-size:14px}.account-toggle-mode{background:none;border:none;color:#8b7355;cursor:pointer;font-size:13px;padding:4px 0;text-decoration:underline}.account-error{margin-top:8px;padding:8px 12px;background:#fbe9e7;color:#c62828;border-radius:6px;font-size:13px}.account-user-info{display:flex;align-items:center;gap:12px;margin-bottom:20px}.account-avatar{width:48px;height:48px;border-radius:50%}.account-name{font-size:16px;font-weight:600;color:#333}.account-email{font-size:13px;color:#888}.account-storage{margin-bottom:20px}.account-storage h4{margin:0 0 8px;font-size:14px;color:#5d4037}.storage-bar{height:12px;background:#e8e4dd;border-radius:6px;overflow:hidden;margin-bottom:6px}.storage-bar-fill{height:100%;border-radius:6px;transition:width .3s}.storage-label{font-size:13px;color:#666}.storage-warning{color:#e53935;font-weight:500}.account-plans{margin-bottom:20px}.account-plans h4{margin:0 0 10px;font-size:14px;color:#5d4037}.plan-card{border:1px solid #e0e0e0;border-radius:8px;padding:14px;background:#faf8f5}.plan-name{font-size:15px;font-weight:600;color:#333}.plan-price{font-size:20px;font-weight:700;color:#4caf50;margin:4px 0}.plan-desc{font-size:13px;color:#888;margin-bottom:10px;line-height:1.4}.account-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #e0e0e0}.community-tabs{display:flex;gap:4px;margin-bottom:12px}.community-search-row{display:flex;gap:8px;margin-bottom:16px;align-items:center}.community-search-row .account-input{flex:1;margin:0}.community-grid{display:flex;flex-direction:column;gap:12px;max-height:50vh;overflow-y:auto;padding-right:4px}.community-card{display:flex;gap:12px;padding:12px;background:#f8f9fa;border-radius:10px;border:1px solid #e0e0e0;align-items:flex-start}.community-card-info,.community-design-info{flex:1;display:flex;flex-direction:column;gap:4px;font-size:13px}.community-author{color:#888;font-size:12px}.community-meta{color:#666;font-size:12px}.community-desc{color:#555;font-size:12px;margin-top:2px}.community-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.community-tag{padding:2px 8px;background:#e8eaf0;border-radius:10px;font-size:11px;color:#555}.community-card-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.community-publish{margin-top:16px;padding:16px;background:#f0f4e8;border-radius:10px;border:1px solid #c8d6b0;display:flex;flex-direction:column;gap:10px}.community-publish h4{margin:0;color:#4a6741}.community-publish-hint{margin:0;font-size:13px;color:#666}.community-publish-grid{display:flex;flex-wrap:wrap;gap:8px;max-height:150px;overflow-y:auto}.community-publish-grid .block-card{width:80px}.community-publish-actions{display:flex;gap:8px}
