.product-card{position:relative;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.product-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.product-card__ribbons{position:absolute;top:12px;left:12px;z-index:10;display:flex;flex-direction:column;gap:6px}.ribbon{display:inline-block;padding:4px 12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;box-shadow:0 2px 4px #0000001a}.ribbon-new{background:#4caf50;color:#fff}.ribbon-sale{background:#f44336;color:#fff}.ribbon-clearance{background:#ff5722;color:#fff}.ribbon-pre-order{background:#2196f3;color:#fff}.ribbon-custom-sale{background:#9c27b0;color:#fff}.product-card__image-wrapper{position:relative;padding-bottom:100%;overflow:hidden;background:#f8f8f8}.product-card__image-link{position:absolute;top:0;left:0;width:100%;height:100%}.product-card__image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.product-card__image--main{z-index:2;opacity:1}.product-card__image--hover{z-index:1;opacity:0}.product-card__quick-view{position:absolute;top:12px;right:12px;z-index:10;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:50%;cursor:pointer;opacity:0;transform:translateY(-10px);transition:all .3s ease;box-shadow:0 2px 8px #00000026}.product-card:hover .product-card__quick-view{opacity:1;transform:translateY(0)}.product-card__quick-view:hover{background:#f5f5f5}.product-card__wishlist{position:absolute;bottom:12px;right:12px;z-index:10;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #00000026}.product-card__wishlist:hover,.product-card__wishlist.active{background:#f44336;color:#fff}.product-card__wishlist.active .icon{fill:#fff}.stock-status{position:absolute;bottom:12px;left:12px;padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;border-radius:4px;z-index:5}.stock-status--out{background:#f44336;color:#fff}.stock-status--low{background:#ff9800;color:#fff}.stock-status--selling-fast{background:#ffc107;color:#333}.product-card__pre-order{position:absolute;bottom:12px;left:12px;padding:6px 12px;background:#2196f3f2;color:#fff;border-radius:4px;font-size:12px;z-index:5}.product-card__pre-order small{display:block;font-size:10px;opacity:.9;margin-top:2px}.product-card__info{padding:16px;display:flex;flex-direction:column;gap:8px}.product-card__categories{display:flex;gap:8px;flex-wrap:wrap}.product-card__category{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.5px;text-decoration:none;transition:color .2s}.product-card__category:hover{color:#333}.product-card__title{margin:0;font-size:16px;font-weight:600;line-height:1.4}.product-card__title a{color:#333;text-decoration:none;transition:color .2s}.product-card__title a:hover{color:#2196f3}.product-card__reviews{display:flex;align-items:center;gap:6px}.star-rating{display:flex;gap:2px}.star{width:14px;height:14px}.star--filled{fill:#ffc107}.star{fill:#e0e0e0}.review-count{font-size:12px;color:#666}.product-card__sku{font-size:12px;color:#999}.product-card__description{font-size:14px;color:#666;line-height:1.6;margin:0}.product-card__price-wrapper{margin-top:4px}.product-card__prices{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.price{font-weight:700;font-size:18px;color:#333}.price--old{font-size:14px;color:#999;text-decoration:line-through;font-weight:400}.price--sale{color:#f44336}.price__badge{display:inline-block;padding:2px 8px;background:#f44336;color:#fff;font-size:11px;font-weight:600;border-radius:3px}.product-card__bulk-pricing{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#e3f2fd;border-radius:4px;font-size:12px;color:#1976d2}.product-card__bulk-pricing .icon{flex-shrink:0}.product-card__free-freight{display:flex;align-items:center;gap:6px;font-size:12px;color:#4caf50;font-weight:600}.product-card__swatches{display:flex;flex-direction:column;gap:10px;margin-top:8px}.swatches{display:flex;flex-direction:column;gap:6px}.swatches__label{font-size:12px;font-weight:600;color:#666}.swatches__items{display:flex;gap:6px;flex-wrap:wrap}.swatch{border:2px solid #e0e0e0;background:#fff;cursor:pointer;transition:all .2s ease;padding:0}.swatch:hover,.swatch.active{border-color:#2196f3}.swatch--color{width:28px;height:28px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:600}.swatch--text{min-width:32px;height:28px;padding:0 10px;border-radius:4px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.product-card__actions{display:flex;gap:8px;margin-top:12px}.quantity-selector{display:flex;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.qty-btn{width:32px;height:40px;border:none;background:#f5f5f5;cursor:pointer;font-size:16px;font-weight:600;transition:background .2s}.qty-btn:hover{background:#e0e0e0}.qty-input{width:50px;height:40px;border:none;border-left:1px solid #e0e0e0;border-right:1px solid #e0e0e0;text-align:center;font-size:14px;font-weight:600}.qty-input:focus{outline:none}.btn{flex:1;height:40px;padding:0 16px;display:flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--add-to-cart{background:#2196f3;color:#fff}.btn--add-to-cart:hover{background:#1976d2}.btn--out-of-stock{background:#e0e0e0;color:#999;cursor:not-allowed}.btn--notify{background:#fff;color:#2196f3;border:1px solid #2196F3}.btn--notify:hover{background:#e3f2fd}.product-card__quick-add{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);opacity:0;transform:translateY(10px);transition:all .3s ease}.product-card:hover .product-card__quick-add{opacity:1;transform:translateY(0)}.btn--quick-add{width:100%;background:#fff;color:#333;height:36px}.btn--quick-add:hover{background:#2196f3;color:#fff}.product-card--list{flex-direction:row}.product-card--list .product-card__image-wrapper{width:250px;padding-bottom:0;flex-shrink:0}.product-card--list .product-card__info{flex:1;padding:20px}.product-card--list .product-card__title{font-size:20px}.product-card--list .product-card__actions{margin-top:auto}.product-card--featured .product-card__title{font-size:18px}.product-card--featured .price{font-size:22px}.product-card--compact .product-card__info{padding:12px}.product-card--compact .product-card__title{font-size:14px}.product-card--compact .price{font-size:16px}.product-card__categories,.product-card__category{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card__title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4;max-height:2.8em}.price--login-required:after{content:"Login for pricing"}[x-ref=track]::-webkit-scrollbar{display:none}.product-card__image-wrapper{aspect-ratio:1 / 1;overflow:hidden}.product-card__image-wrapper img,.product-card__image-wrapper picture,.product-card__image-wrapper picture img{width:100%;height:100%;object-fit:cover}@media(max-width:768px){.product-card--list{flex-direction:column}.product-card--list .product-card__image-wrapper{width:100%;padding-bottom:100%}.product-card__actions{flex-direction:column}.quantity-selector{width:100%}}[data-wishlist],.product-card__wishlist,button[onclick*=wishlist-toggle]{cursor:pointer!important}[data-wishlist].in-wishlist svg,.product-card__wishlist.in-wishlist svg,.product-card__wishlist.active svg{fill:currentColor;color:#ef4444}.product-card__quick-actions button,.product-card__action-btn{cursor:pointer}.btn--add-to-cart.loading,.btn--quick-add.loading,[data-add-to-cart].loading{pointer-events:none;opacity:.7}#toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.75rem 1rem;border-radius:.5rem;box-shadow:0 4px 12px #00000026;color:#fff;font-size:.875rem;font-weight:500;transform:translate(0);opacity:1;transition:transform .3s ease,opacity .3s ease}.toast.translate-x-full{transform:translate(100%)}.toast.opacity-0{opacity:0}.cart-count.animate-pulse,.wishlist-count.animate-pulse{animation:pulse .6s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}
