@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&display=swap";.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%}
