:root{--bg-primary:#000;--bg-secondary:#1d1d1f;--bg-tertiary:#2d2d30;--bg-card:#1c1c1e;--bg-card-hover:#2c2c2e;--text-primary:#f5f5f7;--text-secondary:#86868b;--text-muted:#6e6e73;--accent:#2997ff;--accent-hover:#0071e3;--accent-light:#2997ff26;--accent-dark:#0077ed;--success:#30d158;--error:#ff453a;--warning:#ffd60a;--border:#38383a;--border-light:#48484a;--shadow:0 4px 24px #0006;--shadow-lg:0 12px 48px #0009;--shadow-glow:0 0 60px #2997ff26;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-xl:32px;--font-display:-apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", sans-serif;--font-body:-apple-system, BlinkMacSystemFont, "SF Pro Text", sans-serif;--vh:1vh}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.main-content{flex:1;width:100%;max-width:680px;min-height:100vh;margin:0 auto;padding:0 20px 120px;overflow-x:hidden}.telegram-web-app{min-height:100vh;overflow-x:hidden}.page-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);margin-bottom:24px;font-size:34px;font-weight:700}.category-tabs{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;margin-bottom:32px;padding:4px;display:flex}.category-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px 8px;font-size:14px;font-weight:500;transition:all .3s;display:flex}.category-tab:hover{color:var(--text-primary)}.category-tab.active{background:var(--bg-card);color:var(--text-primary);font-weight:600;box-shadow:0 2px 8px #0000004d}.search-bar{margin-bottom:24px;position:relative}.search-input{background:var(--bg-tertiary);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);border:none;padding:14px 44px 14px 16px;font-size:15px;font-weight:400;transition:all .2s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 24px #e8c54726}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:var(--bg-card);color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.category-tab .emoji{font-size:18px}.subcategory-tabs{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;gap:8px;margin-bottom:20px;padding:6px;display:flex}.subcategory-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;padding:10px 14px;font-size:13px;font-weight:600;transition:all .25s}.subcategory-tab.active{background:var(--bg-secondary);color:var(--accent);border:1px solid var(--accent-light);box-shadow:0 2px 12px #e8c54726}.product-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.product-card{background:var(--bg-card);border-radius:var(--radius-md);cursor:pointer;transition:all .35s;position:relative;overflow:hidden}.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.product-image-wrapper{aspect-ratio:1;width:100%;position:relative;overflow:hidden}.product-image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.product-card:hover .product-image{transform:scale(1.08)}.product-emoji{aspect-ratio:1;background:linear-gradient(145deg, var(--bg-tertiary), var(--bg-secondary));justify-content:center;align-items:center;width:100%;font-size:64px;display:flex}.product-badge{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#000;z-index:2;border-radius:20px;padding:6px 12px;font-size:11px;font-weight:800;position:absolute;top:10px;right:10px;box-shadow:0 2px 12px #e8c54766}.product-info{text-align:center;padding:16px 12px}.product-name{color:var(--text-primary);text-align:center;letter-spacing:-.01em;font-size:15px;font-weight:600}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state .icon{opacity:.6;margin-bottom:16px;font-size:64px}.empty-state h2{color:var(--text-secondary);margin-bottom:8px;font-size:20px}.empty-state p{color:var(--text-muted);font-size:14px}.top-header{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;max-width:100vw;margin:0;padding:28px 16px 20px;display:flex;position:relative}.top-header:after{content:"";background:linear-gradient(90deg, transparent, var(--border), transparent);height:1px;position:absolute;bottom:0;left:16px;right:16px}.back-btn-header{background:linear-gradient(145deg, var(--bg-card), var(--bg-tertiary));border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .25s;display:flex;position:absolute;bottom:14px;left:0;box-shadow:0 4px 16px #0000004d}.back-btn-header:hover{background:var(--accent);color:#000;transform:scale(1.08);box-shadow:0 4px 24px #e8c54766}.top-logo{object-fit:contain;filter:drop-shadow(0 2px 8px #e8c5474d);height:32px}.product-detail-page{padding:0}.product-detail-page .back-btn{display:none}.product-detail{background:linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);border-radius:var(--radius-lg);border:1px solid var(--border);margin:0 -16px 20px;padding:24px}.detail-image-wrapper{border-radius:var(--radius-md);margin-bottom:24px;position:relative;overflow:hidden}.detail-image{aspect-ratio:1;object-fit:cover;width:100%;display:block}.detail-emoji{aspect-ratio:1;background:linear-gradient(145deg, var(--bg-tertiary), var(--bg-secondary));border-radius:var(--radius-md);border:2px solid var(--border);justify-content:center;align-items:center;width:100%;margin-bottom:24px;font-size:160px;display:flex;box-shadow:inset 0 0 60px #0000004d}.detail-header{text-align:center}.detail-name{font-family:var(--font-display);background:linear-gradient(135deg, #fff, var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:28px;font-weight:900}.product-desc{color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border);text-align:left;margin-bottom:24px;padding:16px;font-size:14px;line-height:1.7}.price-buttons{justify-content:center;gap:12px;margin-bottom:24px;display:flex}.price-btn{background:linear-gradient(145deg, var(--bg-card), var(--bg-tertiary));border:2px solid var(--border);min-width:80px;color:var(--text-primary);cursor:pointer;border-radius:14px;padding:16px 24px;font-size:16px;font-weight:800;transition:all .3s cubic-bezier(.4,0,.2,1)}.price-btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #e8c54733}.price-btn.selected{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#000;border-color:var(--accent);box-shadow:var(--shadow-glow);transform:scale(1.05)}.detail-price{font-family:var(--font-display);color:var(--accent);text-shadow:0 0 40px #e8c54766;margin-bottom:20px;font-size:40px;font-weight:900;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.order-btn{background:var(--accent);border-radius:var(--radius-sm);color:#fff;cursor:pointer;border:none;width:100%;padding:18px;font-size:17px;font-weight:600;transition:all .25s}.order-btn:hover{background:var(--accent-hover)}.order-btn:active{transform:scale(.98)}.detail-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}.detail-section h2{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px;font-size:13px;font-weight:700}.flavors-list{flex-wrap:wrap;gap:10px;display:flex}.flavor-tag{background:linear-gradient(145deg, var(--bg-card), var(--bg-tertiary));border:1px solid var(--border);color:var(--text-secondary);border-radius:24px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .2s}.flavor-tag:hover{border-color:var(--accent-light);color:var(--accent)}.ratio-bar{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;height:44px;position:relative;overflow:hidden}.ratio-divider{background:#ffffff4d;width:3px;position:absolute;top:0;bottom:0}.ratio-fill-sativa{background:linear-gradient(90deg,#22c55e,#4ade80);transition:width .5s;position:absolute;top:0;bottom:0;left:0}.ratio-fill-indica{background:linear-gradient(90deg,#a855f7,#c084fc);transition:width .5s;position:absolute;top:0;bottom:0;right:0}.ratio-label{color:#fff;text-shadow:0 1px 4px #0009;font-size:12px;font-weight:800;position:absolute;top:50%;transform:translateY(-50%)}.crypto-section{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border);padding:16px}.crypto-select{background:linear-gradient(145deg, var(--bg-card), var(--bg-secondary));border:2px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;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='%23a0a0b0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border-radius:12px;margin-bottom:16px;padding:16px;font-size:15px;font-weight:700}.crypto-select:focus{border-color:var(--accent);outline:none}.crypto-amount{text-align:center;color:var(--accent);background:var(--bg-secondary);border:2px solid var(--accent-light);border-radius:12px;padding:16px;font-size:22px;font-weight:800;box-shadow:inset 0 0 20px #e8c5471a}.navbar{background:var(--bg-primary);-webkit-backdrop-filter:blur(20px);border-top:.5px solid var(--border);z-index:100;justify-content:space-around;max-width:680px;margin:0 auto;padding:8px 8px 28px;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);border-radius:var(--radius-sm);border-radius:14px;flex-direction:column;align-items:center;padding:8px 16px;text-decoration:none;transition:all .2s;display:flex}.nav-item svg{width:26px;height:26px;margin-bottom:4px;transition:all .2s}.nav-item span{font-size:11px;font-weight:700}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--accent)}.nav-item.active svg{filter:drop-shadow(0 0 12px #e8c54799);transform:scale(1.1)}.payment-modal{z-index:1000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000eb;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.payment-modal-content{background:linear-gradient(180deg, var(--bg-secondary), var(--bg-primary));border-radius:var(--radius-lg);text-align:center;border:2px solid var(--border);width:90%;max-width:380px;box-shadow:var(--shadow-lg);padding:32px;animation:.4s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.payment-modal-content h2{color:var(--text-primary);margin-bottom:16px;font-size:26px;font-weight:900}.payment-amount{margin-bottom:8px;font-size:32px;font-weight:900}.payment-chf{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.qr-code{background:#fff;border-radius:16px;margin:24px auto;padding:20px;display:inline-block;box-shadow:0 8px 32px #0000004d}.qr-code img{display:block}.pay-now-btn{cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:14px;width:100%;margin-bottom:14px;padding:18px;font-size:16px;font-weight:800;transition:all .25s}.pay-now-btn.solana-btn{color:#fff;background:linear-gradient(135deg,#9945ff,#14f195);box-shadow:0 8px 32px #9945ff66}.pay-now-btn.btc-btn{color:#000;background:linear-gradient(135deg,#f7931a,#ffc107);box-shadow:0 8px 32px #f7931a66}.pay-now-btn.eth-btn{color:#fff;background:linear-gradient(135deg,#627eea,#8c9eff);box-shadow:0 8px 32px #627eea66}.pay-now-btn.bnb-btn{color:#000;background:linear-gradient(135deg,#f3ba2f,#fcc669);box-shadow:0 8px 32px #f3ba2f66}.pay-now-btn:hover{transform:translateY(-2px)}.payment-done-btn{background:var(--bg-tertiary);border:2px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;border-radius:14px;padding:16px;font-size:14px;font-weight:700;transition:all .2s}.payment-done-btn:hover{background:var(--bg-card);color:var(--text-primary)}.orders-page{padding:0}.orders-page .page-title{margin-bottom:24px}.orders-list{flex-direction:column;gap:16px;display:flex}.order-card{background:linear-gradient(160deg, var(--bg-card), var(--bg-secondary));border-radius:var(--radius-md);border:1px solid var(--border);padding:20px;transition:all .3s}.order-card:hover{border-color:var(--border-light);box-shadow:var(--shadow)}.order-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.order-id{color:var(--text-primary);font-size:18px;font-weight:800}.order-date{color:var(--text-muted);margin-top:4px;font-size:12px}.status-badge{border:1px solid;border-radius:24px;padding:8px 16px;font-size:12px;font-weight:800}.order-items{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0}.order-item{align-items:center;gap:14px;padding:10px 0;display:flex}.order-item .item-quantity{color:var(--accent);min-width:55px;font-size:14px;font-weight:800}.order-item .item-name{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.order-item .item-price{color:var(--text-secondary);font-size:14px;font-weight:700}.order-footer{justify-content:space-between;align-items:center;margin-top:16px;display:flex}.crypto-payment{align-items:center;gap:10px;font-size:13px;display:flex}.crypto-label{color:var(--text-muted)}.crypto-value{color:var(--accent);font-family:monospace;font-weight:700}.order-total{color:var(--accent);font-size:20px;font-weight:900}.account-page{text-align:center;padding:24px 20px}.account-avatar{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 20px;font-size:40px;font-weight:500;display:flex}.account-name{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:4px;font-size:28px;font-weight:600}.account-id{color:var(--text-muted);margin-bottom:28px;font-size:16px}.account-info-card{background:linear-gradient(160deg, var(--bg-card), var(--bg-secondary));border-radius:var(--radius-md);border:1px solid var(--border);text-align:left;margin-bottom:20px;padding:20px}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:14px 0;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-muted);font-size:14px;font-weight:600}.info-value{color:var(--text-primary);font-size:14px;font-weight:700}.info-value.premium{color:var(--accent)}.wallet-card{background:linear-gradient(160deg, var(--bg-card), var(--bg-secondary));border-radius:var(--radius-md);border:1px solid var(--border);text-align:left;margin-top:20px;padding:24px}.wallet-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.wallet-icon{font-size:28px}.address-card{background:linear-gradient(160deg, var(--bg-card), var(--bg-secondary));border-radius:var(--radius-md);border:1px solid var(--border);text-align:left;margin-top:20px;padding:24px}.address-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.address-icon{font-size:28px}.address-title{color:var(--text-primary);font-size:20px;font-weight:800}.address-saved{background:var(--bg-tertiary);border:1px solid var(--accent-light);border-radius:14px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:16px;display:flex}.address-text{color:var(--accent);font-size:16px;font-weight:600}.address-actions{gap:10px;display:flex}.address-edit-btn{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#000;cursor:pointer;border:none;border-radius:12px;flex:1;padding:14px 20px;font-size:14px;font-weight:800}.address-remove-btn{border:2px solid var(--error);color:var(--error);cursor:pointer;background:0 0;border-radius:12px;padding:14px 18px;font-size:14px;font-weight:700}.address-add-btn{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#000;cursor:pointer;border:none;border-radius:14px;width:100%;padding:18px;font-size:16px;font-weight:800}.wallet-title{color:var(--text-primary);font-size:20px;font-weight:800}.wallet-desc{color:var(--text-muted);margin-bottom:20px;font-size:14px;line-height:1.6}.wallet-input-group{gap:12px;display:flex}.wallet-input{background:var(--bg-tertiary);border:2px solid var(--border);color:var(--text-primary);border-radius:14px;flex:1;padding:16px;font-size:14px;transition:all .2s}.wallet-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 20px #e8c54733}.wallet-save-btn{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#000;cursor:pointer;white-space:nowrap;border:none;border-radius:14px;padding:16px 24px;font-weight:800;transition:all .25s}.wallet-save-btn:hover{box-shadow:var(--shadow-glow);transform:scale(1.05)}.wallet-saved{background:var(--bg-tertiary);border:1px solid var(--accent-light);border-radius:14px;align-items:center;gap:12px;margin-top:20px;padding:16px;display:flex}.wallet-saved-label{color:var(--text-muted);font-size:13px}.wallet-address{color:var(--accent);flex:1;font-family:monospace;font-size:13px}.wallet-clear-btn{border:1px solid var(--error);color:var(--error);cursor:pointer;background:0 0;border-radius:10px;padding:8px 14px;font-size:12px;font-weight:700;transition:all .2s}.wallet-clear-btn:hover{background:var(--error);color:#fff}.loading{justify-content:center;align-items:center;padding:60px;display:flex}.spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.product-card{animation:.4s backwards slideInUp}.product-card:first-child{animation-delay:50ms}.product-card:nth-child(2){animation-delay:.1s}.product-card:nth-child(3){animation-delay:.15s}.product-card:nth-child(4){animation-delay:.2s}.order-card{animation:.4s slideInUp}.admin-page{padding:0}.admin-page .page-title{margin-bottom:24px}.admin-stats{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px;display:grid}.admin-stat-card{background:linear-gradient(160deg, var(--bg-card), var(--bg-secondary));border-radius:var(--radius-md);border:1px solid var(--border);text-align:center;padding:20px}.admin-stat-value{color:var(--accent);font-size:32px;font-weight:900}.admin-stat-label{color:var(--text-muted);margin-top:4px;font-size:12px}.delete-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg, var(--error), #dc2626);border:none;border-radius:12px;padding:12px 20px;font-size:13px;font-weight:700;transition:all .2s}.delete-btn:hover{transform:scale(1.05)}.location-page{text-align:center;padding:20px}.location-fullscreen{background:var(--bg-primary);z-index:200;padding:20px 24px;padding-bottom:max(20px, env(safe-area-inset-bottom,20px));-webkit-overflow-scrolling:touch;min-height:calc(var(--vh,1vh) * 100);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden auto}.location-fullscreen .location-header{margin-bottom:32px}.location-fullscreen .location-icon{font-size:64px}.location-fullscreen .location-page h1{font-size:28px}.location-fullscreen .location-form{width:100%;max-width:400px;margin:0 auto}.location-fullscreen .form-input{padding:18px;font-size:16px}.location-fullscreen .submit-btn{padding:20px;font-size:18px}.location-fullscreen .form-group{margin-bottom:16px}.location-header{margin-bottom:32px}.location-icon{margin-bottom:16px;font-size:64px;animation:3s ease-in-out infinite float}.location-page h1{font-family:var(--font-display);background:linear-gradient(135deg, #fff, var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:28px;font-weight:900}.location-subtitle{color:var(--text-muted);font-size:14px}.location-form{text-align:left}.location-form .form-group{margin-bottom:20px;position:relative}.location-form label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.input-wrapper{position:relative}.form-input{background:linear-gradient(145deg, var(--bg-tertiary), var(--bg-secondary));border:2px solid var(--border);width:100%;color:var(--text-primary);border-radius:14px;padding:18px;font-size:16px;font-weight:600;transition:all .25s}.form-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 24px #e8c54733}.form-input::placeholder{color:var(--text-muted)}.input-loading{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.suggestions-list{background:var(--bg-secondary);border:2px solid var(--border);z-index:10;border-radius:14px;max-height:200px;margin-top:-4px;list-style:none;position:relative;overflow-y:auto}.suggestion-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 18px;transition:background .2s;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--bg-tertiary)}.suggestion-postal{color:var(--accent);min-width:45px;font-weight:800}.suggestion-city{color:var(--text-primary);flex:1}.suggestion-canton{color:var(--text-muted);font-size:12px;font-weight:600}.location-confirmed{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent);border-radius:14px;align-items:center;gap:10px;margin-bottom:20px;padding:16px;font-weight:600;display:flex}.check-icon{font-weight:900}.error-message{color:var(--error);margin-bottom:16px;font-size:13px}.form-input.error{border-color:var(--error)}.input-error-text{color:var(--error);margin-top:6px;font-size:12px}.submit-btn{background:linear-gradient(135deg, var(--accent), var(--accent-dark));border-radius:var(--radius-md);color:#000;cursor:pointer;width:100%;box-shadow:var(--shadow-glow);text-transform:uppercase;letter-spacing:1px;border:none;padding:20px;font-size:18px;font-weight:900;transition:all .3s}.submit-btn:hover{transform:translateY(-3px);box-shadow:0 0 50px #e8c54780}@media (width>=768px){.main-content{padding:0 40px 120px}.product-grid{grid-template-columns:repeat(3,1fr);gap:20px}.product-detail{border-radius:var(--radius-lg);margin:0}.admin-stats{grid-template-columns:repeat(4,1fr)}}.loading-page{justify-content:center;align-items:center;min-height:60vh;padding:40px;display:flex}.loading-spinner-container{text-align:center}.loading-spinner-container p{color:var(--text-muted);margin-top:16px;font-size:14px}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:0 auto;animation:.8s linear infinite spin}.page-transition{animation:.3s fadeInPage}@keyframes fadeInPage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-transition-enter{opacity:0;transform:translate(20px)}.page-transition-enter-active{opacity:1;transition:opacity .3s,transform .3s;transform:translate(0)}.page-transition-exit{opacity:1;transform:translate(0)}.page-transition-exit-active{opacity:0;transition:opacity .3s,transform .3s;transform:translate(-20px)}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-tertiary) 50%, var(--bg-card) 75%);background-size:200% 100%;border-radius:8px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);height:180px}.skeleton-text{height:16px;margin:10px 16px}.skeleton-text.short{width:60%}.pull-to-refresh{z-index:1000;pointer-events:none;justify-content:center;align-items:center;height:50px;display:flex;position:fixed;top:0;left:0;right:0}.pull-to-refresh-indicator{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:30px;height:30px;animation:.8s linear infinite spin}.toast-container{z-index:10000;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:100px;left:50%;transform:translate(-50%)}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);text-align:center;max-width:90vw;padding:14px 20px;animation:.3s toastIn}.toast-error{border-color:var(--error);background:linear-gradient(160deg, var(--bg-card), #f854541a)}.toast-success{border-color:var(--success);background:linear-gradient(160deg, var(--bg-card), #3ce0861a)}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.btn:active{transform:scale(.97)}.product-card:active{transform:scale(.98)}input:focus,button:focus{outline:none}input:focus-visible,button:focus-visible{box-shadow:0 0 0 2px var(--accent)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.touch-optimized{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.no-scroll{width:100%;height:100%;position:fixed;overflow:hidden}
