@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&display=swap";.fabric-editor{display:flex;height:100vh;width:100vw;background:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.fabric-list-panel{width:300px;min-width:300px;background:#fff;display:flex;flex-direction:column;border-right:1px solid #ddd;box-shadow:2px 0 5px #0000000d}.panel-header{padding:16px;border-bottom:1px solid #eee;background:#fafafa}.panel-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.panel-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.logout-button{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#666;font-size:12px;cursor:pointer;transition:all .2s}.logout-button:hover{background:#f5f5f5;border-color:#ccc;color:#333}.search-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;font-size:14px;outline:none;box-sizing:border-box}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26}.search-input::placeholder{color:#999}.add-new-button{width:100%;padding:10px 16px;margin-top:12px;border:2px dashed #007bff;border-radius:6px;background:#f0f7ff;color:#007bff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.add-new-button:hover{background:#e0efff;border-color:#0056b3}.fabric-list{flex:1;overflow-y:auto;padding:8px}.fabric-list-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;cursor:pointer;transition:background .2s;margin-bottom:4px;border:1px solid transparent}.fabric-list-item:hover{background:#f0f0f0;border-color:#ddd}.fabric-list-item.selected{background:#e7f1ff;border-color:#007bff}.fabric-thumbnail{width:50px;height:50px;object-fit:cover;border-radius:6px;border:1px solid #ddd}.fabric-info{flex:1;min-width:0}.fabric-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#333}.fabric-code{font-size:11px;color:#666;margin-top:2px}.preview-panel{flex:1;display:flex;flex-direction:column;background:#fff}.preview-header{padding:16px;border-bottom:1px solid #ddd;background:#fafafa}.preview-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.preview-canvas{flex:1;position:relative;min-height:400px;background:#fff}.preview-canvas canvas{width:100%!important;height:100%!important}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:16px}.preview-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;pointer-events:none}.controls-panel{width:320px;min-width:320px;background:#fff;display:flex;flex-direction:column;border-left:1px solid #ddd;box-shadow:-2px 0 5px #0000000d}.controls-panel .panel-header{padding:16px;border-bottom:1px solid #eee;background:#fafafa}.controls-content{padding:16px;flex:1;overflow-y:auto}.selected-fabric-info{display:flex;gap:16px;padding-bottom:20px;border-bottom:1px solid #eee;margin-bottom:20px}.selected-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:8px;border:1px solid #ddd}.selected-fabric-info h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#333}.selected-fabric-info p{margin:0;font-size:13px;color:#666}.control-group{margin-bottom:24px}.control-group label{display:block;font-size:14px;font-weight:500;margin-bottom:10px;color:#444}.slider-input-group{display:flex;gap:12px;align-items:center}.slider{flex:1;height:6px;border-radius:3px;background:#ddd;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;transition:background .2s;box-shadow:0 2px 4px #0003}.slider::-webkit-slider-thumb:hover{background:#0056b3}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;border:none}.number-input{width:80px;padding:8px 10px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#333;font-size:14px;text-align:center;outline:none}.number-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26}.original-values{background:#f5f5f5;padding:12px;border-radius:8px;margin-bottom:20px;border:1px solid #eee}.original-values p{margin:0;font-size:13px;color:#666}.original-values p:first-child{font-weight:500;color:#444;margin-bottom:4px}.save-button{width:100%;padding:14px 20px;border:none;border-radius:8px;background:#28a745;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.save-button:hover:not(:disabled){background:#218838}.save-button:disabled{background:#ccc;cursor:not-allowed}.save-status{margin-top:12px;padding:10px;border-radius:6px;text-align:center;font-size:14px}.save-status.success{background:#28a74526;color:#1e7e34;border:1px solid rgba(40,167,69,.3)}.save-status.error{background:#dc354526;color:#c82333;border:1px solid rgba(220,53,69,.3)}.fabric-list::-webkit-scrollbar,.controls-content::-webkit-scrollbar{width:8px}.fabric-list::-webkit-scrollbar-track,.controls-content::-webkit-scrollbar-track{background:#f0f0f0}.fabric-list::-webkit-scrollbar-thumb,.controls-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.fabric-list::-webkit-scrollbar-thumb:hover,.controls-content::-webkit-scrollbar-thumb:hover{background:#bbb}.load-more-indicator{padding:16px;text-align:center;color:#666;font-size:13px;border-top:1px solid #eee;background:#fafafa}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px}.login-box h2{margin:0 0 8px;font-size:24px;font-weight:600;color:#333}.login-box p{margin:0 0 24px;color:#666;font-size:14px}.login-field{margin-bottom:20px}.login-field label{display:block;font-size:14px;font-weight:500;color:#444;margin-bottom:8px}.login-field input{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;box-sizing:border-box;transition:border-color .2s}.login-field input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.login-error{background:#dc35451a;color:#c82333;padding:12px;border-radius:6px;font-size:14px;margin-bottom:20px;border:1px solid rgba(220,53,69,.2)}.login-button{width:100%;padding:14px 20px;border:none;border-radius:6px;background:#007bff;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.login-button:hover{background:#0056b3}.panel-tabs{display:flex;gap:0;width:100%}.panel-tab{flex:1;padding:12px 16px;border:1px solid #ddd;background:#f5f5f5;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.panel-tab:first-child{border-radius:6px 0 0 6px}.panel-tab:last-child{border-radius:0 6px 6px 0;border-left:none}.panel-tab.active{background:#007bff;border-color:#007bff;color:#fff;font-weight:600}.panel-tab:hover:not(.active){background:#eee}.section-title{margin:0 0 20px;font-size:16px;font-weight:600;color:#333;padding-bottom:12px;border-bottom:1px solid #eee}.text-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;box-sizing:border-box}.text-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff26}.file-input{width:100%;padding:10px 0;font-size:14px}.file-preview{margin-top:10px;border:1px solid #ddd;border-radius:6px;overflow:hidden}.file-preview img{width:100%;max-height:150px;object-fit:contain;display:block}.file-preview .file-name{display:block;padding:8px;font-size:12px;color:#666;background:#f5f5f5;text-align:center;border-top:1px solid #ddd}.fabric-id-link{margin:8px 0 0;font-size:13px}.fabric-id-link a{color:#06c;text-decoration:none}.fabric-id-link a:hover{text-decoration:underline}.hint{margin:8px 0 0;font-size:12px;color:#888;font-style:italic}.radio-group{display:flex;gap:20px}.radio-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#444;cursor:pointer}.radio-label input[type=radio]{width:16px;height:16px;cursor:pointer}.app-container{display:grid;grid-template-columns:1fr 650px;height:100vh;font-family:Playfair Display,serif}.app-container[data-render-mode=true]{grid-template-columns:1fr}.app-container[data-render-mode=true] .viewer-container{width:100vw;height:100vh}.viewer-container{background:#fff;position:relative;display:flex;justify-content:center;align-items:center}.config-panel{background:#fff;overflow-y:auto;border-left:1px solid #000}.config-title{font-size:1.2rem;font-weight:700;text-transform:uppercase;padding:20px;border-bottom:1px solid #000;margin:0;color:#000}.config-section{border-bottom:1px solid #000}.section-header{padding:12px 20px;cursor:pointer;font-weight:500;font-size:.75rem;text-transform:uppercase;transition:all .3s ease;display:flex;align-items:center;justify-content:space-between;color:#666;background:#fff;line-height:1.4}.section-header:hover{background:#f8f8f8}.section-header.active{background:#4a4a4a;color:#fff;font-weight:600}.section-content{padding:20px;border-top:1px solid #000;display:flex;flex-direction:column;max-height:calc(100vh - 200px);overflow:hidden}.fabric-selection-header{font-weight:700;font-size:1rem;margin-bottom:16px;color:#000}.fabric-label{font-size:.875rem;margin-bottom:8px;color:#000}.fabric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;width:100%}.fabric-swatch{border:1px solid #ddd;cursor:pointer;transition:all .2s;background:#fff;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center}.fabric-swatch:hover,.fabric-swatch.selected{border:2px solid black}.fabric-name{text-align:center;padding:6px 4px;font-weight:600;font-size:10px;color:#000;background:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.fabric-image{width:150px;height:168px;object-fit:cover;display:block;margin:0 auto}.config-panel::-webkit-scrollbar{width:8px}.config-panel::-webkit-scrollbar-track{background:#f1f1f1}.config-panel::-webkit-scrollbar-thumb{background:#888}.config-panel::-webkit-scrollbar-thumb:hover{background:#555}.fabric-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid #ddd}.fabric-tab{flex:1;padding:10px 16px;border:none;background:#fff;color:#000;font-weight:600;font-size:.875rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase}.fabric-tab:hover{background:#f8f8f8}.fabric-tab.active{border-bottom:2px solid black;background:#fff}.fabric-selector{margin-top:16px;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.fabric-search{width:100%;padding:10px;border:1px solid #ddd;font-size:.875rem;margin-bottom:12px;box-sizing:border-box}.fabric-search:focus{outline:none;border:2px solid black}.fabric-results-count{font-size:.75rem;color:#666;margin-bottom:12px}.fabric-list-container{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;max-height:100%;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#888 #f1f1f1}.fabric-code{font-size:.7rem;color:#666;text-align:center;padding:2px 4px;background:#f8f8f8}.load-more-btn{width:100%;padding:12px;margin-top:16px;background:#000;color:#fff;border:none;font-weight:600;cursor:pointer;font-size:.875rem;text-transform:uppercase;transition:background .2s}.load-more-btn:hover{background:#333}.style-options{display:flex;gap:12px;margin-bottom:20px}.style-option{flex:1;padding:16px 24px;border:2px solid #ddd;background:#fff;color:#000;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;text-transform:uppercase;font-family:Playfair Display,serif}.style-option:hover{border-color:#999;background:#f8f8f8}.style-option.active{border-color:#000;background:#000;color:#fff}.style-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.style-card{border:2px solid #ddd;background:#fff;cursor:pointer;transition:all .2s;overflow:hidden}.style-card:hover{border-color:#999;background:#f8f8f8}.style-card.active{border-color:#000;background:#fff}.style-card-image{width:100%;height:120px;overflow:hidden;background:#f0f0f0;display:flex;align-items:center;justify-content:center}.style-card-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.style-card-name{padding:12px;text-align:center;font-weight:600;font-size:.875rem;text-transform:uppercase;color:#000;margin:0;font-family:Playfair Display,serif}.style-card.active .style-card-name{color:#000;font-weight:700}.size-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.size-radio{display:flex;align-items:center;padding:12px;border:2px solid #ddd;background:#fff;cursor:pointer;transition:all .2s;font-size:.875rem}.size-radio:hover{border-color:#999;background:#f8f8f8}.size-radio input[type=radio]{margin-right:12px;cursor:pointer}.size-radio input[type=radio]:checked+span{font-weight:600}.size-radio:has(input[type=radio]:checked){border-color:#000;background:#fff}.rotation-options{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.rotation-label{font-size:.875rem;color:#333;font-weight:500}.rotation-buttons-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.rotation-button-item{display:flex;flex-direction:column;gap:8px}.rotation-label-small{font-size:.75rem;color:#666;font-weight:500;text-transform:uppercase}.rotation-button{padding:12px 20px;background:#fff;border:2px solid #ddd;cursor:pointer;font-size:.875rem;font-weight:600;color:#000;transition:all .2s;font-family:Playfair Display,serif;text-align:center}.rotation-button:hover{border-color:#999;background:#f8f8f8}.rotation-button:active{background:#eee}.closure-options{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.closure-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #ddd}.closure-tab{flex:1;padding:12px 16px;border:none;background:#fff;color:#666;font-weight:600;font-size:.875rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase}.closure-tab:hover{background:#f8f8f8;color:#333}.closure-tab.active{border-bottom:2px solid black;background:#fff;color:#000}.closure-tab-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.closure-radio-group{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.closure-radio{display:flex;align-items:center;gap:10px;padding:10px;cursor:pointer;font-weight:500;font-size:.875rem;color:#000}.closure-radio input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:black}.button-selector-container{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.button-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding-bottom:20px}.button-card{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;overflow:hidden}.button-card:hover{border-color:#999;box-shadow:0 2px 4px #0000001a}.button-card.selected{border:2px solid black;box-shadow:0 2px 8px #00000026}.button-card-top{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8f8f8}.button-small-box{width:12px;height:12px;border:1px solid #ccc;background:#fff}.button-card-name{font-size:.75rem;font-weight:600;color:#000;margin:0;text-transform:uppercase;letter-spacing:.5px}.button-card-inner{padding:12px;display:flex;flex-direction:column;align-items:center}.button-card-image{width:100%;display:flex;justify-content:center;margin-bottom:12px}.button-card-image img{width:80px;height:80px;object-fit:cover;border-radius:50%;border:1px solid #ddd}.button-card-bottom{display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px}.button-card-code{font-size:.75rem;font-weight:600;color:#000;margin:0;flex:1}.button-card-info-icon{font-size:.875rem;color:#4c4c4c;cursor:pointer;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid #4c4c4c;font-style:normal}.button-card-size{font-size:.75rem;color:#666;font-weight:500}.closure-toggle{display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer;font-weight:600;font-size:1rem;color:#000}.closure-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:black}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%}
