html,body{margin:0;padding:0;height:auto!important;min-height:100vh!important;overflow-y:auto!important;overflow-x:hidden}#root{min-height:100vh;height:auto!important;overflow-y:visible!important;width:100%}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;overflow-y:auto!important}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden;max-width:100vw;box-sizing:border-box}body{background:#e9e9e9;overflow:hidden;font-family:Segoe UI,sans-serif;position:relative;max-width:100vw}@media(max-width:768px){body{overflow:auto}}.custom-header{background:#000;color:#fff;padding:18px 30px;display:flex;align-items:center;justify-content:space-between;position:relative}@media(max-width:768px){.custom-header{padding:12px 16px}.header-nav{gap:14px;font-size:12px}.header-actions{gap:12px;font-size:12px}}.header-left{font-weight:600;font-size:18px;letter-spacing:1px}.header-right{display:flex;align-items:center;gap:30px;font-size:14px}@media(max-width:768px){.header-right{gap:10px}.header-nav,.header-actions span{display:none!important}}.header-nav{display:flex;gap:30px;font-size:14px;letter-spacing:1px}.header-nav span{cursor:pointer}.header-nav span:hover{opacity:.7}.header-actions{display:flex;align-items:center;gap:25px;font-size:14px}.hamburger{width:22px;height:2px;background:#fff;position:relative}.hamburger:before,.hamburger:after{content:"";position:absolute;width:22px;height:2px;background:#fff;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.custom-layout{display:flex;height:calc(100vh - 60px)}@media(max-width:768px){.custom-layout{flex-direction:column;height:auto;min-height:calc(100vh - 60px);overflow-y:auto}}.fabric-sidebar{width:400px;min-width:400px;background:#efefef;padding:30px;border-right:1px solid #ddd;overflow-y:auto;flex-shrink:0}@media(max-width:768px){.fabric-sidebar{width:100%!important;min-width:unset!important;border-right:none;border-top:1px solid #ddd;padding:16px;order:2;flex-shrink:0;overflow-y:visible;max-height:none}}.fabric-header{display:flex;gap:10px;margin-bottom:20px}.fabric-header button{padding:6px 14px;border-radius:6px;border:1px solid #ccc;cursor:pointer}.fabric-title{background:#ddd;padding:8px 10px;margin-bottom:20px;font-weight:600;color:#000}.main-center{flex:1;position:relative;display:flex;overflow:hidden;background:transparent;border:none;box-shadow:none}@media(max-width:768px){.main-center{order:1;height:auto;min-height:400px;overflow:visible;flex-direction:column}}.vertical-menu{width:220px;padding-top:120px;padding-left:30px;padding-right:60px;position:relative;z-index:10;flex-shrink:0}@media(max-width:768px){.vertical-menu{display:none}}.menu-item{margin-bottom:30px;font-size:14px;letter-spacing:2px;color:#777;position:relative;cursor:pointer}.menu-item:hover{color:#111}.menu-item.active{color:#111;font-weight:600}.menu-item.active:before{content:"";position:absolute;left:-15px;width:3px;height:18px;background:#000}.monogram-meshes-preview{margin:20px 0;padding:16px;background:linear-gradient(135deg,#fafafa,#f0f0f0);border-radius:10px;box-shadow:0 2px 6px #00000014;transition:all .3s ease}.monogram-meshes-preview:hover{box-shadow:0 4px 12px #0000001f}.monogram-meshes-preview label{font-weight:600;display:block;margin-bottom:10px;font-size:14px;color:#222;letter-spacing:.3px}.mesh-list li{display:flex;justify-content:space-between;align-items:baseline;padding:10px 12px;border-bottom:1px solid #e5e5e5;font-size:14px;transition:background .2s ease}.mesh-display-name{font-weight:600;color:#111;line-height:1.4}.mesh-technical-name{color:#666;font-size:12px;font-family:monospace;background:#f2f2f2;padding:2px 6px;border-radius:4px;line-height:1.4;margin-left:8px}.model-section{flex:1;position:relative;display:flex;flex-direction:column;height:100%;padding:0;margin:0;box-shadow:none;border:none;background:transparent}@media(max-width:768px){.model-section{height:auto;min-height:400px}}.step{display:flex;align-items:center;gap:0;margin-left:-80px;margin-top:40px;margin-bottom:20px;flex-shrink:0}.step-circle{width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;font-weight:700;transition:.2s;z-index:2;background-color:#fff;position:relative;margin-right:44px;color:#333}.step-circle:not(:last-child):after{content:"";position:absolute;width:44px;height:2px;background:#ccc;left:40px;top:50%;transform:translateY(-50%);z-index:1}.step-circle:last-child{margin-right:0}.step-circle.completed{background:#f97316;border-color:#f97316;color:#fff}.step-circle.active{border-color:#f97316;color:#f97316;background:#fff}.step-circle.completed:not(:last-child):after{background:#f97316}.viewer-container{position:absolute;inset:-20px 0 0 -270px;width:100%;height:100%;background:transparent;border-radius:0;overflow:hidden}@media(max-width:768px){.viewer-container{position:relative;top:0;left:0;width:100%;height:70vw;min-height:320px;max-height:500px}}canvas{background:transparent!important}.placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:1rem 2rem;border-radius:30px;box-shadow:0 4px 12px #0000001a;color:#666;font-size:16px;display:flex;align-items:center;gap:.5rem;z-index:10}.loading-overlay{position:absolute;inset:0;background:#f5f5f5cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.loading-spinner{width:36px;height:36px;border:2px solid rgba(0,0,0,.1);border-top:2px solid rgba(0,0,0,.8);border-radius:50%;animation:spin 1s linear infinite;text-indent:-9999px}.skeleton-loader{display:flex;flex-direction:column;gap:.75rem}.skeleton-item{height:60px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.bottom-row{position:absolute;bottom:130px;left:0;width:60%;display:flex;align-items:center;justify-content:center;padding:0 40px;flex-wrap:wrap;gap:20px;box-sizing:border-box;z-index:10}@media(max-width:768px){.bottom-row{position:relative;bottom:auto;left:auto;width:100%;padding:10px 16px;flex-direction:column;align-items:center}}.front-piping{font-size:18px;display:flex;align-items:center;gap:10px;color:#222;position:static}.front-piping input[type=checkbox]{width:20px;height:20px;accent-color:#f97316;cursor:pointer;margin:0}.front-piping label{cursor:pointer;color:#222;font-size:18px;font-weight:500}.submesh-toggles{display:flex;flex-wrap:wrap;gap:15px 25px;align-items:center;justify-content:flex-start;position:absolute;bottom:-60px;left:0;width:100%;padding:0 20px;box-sizing:border-box;z-index:10;top:50px}@media(max-width:768px){.submesh-toggles{position:relative;top:auto;bottom:auto;padding:10px 16px;justify-content:center}}.submesh-toggle-item{display:flex;align-items:center;gap:6px;white-space:nowrap}.submesh-toggle-item input[type=checkbox]{width:16px;height:16px;accent-color:#f97316;cursor:pointer}.submesh-toggle-item label{font-size:13px;color:#222;cursor:pointer}.product-info{text-align:right;color:#000;margin:0;display:flex;flex-direction:column;align-items:flex-end;position:absolute;bottom:100px;right:-140px;z-index:10}@media(max-width:768px){.product-info{position:relative;bottom:auto;right:auto;align-items:flex-end;text-align:right;padding:12px 16px;width:100%}.product-info h2{font-size:22px}.product-info .price{font-size:18px}}.product-info h2{font-size:40px;font-weight:400;margin-bottom:8px;line-height:1.2;color:#111}.product-info .price{font-size:24px;font-weight:400;margin-bottom:12px;line-height:1.2;color:#000}.product-info .proceed{background:#f97316;color:#fff;border:none;padding:14px 40px;border-radius:30px;font-size:18px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s;display:inline-block;width:auto;min-width:140px;text-align:center;box-shadow:0 4px 10px #f973164d}.product-info .proceed:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 6px 15px #f9731666}.measurement-table{background:#fff;border-radius:10px;padding:10px 20px}.measurement-row{display:flex;align-items:center;padding:18px 0;border-bottom:1px solid #eee}.measurement-row:last-child{border-bottom:none}.measurement-label{flex:1;font-weight:500;color:#000;font-size:15px}.measurement-input{flex:1;display:flex;flex-direction:column;gap:8px;width:100%}.measurement-input select,.measurement-input input{width:100%;padding:10px;border-radius:6px;border:1px solid #ccc;background:#fff;color:#000;font-size:14px;box-sizing:border-box;height:40px;margin:0}.measurement-input select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:30px}.measurement-input select:focus,.measurement-input input:focus{outline:none;border-color:#f97316}.form-box{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 6px #00000014}.form-group{margin-bottom:20px}.form-group select{width:100%;padding:10px;border-radius:6px;border:1px solid #ccc;font-size:14px;background:#fff;color:#000;height:40px;box-sizing:border-box}.form-group input[type=range]{width:100%}.fabrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.fabric-card{display:flex;flex-direction:column;align-items:center;padding:1rem;border-radius:10px;background:#fafafa;border:1px solid rgba(0,0,0,.05);cursor:pointer;transition:transform .2s,border-color .2s;text-align:center}.fabric-card.selected{background:#8080801a;border:2px solid #808080}.fabric-swatch{width:100%;height:100px;border-radius:8px;background-size:cover;background-position:center;background-color:#f0f0f0;border:1px solid rgba(0,0,0,.1);margin-bottom:8px}.fabric-name{font-size:16px;font-weight:500;color:#1a1a1a}.fabric-description{font-size:13px;color:#666}.mesh-option-price{font-size:12px;color:#666;white-space:nowrap;font-weight:400;opacity:0;transition:opacity .2s ease}.mesh-option-item:hover .mesh-option-price,.mesh-option-item.active .mesh-option-price{opacity:1}.mesh-price-visible{opacity:1!important}.style-group{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#fafafa;border-radius:8px;border:1px solid rgba(0,0,0,.05);margin-bottom:1rem}.style-header{display:flex;align-items:center;justify-content:space-between}.style-header h4{font-size:15px;font-weight:500;color:#1a1a1a}.parent-mesh-badge{font-size:12px;padding:2px 6px;background:#e0e0e0;border-radius:4px;color:#666}.parent-mesh-detail{display:flex;align-items:center;gap:10px;padding:8px;background:#f0f0f0;border-radius:6px;margin-bottom:8px;overflow:hidden;box-sizing:border-box;width:100%}.mesh-thumb{width:50px;height:50px;background-size:cover;background-position:center;border-radius:4px;background-color:#eee}.child-mesh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;width:100%;box-sizing:border-box}.mesh-display-name{font-size:14px;font-weight:500;color:#1a1a1a;display:block;word-break:break-word;overflow-wrap:break-word;white-space:normal}.mesh-price{font-size:14px;color:#666}.child-mesh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.child-mesh-card{display:flex;flex-direction:column;align-items:center;padding:.5rem;border-radius:6px;background:#fff;border:1px solid rgba(0,0,0,.05);font-size:13px;color:#1a1a1a;cursor:pointer;text-align:center;transition:background .2s,border-color .2s;width:100%;box-sizing:border-box;overflow:hidden;min-width:0}.child-mesh-card.selected{background:#e6f0ff;border:2px solid #0066cc;font-weight:500}.child-mesh-card:hover:not(.selected){background:#f0f0f0}.mesh-thumb-small{width:100%;height:80px;background-size:cover;background-position:center;background-color:#f0f0f0;border-radius:4px;margin-bottom:4px}.mesh-info-small{text-align:center;width:100%;min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;overflow:hidden;padding:0 4px;box-sizing:border-box}.mesh-display-name-small{font-size:14px;font-weight:500;display:block;color:#1a1a1a;word-break:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.3;width:100%;text-align:center}.mesh-price-small{font-size:12px;font-weight:500;color:#666}.submesh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-top:.5rem}.submesh-card{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;background:#fff;border:1px solid rgba(0,0,0,.05);font-size:13px;color:#1a1a1a;cursor:pointer;transition:background .2s,border-color .2s}.submesh-card.visible{background:#e6f0ff;border:2px solid #0066cc}.submesh-card.hidden{background:#f5f5f5;border:1px solid rgba(0,0,0,.1);color:#888}.submesh-card:hover{background:#f0f0f0}.submesh-icon{font-size:16px;width:20px;text-align:center}.submesh-info{flex:1;display:flex;flex-direction:column}.submesh-name{font-weight:500}.submesh-price{font-size:11px;color:#666}.styles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding-right:5px}.style-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;width:100%}.style-card:hover{border-color:#111;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.style-card.selected{border:2px solid #111;background:#f8f8f8}.style-image{width:100%;height:80px;background-color:#f0f0f0;border-radius:4px;margin-bottom:8px;background-size:cover;background-position:center}.style-name{font-size:13px;font-weight:500;color:#333;text-align:center}.style-summary{background:#f5f5f5;padding:15px;border-radius:8px;margin-bottom:20px}.style-summary p{margin:8px 0;font-size:14px;color:#333}.style-navigation{display:flex;justify-content:space-between;margin-top:20px;gap:10px}.style-nav-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease;flex:1}.style-nav-btn.prev-btn{background:#f0f0f0;color:#333}.style-nav-btn.prev-btn:hover{background:#e0e0e0}.style-nav-btn.next-btn{background:#111;color:#fff}.style-nav-btn.next-btn:hover{background:#333}.style-nav-btn.next-btn:disabled{background:#ccc;cursor:not-allowed}.fabric-sidebar::-webkit-scrollbar{width:4px}.fabric-sidebar::-webkit-scrollbar-track{background:#00000005}.fabric-sidebar::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.fabric-details{display:block;font-size:11px;color:#555;margin-top:6px;line-height:1.4;max-height:60px;overflow-y:auto;text-align:center;opacity:0;transition:opacity .2s ease;word-break:break-word;white-space:normal}.fabric-card:hover .fabric-details{opacity:1}.fabric-details-visible{opacity:1!important}.styles-grid::-webkit-scrollbar{width:5px}.styles-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.styles-grid::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.styles-grid::-webkit-scrollbar-thumb:hover{background:#555}.canvas-stepper{position:absolute;top:10px;left:-190px;width:calc(100% - 150px);padding:0 40px;box-sizing:border-box;background:transparent;z-index:5;pointer-events:none}@media(max-width:768px){.canvas-stepper{position:relative;top:0;left:0;width:100%;padding:10px 20px;background:#fff;z-index:5}}.stepper-container{display:flex;align-items:center;justify-content:center;margin-bottom:10px;position:relative;height:40px}.stepper-line-bg{position:absolute;top:50%;left:30%;right:30%;height:2px;background:#ccc;transform:translateY(-50%);z-index:1}.stepper-line-fill{position:absolute;top:50%;left:30%;height:2px;background:#f97316;transform:translateY(-50%);z-index:2;transition:width .3s ease;max-width:40%}.step-btn{width:36px;height:36px;border-radius:50%;background:#fff;border:2px solid #ccc;color:#333;font-weight:700;display:flex;align-items:center;justify-content:center;position:relative;z-index:3;cursor:default;margin:0 auto;pointer-events:auto}.step-btn.active{border-color:#f97316;color:#f97316}.stepper-navigation{display:flex;justify-content:center;gap:20px;margin-top:5px}.stepper-navigation button{padding:8px 20px;border:1px solid #333;background:#fff;color:#333;border-radius:30px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.stepper-navigation button:hover:not(:disabled){background:#333;color:#fff}.stepper-navigation button:disabled{opacity:.3;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.mobile-step-menu{display:none}@media(max-width:768px){.mobile-step-menu{display:flex;overflow-x:auto;gap:0;background:#fff;border-bottom:1px solid #ddd;position:sticky;top:0;z-index:100;width:100%;-webkit-overflow-scrolling:touch;order:0}.mobile-step-item{flex-shrink:0;padding:10px 14px;font-size:11px;letter-spacing:1px;color:#888;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}.mobile-step-item.active{color:#111;font-weight:600;border-bottom:2px solid #111}}.mobile-nav-dropdown{display:none}@media(max-width:768px){.mobile-nav-dropdown{display:flex;flex-direction:column;background:#111;position:fixed;top:50px;left:0;right:0;width:100vw;z-index:999;padding:10px 0;box-shadow:0 4px 12px #0000004d}.mobile-nav-dropdown span{padding:14px 24px;color:#fff;font-size:15px;letter-spacing:1px;cursor:pointer;border-bottom:1px solid #222}.mobile-nav-dropdown span:last-child{border-bottom:none}.mobile-nav-dropdown span:hover{background:#222}.hamburger.open{background:transparent}.hamburger.open:before{transform:rotate(45deg);top:0}.hamburger.open:after{transform:rotate(-45deg);top:0}}@media(max-width:768px){*{max-width:100%;box-sizing:border-box}}@media(min-width:769px){.hamburger{display:none!important}}.fabric-price{font-size:13px;font-weight:500;color:#111!important;margin-top:4px}.fabric-price{opacity:0;transition:opacity .2s ease}.fabric-card:hover .fabric-price,.fabric-price-visible{opacity:1}.toast-notification{position:fixed;top:20px;right:20px;z-index:10000;background:#333;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;max-width:350px;word-break:break-word}.toast-success{background:#10b981;border-left:4px solid #059669}.toast-error{background:#ef4444;border-left:4px solid #dc2626}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.App{min-height:100vh;height:auto;overflow-y:visible}
