/* Grid Responsive Fix - Ensure consistent card layouts across all pages */

/* Enhanced Products Grid - Consistent across Home, Search, Wishlist, Product Details */
body .products-grid,
.container .products-grid,
.main-content .products-grid {
    display: grid !important;
    gap: 20px !important;
    margin: 30px auto !important;
    padding: 0 15px !important;
    max-width: 1200px !important;
    width: 100% !important;
}

/* Desktop Large - 4 columns */
@media (min-width: 1200px) {
    body .products-grid,
    .container .products-grid,
    .main-content .products-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 25px !important;
        padding: 0 20px !important;
    }
}

/* Desktop/Laptop - 3 columns */
@media (min-width: 992px) and (max-width: 1199px) {
    body .products-grid,
    .container .products-grid,
    .main-content .products-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 20px !important;
        padding: 0 15px !important;
    }
}

/* Tablet - 2 columns */
@media (min-width: 768px) and (max-width: 991px) {
    body .products-grid,
    .container .products-grid,
    .main-content .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
        padding: 0 15px !important;
    }
}

/* Mobile - 1 column */
@media (max-width: 767px) {
    body .products-grid,
    .container .products-grid,
    .main-content .products-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }
}

/* Ensure product cards have consistent max width */
body .product-card-wrapper,
.container .product-card-wrapper,
.main-content .product-card-wrapper {
    width: 100% !important;
    max-width: 350px !important;
    margin: 0 auto !important;
}

body .product-card,
.container .product-card,
.main-content .product-card {
    width: 100% !important;
    height: auto !important;
    min-height: 400px !important;
    display: flex !important;
    flex-direction: column !important;
}

body .product-card .card-body,
.container .product-card .card-body,
.main-content .product-card .card-body {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

body .product-card .mt-auto,
.container .product-card .mt-auto,
.main-content .product-card .mt-auto {
    margin-top: auto !important;
}

/* On desktop, ensure cards don't stretch too wide */
@media (min-width: 1200px) {
    .product-card-wrapper {
        max-width: 280px !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .product-card-wrapper {
        max-width: 300px !important;
    }
}

/* Force grid layout on all template pages */
.search-results .products-grid,
.wishlist .products-grid,
.products-section .products-grid,
#recommendations .products-grid {
    display: grid !important;
    margin-top: 2rem !important;
}

/* Override all competing grid-template-columns rules */
div[class*="grid"] {
    grid-template-columns: unset !important;
}

/* Re-apply our grid columns to products-grid specifically */
@media (min-width: 1200px) {
    div.products-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    div.products-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    div.products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 767px) {
    div.products-grid {
        grid-template-columns: 1fr !important;
    }
}