*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overscroll-behavior-x:none;overscroll-behavior-y:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-x:none;overscroll-behavior-y:none;touch-action:pan-x pan-y}body.pan-mode-active{overscroll-behavior-x:none!important;overscroll-behavior-y:none!important;touch-action:none!important;user-select:none!important;-webkit-user-select:none!important}img{image-rendering:-webkit-optimize-contrast}@media(max-width:768px){body{-webkit-overflow-scrolling:touch}*{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}button,a{min-height:44px;min-width:44px}input[type=text],input[type=number],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],textarea,select{font-size:16px!important}}.App{max-width:100%;width:100%;min-height:100vh}header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;position:sticky;top:0;z-index:100}header h1{font-size:1.3rem;font-weight:700;color:#333;margin:0;line-height:1;display:flex;align-items:center}header h1 a{text-decoration:none;color:inherit;transition:opacity .15s}header h1 a:hover{opacity:.8}header nav{display:flex;gap:24px;align-items:center}header nav a{text-decoration:none;color:#666;font-weight:500;font-size:14px;transition:color .15s;line-height:1;display:inline-flex;align-items:center}header nav a:hover{color:#2196f3}.header-logout-btn{padding:6px 16px;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;margin-left:8px}.header-logout-btn:hover{background:#c82333}.language-switcher{display:flex;gap:4px;margin-left:8px;padding-left:16px;border-left:1px solid #e0e0e0}.lang-btn{padding:4px 8px;font-size:12px;font-weight:600;border:1px solid #e0e0e0;background:#fff;color:#666;cursor:pointer;border-radius:4px;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;line-height:1;min-height:28px}.lang-btn .flag-icon{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0;display:block}.lang-btn span{line-height:1;white-space:nowrap}.lang-btn:hover{background:#f5f5f5;border-color:#2196f3;color:#2196f3}.lang-btn.active{background:#2196f3;color:#fff;border-color:#2196f3}@media(max-width:768px){header{padding:10px 16px;flex-wrap:wrap;gap:8px}header h1{font-size:1.1rem;flex-shrink:0}header nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center;flex:1;justify-content:flex-end}header nav a{font-size:12px;padding:4px 8px;white-space:nowrap}.header-logout-btn{padding:4px 12px;font-size:12px;margin-left:0;line-height:1}.language-switcher{margin-left:4px;padding-left:8px;border-left:1px solid #e0e0e0;gap:2px;align-items:center}.lang-btn{padding:4px 6px;font-size:10px;min-height:24px;gap:4px}.lang-btn .flag-icon{width:18px;height:18px;flex-shrink:0}.lang-btn span{display:inline-block;font-size:10px;line-height:1}header.designer-view .nav-link-main,header.designer-view .nav-link-admin,header.designer-view .nav-button-admin{display:none}header.designer-view .language-switcher{margin-left:0;padding-left:0;border-left:none}header.designer-view{flex-wrap:nowrap}header.designer-view nav{flex:0 0 auto;justify-content:flex-end}}@media(max-width:480px){header{padding:8px 12px;gap:6px}header h1{font-size:1rem}header nav{gap:6px}header nav a{font-size:11px;padding:3px 6px}.header-logout-btn{padding:3px 10px;font-size:11px;line-height:1}.language-switcher{padding-left:6px;margin-left:2px;gap:2px}.lang-btn{padding:3px 5px;font-size:9px;min-height:22px;gap:3px}.lang-btn .flag-icon{width:16px;height:16px;flex-shrink:0}.lang-btn span{display:inline-block;font-size:9px;line-height:1}header.designer-view .nav-link-main,header.designer-view .nav-link-admin,header.designer-view .nav-button-admin{display:none}header.designer-view .language-switcher{margin-left:0;padding-left:0;border-left:none}header.designer-view{flex-wrap:nowrap}header.designer-view nav{flex:0 0 auto;justify-content:flex-end}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:1200px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.modal-header h2{margin:0;color:#333;font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.modal-close:hover{background:#e0e0e0}.modal-body{padding:2rem;overflow-y:auto;flex:1}.order-summary{display:flex;gap:2rem;margin-bottom:2rem;padding:1rem;background:#f8f9fa;border-radius:8px}.summary-item{font-size:1rem}.summary-item strong{color:#333;margin-right:.5rem}.preview-section{margin-top:1.5rem}.preview-section h3{margin:0 0 .5rem;color:#333;font-size:1.2rem}.preview-description{color:#666;font-size:.9rem;margin-bottom:1.5rem}.preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1rem}.preview-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;text-align:center}.preview-label{font-weight:600;color:#2c5aa0;margin-bottom:.75rem;font-size:.9rem;letter-spacing:1px;text-transform:none!important}.preview-image-wrapper{background:#fff;border-radius:4px;padding:.5rem;box-shadow:0 2px 8px #0000001a}.preview-image{max-width:100%;max-height:400px;border-radius:4px;display:block;margin:0 auto}.preview-loading{text-align:center;padding:3rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #2c5aa0;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.preview-loading p{color:#666;font-size:1rem}.preview-error{text-align:center;padding:2rem;color:#d32f2f}.retry-btn{margin-top:1rem;padding:.5rem 1.5rem;background:#2c5aa0;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.retry-btn:hover{background:#1e3d6f}.preview-empty{text-align:center;padding:2rem;color:#999}.warning-message{background:#fff3cd;border:1px solid #ffc107;color:#856404;padding:1rem;border-radius:4px;margin-top:1.5rem;text-align:center}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e0e0e0;background:#f8f9fa}.btn-cancel,.btn-confirm{padding:.75rem 2rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background:#e0e0e0;color:#333}.btn-cancel:hover{background:#d0d0d0}.btn-confirm{background:#2c5aa0;color:#fff}.btn-confirm:hover:not(:disabled){background:#1e3d6f}.btn-confirm:disabled{background:#ccc;cursor:not-allowed}@media(max-width:768px){.modal-overlay{padding:0;align-items:stretch;height:100vh;height:100dvh;overflow:hidden}.modal-content{max-width:100%;width:100%;height:100%;max-height:none;border-radius:0;display:flex;flex-direction:column}.modal-header{padding:1rem 1.5rem;flex-shrink:0}.modal-header h2{font-size:1.2rem}.modal-close{width:28px;height:28px;font-size:1.5rem}.modal-body{padding:1rem 1.5rem;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}.order-summary{flex-direction:column;gap:.75rem;padding:.75rem;margin-bottom:1rem}.summary-item{font-size:.9rem}.preview-section{margin-top:1rem}.preview-section h3{font-size:1.1rem}.preview-grid{grid-template-columns:1fr;gap:1rem}.preview-item{padding:.75rem}.preview-image{max-height:300px}.modal-footer{flex-direction:column;gap:.75rem;padding:1rem 1.5rem;flex-shrink:0;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));background:#f8f9fa;border-top:1px solid #e0e0e0}.btn-cancel,.btn-confirm{width:100%;padding:.875rem 1rem;font-size:1rem}.btn-confirm{order:-1}}@media(max-width:480px){.modal-header{padding:.75rem 1rem}.modal-header h2{font-size:1.1rem}.modal-body{padding:.75rem 1rem}.order-summary{padding:.5rem}.summary-item{font-size:.85rem}.preview-section h3{font-size:1rem}.preview-description{font-size:.85rem}.preview-image{max-height:220px}.modal-footer{padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px));gap:.5rem}.btn-cancel,.btn-confirm{padding:.75rem;font-size:.95rem}}.leave-confirmation-overlay{position:fixed;inset:0;background:#111827b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px}.leave-confirmation-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;width:100%;max-width:400px;padding:32px;position:relative}.leave-confirmation-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.leave-confirmation-title{font-family:sans-serif;font-weight:700;font-size:24px;color:#1a1a1a;margin:0;padding:0}.leave-confirmation-close{background:none;border:none;color:#9ca3af;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s;flex-shrink:0}.leave-confirmation-close:hover{color:#6b7280}.leave-confirmation-close:focus{outline:2px solid #dc2626;outline-offset:2px;border-radius:4px}.leave-confirmation-body{margin-top:16px}.leave-confirmation-message{font-family:sans-serif;font-weight:400;font-size:15px;color:#4a5568;line-height:1.5;margin:0;padding:0}.leave-confirmation-buttons{display:flex;gap:12px;margin-top:32px}.leave-confirmation-button{font-family:sans-serif;font-weight:600;padding:12px 28px;border-radius:6px;border:none;cursor:pointer;transition:background-color .2s;flex:1}.leave-confirmation-button:focus{outline:2px solid #dc2626;outline-offset:2px}.leave-confirmation-button-stay{background:#dc2626;color:#fff}.leave-confirmation-button-stay:hover{background:#b91c1c}.leave-confirmation-button-leave{background:#e5e7eb;color:#374151}.leave-confirmation-button-leave:hover{background:#d1d5db}@media(max-width:480px){.leave-confirmation-modal{padding:24px;max-width:calc(100% - 32px)}.leave-confirmation-title{font-size:20px}.leave-confirmation-message{font-size:14px}.leave-confirmation-buttons{flex-direction:column}.leave-confirmation-button{width:100%}}.designer-layout{display:flex;gap:0;height:calc(100vh - 50px);background-color:#f5f5f5;overflow:hidden}.tools-sidebar{width:160px;min-width:160px;display:flex;flex-direction:column;gap:0;background:#fff;border-right:1px solid #e0e0e0;padding:10px}.tools-section{padding-bottom:12px;border-bottom:1px solid #eee;margin-bottom:12px}.sidebar-title{font-size:10px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.tool-button{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;padding:14px 8px;margin-bottom:6px;background:#f8f9fa;border:1px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .15s}.tool-button:hover{background:#e3f2fd;border-color:#2196f3}.tool-icon{font-size:20px}.tool-label{font-size:11px;font-weight:500;color:#333}.uploads-panel{flex:1;overflow-y:auto}.panel-title{font-size:10px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.empty-message{font-size:11px;color:#aaa;text-align:center;padding:20px 5px}.elements-section{margin-bottom:10px}.section-label{display:block;font-size:10px;font-weight:500;color:#888;margin-bottom:6px}.elements-list{display:flex;flex-direction:column;gap:4px}.element-item{display:flex;align-items:center;gap:8px;padding:8px;background:#f8f9fa;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s}.element-item:hover{background:#f0f0f0}.element-item.selected{background:#e3f2fd;border-color:#2196f3}.element-thumbnail{width:36px;height:36px;border-radius:4px;overflow:hidden;background:#fff;border:1px solid #ddd;display:flex;align-items:center;justify-content:center}.element-thumbnail img{width:100%;height:100%;object-fit:cover}.element-thumbnail.text-preview{font-size:18px;font-weight:700}.element-name{font-size:11px;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.center-column{width:200px;min-width:200px;display:flex;flex-direction:column;gap:0;background:#fff;border-right:1px solid #e0e0e0;padding:12px;overflow-y:auto;overflow-x:hidden}.product-options{padding-bottom:12px;border-bottom:1px solid #eee;margin-bottom:12px}.designer-controls{flex:1}.options-title,.controls-title{font-size:12px;font-weight:600;color:#333;margin-bottom:10px}.option-group{margin-bottom:10px}.option-label{display:block;font-size:10px;font-weight:500;color:#888;margin-bottom:5px;text-transform:uppercase}.custom-dropdown-container{position:relative;width:100%;background:transparent;border-radius:6px;padding:0;box-shadow:none}.custom-dropdown-header{width:100%;background:#fff;border:2px solid #ddd;border-radius:4px;padding:10px 40px 10px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .3s ease,box-shadow .3s ease,transform .2s ease;text-align:left;font-size:12px;font-weight:500;color:#000;position:relative;z-index:2;box-sizing:border-box}.custom-dropdown-header:hover{border-color:#bbb;box-shadow:0 1px 3px #0000001a}.custom-dropdown-header.open{border-color:#2196f3;border-width:2px;box-shadow:0 2px 4px #2196f333;transition:border-color .3s ease,box-shadow .3s ease}.custom-dropdown-header:active{transform:translateY(1px)}.custom-dropdown-text{flex:1;text-align:left;color:#000;font-weight:500;font-size:14px}.custom-dropdown-chevron{position:absolute;right:14px;top:50%;transform:translateY(-50%);transition:transform .3s ease;flex-shrink:0}.custom-dropdown-chevron.rotated{transform:translateY(-50%) rotate(180deg)}.custom-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:2px solid #2196f3;border-radius:4px;box-shadow:0 4px 12px #2196f333;z-index:1000;overflow:hidden;animation:dropdownSlideDown .2s ease-out;margin-top:4px}.custom-dropdown-menu-portal{background:#fff;border:2px solid #2196f3;border-radius:8px;box-shadow:0 8px 24px #2196f340,0 4px 8px #0000001a;overflow:hidden;animation:dropdownSlideDown .2s ease-out;box-sizing:border-box;-webkit-overflow-scrolling:touch;backface-visibility:hidden;-webkit-backface-visibility:hidden;will-change:transform,opacity}.custom-dropdown-menu-portal.closing{animation:dropdownSlideUp .15s ease-in forwards}@keyframes dropdownSlideDown{0%{opacity:0;transform:translate3d(0,-8px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes dropdownSlideUp{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-8px,0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-dropdown-menu.closing{animation:slideUp .15s ease-in forwards}@keyframes slideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.custom-dropdown-item{width:100%;padding:14px 16px;background:#fff;border:none;text-align:left;font-size:14px;font-weight:400;color:#333;cursor:pointer;transition:background-color .15s ease;display:block;border-bottom:1px solid #f0f0f0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none}.custom-dropdown-item:last-child{border-bottom:none}.custom-dropdown-item:hover{background:#f5f5f5}.custom-dropdown-item.selected{color:#2196f3;font-weight:600;background:#e8f4fd}.custom-dropdown-item:active{background:#e3f2fd}@media(hover:none)and (pointer:coarse){.custom-dropdown-item:active{background:#e3f2fd;transform:scale(.98)}}.size-dropdown-custom{width:100%}.view-tabs-size-dropdown-custom{margin-left:auto;width:100px;margin-right:4px}.size-dropdown{width:100%;padding:8px 35px 8px 12px;font-size:12px;font-weight:500;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .15s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.size-dropdown:hover{border-color:#2196f3}.size-dropdown:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a}.no-selection{padding:30px 10px;text-align:center}.no-selection p{font-size:12px;color:#aaa}.control-group{margin-bottom:14px}.control-group label{display:block;font-size:10px;font-weight:500;color:#888;margin-bottom:5px;text-transform:uppercase}.control-row{display:flex;gap:8px}.control-group.half{flex:1}.controls-divider{border:none;border-top:1px solid #eee;margin:14px 0}.text-input,.select-input,.number-input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:12px;background:#fff}.text-input:focus,.select-input:focus,.number-input:focus{outline:none;border-color:#2196f3}.full-width{width:100%}.color-input{width:100%;height:36px;padding:3px;border:1px solid #ddd;border-radius:6px;cursor:pointer;background:#fff}.rotation-row{display:flex;align-items:center;gap:8px}.rotation-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#e0e0e0;border-radius:2px;outline:none}.rotation-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid #2196f3;cursor:grab}.rotation-number{width:50px;padding:6px;text-align:center;border:1px solid #ddd;border-radius:6px;font-size:11px}.degree-symbol{font-size:11px;color:#888}.flip-row{display:flex;gap:6px}.flip-btn{flex:1;padding:8px;font-size:11px;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .15s}.flip-btn:hover{background:#f5f5f5}.flip-btn.active{background:#e3f2fd;border-color:#2196f3}.delete-btn{width:100%;padding:10px;background:#fff;border:1px solid #f44336;color:#f44336;border-radius:6px;font-size:12px;cursor:pointer;transition:all .15s}.delete-btn:hover{background:#f44336;color:#fff}.text-preview-mobile{display:none}.canvas-column{flex:1;display:flex;flex-direction:column;min-width:0;background:#f5f5f5}.view-tabs{display:flex;background:#fff;border-bottom:1px solid #e0e0e0;padding:0 16px;flex-shrink:0}.view-tab{padding:10px 24px;font-size:13px;font-weight:500;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;color:#666;margin-bottom:-1px}.view-tab:hover{color:#333}.view-tab.active{color:#2196f3;border-bottom-color:#2196f3}.view-tabs-size-dropdown{margin-left:auto;padding:6px 32px 6px 10px;font-size:11px;font-weight:500;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .15s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;color:#333;width:100px;height:28px;margin-right:4px}.view-tabs-size-dropdown:hover{border-color:#2196f3}.view-tabs-size-dropdown:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a}.canvas-wrapper{flex:1;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden;min-height:0}.design-canvas-area{flex:1;display:flex;justify-content:center;align-items:center;overflow:auto;background:linear-gradient(45deg,#eee 25%,transparent 25%),linear-gradient(-45deg,#eee 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#eee 75%),linear-gradient(-45deg,transparent 75%,#eee 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0px;background-color:#f5f5f5;cursor:default;padding:0;min-height:0;overscroll-behavior-x:none;overscroll-behavior-y:none}@media(max-width:768px){.design-canvas-area{background-image:none;background-color:#fff}.canvas-wrapper{background:#fff}}.design-canvas-area.pan-mode{cursor:grab;overscroll-behavior-x:none!important;overscroll-behavior-y:none!important;touch-action:none!important}.design-canvas-area.pan-mode:active{cursor:grabbing}.canvas-container{background:#fff;box-shadow:0 2px 16px #00000014;flex-shrink:0}.zoom-controls{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;background:#fff;border-top:1px solid #e8e8e8;flex-shrink:0;touch-action:none;overscroll-behavior:none;-webkit-overflow-scrolling:auto}.zoom-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:18px;font-weight:700;cursor:pointer;transition:all .15s;color:#333;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.zoom-btn:hover:not(:disabled){background:#e8e8e8;border-color:#ccc}.zoom-btn:disabled{opacity:.4;cursor:not-allowed}.zoom-btn.active-touch:not(:disabled),.zoom-percent.active-touch,.pan-btn.active-touch{background:#d0d0d0;border-color:#999;transform:scale(.95)}.zoom-slider{width:120px;height:4px;-webkit-appearance:none;appearance:none;background:#e0e0e0;border-radius:2px;outline:none;touch-action:manipulation}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #2196f3;cursor:pointer}.zoom-percent{min-width:55px;padding:6px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;text-align:center;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.zoom-percent:hover{background:#e8e8e8}.zoom-divider{color:#ddd;font-size:16px;margin:0 4px;flex-shrink:0;display:flex;align-items:center;line-height:1}.pan-btn{width:36px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:18px;cursor:pointer;transition:all .15s;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.pan-btn:hover{background:#e8e8e8}.pan-btn.active{background:#2196f3;border-color:#2196f3;color:#fff}@media(max-width:1200px){.tools-sidebar{width:160px;min-width:160px}.center-column{width:180px;min-width:180px}}@media(max-width:900px){.designer-layout{flex-direction:column;height:auto;min-height:calc(100vh - 50px)}.tools-sidebar{width:100%;min-width:100%;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid #e0e0e0;max-height:200px;overflow-y:auto}.tools-section{flex:1;min-width:120px;margin-right:12px}.uploads-panel{flex:1;min-width:200px;max-height:180px}.center-column{width:100%;min-width:100%;max-height:300px;overflow-y:auto;border-right:none;border-bottom:1px solid #e0e0e0}.canvas-column{min-height:500px;flex:1}}@media(max-width:768px){.designer-layout{flex-direction:column;height:100vh;height:100dvh;overflow:hidden;background:#fff;position:relative}.tools-sidebar,.center-column{display:none}.canvas-column{flex:1;display:flex;flex-direction:column;min-height:0;width:100%;overflow:hidden;padding-bottom:212px}.view-tabs{flex-shrink:0;padding:2px 4px;overflow-x:auto;-webkit-overflow-scrolling:touch;background:#fff;border-bottom:1px solid #e0e0e0;min-height:36px;z-index:10}.view-tab{padding:4px 10px;font-size:11px;white-space:nowrap}.view-tabs-size-wrapper{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0;margin-right:2px}.view-tabs-size-label{font-size:11px;font-weight:500;color:#666;white-space:nowrap}.view-tabs-size-dropdown-custom{width:75px;flex-shrink:0}.view-tabs-size-dropdown-custom .custom-dropdown-header{padding:4px 26px 4px 8px;font-size:12px;font-weight:600;height:26px;display:flex;align-items:center}.view-tabs-size-dropdown-custom .custom-dropdown-text{font-size:12px;font-weight:600}.view-tabs-size-dropdown-custom .custom-dropdown-chevron{right:8px;width:8px;height:8px}.view-tabs-size-dropdown-custom .custom-dropdown-menu-portal{border-radius:6px}.view-tabs-size-dropdown-custom .custom-dropdown-item{padding:10px 12px;font-size:12px}.canvas-wrapper{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;background:#fff;position:relative}.design-canvas-area{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden;padding:4px;min-height:0;-webkit-overflow-scrolling:touch;position:relative;width:100%;height:100%;background:#fff;background-image:none}.canvas-container{position:relative!important;box-shadow:none;background:transparent;transform-origin:center center!important;width:900px!important;height:1000px!important;margin:0 auto}.canvas-container>div{width:100%!important;height:100%!important}.canvas-container canvas{touch-action:auto;display:block}.design-canvas-area.pan-mode .canvas-container canvas{touch-action:none;pointer-events:auto}.zoom-controls{position:fixed;bottom:152px;left:0;right:0;flex-shrink:0;padding:12px 16px;gap:12px;background:#fff;border-top:1px solid #d0d0d0;border-bottom:1px solid #e8e8e8;height:60px;z-index:102;transition:opacity .2s,transform .2s;box-shadow:none;display:flex;align-items:center;justify-content:center;box-sizing:border-box;margin:0}.designer-layout.controls-overlay-active .zoom-controls{opacity:0;pointer-events:none;transform:translateY(100%)}.zoom-btn{width:34px;height:34px;font-size:18px;font-weight:700;flex-shrink:0;box-sizing:border-box;border-radius:6px;background:#f5f5f5;border:1px solid #ddd;display:flex;align-items:center;justify-content:center}.pan-btn{width:38px;height:34px;font-size:18px;flex-shrink:0;box-sizing:border-box;border-radius:6px;background:#f5f5f5;border:1px solid #ddd;display:flex;align-items:center;justify-content:center}.zoom-slider{width:100px;height:6px;flex-shrink:0}.zoom-percent{min-width:52px;height:34px;padding:6px 10px;font-size:13px;font-weight:500;flex-shrink:0;box-sizing:border-box;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:1px solid #ddd;border-radius:6px}.zoom-divider{font-size:20px;color:#ccc;margin:0 2px}.mobile-tools-toolbar{position:fixed;bottom:76px;left:0;right:0;display:flex;flex-shrink:0;background:#fff;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8;padding:8px 12px;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;height:76px;z-index:101;transition:opacity .2s,transform .2s;box-shadow:none;box-sizing:border-box;align-items:center;margin:0}.mobile-tools-toolbar.hidden-by-overlay{opacity:0;pointer-events:none;transform:translateY(100%)}.mobile-tool-button{flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;background:#f8f9fa;border:1px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .15s}.mobile-tool-button:active{background:#e3f2fd;border-color:#2196f3}.mobile-tool-icon{font-size:22px}.mobile-tool-label{font-size:11px;font-weight:500;color:#333}.mobile-controls-section{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;padding:0;height:calc(100vh - 50px);display:flex;flex-direction:column;z-index:1000;box-shadow:0 -2px 16px #00000026;animation:mobileSlideUp .3s ease-out}@keyframes mobileSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-controls-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f0f7ff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:1}.mobile-controls-title{font-size:13px;font-weight:600;color:#2196f3}.mobile-controls-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #ddd;border-radius:50%;font-size:14px;color:#666;cursor:pointer;transition:all .15s}.mobile-controls-close:active{background:#f44336;border-color:#f44336;color:#fff}.mobile-controls-section .designer-controls{padding:8px 12px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-controls-section .controls-title,.mobile-controls-section .no-selection{display:none}.mobile-controls-section .control-group{margin-bottom:10px}.mobile-controls-section .control-group label{font-size:10px;margin-bottom:4px}.mobile-controls-section .text-input,.mobile-controls-section .select-input,.mobile-controls-section .number-input{padding:8px 10px;font-size:13px}.mobile-controls-section .control-row{display:flex;gap:8px}.mobile-controls-section .rotation-row{display:flex;align-items:center;gap:8px}.mobile-controls-section .rotation-slider{flex:1}.mobile-controls-section .rotation-number{width:55px;padding:6px;font-size:12px}.mobile-controls-section .flip-row{display:flex;gap:8px}.mobile-controls-section .flip-btn{flex:1;padding:10px;font-size:12px}.mobile-controls-section .delete-btn{width:100%;padding:10px;font-size:13px}.mobile-controls-section .color-input{height:40px}.mobile-controls-section .text-preview-mobile{display:block}.mobile-controls-section .text-preview-display{font-size:22px!important;padding:14px!important;min-height:56px!important}.mobile-order-section{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;flex-shrink:0;background:#fff;border-top:1px solid #e8e8e8;border-bottom:none;padding:10px 12px;height:76px;z-index:100;transition:opacity .2s,transform .2s;box-shadow:none;box-sizing:border-box;margin:0}.mobile-order-section.hidden-by-overlay{opacity:0;pointer-events:none;transform:translateY(100%)}.mobile-order-section .order-button{padding:10px 20px!important;font-size:14px!important}.mobile-order-section .order-button-container{width:100%}.mobile-order-section .order-button{width:100%!important;padding:12px 24px!important;font-size:15px!important}.mobile-order-section .order-helper-text,.mobile-order-section p,.mobile-order-section small{font-size:11px;color:#888;text-align:center;margin:0;line-height:1.3}}@media(min-width:769px){.mobile-tools-toolbar,.mobile-controls-section,.mobile-order-section,.view-tabs-size-dropdown-custom,.view-tabs-size-wrapper{display:none}}@media(max-width:480px){.designer-layout{height:100vh;height:100dvh}.canvas-column{padding-bottom:194px}.view-tabs{padding:6px 8px}.view-tab{padding:8px 12px;font-size:12px}.view-tabs-size-wrapper{gap:6px;margin-right:2px}.view-tabs-size-label{font-size:10px}.view-tabs-size-dropdown-custom{width:70px}.view-tabs-size-dropdown-custom .custom-dropdown-header{padding:3px 24px 3px 6px;font-size:11px;font-weight:600;height:24px}.view-tabs-size-dropdown-custom .custom-dropdown-text{font-size:11px;font-weight:600}.view-tabs-size-dropdown-custom .custom-dropdown-chevron{right:6px;width:7px;height:7px}.view-tabs-size-dropdown-custom .custom-dropdown-item{padding:8px 10px;font-size:11px}.design-canvas-area{padding:2px;display:flex!important;justify-content:center!important;align-items:center!important}.canvas-container{transform-origin:center center!important;margin:0 auto}.zoom-controls{bottom:140px;height:54px;padding:10px 12px;gap:10px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;border-top:1px solid #d0d0d0;border-bottom:1px solid #e8e8e8;box-shadow:none;margin:0}.zoom-btn{width:30px;height:30px;font-size:16px}.pan-btn{width:34px;height:30px;font-size:16px}.zoom-slider{width:80px;height:5px}.zoom-percent{min-width:46px;height:30px;padding:4px 8px;font-size:12px}.zoom-divider{font-size:18px;margin:0 1px}.zoom-btn,.pan-btn{width:26px;height:26px;font-size:12px;flex-shrink:0;box-sizing:border-box}.zoom-slider{width:75px;flex-shrink:0}.zoom-percent{min-width:38px;padding:3px 5px;font-size:10px;flex-shrink:0;box-sizing:border-box}.mobile-tools-toolbar{bottom:70px;height:70px;padding:6px 10px;gap:6px;box-sizing:border-box;align-items:center;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8;box-shadow:none;margin:0}.mobile-tool-button{min-width:70px;padding:6px;gap:3px}.mobile-tool-icon{font-size:20px}.mobile-tool-label{font-size:10px}.mobile-order-section{height:70px;padding:8px 10px;gap:3px;box-sizing:border-box;border-top:1px solid #e8e8e8;border-bottom:none;box-shadow:none;margin:0}.mobile-order-section .order-helper-text,.mobile-order-section p,.mobile-order-section small{font-size:10px}.mobile-order-section .order-button{padding:10px 20px!important;font-size:14px!important}.mobile-controls-section{padding:0;height:calc(100vh - 50px)}.mobile-controls-header{padding:8px 10px}.mobile-controls-title{font-size:12px}.mobile-controls-close{width:26px;height:26px;font-size:12px}.mobile-controls-section .designer-controls{padding:6px 10px}.mobile-controls-section .control-group{margin-bottom:8px}.mobile-controls-section .text-input,.mobile-controls-section .select-input,.mobile-controls-section .number-input{padding:6px 8px;font-size:12px}.mobile-controls-section .flip-btn{padding:8px;font-size:11px}.mobile-controls-section .delete-btn{padding:8px;font-size:12px}.mobile-controls-section .text-preview-display{font-size:20px!important;padding:12px!important;min-height:50px!important}}.size-preview-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}.size-preview-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d;animation:slideUp .3s ease-out}.size-preview-modal-header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #e0e0e0;position:relative}.size-preview-modal-close{position:absolute;left:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;font-size:20px;color:#666;cursor:pointer;transition:all .15s;padding:0}.size-preview-modal-close:hover{background:#f5f5f5;color:#333}.size-preview-modal-close:active{background:#e0e0e0}.size-preview-modal-title{flex:1;text-align:center;font-size:18px;font-weight:600;color:#333;margin:0;padding:0 40px}.size-preview-modal-content{padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.size-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}.size-preview-item{display:flex;flex-direction:column;align-items:center;padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.size-preview-item:hover{border-color:#2196f3;background:#f5f9ff}.size-preview-item.active{border-color:#2196f3;background:#e3f2fd}.size-preview-label{font-size:16px;font-weight:600;color:#333;margin-bottom:8px}.size-preview-item.active .size-preview-label{color:#2196f3}.size-preview-image{width:100%;display:flex;align-items:center;justify-content:center;min-height:120px}.size-preview-image img{max-width:100%;height:auto;object-fit:contain}@media(max-width:768px){.size-preview-modal{max-width:95%;max-height:85vh;border-radius:8px}.size-preview-modal-header{padding:12px 16px}.size-preview-modal-close{left:12px;width:28px;height:28px;font-size:18px}.size-preview-modal-title{font-size:16px;padding:0 36px}.size-preview-modal-content{padding:16px}.size-preview-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.size-preview-item{padding:10px}.size-preview-image{min-height:100px}}.product-list-container{max-width:1200px;margin:0 auto;padding:2rem}.product-list-container h1{text-align:center;margin-bottom:2rem;color:#333}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2rem}.product-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.product-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.product-thumbnail{width:100%;height:250px;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.product-thumbnail img{width:100%;height:100%;object-fit:contain}.product-info{padding:1rem}.product-info h3{margin:0 0 .5rem;color:#333;font-size:1.2rem}.product-type{margin:0 0 .5rem;color:#666;text-transform:capitalize;font-size:.9rem}.product-price{margin:0;color:#2c5aa0;font-size:1.3rem;font-weight:700}.color-preview{display:flex;gap:.5rem;margin-top:.5rem;align-items:center}.color-dot{width:20px;height:20px;border-radius:50%;border:2px solid #ddd;display:inline-block}.more-colors{font-size:.8rem;color:#666}.back-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;margin-bottom:1rem;font-size:.9rem}.back-button:hover{background:#5a6268}.colors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2rem}.color-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.color-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.color-swatch-large{width:100%;height:150px;border-bottom:2px solid #ddd}.color-info{padding:1rem}.color-info h3{margin:0 0 .5rem;color:#333;font-size:1rem}.color-name{margin:0 0 .5rem;color:#666;text-transform:capitalize;font-size:.9rem}@media(max-width:768px){.product-list-container{padding:1rem}.product-list-container h1{font-size:1.5rem;margin-bottom:1.5rem}.products-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.product-thumbnail{height:200px}.product-info{padding:.75rem}.product-info h3{font-size:1rem}.product-price{font-size:1.1rem}}@media(max-width:480px){.product-list-container{padding:.75rem}.product-list-container h1{font-size:1.3rem;margin-bottom:1rem}.products-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.product-thumbnail{height:180px}.product-info{padding:.5rem}.product-info h3{font-size:.9rem;margin-bottom:.25rem}.product-type{font-size:.8rem;margin-bottom:.25rem}.product-price{font-size:1rem}}.admin-container{max-width:1200px;margin:0 auto;padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{margin:0;color:#333}.products-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 8px #0000001a;border-radius:8px;overflow:hidden}.products-table thead{background:#f5f5f5}.products-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #ddd}.products-table td{padding:1rem;border-bottom:1px solid #eee}.products-table tbody tr:hover{background:#f9f9f9}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-edit,.btn-deactivate,.btn-activate,.btn-delete-permanent{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.btn-edit{background:#17a2b8;color:#fff}.btn-edit:hover{background:#138496}.btn-deactivate{background:#ffc107;color:#000}.btn-deactivate:hover{background:#e0a800}.btn-activate{background:#28a745;color:#fff}.btn-activate:hover{background:#218838}.btn-delete-permanent{background:#dc3545;color:#fff}.btn-delete-permanent:hover{background:#c82333}.loading,.error{text-align:center;padding:2rem;font-size:1.1rem}.error{color:#d32f2f}@media(max-width:768px){.admin-container{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-header h1{font-size:1.3rem}.btn-primary{width:100%;padding:.6rem 1rem;font-size:.9rem}.products-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.products-table thead{display:none}.products-table tbody{display:block}.products-table tr{display:block;margin-bottom:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem}.products-table td{display:block;padding:.5rem 0;text-align:left;border-bottom:1px solid #eee}.products-table td:last-child{border-bottom:none}.products-table td:before{content:attr(data-label) ": ";font-weight:600;color:#333;display:inline-block;min-width:100px}.action-buttons{flex-direction:column;gap:.5rem}.btn-edit,.btn-deactivate,.btn-activate,.btn-delete-permanent{width:100%;padding:.6rem;font-size:.85rem}}@media(max-width:480px){.admin-container{padding:.75rem}.admin-header h1{font-size:1.1rem}.btn-primary{padding:.5rem .75rem;font-size:.85rem}.products-table tr{padding:.75rem}.products-table td{font-size:.9rem}}.print-area-editor{position:relative;display:inline-block;border:2px solid #ddd;border-radius:4px;background:#f5f5f5}.print-area-editor canvas{display:block;max-width:100%;cursor:grab}.print-area-editor canvas:active{cursor:grabbing}.print-area-editor-placeholder{width:400px;height:400px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:2px dashed #ddd;border-radius:4px;color:#999}.print-area-controls{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.print-area-info{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;font-size:.9rem}.info-row{display:flex;align-items:center;gap:.5rem}.info-row label{min-width:50px;font-weight:500;color:#333}.number-input{flex:1;padding:.4rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;text-align:right;max-width:80px}.number-input:focus{outline:none;border-color:#2c5aa0;box-shadow:0 0 0 2px #2c5aa01a}.info-row span{color:#666;font-size:.85rem}.center-button{padding:.5rem 1rem;background:#2c5aa0;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s;align-self:flex-start}.center-button:hover{background:#1e3d6f}@media(max-width:768px){.print-area-editor{width:100%;max-width:100%}.print-area-editor canvas{width:100%;height:auto}.print-area-editor-placeholder{width:100%;max-width:100%;height:auto;min-height:300px}.print-area-controls{margin-top:.75rem}.print-area-info{grid-template-columns:1fr;gap:.5rem;font-size:.85rem}.info-row{flex-wrap:wrap}.info-row label{min-width:60px;font-size:.85rem}.number-input{max-width:100px;padding:.35rem .4rem;font-size:.85rem}.center-button{width:100%;padding:.6rem;font-size:.85rem}}@media(max-width:480px){.print-area-editor-placeholder{min-height:250px}.print-area-info{font-size:.8rem}.info-row label{min-width:50px;font-size:.8rem}.number-input{max-width:80px;padding:.3rem .35rem;font-size:.8rem}.center-button{padding:.5rem;font-size:.8rem}}.admin-form-container{max-width:1000px;margin:0 auto;padding:2rem}.admin-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-form-header h1{margin:0;color:#333}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.btn-secondary:hover{background:#5a6268}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.product-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid #eee}.form-section:last-of-type{border-bottom:none}.form-section h2{margin:0 0 1rem;color:#333;font-size:1.5rem}.section-description{color:#666;font-size:.9rem;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2c5aa0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.view-section{margin-bottom:2rem;padding:1.5rem;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.view-header h3{margin:0;color:#333}.view-enable-toggle{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#666}.view-enable-toggle input[type=checkbox]{margin:0}.view-enable-toggle:has(input:disabled){opacity:.5;cursor:not-allowed}.view-section h3{margin:0;color:#333;text-transform:capitalize}.view-upload{margin-bottom:1rem}.view-upload label{display:block;margin-bottom:.5rem;font-weight:500}.view-upload input[type=file]{margin-bottom:.5rem}.uploading{color:#2c5aa0;font-size:.9rem;margin-left:.5rem}.image-preview{margin-top:1rem}.image-preview img{max-width:200px;max-height:200px;border:1px solid #ddd;border-radius:4px}.print-area-section{margin-top:1.5rem}.print-area-section label{display:block;margin-bottom:.5rem;font-weight:500}.btn-add{background:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;margin-bottom:1rem;transition:background .2s}.btn-add:hover{background:#218838}.sizes-list{display:flex;flex-direction:column;gap:.75rem}.size-item{display:grid;grid-template-columns:120px 1fr auto;gap:.75rem;align-items:center;padding:.75rem;background:#f9f9f9;border-radius:4px}.size-item select,.size-item input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.btn-remove{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-remove:hover{background:#c82333}.empty-state{color:#999;font-style:italic;padding:1rem;text-align:center}.colors-list{display:flex;flex-direction:column;gap:.75rem}.color-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f9f9f9;border-radius:4px}.color-swatch{width:40px;height:40px;border-radius:4px;border:2px solid #ddd;flex-shrink:0}.color-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.color-name{font-weight:500;color:#333}.hex-code{font-family:monospace;color:#666;font-size:.85rem}.link-badge,.type-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:3px;display:inline-block;margin-top:.25rem}.link-badge{background:#e3f2fd;color:#1976d2}.type-badge{background:#f3e5f5;color:#7b1fa2}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.form-hint{display:block;margin-top:.5rem;color:#666;font-size:.85rem}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid #eee}.btn-primary{background:#2c5aa0;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.btn-primary:hover{background:#1e3d6f}.loading{text-align:center;padding:2rem;font-size:1.1rem}@media(max-width:768px){.admin-form-container{padding:1rem}.admin-form-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-form-header h1{font-size:1.3rem}.btn-secondary{width:100%;padding:.6rem 1rem;font-size:.9rem}.product-form{padding:1.5rem}.form-section{margin-bottom:2rem;padding-bottom:1.5rem}.form-section h2{font-size:1.3rem}.form-row{grid-template-columns:1fr;gap:0}.view-section{padding:1rem;margin-bottom:1.5rem}.view-header{flex-direction:column;align-items:flex-start;gap:.75rem}.view-header h3{font-size:1.1rem}.view-enable-toggle{width:100%}.image-preview img{max-width:150px;max-height:150px}.size-item{grid-template-columns:100px 1fr auto;gap:.5rem;padding:.5rem}.form-actions{flex-direction:column;gap:.75rem}.btn-primary{width:100%;padding:.6rem 1rem;font-size:.9rem}}@media(max-width:480px){.admin-form-container{padding:.75rem}.admin-form-header h1{font-size:1.1rem}.product-form{padding:1rem}.form-section{margin-bottom:1.5rem;padding-bottom:1rem}.form-section h2{font-size:1.1rem}.form-group{margin-bottom:1rem}.form-group input,.form-group select,.form-group textarea{padding:.6rem;font-size:.9rem}.view-section{padding:.75rem;margin-bottom:1rem}.view-header h3{font-size:1rem}.image-preview img{max-width:120px;max-height:120px}.size-item{grid-template-columns:80px 1fr auto;gap:.4rem;padding:.4rem}.size-item select,.size-item input{padding:.4rem;font-size:.85rem}.btn-add,.btn-remove{padding:.4rem .75rem;font-size:.85rem}.btn-primary,.btn-secondary{padding:.5rem .75rem;font-size:.85rem}}.orders-list{display:flex;flex-direction:column;gap:1rem}.order-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.order-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #eee}.order-header:hover{background:#f9f9f9}.order-info{flex:1}.order-id{font-weight:600;font-size:1.1rem;color:#333;margin-bottom:.5rem}.order-product{font-size:1rem;color:#666;margin-bottom:.5rem}.order-meta{display:flex;gap:.5rem;font-size:.9rem;color:#999}.order-actions-header{display:flex;align-items:center;gap:1rem}.expand-icon{font-size:.8rem;color:#666}.order-details{padding:1.5rem;background:#fafafa;border-top:1px solid #eee}.order-section{margin-bottom:2rem}.order-section:last-child{margin-bottom:0}.order-section h3{margin:0 0 1rem;color:#333;font-size:1.1rem;border-bottom:2px solid #2c5aa0;padding-bottom:.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-grid>div{padding:.5rem;background:#fff;border-radius:4px}.preview-images-container{padding:1rem;background:#fff;border-radius:4px}.preview-image-container{text-align:center;padding:1rem;background:#fff;border-radius:4px}.preview-images-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.preview-image-item{text-align:center;padding:1rem;background:#f9f9f9;border-radius:4px;border:1px solid #ddd}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.preview-label{font-weight:600;color:#2c5aa0;text-transform:uppercase;font-size:.9rem}.download-btn{display:inline-block;padding:4px 12px;background:#2c5aa0;color:#fff;text-decoration:none;border-radius:4px;font-size:.85rem;transition:background .2s}.download-btn:hover{background:#1e3d6f}.download-btn-small{display:inline-block;padding:2px 6px;background:#2c5aa0;color:#fff;text-decoration:none;border-radius:3px;font-size:.75rem;margin-left:4px;transition:background .2s}.download-btn-small:hover{background:#1e3d6f}.preview-image{max-width:100%;max-height:400px;border-radius:4px;box-shadow:0 2px 8px #0000001a}.snapshots-container{display:flex;flex-direction:column;gap:2rem}.view-snapshots{background:#fff;padding:1.5rem;border-radius:4px;border:1px solid #eee}.view-title{margin:0 0 1rem;color:#2c5aa0;font-size:1rem;text-transform:capitalize;padding-bottom:.5rem;border-bottom:1px solid #ddd}.snapshots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.snapshot-card{background:#f9f9f9;border:1px solid #ddd;border-radius:4px;padding:1rem}.snapshot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #ddd}.snapshot-type{font-weight:600;color:#2c5aa0;text-transform:uppercase;font-size:.85rem}.snapshot-zindex{font-size:.8rem;color:#666}.snapshot-details{font-size:.9rem;line-height:1.6}.snapshot-details>div{margin-bottom:.5rem}.snapshot-details strong{color:#333;margin-right:.5rem}.snapshot-image{margin:.5rem 0;text-align:center;position:relative;display:inline-block}.snapshot-transform{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #ddd;font-size:.85rem;color:#666}.no-orders{text-align:center;padding:4rem 2rem;color:#666;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.no-snapshots{text-align:center;padding:2rem;color:#999;font-style:italic}@media(max-width:768px){.admin-container{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-header h1{font-size:1.3rem}.btn-primary{width:100%;padding:.6rem 1rem;font-size:.9rem}.order-card{border-radius:6px}.order-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem}.order-info{width:100%}.order-id{font-size:1rem}.order-product{font-size:.9rem}.order-meta{flex-wrap:wrap;font-size:.85rem}.order-actions-header{width:100%;justify-content:space-between}.order-details{padding:1rem}.order-section{margin-bottom:1.5rem}.order-section h3{font-size:1rem}.info-grid{grid-template-columns:1fr;gap:.75rem}.preview-images-grid{grid-template-columns:1fr;gap:1rem}.preview-image-item{padding:.75rem}.preview-header{flex-direction:column;align-items:flex-start;gap:.5rem}.download-btn{width:100%;text-align:center;padding:6px 12px}.snapshots-grid{grid-template-columns:1fr;gap:.75rem}.snapshot-card{padding:.75rem}.snapshot-details{font-size:.85rem}}@media(max-width:480px){.admin-container{padding:.75rem}.admin-header h1{font-size:1.1rem}.btn-primary{padding:.5rem .75rem;font-size:.85rem}.order-header{padding:.75rem}.order-id{font-size:.95rem}.order-product{font-size:.85rem}.order-meta{font-size:.8rem}.order-details{padding:.75rem}.order-section h3{font-size:.95rem}.info-grid>div{padding:.4rem;font-size:.9rem}.preview-image{max-height:300px}.snapshot-card{padding:.5rem}.snapshot-details{font-size:.8rem}}.admin-login-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.admin-login-card{background:#fff;border-radius:12px;padding:3rem;width:100%;max-width:420px;box-shadow:0 10px 40px #0000001a}.admin-login-card h1{margin:0 0 .5rem;font-size:2rem;color:#333;text-align:center}.admin-login-subtitle{text-align:center;color:#666;margin-bottom:2rem;font-size:.95rem}.admin-login-form{display:flex;flex-direction:column;gap:1.5rem}.admin-login-field{display:flex;flex-direction:column;gap:.5rem}.admin-login-field label{font-weight:500;color:#333;font-size:.9rem}.admin-login-field input{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.admin-login-field input:focus{outline:none;border-color:#667eea}.admin-login-button{padding:.875rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.admin-login-button:hover:not(:disabled){background:#5568d3}.admin-login-button:disabled{opacity:.6;cursor:not-allowed}.admin-login-error{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem;border:1px solid #fcc}.admin-dashboard{padding:2rem;max-width:1200px;margin:0 auto}.admin-dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem}.admin-dashboard-header h1{margin:0;font-size:2.5rem;color:#333}.admin-logout-button{padding:.75rem 1.5rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.admin-logout-button:hover{background:#c82333}.admin-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.admin-dashboard-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem;text-decoration:none;color:inherit;transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center}.admin-dashboard-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.admin-dashboard-card-icon{font-size:3rem;margin-bottom:1rem}.admin-dashboard-card h2{margin:0 0 .5rem;font-size:1.5rem;color:#333}.admin-dashboard-card p{margin:0;color:#666;font-size:.95rem}
