.toolbar{display:flex;gap:16px;align-items:center}.toolbar-group{display:flex;gap:6px;align-items:center}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-active{background:#e94560;color:#fff}.toolbar-label{font-size:12px;color:#aaa;white-space:nowrap}.product-color-swatches{display:flex;gap:4px;align-items:center}.product-color-swatch{width:24px;height:24px;border-radius:4px;border:2px solid #0f3460;cursor:pointer;transition:border-color .15s,transform .15s}.product-color-swatch:hover{transform:scale(1.15)}.product-color-active{border-color:#e94560;box-shadow:0 0 0 2px #e94560}.btn-save{background:#3a86ff;color:#fff;font-weight:600}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-save-ok{background:#06d6a0;color:#1a1a2e}.btn-save-err{background:#e94560;color:#fff}.btn-export{background:#06d6a0;color:#1a1a2e;font-weight:700}.btn-guest-cart{background:linear-gradient(135deg,#e94560,#ff6b1a);color:#fff;font-weight:700;padding:8px 20px;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px #e945604d;white-space:nowrap}.btn-guest-cart:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e9456066}.btn-guest-cart:active{transform:translateY(0)}.btn-kiosk-upload{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;padding:6px 14px;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:transform .15s,box-shadow .15s;white-space:nowrap}.btn-kiosk-upload:hover{transform:translateY(-1px);box-shadow:0 3px 10px #667eea66}.btn-kiosk-upload:active{transform:translateY(0)}.toolbar-mobile{position:fixed;bottom:0;left:0;right:0;z-index:200;background:#16213e;border-top:1px solid #0f3460;padding:0;display:flex;flex-direction:column;gap:0;box-shadow:0 -2px 12px #0000004d;padding-bottom:env(safe-area-inset-bottom,0)}.toolbar-mobile-row{display:flex;justify-content:space-around;align-items:stretch;padding:4px 0}.toolbar-mobile-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:8px 4px;background:transparent;border:none;color:#aaa;font-size:10px;cursor:pointer;border-radius:0;min-height:52px;min-width:unset;transition:color .15s,background .15s}.toolbar-mobile-btn:hover,.toolbar-mobile-btn:active{color:#e0e0e0;background:#ffffff0d}.toolbar-mobile-btn-active{color:#e94560}.toolbar-mobile-cart{color:#ff6b1a}.toolbar-mobile-cart:hover,.toolbar-mobile-cart:active{color:#e94560}.toolbar-mobile-icon{font-size:20px;line-height:1}.toolbar-mobile-label{font-size:10px;font-weight:500;white-space:nowrap}.toolbar-mobile-menu{position:fixed;bottom:calc(52px + env(safe-area-inset-bottom,0));left:0;right:0;z-index:199;background:#1a1a3e;border-top:1px solid #0f3460;padding:12px 16px;display:flex;flex-direction:column;gap:8px;animation:toolbar-menu-slide-up .2s ease;max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 -4px 16px #0000004d}@keyframes toolbar-menu-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.toolbar-mobile-menu-btn{width:100%;padding:12px 16px;background:#0f3460;color:#e0e0e0;border:none;border-radius:8px;font-size:14px;font-weight:500;text-align:left;cursor:pointer;min-height:44px}.toolbar-mobile-menu-btn:hover,.toolbar-mobile-menu-btn:active{background:#1a4080}.toolbar-mobile-menu-btn.btn-active{background:#e94560;color:#fff}.toolbar-mobile-menu-btn.btn-save{background:#3a86ff;color:#fff;text-align:center;font-weight:600}.toolbar-mobile-colors{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#16213e;border-radius:8px}.toolbar-mobile-colors .product-color-swatch{width:32px;height:32px}@media (min-width: 769px) and (max-width: 1024px){.toolbar{gap:8px;flex-wrap:wrap}.toolbar-group{gap:4px;flex-wrap:wrap}.btn-primary,.btn-secondary,.btn-kiosk-upload,.btn-guest-cart,.btn-save{padding:6px 10px;font-size:12px}}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:#fff;overflow:auto;padding:20px;position:relative}.canvas-text-editor{position:absolute;background:#fffffff2;border:2px solid #e94560;outline:none;resize:none;padding:2px 4px;line-height:1.2;box-sizing:border-box;z-index:10;overflow:hidden;font-size:16px}.canvas-container canvas{background:#fff;box-shadow:0 4px 24px #0006;touch-action:none;max-width:100%;max-height:100%}.pen-tooltip{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#000c;color:#e0e0e0;font-size:12px;padding:6px 14px;border-radius:6px;white-space:nowrap;pointer-events:none;z-index:10}@media (max-width: 768px){.canvas-container{padding:8px}}@media (max-width: 480px){.canvas-container{padding:4px}.pen-tooltip{font-size:11px;padding:4px 10px;bottom:8px}}.font-picker{position:relative;width:100%}.font-picker-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 10px;background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#e0e0e0;font-size:13px;cursor:pointer;text-align:left;gap:6px}.font-picker-trigger:hover{border-color:#e94560}.font-picker-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.font-picker-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:#16213e;border:1px solid #0f3460;border-radius:8px;box-shadow:0 8px 24px #00000080;margin-top:4px;overflow:hidden;display:flex;flex-direction:column;max-height:380px;animation:fontPickerIn .15s ease}@keyframes fontPickerIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.font-picker-search{padding:8px 10px;background:#1a1a2e;border:none;border-bottom:1px solid #0f3460;color:#e0e0e0;font-size:13px;outline:none}.font-picker-search::placeholder{color:#555}.font-picker-search:focus{background:#1e1e38}.font-picker-categories{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;border-bottom:1px solid #0f3460}.font-picker-cat{padding:3px 8px;font-size:10px;font-weight:600;text-transform:uppercase;background:transparent;color:#888;border:none;border-radius:3px;cursor:pointer;transition:background .1s,color .1s}.font-picker-cat:hover{color:#ccc}.font-picker-cat-active{background:#0f3460;color:#e0e0e0}.font-picker-list{flex:1;overflow-y:auto;padding:4px 0}.font-picker-status{padding:16px;text-align:center;font-size:12px;color:#666}.font-picker-section-label{padding:6px 12px 2px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#e94560}.font-picker-divider{height:1px;background:#0f3460;margin:4px 8px}.font-picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 12px;background:transparent;border:none;color:#e0e0e0;cursor:pointer;text-align:left;gap:8px;transition:background .1s}.font-picker-item:hover{background:#0f3460}.font-picker-item-selected{background:#e9456026}.font-picker-item-selected:hover{background:#e9456040}.font-picker-item-preview{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;min-height:22px}.font-picker-item-cat{font-size:9px;color:#666;text-transform:uppercase;flex-shrink:0}@media (max-width: 768px){.font-picker-dropdown{max-height:300px}.font-picker-trigger{padding:10px 12px;font-size:14px;min-height:44px}.font-picker-search{font-size:16px;padding:12px;min-height:44px}.font-picker-cat{padding:6px 12px;font-size:11px;min-height:32px}.font-picker-item{padding:10px 14px;min-height:44px}.font-picker-item-preview{font-size:17px}.font-picker-list{-webkit-overflow-scrolling:touch}}.layer-panel{width:260px;background:#16213e;border-left:1px solid #0f3460;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.bottom-sheet-content .layer-panel{width:100%;border-left:none;padding:8px 4px;background:transparent}.layer-panel h2{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:#e94560}.layer-panel h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:8px}.layer-list{list-style:none;display:flex;flex-direction:column;gap:4px}.layer-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;background:#1a1a3e;transition:background .15s}.layer-item:hover{background:#0f3460}.layer-item.selected{background:#0f3460;outline:1px solid #e94560}.layer-drag-handle{cursor:grab;color:#555;font-size:14px;-webkit-user-select:none;user-select:none;line-height:1}.layer-drag-handle:active{cursor:grabbing}.layer-type{font-size:11px;text-transform:uppercase;color:#06d6a0;font-weight:700;min-width:48px}.layer-id{flex:1;font-size:12px;color:#aaa}.layer-order-btn{background:transparent;color:#888;font-size:12px;padding:2px 4px;min-width:0;line-height:1}.layer-order-btn:hover{color:#06d6a0}.layer-delete{background:transparent;color:#e94560;font-size:16px;padding:2px 6px}.locked-layers{border-top:1px solid #0f3460;padding-top:8px;margin-top:4px}.layer-locked{opacity:.5;cursor:default}.layer-locked:hover{background:transparent}.layer-lock-icon{font-size:12px;flex-shrink:0}.layer-props{display:flex;flex-direction:column;gap:8px}.layer-props label{display:flex;align-items:center;gap:8px;font-size:12px;color:#aaa}.layer-props input[type=number]{width:70px;padding:4px 6px;border:1px solid #0f3460;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:12px}.layer-props input[type=range]{flex:1}.layer-empty{font-size:12px;color:#666;text-align:center;padding:20px 0}.checkbox-label{cursor:pointer}.text-props{display:flex;flex-direction:column;gap:8px}.text-content-input{width:100%;padding:6px;border:1px solid #0f3460;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:12px;resize:vertical;font-family:inherit}.text-props select{flex:1;padding:4px 6px;border:1px solid #0f3460;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:12px}.text-style-row{display:flex;gap:12px}.icon-name-display{font-size:11px;color:#06d6a0;word-break:break-all}.transform-section{display:flex;flex-direction:column;gap:8px;padding:10px;background:#1a1a3e;border-radius:6px}.transform-section h3{margin-bottom:4px}.transform-section label{display:flex;align-items:center;gap:6px;font-size:12px;color:#aaa}.transform-label{min-width:58px;flex-shrink:0}.transform-section input[type=range]{flex:1;min-width:0}.transform-value{min-width:36px;text-align:right;font-size:11px;color:#e0e0e0;flex-shrink:0}.transform-value-unit{font-size:11px;color:#e0e0e0;flex-shrink:0}.transform-number{width:52px;padding:2px 4px;border:1px solid #0f3460;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:11px;text-align:center}.flip-buttons{display:flex;gap:6px;margin-top:4px}.flip-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 8px;background:#1a1a3e;border:1px solid #0f3460;border-radius:6px;color:#aaa;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.flip-btn:hover{background:#0f3460;color:#e0e0e0}.flip-btn-active{background:#e9456033;border-color:#e94560;color:#e94560}.flip-btn-active:hover{background:#e945604d}@media (max-width: 768px){.layer-panel{width:100%;border-left:none;padding:8px 4px}.layer-item{padding:10px 12px;min-height:44px}.layer-order-btn{padding:6px 8px;font-size:14px;min-height:36px;min-width:36px}.layer-delete{padding:6px 10px;font-size:18px;min-height:36px;min-width:36px}.transform-section{padding:12px}.transform-section label{font-size:13px;min-height:36px}.transform-number{width:60px;padding:6px 8px;font-size:13px;min-height:36px}.flip-btn{padding:10px 12px;font-size:13px;min-height:44px}.text-content-input{font-size:16px;padding:10px;min-height:44px}.text-props select{font-size:16px;padding:8px;min-height:44px}.layer-props input[type=number]{font-size:16px;padding:8px;min-height:36px}}.icon-library{width:280px;background:#16213e;border-right:1px solid #0f3460;display:flex;flex-direction:column;overflow:hidden}.icon-library-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #0f3460}.icon-library-header h2{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:#e94560}.icon-library-close{background:transparent;color:#e94560;font-size:18px;padding:2px 8px}.icon-library-tabs{display:flex;border-bottom:1px solid #0f3460}.tab-btn{flex:1;padding:8px;background:transparent;color:#888;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab-btn.active{color:#e0e0e0;border-bottom-color:#e94560}.tab-content{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:10px}.icon-search{width:100%;padding:8px 10px;border:1px solid #0f3460;border-radius:6px;background:#1a1a2e;color:#e0e0e0;font-size:13px;outline:none}.icon-search:focus{border-color:#e94560}.icon-status{font-size:12px;color:#666;text-align:center;padding:8px 0}.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.icon-grid-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:#1a1a3e;border-radius:6px;color:#e0e0e0;transition:background .15s}.icon-grid-item:hover{background:#0f3460}.icon-grid-label{font-size:9px;color:#888;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emoji-categories{display:flex;flex-wrap:wrap;gap:4px}.emoji-cat-btn{padding:4px 8px;font-size:11px;background:#1a1a3e;color:#aaa;border-radius:4px;transition:background .15s}.emoji-cat-btn.active{background:#0f3460;color:#e0e0e0}.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}.emoji-grid-item{display:flex;align-items:center;justify-content:center;padding:6px;font-size:22px;background:#1a1a3e;border-radius:6px;transition:background .15s;line-height:1}.emoji-grid-item:hover{background:#0f3460}.bottom-sheet-content .icon-library{width:100%;border-right:none;background:transparent}.bottom-sheet-content .icon-library-header{display:none}@media (max-width: 768px){.icon-search{font-size:16px;padding:10px 12px;min-height:44px}.icon-grid{grid-template-columns:repeat(5,1fr);gap:6px}.icon-grid-item{padding:10px 6px;min-height:44px}.emoji-grid{grid-template-columns:repeat(7,1fr);gap:6px}.emoji-grid-item{padding:8px;font-size:24px;min-height:44px}.emoji-cat-btn{padding:8px 12px;font-size:12px;min-height:36px}.tab-btn{padding:12px 8px;font-size:13px;min-height:44px}}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:300;animation:bs-fadeIn .2s ease}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;max-height:75vh;background:#16213e;border-radius:20px 20px 0 0;z-index:301;display:flex;flex-direction:column;animation:bs-slideUp .3s ease;transition:transform .15s ease;box-shadow:0 -4px 24px #0000004d}.bottom-sheet-handle-area{display:flex;flex-direction:column;align-items:center;padding:12px 16px 8px;cursor:grab;flex-shrink:0;touch-action:none}.bottom-sheet-handle-area:active{cursor:grabbing}.bottom-sheet-handle{width:36px;height:4px;background:#ffffff40;border-radius:2px;margin-bottom:8px}.bottom-sheet-title{font-size:14px;font-weight:600;color:#e94560;text-transform:uppercase;letter-spacing:.5px}.bottom-sheet-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 12px 16px;min-height:0}@keyframes bs-slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes bs-fadeIn{0%{opacity:0}to{opacity:1}}@media (min-width: 769px){.bottom-sheet,.bottom-sheet-overlay{display:none}}.my-designs-panel{position:absolute;right:0;top:100%;width:320px;max-height:480px;background:#16213e;border:1px solid #0f3460;border-radius:10px;box-shadow:0 8px 32px #00000080;z-index:100;display:flex;flex-direction:column;overflow:hidden}.my-designs-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px 8px;border-bottom:1px solid #0f3460}.my-designs-header h3{font-size:14px;color:#e0e0e0;margin:0}.my-designs-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.my-designs-close:hover{color:#e94560}.my-designs-error{background:#e9456022;color:#e94560;padding:6px 12px;font-size:12px;margin:8px 14px 0;border-radius:4px}.my-designs-new{margin:10px 14px 6px;background:#0f3460;color:#06d6a0;border:1px dashed #06d6a0;border-radius:6px;padding:8px 0;font-size:13px;font-weight:600;cursor:pointer;text-align:center}.my-designs-new:hover{background:#1a2a50}.my-designs-loading,.my-designs-empty{padding:24px 14px;text-align:center;color:#888;font-size:13px}.my-designs-grid{padding:8px 14px 14px;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:10px}.my-designs-card{position:relative;background:#0f0f23;border:2px solid #0f3460;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s}.my-designs-card:hover{border-color:#3a86ff;transform:translateY(-1px)}.my-designs-card-active{border-color:#06d6a0}.my-designs-thumb{width:100%;height:100px;object-fit:contain;background:#1a1a2e;display:flex;align-items:center;justify-content:center}.my-designs-placeholder{color:#555;font-size:11px}.my-designs-info{padding:4px 6px 0;display:flex;justify-content:space-between;align-items:center;min-height:22px}.my-designs-name{font-size:11px;color:#e0e0e0;cursor:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.my-designs-name:hover{color:#3a86ff}.my-designs-name-empty{color:#555;font-style:italic}.my-designs-name-input{font-size:11px;color:#e0e0e0;background:#0f0f23;border:1px solid #3a86ff;border-radius:3px;padding:1px 4px;width:80px;outline:none}.my-designs-date{font-size:10px;color:#888;padding:0 6px 4px}.my-designs-current{font-size:10px;color:#06d6a0;font-weight:600}.my-designs-delete{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#e94560cc;color:#fff;border:none;border-radius:50%;font-size:12px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.my-designs-card:hover .my-designs-delete{opacity:1}.my-designs-delete:hover{background:#e94560}.save-name-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center}.save-name-modal{background:#16213e;border:1px solid #0f3460;border-radius:12px;padding:20px 24px;width:340px;box-shadow:0 8px 32px #00000080}.save-name-modal h4{margin:0 0 12px;font-size:15px;color:#e0e0e0}.save-name-modal input{width:100%;padding:8px 12px;background:#0f0f23;border:1px solid #0f3460;border-radius:6px;color:#e0e0e0;font-size:14px;outline:none;box-sizing:border-box}.save-name-modal input:focus{border-color:#3a86ff}.save-name-actions{display:flex;gap:8px;margin-top:14px}.save-name-btn{flex:1;padding:8px 0;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;border:none}.save-name-confirm{background:#3a86ff;color:#fff}.save-name-confirm:hover{background:#2d6fdf}.save-name-skip{background:#0f3460;color:#888}.save-name-skip:hover{background:#1a2a50;color:#aaa}.kiosk-upload-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.kiosk-upload-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:460px;max-width:94vw;max-height:90vh;overflow-y:auto;animation:kioskModalIn .25s ease}@keyframes kioskModalIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.kiosk-upload-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid #f0f0f0}.kiosk-upload-header h3{margin:0;font-size:18px;font-weight:700;color:#1a1a2e}.kiosk-upload-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0 4px;line-height:1}.kiosk-upload-close:hover{color:#333}.kiosk-upload-body{padding:24px}.kiosk-upload-center{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.kiosk-upload-qr-section{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:20px}.kiosk-upload-qr{padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:16px}.kiosk-upload-or{font-size:14px;color:#aaa;font-weight:600;text-transform:uppercase}.kiosk-upload-code-section{display:flex;flex-direction:column;align-items:center;gap:6px}.kiosk-upload-code-label{font-size:12px;color:#888;font-weight:500}.kiosk-upload-code{font-size:48px;font-weight:900;letter-spacing:8px;color:#1a1a2e;font-family:Courier New,monospace;background:#f5f5ff;padding:8px 20px;border-radius:12px;border:2px dashed #c0c0e0}.kiosk-upload-code-url{font-size:11px;color:#999;word-break:break-all}.kiosk-upload-instructions{background:#f8f9ff;border-radius:12px;padding:14px 18px;margin-bottom:16px}.kiosk-upload-instructions p{margin:0;font-size:13px;color:#555;line-height:1.8}.kiosk-upload-instructions strong{color:#6c2fd2}.kiosk-upload-timer{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;color:#888;font-size:13px}.kiosk-upload-countdown{font-size:16px;font-weight:700;color:#1a1a2e;font-variant-numeric:tabular-nums}.kiosk-upload-countdown-warn{color:#e94560}.kiosk-upload-pulse{width:10px;height:10px;border-radius:50%;background:#22c55e;animation:kioskPulse 1.5s ease infinite}@keyframes kioskPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.kiosk-upload-spinner{width:36px;height:36px;border:3px solid #e0e0e0;border-top-color:#6c2fd2;border-radius:50%;animation:kioskSpin .7s linear infinite}@keyframes kioskSpin{to{transform:rotate(360deg)}}.kiosk-upload-error-icon{width:48px;height:48px;border-radius:50%;background:#fee2e2;color:#e94560;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center}.kiosk-upload-expired-icon{font-size:48px}.kiosk-upload-success-icon{animation:kioskSuccessPop .4s ease}@keyframes kioskSuccessPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.kiosk-upload-body h4{margin:0;font-size:20px;font-weight:700;color:#1a1a2e}.kiosk-upload-body p{margin:0;color:#666;font-size:14px}.kiosk-upload-btn{background:#1a1a2e;color:#fff;border:none;border-radius:10px;padding:10px 28px;font-size:14px;font-weight:600;cursor:pointer;margin-top:8px}.kiosk-upload-btn:hover{background:#2d2d4e}@media (max-width: 500px){.kiosk-upload-qr-section{flex-direction:column;gap:12px}.kiosk-upload-or{display:none}.kiosk-upload-code{font-size:36px;letter-spacing:6px}}.asset-library{width:300px;background:#16213e;border-right:1px solid #0f3460;display:flex;flex-direction:column;overflow:hidden}.asset-library-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #0f3460}.asset-library-header h2{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:#e94560;margin:0}.asset-library-close{background:transparent;border:none;color:#e94560;font-size:20px;padding:2px 8px;cursor:pointer}.asset-library-tabs{display:flex;border-bottom:1px solid #0f3460}.asset-tab{flex:1;padding:10px 8px;background:transparent;border:none;color:#888;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.asset-tab:hover{color:#bbb}.asset-tab-active{color:#e0e0e0;border-bottom-color:#e94560}.asset-tab-content{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:10px}.asset-status{font-size:12px;color:#666;text-align:center;padding:20px 8px}.asset-empty{text-align:center;padding:30px 14px;color:#888}.asset-empty p{font-size:13px;font-weight:600;margin:0 0 6px}.asset-empty span{font-size:11px;color:#666}.asset-cat-pills,.stock-source-pills{display:flex;flex-wrap:wrap;gap:4px}.asset-cat-pill{padding:4px 10px;font-size:11px;background:#1a1a3e;color:#aaa;border:none;border-radius:4px;cursor:pointer;transition:background .15s,color .15s}.asset-cat-pill:hover{background:#0f3460;color:#ddd}.asset-cat-pill-active{background:#0f3460;color:#e0e0e0;border-bottom:2px solid #e94560}.asset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.asset-grid-item{background:#1a1a3e;border:none;border-radius:6px;overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;padding:0;display:flex;flex-direction:column}.asset-grid-item:hover{transform:scale(1.03);box-shadow:0 2px 8px #0000004d}.asset-grid-item img{width:100%;height:72px;object-fit:cover;display:block;background:#0f0f23}.asset-grid-label{font-size:9px;color:#888;padding:3px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.stock-search-bar{position:relative}.stock-search-input{width:100%;padding:9px 10px;border:1px solid #0f3460;border-radius:6px;background:#1a1a2e;color:#e0e0e0;font-size:13px;outline:none;box-sizing:border-box}.stock-search-input:focus{border-color:#e94560}.stock-search-input::placeholder{color:#555}.stock-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stock-grid-item{background:#1a1a3e;border:none;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .15s;padding:0;display:flex;flex-direction:column;position:relative}.stock-grid-item:hover{transform:scale(1.02)}.stock-grid-item img{width:100%;height:90px;object-fit:cover;display:block;background:#0f0f23}.stock-grid-info{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;gap:4px}.stock-grid-author{font-size:9px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;text-align:left}.stock-grid-source{font-size:8px;font-weight:700;text-transform:uppercase;padding:1px 4px;border-radius:3px;flex-shrink:0}.stock-source-pixabay{background:#3fcc6e;color:#000}.stock-source-pexels{background:#07a081;color:#fff}.stock-source-unsplash{background:#333;color:#fff}.stock-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:8px}.stock-grid-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:assetSpin .6s linear infinite}@keyframes assetSpin{to{transform:rotate(360deg)}}.stock-grid-loading{pointer-events:none}.stock-skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stock-skeleton{height:90px;border-radius:8px;background:linear-gradient(90deg,#1a1a3e 25%,#222250,#1a1a3e 75%);background-size:200% 100%;animation:assetShimmer 1.2s ease infinite}@keyframes assetShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.stock-load-more{width:100%;padding:10px;background:#1a1a3e;border:1px solid #0f3460;border-radius:6px;color:#aaa;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.stock-load-more:hover:not(:disabled){background:#0f3460;color:#e0e0e0}.stock-load-more:disabled{opacity:.5;cursor:not-allowed}.bottom-sheet-content .asset-library{width:100%;border-right:none;background:transparent}.bottom-sheet-content .asset-library-header{display:none}@media (max-width: 768px){.stock-search-input{font-size:16px;padding:12px;min-height:44px}.asset-tab{padding:12px 8px;font-size:13px;min-height:44px}.asset-cat-pill{padding:8px 14px;font-size:12px;min-height:36px}.asset-grid{grid-template-columns:repeat(3,1fr);gap:8px}.asset-grid-item img{height:80px}.stock-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stock-grid-item img{height:100px}.stock-load-more{padding:14px;font-size:14px;min-height:44px}}.app{height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#16213e;border-bottom:1px solid #0f3460}.app-header-left{display:flex;align-items:center;gap:12px}.app-header h1{font-size:18px;font-weight:600;color:#e94560}.btn-back{background:#0f3460;color:#e0e0e0;border:none;border-radius:6px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:44px;min-width:44px}.btn-back:hover{background:#e94560;color:#fff}.app-main{flex:1;display:flex;overflow:hidden}.angle-tabs{display:flex;gap:0;background:#16213e;border-bottom:1px solid #0f3460;padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.angle-tab{padding:8px 20px;border:none;background:transparent;color:#888;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;min-height:44px}.angle-tab:hover{color:#e0e0e0}.angle-tab-active{color:#e94560;border-bottom-color:#e94560}.keyboard-open .toolbar-mobile,.keyboard-open .toolbar-mobile-menu,.keyboard-open .mobile-layers-fab{display:none!important}.keyboard-open .app-main{padding-bottom:0!important}.mobile-layers-fab{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0));right:12px;z-index:150;width:48px;height:48px;border-radius:50%;background:#e94560;color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #e9456066;cursor:pointer;padding:0;min-height:48px;min-width:48px}.mobile-layers-fab:hover,.mobile-layers-fab:active{background:#d63350}@media (max-width: 768px){.app-header{padding:8px 12px}.app-header h1{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.app-header>div:last-child .toolbar:not(.toolbar-mobile){display:none}.app-main{flex-direction:column;padding-bottom:calc(56px + env(safe-area-inset-bottom,0))}.angle-tabs{padding:0 12px}.angle-tab{padding:6px 14px;font-size:12px}}@media (min-width: 769px) and (max-width: 1024px){.app-header{padding:8px 14px;flex-wrap:wrap;gap:8px}.app-header h1{font-size:15px}}.login-panel{display:flex;align-items:center;justify-content:center;padding:60px 24px}.login-card{background:var(--card-bg, #fff);border-radius:16px;box-shadow:0 4px 24px #00000014;padding:36px 32px;max-width:400px;width:100%;text-align:center}.login-card h3{font-family:var(--font-display, sans-serif);font-size:22px;font-weight:700;color:var(--text-primary, #1a1a2e);margin:0 0 8px}.login-card p{font-size:14px;color:var(--text-muted, #666);margin:0 0 20px;line-height:1.5}.login-tabs{display:flex;gap:4px;background:#f0f0f5;border-radius:10px;padding:4px;margin-bottom:20px}.login-tab{flex:1;padding:10px 12px;border:none;border-radius:8px;background:transparent;font-family:var(--font-body, sans-serif);font-size:13px;font-weight:600;color:var(--text-muted, #666);cursor:pointer;transition:all .2s}.login-tab-active{background:#fff;color:var(--text-primary, #1a1a2e);box-shadow:0 1px 4px #00000014}.login-tab:hover:not(.login-tab-active){color:var(--text-primary, #1a1a2e)}.login-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px;text-align:left}.login-form{display:flex;flex-direction:column;gap:12px}.login-form input{padding:12px 16px;border:1px solid #ddd;border-radius:10px;font-size:15px;font-family:var(--font-body, sans-serif);color:var(--text-primary, #1a1a2e);outline:none;transition:border-color .15s;text-align:center}.login-form input:focus{border-color:var(--hero-from, #6C2FD4);box-shadow:0 0 0 3px #6c2fd41a}.login-pwd-wrap{position:relative;display:flex}.login-pwd-wrap input{width:100%;padding-right:64px}.login-pwd-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:12px;font-weight:600;color:var(--text-muted, #666);cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}.login-pwd-toggle:hover{color:var(--text-primary, #1a1a2e)}.login-submit-btn{padding:12px 0;border:none;border-radius:10px;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--hero-to, #FF8C1A));color:#fff;font-family:var(--font-display, sans-serif);font-size:15px;font-weight:700;cursor:pointer;transition:opacity .15s}.login-submit-btn:hover{opacity:.9}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed}.login-skip-btn{margin-top:16px;background:none;border:none;color:var(--text-muted, #666);font-size:13px;font-weight:500;cursor:pointer;text-decoration:underline;padding:4px 8px}.login-skip-btn:hover{color:var(--text-primary, #1a1a2e)}.login-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:16px}.login-link-btn{background:none;border:none;color:var(--hero-from, #6C2FD4);font-size:13px;font-weight:500;cursor:pointer;padding:4px 8px;transition:opacity .15s}.login-link-btn:hover{opacity:.75;text-decoration:underline}.login-success-msg{text-align:center;padding:8px 0}.login-success-msg h4{font-family:var(--font-display, sans-serif);font-size:18px;font-weight:700;color:var(--text-primary, #1a1a2e);margin:8px 0}.login-success-msg p{font-size:14px;color:var(--text-muted, #666);line-height:1.5;margin:0 0 16px}.login-sent-icon{margin-bottom:12px}.login-back-btn{margin-top:8px;background:none;border:1px solid #ddd;border-radius:8px;padding:8px 20px;font-size:13px;color:var(--text-muted, #666);cursor:pointer}.login-back-btn:hover{background:#f5f5f5}@media (max-width: 480px){.login-card{padding:28px 20px}}.welcome-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--hero-from, #6C2FD4) 0%,var(--hero-to, #FF8C1A) 100%);font-family:var(--font-body, "DM Sans", sans-serif);padding:24px;position:relative}.welcome-loading{color:#ffffffb3;font-size:15px}.welcome-card{background:#fff;border-radius:24px;padding:48px 40px 40px;max-width:420px;width:100%;text-align:center;box-shadow:0 20px 60px #00000040,0 0 0 1px #ffffff1a;animation:welcomeFadeIn .5s ease-out}@keyframes welcomeFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-logo{margin-bottom:20px}.welcome-logo-img{width:80px;height:80px;object-fit:contain;border-radius:16px}.welcome-title{font-family:var(--font-display, "Plus Jakarta Sans", sans-serif);font-size:28px;font-weight:800;color:var(--text-primary, #1a1a2e);margin:0 0 8px}.welcome-subtitle{font-size:15px;color:var(--text-muted, #666680);margin:0 0 32px;line-height:1.5}.welcome-actions{margin-top:8px}.welcome-start-btn{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:16px 32px;font-size:16px;font-weight:700;font-family:var(--font-body, "DM Sans", sans-serif);color:#fff;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--accent, #FF6B1A));border:none;border-radius:14px;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #6c2fd44d}.welcome-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #6c2fd466}.welcome-start-btn:active{transform:translateY(0)}.welcome-login-section{margin-top:8px}.welcome-login-section .login-panel{position:static;background:none;min-height:auto;padding:0;display:block}.welcome-login-section .login-card{background:none;box-shadow:none;padding:0;border-radius:0;max-width:none}.welcome-login-section .login-card h3{display:none}.welcome-login-section .login-card>p{display:none}.welcome-login-section .login-form{gap:12px}.welcome-login-section .login-form input{padding:14px 16px;border-radius:12px;font-size:15px;border:2px solid #e8e8f0;background:#fafafe;transition:border-color .2s}.welcome-login-section .login-form input:focus{border-color:var(--accent, #FF6B1A);outline:none;background:#fff}.welcome-login-section .login-submit-btn{padding:14px 24px;border-radius:12px;font-size:15px;font-weight:700;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--accent, #FF6B1A));color:#fff;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #6c2fd44d}.welcome-login-section .login-submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #6c2fd466}.welcome-login-section .login-skip-btn{margin-top:16px;padding:12px 24px;font-size:14px;color:var(--text-muted, #666680);background:transparent;border:2px solid #e8e8f0;border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s;width:100%;font-weight:500}.welcome-login-section .login-skip-btn:hover{background:#f5f5fa;border-color:#d0d0e0}.welcome-login-section .login-sent-icon{margin-bottom:12px}.welcome-footer{position:absolute;bottom:20px;left:0;right:0;text-align:center;color:#ffffff80;font-size:12px}.welcome-footer strong{color:#ffffffb3}@media (max-width: 768px){.welcome-card{padding:40px 28px 36px;border-radius:22px;max-width:100%}.welcome-start-btn{padding:18px 32px;font-size:17px;min-height:56px}}@media (max-width: 480px){.welcome-screen{padding:16px}.welcome-card{padding:32px 20px 28px;border-radius:18px}.welcome-title{font-size:24px}.welcome-subtitle{font-size:14px}.welcome-logo-img{width:64px;height:64px}.welcome-start-btn{padding:16px 28px;font-size:16px;min-height:52px}.welcome-login-section .login-form input{padding:16px 18px;font-size:16px;min-height:52px}.welcome-login-section .login-submit-btn{padding:16px 24px;font-size:16px;min-height:52px}.welcome-login-section .login-skip-btn{padding:14px 24px;font-size:15px;min-height:48px}.welcome-footer{position:relative;bottom:auto;margin-top:24px}}.cart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;animation:cart-fadeIn .2s ease}.cart-panel{position:fixed;top:0;right:0;width:380px;max-width:92vw;height:100vh;background:#fff;z-index:201;box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;animation:cart-slideIn .25s ease}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #eee;flex-shrink:0}.cart-header h3{font-family:var(--font-display, sans-serif);font-size:18px;font-weight:700;margin:0;color:var(--text-primary, #1a1a2e);display:flex;align-items:center;gap:8px}.cart-count{background:var(--accent, #FF6B1A);color:#fff;font-size:11px;font-weight:700;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.cart-close{background:none;border:none;font-size:22px;color:var(--text-muted, #666);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.cart-close:hover{background:#f0f0f0}.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--text-muted, #666)}.cart-empty p{font-size:15px;font-weight:600;color:var(--text-primary, #1a1a2e);margin:8px 0 0}.cart-empty span{font-size:13px}.cart-items{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.cart-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:10px;background:#f8f8fb;transition:background .15s}.cart-item:hover{background:#f0f0f5}.cart-item-thumb{width:48px;height:48px;border-radius:8px;object-fit:contain;background:#eee;flex-shrink:0}.cart-item-nothumb{display:flex;align-items:center;justify-content:center;color:#bbb;font-size:16px}.cart-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cart-item-name{font-size:13px;font-weight:600;color:var(--text-primary, #1a1a2e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-product{font-size:11px;color:var(--text-muted, #666);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-remove{background:none;border:none;color:#bbb;padding:6px;border-radius:6px;cursor:pointer;flex-shrink:0;transition:color .15s,background .15s}.cart-item-remove:hover{color:#e53e3e;background:#e53e3e14}.cart-footer{padding:16px 20px 20px;border-top:1px solid #eee;flex-shrink:0}.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px;color:var(--text-primary, #1a1a2e);font-weight:600}.cart-price{font-size:13px;font-weight:500;color:var(--text-muted, #666);font-style:italic}.cart-checkout-btn{width:100%;padding:12px 0;border:none;border-radius:10px;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--hero-to, #FF8C1A));color:#fff;font-family:var(--font-display, sans-serif);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s}.cart-checkout-btn:hover{opacity:.9}.cart-form{flex:1;padding:20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.cart-form-intro{font-size:14px;color:var(--text-muted, #666);margin:0;line-height:1.4}.cart-form-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px}.cart-label{display:flex;flex-direction:column;gap:6px}.cart-label span{font-size:12px;font-weight:600;color:var(--text-primary, #1a1a2e)}.cart-label input{padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:var(--font-body, sans-serif);color:var(--text-primary, #1a1a2e);outline:none;transition:border-color .15s}.cart-label input:focus{border-color:var(--hero-from, #6C2FD4);box-shadow:0 0 0 3px #6c2fd41a}.cart-form-summary{font-size:13px;color:var(--text-muted, #666);text-align:center;padding:8px 0}.cart-form-actions{display:flex;gap:10px;margin-top:auto}.cart-back-btn{flex:1;padding:11px 0;border:1px solid #ddd;border-radius:10px;background:#fff;color:var(--text-primary, #1a1a2e);font-family:var(--font-display, sans-serif);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.cart-back-btn:hover{background:#f5f5f5}.cart-submit-btn{flex:2;padding:11px 0;border:none;border-radius:10px;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--hero-to, #FF8C1A));color:#fff;font-family:var(--font-display, sans-serif);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s}.cart-submit-btn:hover{opacity:.9}.cart-submit-btn:disabled,.cart-back-btn:disabled{opacity:.5;cursor:not-allowed}.cart-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:12px}.cart-success-icon{width:72px;height:72px;border-radius:50%;background:#f0fdf4;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.cart-success h4{font-family:var(--font-display, sans-serif);font-size:20px;font-weight:700;color:var(--text-primary, #1a1a2e);margin:0}.cart-success p{font-size:14px;color:var(--text-muted, #666);margin:0;line-height:1.5}.cart-newdesign-btn{margin-top:12px;padding:11px 28px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--hero-from, #6C2FD4),var(--hero-to, #FF8C1A));color:#fff;font-family:var(--font-display, sans-serif);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s}.cart-newdesign-btn:hover{opacity:.9}@keyframes cart-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes cart-slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 768px){.cart-panel{width:100%;max-width:100vw}.cart-close,.cart-item-remove{min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.cart-label input{font-size:16px;padding:14px 16px;min-height:48px}.cart-checkout-btn,.cart-submit-btn{padding:14px 0;font-size:15px;min-height:48px}.cart-back-btn{padding:14px 0;font-size:14px;min-height:48px}.cart-newdesign-btn{padding:14px 28px;font-size:15px;min-height:48px}.cart-items{-webkit-overflow-scrolling:touch}}.homepage{min-height:100vh;background:#fafafa;font-family:var(--font-body);color:var(--text-primary);overflow-y:auto;height:auto}.hp-navbar{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 8px #0000000a}.hp-navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px}.hp-navbar-left{display:flex;align-items:center;gap:28px;min-width:0}.hp-logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}.hp-logo-img{height:32px;width:auto;object-fit:contain}.hp-logo-text{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--text-primary);letter-spacing:-.3px}.hp-cat-menu{display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none}.hp-cat-menu::-webkit-scrollbar{display:none}.hp-cat-btn{background:none;border:none;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-muted);padding:6px 14px;border-radius:20px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.hp-cat-btn:hover{background:#0000000a;color:var(--text-primary)}.hp-cat-btn-active{background:var(--hero-from);color:#fff}.hp-cat-btn-active:hover{background:var(--hero-from);color:#fff;opacity:.9}.hp-navbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.hp-nav-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-family:var(--font-body);font-size:13px;font-weight:500;padding:8px 12px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;position:relative}.hp-nav-btn:hover{background:#0000000a;color:var(--text-primary)}.hp-nav-user{display:flex;align-items:center;gap:4px}.hp-nav-email{font-size:12px;font-weight:500;color:var(--text-muted);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-nav-login{color:var(--hero-from);font-weight:600}.hp-nav-login:hover{background:#6c2fd414;color:var(--hero-from)}.hp-nav-btn-label{display:inline}.hp-cart-badge{position:absolute;top:2px;right:4px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.hp-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;animation:hp-fadeIn .2s ease}.hp-sidebar{position:fixed;top:0;right:0;width:340px;max-width:90vw;height:100vh;background:#fff;z-index:201;box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;animation:hp-slideIn .25s ease}.hp-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #eee}.hp-sidebar-header h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0;color:var(--text-primary)}.hp-sidebar-close{background:none;border:none;font-size:22px;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.hp-sidebar-close:hover{background:#f0f0f0}.hp-sidebar-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.hp-sidebar-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.hp-sidebar-card{display:flex;align-items:center;gap:8px;padding:10px;border-radius:10px;transition:background .15s}.hp-sidebar-card:hover{background:#f5f5f8}.hp-sidebar-card-main{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer}.hp-sidebar-cart-btn{flex-shrink:0;width:34px;height:34px;border-radius:8px;border:1px solid #e0e0e0;background:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,border-color .15s}.hp-sidebar-cart-btn:hover:not(:disabled){background:#f0f0f5;border-color:var(--hero-from)}.hp-sidebar-cart-btn-done{background:#f0fdf4;border-color:#86efac;color:#22c55e;cursor:default}.hp-sidebar-cart-btn:disabled{opacity:1}.hp-sidebar-thumb{width:56px;height:56px;border-radius:8px;object-fit:contain;background:#f0f0f4;flex-shrink:0;display:flex;align-items:center;justify-content:center}.hp-sidebar-placeholder{font-size:9px;color:#bbb}.hp-sidebar-info{display:flex;flex-direction:column;gap:2px;min-width:0}.hp-sidebar-name{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-sidebar-date{font-size:11px;color:var(--text-muted)}.hp-hero{position:relative;background:linear-gradient(135deg,var(--hero-from) 0%,var(--hero-to) 100%);overflow:hidden}.hp-hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:40px;padding:56px 24px 48px;align-items:center}.hp-hero-left{position:relative;z-index:1}.hp-hero-title{font-family:var(--font-display);font-size:40px;font-weight:800;color:#fff;margin:0 0 12px;line-height:1.12;letter-spacing:-.5px;text-align:left}.hp-hero-sub{font-size:16px;color:#ffffffd1;margin:0 0 28px;font-weight:400;text-align:left;max-width:420px}.hp-hero-pills{display:flex;flex-wrap:wrap;gap:10px}.hp-hero-pill{background:#ffffff2e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);border-radius:24px;padding:9px 22px;font-family:var(--font-display);font-size:13px;font-weight:600;color:#ffffffe6;cursor:pointer;transition:background .2s,color .2s,transform .15s,border-color .2s;white-space:nowrap}.hp-hero-pill:hover{background:#ffffff4d;transform:translateY(-1px)}.hp-hero-pill-active{background:#fff;color:var(--text-primary);border-color:#fff;box-shadow:0 4px 16px #0000001f}.hp-hero-pill-active:hover{background:#fff;color:var(--text-primary);transform:translateY(-1px)}.hp-hero-right{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}.hp-hero-cover-img{width:100%;max-width:400px;height:auto;border-radius:16px;box-shadow:0 12px 40px #0003;object-fit:cover}.hp-hero-mockup{display:flex;flex-direction:column;align-items:center}.hp-mockup-screen{width:280px;height:180px;background:#1a1a2e;border-radius:12px 12px 0 0;border:3px solid #333;border-bottom:none;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.hp-mockup-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--hero-from),var(--hero-to));opacity:.25}.hp-mockup-text{position:relative;z-index:1;font-family:var(--font-display);font-size:22px;font-weight:800;color:#ffffffb3;letter-spacing:-.5px}.hp-mockup-base{width:320px;height:14px;background:#444;border-radius:0 0 8px 8px}.hp-section{max-width:1200px;margin:0 auto;padding:40px 24px 0}.hp-section-designs{padding-bottom:24px}.hp-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.hp-section-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);margin:0}.hp-link-btn{background:none;border:none;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--hero-from);cursor:pointer;padding:6px 12px;border-radius:6px;transition:background .15s}.hp-link-btn:hover{background:#6c2fd414}.hp-loading,.hp-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:32px 0}.hp-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;padding-bottom:16px}.hp-product-card{background:var(--card-bg);border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #0000000f;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;animation:hp-fadeUp .4s ease both}.hp-product-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px #6c2fd424}.hp-product-img-wrap{background:#f5f5f5;padding:16px;display:flex;align-items:center;justify-content:center;height:180px}.hp-product-img{max-width:100%;max-height:100%;object-fit:contain}.hp-product-placeholder{color:#bbb;font-size:13px}.hp-product-body{padding:14px 16px 8px;flex:1}.hp-product-body h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.hp-product-body p{font-size:12px;color:var(--text-muted);margin:0;line-height:1.4}.hp-product-btn{margin:0 16px 16px;padding:9px 0;border:none;border-radius:8px;background:linear-gradient(135deg,var(--hero-from),var(--hero-to));color:#fff;font-family:var(--font-display);font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s;text-align:center}.hp-product-btn:hover{opacity:.88}.hp-designs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}.hp-design-card{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000000d;cursor:pointer;transition:transform .2s,box-shadow .2s;animation:hp-fadeUp .4s ease both}.hp-design-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #6c2fd41f}.hp-design-thumb{width:100%;height:120px;object-fit:contain;background:#f5f5f5;display:flex;align-items:center;justify-content:center}.hp-design-placeholder{color:#ccc;font-size:11px}.hp-design-info{padding:8px 10px;display:flex;justify-content:space-between;align-items:center}.hp-design-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.hp-design-date{font-size:10px;color:var(--text-muted)}.hp-design-card-clickable{cursor:pointer}.hp-design-cart-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;padding:6px 8px;border:none;border-top:1px solid rgba(0,0,0,.06);background:#fff;font-size:11px;font-weight:600;color:var(--hero-from, #6c2fd2);cursor:pointer;transition:background .15s,color .15s}.hp-design-cart-btn:hover:not(:disabled){background:var(--hero-from, #6c2fd2);color:#fff}.hp-design-cart-done{color:#22c55e;cursor:default;background:#f0fdf4}.hp-design-cart-done:hover{background:#f0fdf4;color:#22c55e}.hp-nav-exit{display:flex;align-items:center;gap:4px;color:#888}.hp-nav-exit:hover{color:#e94560}.hp-footer{text-align:center;padding:32px 24px;font-size:12px;color:var(--text-muted)}.hp-footer strong{color:var(--text-primary)}@keyframes hp-fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes hp-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes hp-slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.hp-hamburger{display:none;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;color:var(--text-primary);cursor:pointer;border-radius:8px;padding:0;flex-shrink:0}.hp-hamburger:hover{background:#0000000a}.hp-mobile-nav{position:sticky;top:56px;z-index:99;background:#fff;border-bottom:1px solid rgba(0,0,0,.08);padding:8px 16px;display:flex;flex-wrap:wrap;gap:8px;animation:hp-fadeIn .15s ease;box-shadow:0 4px 12px #0000000f}.hp-mobile-nav-btn{padding:10px 18px;background:#f5f5f8;border:none;border-radius:20px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s;min-height:44px}.hp-mobile-nav-btn:hover,.hp-mobile-nav-btn:active{background:#0000000f;color:var(--text-primary)}.hp-mobile-nav-btn-active{background:var(--hero-from);color:#fff}.hp-mobile-nav-btn-active:hover{background:var(--hero-from);color:#fff;opacity:.9}@media (max-width: 768px){.hp-hamburger{display:flex}.hp-navbar-inner{padding:0 12px}.hp-cat-menu,.hp-nav-btn-label{display:none}.hp-nav-btn{padding:10px 14px;min-height:44px;min-width:44px}.hp-hero-inner{grid-template-columns:1fr;padding:40px 20px 36px;gap:24px}.hp-hero-right{display:none}.hp-hero-title{font-size:28px}.hp-hero-sub{font-size:14px;margin-bottom:20px}.hp-hero-pills{gap:8px}.hp-hero-pill{padding:7px 16px;font-size:12px}.hp-section{padding:28px 16px 0}.hp-products-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.hp-product-img-wrap{height:140px;padding:12px}.hp-sidebar{width:100%;max-width:100vw}.hp-product-btn{padding:12px 0;font-size:14px;min-height:44px}.hp-design-cart-btn{padding:10px 8px;font-size:12px;min-height:44px}.hp-hero-pill{min-height:40px;display:flex;align-items:center}.hp-sidebar-cart-btn{width:44px;height:44px}}@media (max-width: 480px){.hp-hero-pills{gap:6px}.hp-hero-pill{padding:6px 14px;font-size:11px}.hp-products-grid{grid-template-columns:1fr 1fr}.hp-designs-grid{grid-template-columns:1fr 1fr;gap:10px}}.admin{min-height:100vh;background:#1a1a2e;color:#e0e0e0}.admin-header{display:flex;align-items:center;gap:24px;padding:12px 24px;background:#16213e;border-bottom:1px solid #0f3460}.admin-header h1{font-size:18px;color:#e94560;margin-right:auto}.admin-header a{color:#aaa;text-decoration:none;font-size:13px}.admin-header a:hover,.admin-header a.active{color:#06d6a0}.admin-content{max-width:960px;margin:0 auto;padding:24px}.admin-content h2{font-size:20px;color:#e94560;margin-bottom:20px}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:24px}.product-card{background:#16213e;border:1px solid #0f3460;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s}.product-card:hover{border-color:#e94560}.product-card img{width:100%;height:160px;object-fit:cover;background:#0f0f23}.product-card-body{padding:12px}.product-card-body h3{font-size:14px;color:#e0e0e0;margin-bottom:4px}.product-card-body p{font-size:12px;color:#888}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none}.btn-primary{background:#e94560;color:#fff}.btn-secondary{background:#0f3460;color:#e0e0e0}.btn-success{background:#06d6a0;color:#1a1a2e}.btn-small{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;color:#aaa;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:8px 10px;border:1px solid #0f3460;border-radius:6px;background:#1a1a3e;color:#e0e0e0;font-size:13px;font-family:inherit}.form-group textarea{resize:vertical;min-height:60px}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.color-list{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.color-swatch{width:32px;height:32px;border-radius:6px;border:2px solid #0f3460;cursor:pointer;position:relative}.color-swatch:hover:after{content:"×";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0009;color:#fff;font-size:16px;border-radius:4px}.color-add{width:32px;height:32px;border:2px dashed #0f3460;border-radius:6px;background:transparent;color:#888;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-upload{border:2px dashed #0f3460;border-radius:8px;padding:24px;text-align:center;cursor:pointer;color:#888;font-size:13px}.image-upload:hover{border-color:#e94560}.image-preview{max-width:300px;max-height:200px;border-radius:8px;margin-top:8px}.orders-table{width:100%;border-collapse:collapse}.orders-table th,.orders-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #0f3460;font-size:13px}.orders-table th{color:#888;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase}.status-pending{background:#e9456033;color:#e94560}.status-processing{background:#06f3;color:#6af}.status-completed{background:#06d6a033;color:#06d6a0}.empty-state{text-align:center;padding:48px 0;color:#666;font-size:14px}.error-msg{background:#e9456022;border:1px solid #e94560;color:#e94560;padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:16px}.product-form-scroll{max-height:calc(100vh - 80px);overflow-y:auto;padding-right:8px}.color-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.color-modal{background:#16213e;border:1px solid #0f3460;border-radius:10px;padding:20px;width:320px;max-width:90vw}.color-modal h3{font-size:15px;color:#e0e0e0;margin-bottom:12px}.color-modal-preview{width:100%;height:48px;border-radius:6px;border:2px solid #0f3460;margin-bottom:12px}.color-modal-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.color-modal-row label{width:42px;font-size:11px;color:#888;text-transform:uppercase;flex-shrink:0}.color-modal-row input[type=color]{width:36px;height:30px;border:none;background:none;cursor:pointer}.color-modal-row input[type=text],.color-modal-row input[type=number]{flex:1;padding:4px 6px;border:1px solid #0f3460;border-radius:4px;background:#1a1a3e;color:#e0e0e0;font-size:12px;font-family:monospace}.color-modal-inputs{display:flex;gap:4px;flex:1}.color-modal-inputs input{width:100%;padding:4px;border:1px solid #0f3460;border-radius:4px;background:#1a1a3e;color:#e0e0e0;font-size:12px;text-align:center}.color-modal-actions{display:flex;gap:8px;margin-top:14px;justify-content:flex-end}.angles-list{display:flex;flex-direction:column;gap:10px}.angle-card{background:#1a1a3e;border:1px solid #0f3460;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:10px}.angle-card-header{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.angle-name-input{width:140px;padding:4px 8px;border:1px solid #0f3460;border-radius:4px;background:#16213e;color:#e0e0e0;font-size:12px}.angle-thumb{width:80px;height:60px;object-fit:cover;border-radius:6px;background:#0f0f23}.angle-upload{width:80px;height:60px;border:2px dashed #0f3460;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#888;cursor:pointer}.angle-upload:hover{border-color:#e94560}.angle-actions{display:flex;gap:6px;align-items:center;margin-left:auto}.angle-principal{font-size:11px;color:#aaa;display:flex;align-items:center;gap:4px;cursor:pointer}.angle-mask-controls{border-top:1px solid #0f3460;padding-top:10px;display:flex;flex-direction:column;gap:8px}.angle-mask-controls .mask-preview-container{width:400px;height:400px;max-width:none}.angle-mask-row{display:flex;gap:8px;align-items:flex-end}.tint-toggle{display:flex!important;align-items:center;gap:8px;cursor:pointer;font-size:13px!important;text-transform:none!important;letter-spacing:0!important;color:#e0e0e0!important}.tint-toggle input[type=checkbox]{width:auto}.angle-add{border:2px dashed #0f3460;border-radius:8px;background:transparent;color:#888;padding:10px;cursor:pointer;font-size:13px}.angle-add:hover{border-color:#06d6a0;color:#06d6a0}.mask-preview-container{position:relative;width:400px;height:400px;border-radius:8px;overflow:hidden;background:#0f0f23;border:1px solid #0f3460}.mask-preview-img{width:100%;height:100%;display:block;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.mask-preview-rect{position:absolute;background:#06d6a033;border:2px solid #06d6a0;cursor:move;box-sizing:border-box}.mask-preview-label{position:absolute;top:2px;left:4px;font-size:9px;color:#06d6a0;text-transform:uppercase;pointer-events:none}.mask-preview-handle{position:absolute;right:-4px;bottom:-4px;width:10px;height:10px;background:#06d6a0;border-radius:2px;cursor:nwse-resize}.mask-preview-placeholder{border:2px dashed #0f3460;border-radius:8px;padding:24px;text-align:center;color:#666;font-size:12px}.svg-preview{margin-top:8px;max-width:200px;max-height:120px;background:#0f0f23;border:1px solid #0f3460;border-radius:6px;padding:8px;overflow:hidden}.svg-preview svg{width:100%;height:auto;fill:#e0e0e0}.asset-admin-upload{background:#16213e;border:1px solid #0f3460;border-radius:10px;padding:16px;margin-bottom:24px}.asset-admin-upload-form{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.asset-admin-cat-select{display:flex;flex-direction:column;gap:6px}.asset-admin-select,.asset-admin-input{padding:7px 10px;background:#1a1a2e;color:#e0e0e0;border:1px solid #0f3460;border-radius:6px;font-size:13px;outline:none}.asset-admin-select:focus,.asset-admin-input:focus{border-color:#e94560}.asset-admin-progress{height:6px;background:#1a1a2e;border-radius:3px;margin-top:12px;overflow:hidden}.asset-admin-progress-bar{height:100%;background:linear-gradient(90deg,#e94560,#06d6a0);border-radius:3px;transition:width .3s ease}.asset-admin-category{margin-bottom:24px}.asset-admin-cat-title{font-size:15px;color:#e94560;margin-bottom:10px;border-bottom:1px solid #0f3460;padding-bottom:6px}.asset-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.asset-admin-card{background:#16213e;border:1px solid #0f3460;border-radius:8px;overflow:hidden;transition:border-color .15s}.asset-admin-card:hover{border-color:#e94560}.asset-admin-card-inactive{opacity:.5}.asset-admin-card-img{position:relative;height:100px;background:#0f0f23}.asset-admin-card-img img{width:100%;height:100%;object-fit:cover}.asset-admin-card-badge{position:absolute;top:4px;right:4px;background:#e94560;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px}.asset-admin-card-body{padding:8px}.asset-admin-card-name{display:block;font-size:11px;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}.asset-admin-card-actions{display:flex;gap:4px}.asset-admin-btn{background:#1a1a3e;border:1px solid #0f3460;border-radius:4px;color:#aaa;font-size:10px;font-weight:600;padding:3px 6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.asset-admin-btn:hover{background:#0f3460;color:#e0e0e0}.asset-admin-btn-active{color:#06d6a0}.asset-admin-btn-inactive{color:#e94560}.asset-admin-btn-delete:hover{background:#e94560;color:#fff}.form-success{background:#06d6a026;border:1px solid #06d6a0;color:#06d6a0;padding:8px 14px;border-radius:6px;margin-bottom:14px;font-size:13px}.mobile-upload{min-height:100vh;min-height:100dvh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.mobile-upload-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0003;width:100%;max-width:400px;padding:28px 24px;animation:mobileCardIn .3s ease}@keyframes mobileCardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-upload-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px;font-size:18px;font-weight:700;color:#1a1a2e}.mobile-upload-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.mobile-upload-state h3{margin:0;font-size:20px;font-weight:700;color:#1a1a2e}.mobile-upload-state p{margin:0;font-size:14px;color:#666;line-height:1.5}.mobile-upload-camera-icon{margin-bottom:8px}.mobile-upload-code-icon{margin-bottom:4px}.mobile-upload-code-form{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}.mobile-upload-code-input{width:180px;text-align:center;font-size:32px;font-weight:800;letter-spacing:8px;padding:12px 16px;border:2px solid #e0e0e0;border-radius:14px;font-family:Courier New,monospace;text-transform:uppercase;outline:none;transition:border-color .2s}.mobile-upload-code-input:focus{border-color:#6c2fd2}.mobile-upload-code-error{color:#e94560;font-size:13px;font-weight:500}.mobile-upload-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;padding:14px 32px;font-size:16px;font-weight:700;cursor:pointer;width:100%;max-width:280px;transition:transform .15s,box-shadow .15s}.mobile-upload-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #667eea66}.mobile-upload-btn-primary:active{transform:translateY(0)}.mobile-upload-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.mobile-upload-btn-large{padding:18px 32px;font-size:17px;margin-top:8px}.mobile-upload-btn-secondary{background:#f5f5f8;color:#555;border:none;border-radius:14px;padding:14px 24px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.mobile-upload-btn-secondary:hover{background:#ebebf0}.mobile-upload-preview{width:100%;border-radius:14px;overflow:hidden;border:2px solid #e0e0e0;margin-bottom:4px}.mobile-upload-preview img{width:100%;max-height:300px;object-fit:contain;background:#f9f9f9;display:block}.mobile-upload-preview-actions{display:flex;gap:12px;width:100%;margin-top:4px}.mobile-upload-preview-actions .mobile-upload-btn-secondary,.mobile-upload-preview-actions .mobile-upload-btn-primary{flex:1;max-width:none}.mobile-upload-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#6c2fd2;border-radius:50%;animation:mobileSpin .7s linear infinite}@keyframes mobileSpin{to{transform:rotate(360deg)}}.mobile-upload-error-badge{width:56px;height:56px;border-radius:50%;background:#fee2e2;color:#e94560;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center}.mobile-upload-expired-badge{font-size:56px}.mobile-upload-done-badge{width:64px;height:64px;display:flex;align-items:center;justify-content:center}.mobile-upload-success-badge{animation:mobileSuccessPop .4s ease}@keyframes mobileSuccessPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.mobile-upload *{box-sizing:border-box}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#e0e0e0;overflow:hidden;height:100vh;-webkit-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}#root{height:100vh;display:flex;flex-direction:column}button{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .2s;touch-action:manipulation}button:hover{filter:brightness(1.1)}button,a,[role=button],.clickable{min-height:44px;min-width:44px}.layer-order-btn,.layer-delete,.layer-drag-handle,.shape-opt,.product-color-swatch,.hp-sidebar-close{min-height:unset;min-width:unset}input[type=color]{border:none;width:32px;height:32px;cursor:pointer;background:none;min-height:44px;min-width:44px}input[type=text],input[type=email],input[type=number],input[type=search],input[type=tel],input[type=url],textarea,select{font-size:16px;touch-action:manipulation}.scroll-touch{-webkit-overflow-scrolling:touch;overflow-y:auto}
