.skeleton-item{pointer-events:none;user-select:none}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-box{width:100%;height:100%;background:linear-gradient(90deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:12px}.skeleton-text{background:linear-gradient(90deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes skeleton-pulse{0%,100%{opacity:1}50%{opacity:.7}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.fade-in-item{opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.fade-in-item.visible{opacity:1;transform:translateY(0)}.shop-item-image img{opacity:0;transition:opacity .3s ease}.shop-item-image img.loaded{opacity:1}.shop-item-image img:not(.loaded){background:linear-gradient(90deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.shop-redeem-modal{background:var(--bg-card);border-radius:20px;padding:30px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.8);position:relative;animation:slideUp .3s ease}.modal-close-btn{position:absolute;top:15px;right:15px;background:rgba(255,255,255,.1);border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:18px}.modal-close-btn:hover{background:var(--primary);transform:rotate(90deg)}.redeem-modal-header{text-align:center;margin-bottom:25px}.redeem-modal-header i{font-size:48px;color:var(--primary);margin-bottom:15px}.redeem-modal-header h2{font-size:24px;color:var(--text-primary);margin:0}.redeem-item-preview{display:flex;gap:20px;padding:20px;background:rgba(0,0,0,.3);border-radius:12px;margin-bottom:20px}.redeem-item-preview .item-placeholder,.redeem-item-preview img{width:120px;height:120px;object-fit:cover;border-radius:8px;flex-shrink:0}.redeem-item-preview .item-placeholder{background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--primary)}.redeem-item-info{flex:1}.redeem-item-info h3{font-size:18px;color:var(--text-primary);margin-bottom:8px}.redeem-item-info p{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.redeem-item-price{display:flex;align-items:center;gap:8px;color:var(--primary);font-size:18px;font-weight:700}.redeem-item-price i{font-size:20px}.redeem-user-info{background:rgba(0,0,0,.3);border-radius:12px;padding:20px;margin-bottom:20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0}.info-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,.1)}.info-label{color:var(--text-secondary);font-size:14px}.info-value{color:var(--text-primary);font-weight:700;font-size:16px}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.redeem-form{margin-bottom:20px}.redeem-form label{display:block;margin-bottom:8px;color:var(--text-secondary);font-size:14px;font-weight:600}.redeem-form textarea{width:100%;padding:12px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.2);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;transition:all .3s ease}.redeem-form textarea:focus{outline:0;border-color:var(--primary);background:rgba(0,0,0,.5)}.redeem-warning{display:flex;gap:12px;padding:15px;background:rgba(255,165,0,.1);border:1px solid rgba(255,165,0,.3);border-radius:8px;margin-bottom:20px}.redeem-warning i{color:orange;font-size:20px;flex-shrink:0;margin-top:2px}.redeem-warning p{color:var(--text-secondary);font-size:14px;margin:0;line-height:1.5}.redeem-actions{display:flex;gap:12px;justify-content:flex-end}.redeem-actions .btn{padding:12px 24px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.redeem-actions .btn-secondary{background:rgba(255,255,255,.1);color:var(--text-primary)}.redeem-actions .btn-secondary:hover{background:rgba(255,255,255,.2)}.redeem-actions .btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.redeem-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px rgba(220,38,38,.5)}.shop-item.out-of-stock{opacity:.6}.shop-item.out-of-stock .shop-item-image{filter:grayscale(.5)}.shop-item-stock{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:600;margin:10px 0;transition:all .3s ease}.shop-item-stock i{font-size:16px}.shop-item-stock.stock-unlimited{background:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.2)}.shop-item-stock.stock-normal{background:rgba(59,130,246,.1);color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.shop-item-stock.stock-low{background:rgba(249,115,22,.1);color:#f97316;border:1px solid rgba(249,115,22,.2);animation:pulse-stock 2s ease-in-out infinite}@keyframes pulse-stock{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.shop-item.out-of-stock .shop-item-stock{background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.2)}.shop-empty-state{text-align:center;padding:60px 20px;grid-column:1/-1}.shop-empty-state i{font-size:64px;color:rgba(220,38,38,.3);margin-bottom:20px}.shop-empty-state h3{font-size:24px;color:var(--text-primary);margin-bottom:10px}.shop-empty-state p{font-size:16px;color:var(--text-secondary)}@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@media (max-width:768px){.shop-redeem-modal{padding:20px;width:95%}.redeem-item-preview{flex-direction:column;align-items:center;text-align:center}.redeem-item-preview .item-placeholder,.redeem-item-preview img{width:100%;max-width:200px;height:200px}.redeem-actions{flex-direction:column}.redeem-actions .btn{width:100%;justify-content:center}.shop-item-stock{font-size:13px;padding:6px 10px}.shop-item-stock i{font-size:14px}}.shop-item-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:15px}.shop-item-badge.new{background:linear-gradient(135deg,#10b981,#059669)}.shop-item-badge.limited{background:linear-gradient(135deg,#f59e0b,#d97706)}.shop-item-badge.popular{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.mini-player{position:fixed;bottom:20px;right:20px;width:360px;height:220px;background:var(--bg-card);border:2px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.8);z-index:9998;overflow:hidden;transition:all .3s ease;cursor:move}.mini-player.large{width:480px;height:300px}.mini-player-header{background:var(--bg-secondary);padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);cursor:move}.mini-player-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.mini-player-title i{color:#9146ff;font-size:16px}.mini-player-live{background:linear-gradient(135deg,red,#c00);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;animation:pulse 2s infinite}.mini-player-controls{display:flex;gap:4px}.mini-player-btn{background:0 0;border:none;color:var(--text-secondary);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:12px}.mini-player-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.mini-player-content{width:100%;height:calc(100% - 40px);position:relative}.mini-player-content iframe{width:100%;height:100%;border:none}.live-indicator{display:inline-flex;align-items:center;gap:6px;margin-left:12px;padding:4px 10px;background:rgba(255,0,0,.1);border:1px solid rgba(255,0,0,.3);border-radius:20px;animation:slideIn .4s ease}.live-indicator-dot{width:8px;height:8px;background:red;border-radius:50%;animation:blink 1.5s infinite;box-shadow:0 0 10px rgba(255,0,0,.8)}.live-indicator-text{font-size:12px;font-weight:700;color:red;text-transform:uppercase;letter-spacing:.5px}@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,0,0,.7)}50%{box-shadow:0 0 0 4px rgba(255,0,0,0)}}@keyframes slideIn{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.mini-player{width:280px;height:180px;bottom:80px;right:10px}.mini-player.large{width:320px;height:200px}.live-indicator{padding:3px 8px;margin-left:8px}.live-indicator-text{font-size:10px}.live-indicator-dot{width:6px;height:6px}}@media (max-width:480px){.mini-player{width:calc(100% - 20px);max-width:280px;height:160px}.mini-player.large{max-width:320px;height:180px}}