 @keyframes slideUp {
            from {
                opacity: 0;
                transform: translateY(100%);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }
        
        /* Mobile/Tablet-First Responsive Enhancements - Extended to 1024px */
        @media (max-width: 1023.98px) {
            #pwa-install-banner {
                bottom: 70px !important; /* Position above bottom nav (64px + 6px gap) */
                border-radius: 1rem;
                padding: 1rem;
                margin: 0 0.5rem;
                left: 0 !important;
                right: 0 !important;
            }
            
            /* Improve touch targets */
            .btn {
                min-height: 44px;
            }
            
            /* Better spacing for mobile/tablet */
            .container {
                padding-left: 1rem;
                padding-right: 1rem;
            }
            
            /* Reduce header padding on mobile/tablet */
            #header {
                padding-top: 0.5rem !important;
                padding-bottom: 0.5rem !important;
            }
            
            #header .container-xxl {
                padding-left: 0.75rem !important;
                padding-right: 0.75rem !important;
            }
            
            /* Reduce search field spacing on mobile/tablet */
            #header .header-search {
                margin-top: 0 !important;
            }
            
            #header .header-search .input-group {
                margin-bottom: 0.5rem !important;
            }
            
            /* Reduce spacing between header elements on mobile/tablet */
            #header .row > [class*="col-"] {
                margin-top: 0.5rem !important;
            }
            
            #header .row > [class*="col-"]:first-child {
                margin-top: 0 !important;
            }
            
            /* Reduce logo size slightly for better fit */
            #header .logo img {
                max-height: 48px !important;
            }
            
            /* Tighter header controls spacing */
            #header .header-ctn {
                gap: 0.75rem !important;
                margin-top: 0 !important;
            }
            
            #header .header-ctn span.d-block {
                font-size: 0.7rem !important;
                margin-top: 0.25rem !important;
            }
        }
        
        @media (min-width: 1024px) {
            #pwa-install-banner {
                bottom: 1rem !important;
                left: 1rem !important;
                right: auto !important;
                max-width: 400px;
                border-radius: 1rem;
                border: 1px solid rgba(0,0,0,0.1);
            }
        }


        .category-item:hover .category-circle {
                    border-color: #0046be !important;
                    box-shadow: 0 0.25rem 0.5rem rgba(0, 70, 190, 0.3) !important;
                }
                .category-item:hover .category-img {
                    transform: scale(1.1);
                }
                .category-item:hover span {
                    color: #0046be !important;
                }
                .fade-in {
                    animation: fadeInUp 0.3s ease-out forwards;
                }
                @keyframes fadeInUp {
                    from {
                        opacity: 0;
                        transform: translateY(10px);
                    }
                    to {
                        opacity: 1;
                        transform: translateY(0);
                    }
                }
/* CTA Button Hover Effect */
    .btn.rounded-pill:hover {
        background-color: #0046be !important;
        color: white !important;
        transform: scale(0.98);
    }
    
    .btn.rounded-pill:active {
        transform: scale(0.95);
    }

 /* Product Card Hover Effects */
            .product-item:hover {
                box-shadow: 0 0.5rem 1rem rgba(0, 70, 190, 0.15) !important;
            }
            
            .product-item:hover .product-img {
                transform: scale(1.05);
            }
            
            .product-card a:hover {
                text-decoration: none !important;
            }
            
            /* Wishlist Button Hover */
            .add-to-wishlist:hover {
                background-color: #f8f9fa !important;
            }
            
            .add-to-wishlist.active i {
                color: #dc3545 !important;
            }
            
            /* View Toggle Buttons */
            .view-toggle {
                background: transparent;
                border: none;
                color: #6c757d;
                padding: 0.375rem 0.75rem;
                transition: all 0.2s;
            }
            
            .view-toggle.active {
                background: white;
                color: #0046be;
                box-shadow: 0 1px 3px rgba(0,0,0,0.1);
            }
            
            .view-toggle:hover:not(.active) {
                color: #495057;
            }
            
            /* Mobile Optimization for Grid View */
            @media (max-width: 767px) {
                .products-grid-view .mt-2 > .d-flex {
                    flex-direction: column !important;
                    align-items: flex-start !important;
                    gap: 0.5rem !important;
                }
                
                .products-grid-view .d-flex.gap-2 {
                    width: 100%;
                    justify-content: flex-start !important;
                }
                
                .products-grid-view .d-flex.gap-2 button {
                    width: 32px !important;
                    height: 32px !important;
                }
                
                .products-grid-view .d-flex.gap-2 button i {
                    font-size: 0.7rem !important;
                }
            }
            
            /* List View Styles */
            .products-list-view .product-card {
                width: 100%;
                flex: 0 0 100%;
                max-width: 100%;
            }
            
            .products-list-view .product-card > a {
                display: flex;
                width: 100%;
            }
            
            .products-list-view .product-item {
                flex-direction: row !important;
                height: auto !important;
                border-radius: 0.75rem !important;
                padding: 0.75rem !important;
                width: 100% !important;
            }
            
            .products-list-view .product-item .bg-light.overflow-hidden {
                width: 96px !important;
                height: 96px !important;
                min-width: 96px !important;
                max-width: 96px !important;
                flex-shrink: 0;
                border-radius: 0.5rem !important;
                aspect-ratio: unset !important;
                position: relative !important;
            }
            
            .products-list-view .product-item .bg-light.overflow-hidden .product-img {
                width: 100% !important;
                height: 100% !important;
                object-fit: contain !important;
            }
            
            .products-list-view .product-item .card-body {
                flex: 1;
                display: flex;
                flex-direction: column;
                justify-content: center;
                padding: 0 0 0 0.75rem !important;
            }
            
            .products-list-view .product-item .card-title {
                font-size: 0.875rem !important;
                font-weight: 700 !important;
                line-height: 1.2 !important;
                height: auto !important;
                margin-bottom: 0.25rem !important;
            }
            
            .products-list-view .product-item .mb-2 {
                font-size: 0.7rem !important;
                margin-bottom: 0.25rem !important;
            }
            
            .products-list-view .product-item .mt-2 {
                margin-top: 0.25rem !important;
            }
            
            .products-list-view .add-to-wishlist {
                top: 0.25rem !important;
                left: 68px !important;
                right: auto !important;
                width: 26px !important;
                height: 26px !important;
                background-color: rgba(255, 255, 255, 0.9) !important;
            }
            
            .products-list-view .add-to-wishlist:hover {
                background-color: white !important;
            }
            
            .products-list-view .add-to-wishlist i {
                font-size: 0.7rem;
            }
            
            .products-list-view .d-flex.gap-2 button {
                width: 30px !important;
                height: 30px !important;
            }
            
            .products-list-view .d-flex.gap-2 button i {
                font-size: 0.7rem !important;
            }
            
            @media (min-width: 768px) {
                .products-list-view .product-item .bg-light.overflow-hidden {
                    width: 120px !important;
                    height: 120px !important;
                    min-width: 120px !important;
                    max-width: 120px !important;
                }
                
                .products-list-view .add-to-wishlist {
                    left: 90px !important;
                    width: 28px !important;
                    height: 28px !important;
                }
                
                .products-list-view .product-item .card-title {
                    font-size: 1rem !important;
                }
                
                .products-list-view .d-flex.gap-2 button {
                    width: 32px !important;
                    height: 32px !important;
                }
            }