*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f1a;color:#e0e0e0;height:100vh;overflow:hidden;margin:0}.btn:disabled,.btn.btn-disabled{background:#3a3a5a;color:#666;cursor:not-allowed;opacity:.7}.btn:disabled:hover,.btn.btn-disabled:hover{background:#3a3a5a}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-danger:disabled{background:#6c3540;opacity:.7}.sidebar{width:280px;min-width:280px;background:#1a1a2e;border-right:1px solid #2a2a4a;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.sidebar h1{font-size:1.3rem;color:#f0e6d3;letter-spacing:.5px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:#88a}.slider-row{display:flex;align-items:center;gap:10px}.slider-row input[type=range]{flex:1}.slider-row .val{min-width:32px;text-align:right;font-size:.85rem;color:#ccd;font-variant-numeric:tabular-nums}.toggle-row{display:flex;gap:4px;margin-top:6px}.toggle-btn{flex:1;padding:6px 10px;font-size:.75rem;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#88a;cursor:pointer;transition:all .15s}.toggle-btn:hover{background:#3a3a5a;color:#ccd}.toggle-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}input[type=range]{-webkit-appearance:none;height:6px;background:#2a2a4a;border-radius:3px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#6c63ff;border-radius:50%;cursor:pointer}.btn{background:#6c63ff;color:#fff;border:none;border-radius:4px;padding:6px 14px;cursor:pointer;font-size:.85rem;white-space:nowrap}.btn:hover{background:#5a52e0}.btn-secondary{background:#2a2a4a;border:1px solid #3a3a5a}.btn-secondary:hover{background:#3a3a5a}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.randomise-section{display:flex;flex-direction:column;gap:8px}.btn-randomise{background:linear-gradient(135deg,#6c63ff,#a855f7);font-size:1rem;padding:10px 16px}.btn-randomise:hover{background:linear-gradient(135deg,#5a52e0,#9333ea)}.history-dropdown{position:relative}.history-toggle{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center}.history-toggle:after{content:"▼";font-size:.7rem;opacity:.6}.history-toggle.open:after{content:"▲"}.history-list{display:none;position:absolute;top:100%;left:0;right:0;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:4px;max-height:200px;overflow-y:auto;z-index:10;margin-top:4px}.history-list.open{display:block}.history-item{padding:8px 12px;cursor:pointer;font-size:.85rem;border-bottom:1px solid #2a2a4a;display:flex;justify-content:space-between;align-items:center}.history-item:last-child{border-bottom:none}.history-item:hover{background:#2a2a4a}.history-item.active{background:#3a3a5a;color:#fff}.history-item-name{font-weight:500}.history-item-date{font-size:.7rem;opacity:.6}#symmetry-modes{display:flex;flex-wrap:wrap;gap:4px}.sym-mode-btn{background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#99b;font-size:.75rem;padding:3px 8px;cursor:pointer;transition:color .1s,border-color .1s}.sym-mode-btn:hover{color:#e0e0e0;border-color:#555}.sym-mode-btn.active{color:#fff;background:#6c63ff;border-color:#6c63ff}.shape-toggles{display:flex;flex-direction:column;gap:10px}.shape-item{display:flex;flex-direction:column;gap:4px}.shape-header{display:flex;align-items:center;gap:8px}.shape-header input[type=checkbox]{accent-color:#6c63ff}.shape-header span{font-size:.9rem}#palette-swatches{display:flex;flex-wrap:wrap;gap:6px}.palette-btn{display:flex;gap:2px;padding:5px 6px;background:#2a2a4a;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:border-color .15s}.palette-btn:hover{border-color:#555}.palette-btn.active{border-color:#6c63ff}.palette-btn.custom{outline:2px dashed #6c63ff55;outline-offset:1px}.palette-btn-wrapper{position:relative;display:inline-block}.palette-btn-actions{display:none;position:absolute;top:-8px;right:-8px;gap:2px}.palette-btn-wrapper:hover .palette-btn-actions{display:flex}.palette-action-btn{width:18px;height:18px;border-radius:50%;border:none;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.palette-action-btn.edit{background:#6c63ff;color:#fff}.palette-action-btn.share{background:#22c55e;color:#fff}.palette-action-btn.delete{background:#f55;color:#fff}.palette-action-btn:hover{transform:scale(1.1)}.swatch-dot{display:block;width:12px;height:12px;border-radius:2px}.swatch-dot.fabric{background-size:cover;background-position:center}.advanced-section{border:1px solid #2a2a4a;border-radius:8px;background:#16162a}.advanced-section summary{padding:10px 14px;cursor:pointer;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:#88a;list-style:none;display:flex;align-items:center;gap:8px}.advanced-section summary::-webkit-details-marker{display:none}.advanced-section summary:before{content:"▶";font-size:.6rem;transition:transform .2s}.advanced-section[open] summary:before{transform:rotate(90deg)}.advanced-content{padding:0 14px 14px;display:flex;flex-direction:column;gap:8px}.advanced-content label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:#88a}.save-image-row{display:flex;gap:4px;margin-bottom:8px}.save-image-row .btn{flex:1;border-radius:6px 0 0 6px}.format-select{padding:8px 10px;background:#2a2a4a;border:1px solid #3a3a5a;border-left:none;border-radius:0 6px 6px 0;color:#e0e0e0;font-size:.8rem;cursor:pointer}.format-select:focus{outline:none;border-color:#6c63ff}.btn.full-width{width:100%;margin-bottom:8px}.btn.full-width:last-of-type{margin-bottom:0}.canvas-area{flex:1;display:flex;flex-direction:column;background:#0f0f1a;padding:10px;position:relative}.canvas-controls{display:flex;justify-content:center;gap:16px;padding:8px;background:#1a1a2e;border-radius:8px;margin-bottom:10px}.canvas-control{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#88a}.canvas-control input[type=range]{width:80px}.canvas-control .val{min-width:24px;font-variant-numeric:tabular-nums;color:#ccd}.quilt-dimensions{font-size:.8rem;color:#88a;font-variant-numeric:tabular-nums;white-space:nowrap}.canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;position:relative}#quilt-canvas{width:100%;height:100%}.kofi-link{display:inline-block;margin-top:8px;padding:8px 12px;background:linear-gradient(135deg,#ff5e5b,#f96);color:#fff;text-decoration:none;border-radius:6px;font-size:.8rem;font-weight:500;text-align:center;transition:transform .15s,box-shadow .15s}.kofi-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff5e5b4d}.legal-links{margin-top:16px;padding-top:12px;border-top:1px solid #2a2a4a;font-size:.7rem;color:#666;text-align:center}.legal-links a{color:#666;text-decoration:none}.legal-links a:hover{color:#888;text-decoration:underline}.legal-links span{margin:0 6px}.palette-modal-overlay{display:none;position:fixed;inset:0;background:#000000b3;z-index:100;align-items:center;justify-content:center}.palette-modal-overlay.open{display:flex}.palette-modal{background:#1a1a2e;border:1px solid #3a3a5a;border-radius:12px;padding:24px;width:90%;max-width:400px;max-height:90vh;overflow-y:auto}.palette-modal h2{margin-bottom:16px;font-size:1.1rem;color:#f0e6d3}.palette-editor{display:flex;flex-direction:column;gap:12px}.palette-editor input[type=text]{background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#e0e0e0;padding:8px 12px;font-size:.9rem;outline:none}.palette-editor input[type=text]:focus{border-color:#6c63ff}.palette-colors{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.palette-color-slot{display:flex;flex-direction:column;gap:4px}.palette-color-slot input[type=color]{width:100%;height:40px;padding:0;border:none;border-radius:4px;background:transparent;cursor:pointer}.palette-color-slot .fabric-preview-thumb{width:100%;height:40px;border-radius:4px;object-fit:cover;cursor:pointer;border:2px solid #3a3a5a}.palette-color-slot .fabric-preview-thumb:hover{border-color:#6c63ff}.swatch-type-toggle{display:flex;gap:2px}.swatch-type-btn{flex:1;padding:4px;font-size:.7rem;background:#2a2a4a;border:1px solid #3a3a5a;color:#88a;cursor:pointer}.swatch-type-btn:first-child{border-radius:4px 0 0 4px}.swatch-type-btn:last-child{border-radius:0 4px 4px 0}.swatch-type-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.fabric-upload-btn{width:100%;height:40px;background:#2a2a4a;border:2px dashed #3a3a5a;border-radius:4px;color:#88a;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px}.fabric-upload-btn:hover{border-color:#6c63ff;color:#e0e0e0}.fabric-editor-overlay{display:none;position:fixed;inset:0;background:#000000d9;z-index:200;align-items:center;justify-content:center}.fabric-editor-overlay.open{display:flex}.fabric-editor-modal{background:#1a1a2e;border:1px solid #3a3a5a;border-radius:12px;padding:24px;width:90%;max-width:500px}.fabric-editor-modal h2{margin-bottom:16px;font-size:1.1rem;color:#f0e6d3}.fabric-editor{display:flex;flex-direction:column;gap:16px}.fabric-preview-container{position:relative;width:200px;height:200px;margin:0 auto;border-radius:8px;overflow:hidden}.fabric-preview{width:100%;height:100%}.fabric-controls{display:flex;flex-direction:column;gap:12px}.fabric-control{display:flex;align-items:center;gap:10px}.fabric-control label{width:80px;font-size:.8rem;color:#88a}.fabric-control input[type=range]{flex:1}.fabric-control span{min-width:50px;text-align:right;font-size:.8rem;color:#ccd}.fabric-actions{display:flex;gap:8px;margin-top:8px}.fabric-actions .btn{flex:1}.fabric-legend{display:flex;gap:16px;justify-content:center;font-size:.75rem;color:#88a}.fabric-legend span{display:flex;align-items:center;gap:4px}.fabric-legend .line-hst{width:16px;height:2px;background:#ff6b6b}.fabric-legend .line-qst{width:16px;height:2px;background:#4ecdc4}.palette-photo{display:flex;flex-direction:column;gap:8px}.palette-photo canvas{width:100%;height:140px;background:#141424;border:1px solid #2a2a4a;border-radius:6px;cursor:crosshair}.palette-photo input[type=file]{color:#c6c6d8;font-size:.8rem}.palette-modal-actions{display:flex;gap:8px;margin-top:16px}.palette-modal-actions .btn{flex:1}.share-modal-wide{max-width:480px!important}.share-preview-swatches{display:flex;gap:8px;justify-content:center;margin-bottom:16px}.share-swatch{width:48px;height:48px;border-radius:8px;background-size:cover;background-position:center;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .15s}.share-swatch:hover{transform:scale(1.1)}.share-swatch.active{border-color:#6c63ff}.share-swatch.has-meta:after{content:"✓";position:absolute;bottom:-4px;right:-4px;background:#6c63ff;color:#fff;width:14px;height:14px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center}.share-swatch{position:relative}.share-form-row{margin-bottom:12px}.share-form-row label{display:block;font-size:.8rem;color:#88a;margin-bottom:4px}.share-form-row label .optional{color:#666;font-weight:400}.share-form-row input,.share-form-row textarea{width:100%;padding:8px 12px;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:6px;color:#e0e0e0;font-size:.9rem;font-family:inherit}.share-form-row textarea{resize:vertical;min-height:60px}.share-form-row input:focus,.share-form-row textarea:focus{outline:none;border-color:#6c63ff}.share-fabric-section{margin:16px 0;padding:12px;background:#252542;border-radius:8px}.share-fabric-section>label{display:block;font-size:.8rem;color:#88a;margin-bottom:8px}.share-fabric-list{display:flex;flex-direction:column;gap:8px}.share-fabric-item{display:none;gap:10px;padding:10px;background:#1a1a2e;border-radius:6px;align-items:flex-start}.share-fabric-item.active{display:flex}.share-fabric-swatch{width:40px;height:40px;border-radius:6px;background-size:cover;flex-shrink:0}.share-fabric-fields{flex:1;display:flex;flex-direction:column;gap:6px}.share-fabric-fields input{padding:6px 10px;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#e0e0e0;font-size:.8rem}.share-fabric-fields input:focus{outline:none;border-color:#6c63ff}.share-fabric-fields input::placeholder{color:#666}.share-design-preview{display:flex;justify-content:center;margin-bottom:16px;padding:16px;background:#1a1a2e;border-radius:8px}.share-design-preview img{max-width:100%;max-height:200px;border-radius:6px;object-fit:contain}.share-palette-select{width:100%;padding:8px 12px;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:6px;color:#e0e0e0;font-size:.9rem;font-family:inherit;cursor:pointer}.share-palette-select:focus{outline:none;border-color:#6c63ff}.share-palette-select option{background:#2a2a4a;color:#e0e0e0}.share-new-palette{margin-top:8px;padding:12px;background:#252542;border-radius:6px}.share-new-palette input{width:100%;padding:8px 12px;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:6px;color:#e0e0e0;font-size:.9rem;font-family:inherit}.share-new-palette input:focus{outline:none;border-color:#6c63ff}.share-default-palette-msg{padding:12px 16px;background:linear-gradient(135deg,#2d4a3e,#1a3a2e);border:1px solid #3d6a5e;border-radius:8px;color:#8fc9a9;font-size:.9rem;margin-bottom:12px;text-align:center}.share-palette-info{padding:12px 16px;background:#252542;border:1px solid #3a3a5a;border-radius:8px;color:#aac;font-size:.85rem;margin:0}.share-palette-info strong{color:#cce}.app-container{display:flex;flex-direction:column;height:100vh;width:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#1a1a2e;border-bottom:1px solid #2a2a4a;flex-shrink:0}.app-header h1{font-size:1.3rem;color:#f0e6d3;letter-spacing:.5px;margin:0}.app-nav-tabs{display:flex;gap:4px}.app-header-right{display:flex;align-items:center;gap:12px}.app-header-right .user-info{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#ccc}.app-header-right .user-avatar{width:28px;height:28px;border-radius:50%;background:#3a3a5a}.app-nav-tab{padding:8px 16px;font-size:.85rem;background:transparent;border:1px solid transparent;border-radius:6px;color:#88a;cursor:pointer;transition:all .15s}.app-nav-tab:hover{background:#252542;color:#ccd}.app-nav-tab.active{background:#6c63ff;color:#fff;border-color:#6c63ff}.app-views{display:flex;flex:1;overflow:hidden}.app-view{display:none;flex:1;overflow:hidden}.app-view.active{display:flex}#editor-view{flex-direction:row}.community-view{flex-direction:column;background:#0f0f1a}.community-header{display:flex;align-items:center;gap:16px;padding:16px 24px;border-bottom:1px solid #2a2a4a;flex-shrink:0}.community-search{flex:1;max-width:400px}.community-search input{width:100%;padding:10px 16px;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:8px;color:#e0e0e0;font-size:.9rem}.community-search input:focus{outline:none;border-color:#6c63ff}.community-filters{display:flex;gap:8px}.filter-btn{padding:8px 14px;font-size:.8rem;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:6px;color:#88a;cursor:pointer;transition:all .15s}.filter-btn:hover{background:#252542;color:#ccd}.filter-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.community-content{flex:1;overflow-y:auto;padding:24px}.community-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;max-width:1600px;margin:0 auto}.community-card{background:#1a1a2e;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;border:1px solid #2a2a4a}.community-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:#6c63ff}.card-preview{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);padding:12px;gap:6px;background:#252542;aspect-ratio:3/2}.card-preview.design-preview{display:flex;align-items:center;justify-content:center;padding:12px}.card-preview.design-preview img{width:100%;height:100%;object-fit:contain;border-radius:6px}.card-swatch{border-radius:6px;background-size:cover;background-position:center}.card-info{padding:14px}.card-type{font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:#6c63ff;margin-bottom:4px}.card-name{font-size:.95rem;font-weight:500;color:#fff;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-meta{display:flex;gap:12px;font-size:.75rem;color:#88a}.card-meta span{display:flex;align-items:center;gap:4px}.card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.card-tag{font-size:.65rem;padding:3px 8px;background:#252542;border-radius:10px;color:#88a}.community-empty{text-align:center;padding:60px 20px;color:#88a}.community-empty h3{font-size:1.1rem;color:#ccd;margin-bottom:8px}.community-loading{display:flex;justify-content:center;padding:40px;color:#88a}.load-more-row{display:flex;justify-content:center;padding:20px}.detail-modal-overlay{position:fixed;inset:0;background:#000c;display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}.detail-modal-overlay.open{display:flex}.detail-modal{background:#1a1a2e;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.detail-header{padding:20px;border-bottom:1px solid #2a2a4a;display:flex;justify-content:space-between;align-items:flex-start}.detail-header h2{font-size:1.2rem;color:#fff;margin:0}.detail-close{background:none;border:none;color:#88a;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.detail-close:hover{color:#fff}.detail-preview{padding:20px;background:#252542}.detail-swatches{display:flex;gap:8px;flex-wrap:wrap}.detail-swatch{width:60px;height:60px;border-radius:8px;background-size:cover;background-position:center;position:relative}.detail-swatch-info{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);background:#1a1a2e;padding:2px 6px;border-radius:4px;font-size:.6rem;white-space:nowrap;opacity:0;transition:opacity .15s}.detail-swatch:hover .detail-swatch-info{opacity:1}.detail-body{padding:20px}.detail-meta{display:flex;gap:16px;font-size:.85rem;color:#88a;margin-bottom:16px}.detail-description{font-size:.9rem;color:#ccd;line-height:1.5;margin-bottom:16px}.detail-fabric-list{margin-top:16px}.detail-fabric-item{display:flex;align-items:center;gap:12px;padding:10px;background:#252542;border-radius:8px;margin-bottom:8px}.detail-fabric-swatch{width:40px;height:40px;border-radius:6px;background-size:cover;flex-shrink:0}.detail-fabric-info{flex:1;min-width:0}.detail-fabric-name{font-size:.85rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-fabric-brand{font-size:.75rem;color:#88a}.detail-fabric-link{font-size:.75rem;color:#6c63ff;text-decoration:none}.detail-fabric-link:hover{text-decoration:underline}.detail-actions{padding:16px 20px;border-top:1px solid #2a2a4a;display:flex;gap:12px}.detail-actions .btn{flex:1}.border-colors{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.border-color-picker{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#88a}.border-color-picker span{min-width:14px}.border-color-picker select{background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#e0e0e0;padding:4px 6px;font-size:.75rem;cursor:pointer}.border-color-picker select:focus{border-color:#6c63ff;outline:none}.border-swatch-row{display:flex;gap:4px;flex-wrap:wrap}.border-swatch-btn{width:24px;height:24px;border:2px solid transparent;border-radius:4px;cursor:pointer;padding:0;background-size:cover;background-position:center}.border-swatch-btn:hover{border-color:#888}.border-swatch-btn.active{border-color:#6c63ff;box-shadow:0 0 0 1px #6c63ff}.cornerstone-swatch-row{margin-left:auto}.border-width-select{flex:1;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:4px;color:#e0e0e0;padding:4px 8px;font-size:.8rem;cursor:pointer}.border-width-select:focus{border-color:#6c63ff;outline:none}.hint{font-size:.7rem;color:#666;margin-top:4px}.drop-active{outline:3px dashed #6c63ff;outline-offset:-3px}.mode-tabs{display:flex;gap:4px;margin-bottom:16px}.mode-tab{flex:1;padding:10px 16px;background:#2a2a4a;border:1px solid #3a3a5a;border-radius:6px;color:#88a;font-size:.9rem;cursor:pointer;transition:all .15s}.mode-tab:hover{background:#3a3a5a;color:#ccd}.mode-tab.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.manual-editor-overlay{position:absolute;top:0;left:0;pointer-events:none}.cell-hover-controls{display:flex;gap:4px;padding:2px;background:#1a1a2ef2;border-radius:4px;border:1px solid #3a3a5a}.cell-btn{width:24px;height:24px;border:none;border-radius:4px;background:#6c63ff;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.cell-btn:hover{background:#5a52e0}.primary-segment-overlay{position:absolute;background:#6495ed26;border:2px dashed rgba(100,149,237,.6);pointer-events:none;box-sizing:border-box}.symmetry-guide{position:absolute;pointer-events:none}.symmetry-guide.horizontal{height:2px;background:repeating-linear-gradient(90deg,rgba(100,149,237,.6) 0,rgba(100,149,237,.6) 8px,transparent 8px,transparent 16px)}.symmetry-guide.vertical{width:2px;background:repeating-linear-gradient(0deg,rgba(100,149,237,.6) 0,rgba(100,149,237,.6) 8px,transparent 8px,transparent 16px)}.manual-mode .random-only,.random-mode .manual-only{display:none}@media(max-width:820px){body{overflow:hidden;height:100dvh}.app-container{height:100dvh;overflow:hidden}.app-views{flex:1;overflow:hidden}#editor-view{flex-direction:column;height:100%;overflow:hidden}.sidebar{width:100%;min-width:0;border-right:none;border-top:1px solid #2a2a4a;padding:16px;overflow-y:auto;flex:1}.canvas-area{order:-1;height:50%;min-height:0;padding:8px;background:#0f0f1a;flex-shrink:0;display:flex;flex-direction:column}.canvas-controls{padding:4px 8px;gap:12px;flex-shrink:0}.canvas-wrapper{flex:1;min-height:0}#quilt-canvas{width:100%;height:100%;max-height:100%}.slider-row{gap:8px}.btn-row{gap:6px}.palette-colors{grid-template-columns:repeat(2,1fr)}.app-header{padding:8px 12px;gap:8px;flex-shrink:0}.app-header h1{font-size:1rem}.app-nav-tab{padding:6px 10px;font-size:.8rem}.app-header-right .user-info{font-size:0}.app-header-right .user-avatar{width:32px;height:32px}#palette-swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:8px}.palette-btn{width:100%;justify-content:center;padding:8px}.palette-btn-wrapper{display:block}.swatch-dot{width:14px;height:14px}.palette-btn-wrapper:hover .palette-btn-actions{display:none}.palette-btn-wrapper:has(.palette-btn.active) .palette-btn-actions{display:flex}}
