/* ============================================================
   MODERN PRODUCT CARD — PrimeABGB-Inspired
   Clean white cards • Discount badges • Minimal hover icons
   Conditionally loaded when admin toggle is ON
   ============================================================ */

/* ---------- Card surface ---------- */
.cardprod {
    background: #ffffff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    padding: 0 !important;
    transition: transform 0.3s ease-in-out,
        box-shadow 0.3s ease-in-out,
        border-color 0.3s ease !important;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06) !important;
    font-family: 'Outfit', sans-serif !important;
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
}

/* Ensure inline display: none is respected */
.cardprod[style*="display: none"] {
    display: none !important;
}

.cardprod:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10) !important;
    border-color: #d0d0d0 !important;
}

/* ---------- Image area ---------- */
.cardprod .card-header_prod,
.cardprod .card-header.card-header_prod {
    background: #f7f8fa !important;
    border-bottom: 1px solid #f0f0f0 !important;
    height: 280px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    position: relative !important;
    margin: 0 !important;
    border-radius: 6px 6px 0 0 !important;
    overflow: hidden !important;
}

.cardprod .card-header_prod .product-img,
.cardprod .card-header_prod img.cardimg,
.cardprod .card-header_prod img.img-fluid,
.cardprod .card-header_prod .product-img img {
    height: 100% !important;
    max-height: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    object-fit: cover !important;
    margin: 0 !important;
    display: block !important;
    transition: transform 0.4s ease !important;
}

.cardprod:hover .card-header_prod img.cardimg,
.cardprod:hover .card-header_prod img.img-fluid {
    transform: scale(1.05) !important;
}

/* ---------- Wishlist heart icon — floating circle ---------- */
.cardprod .wishlist-icon {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    left: auto !important;
    z-index: 5 !important;
    background: #ffffff !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 50% !important;
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08) !important;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease !important;
    cursor: pointer !important;
    float: none !important;
    margin: 0 !important;
    opacity: 0 !important;
}

.cardprod:hover .wishlist-icon {
    opacity: 1 !important;
}

.cardprod .wishlist-icon:hover {
    background: #fff0f3 !important;
    transform: scale(1.1) !important;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.12) !important;
}

.cardprod .wishlist-icon i {
    font-size: 15px !important;
    color: #999 !important;
    transition: color 0.2s ease !important;
}

.cardprod .wishlist-icon:hover i {
    color: #e74c3c !important;
}

.cardprod .wishlist-icon.active i,
.cardprod .wishlist-icon i.fas.fa-heart {
    color: #e74c3c !important;
}

/* Reposition the card-body that wraps the wishlist icon */
.cardprod .card-header_prod>.card-body:first-child {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    width: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    float: none !important;
    z-index: 5 !important;
    background: transparent !important;
    flex: none !important;
    min-height: auto !important;
}

/* ---------- Product tag badge — discount pill ---------- */
.cardprod .card-header_prod h2[align='right'] {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
    float: none !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    font-family: 'Outfit', sans-serif !important;
    letter-spacing: 0.3px !important;
    text-transform: uppercase !important;
    background: #e85d04 !important;
    color: #fff !important;
    padding: 5px 10px !important;
    border-radius: 4px !important;
    margin: 0 !important;
    z-index: 4 !important;
    line-height: 1.3 !important;
    box-shadow: none !important;
}

/* ---------- Card body / info area ---------- */
.cardprod>.card-body {
    background: #ffffff !important;
    padding: 14px 16px 16px !important;
    text-align: left !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    flex: 1 !important;
}

/* ---------- Product name ---------- */
.cardprod .card-body h6.text-truncate,
.cardprod .card-body .text-truncate {
    color: #222222 !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 400 !important;
    font-size: 13.5px !important;
    line-height: 1.45 !important;
    margin-bottom: 6px !important;
    white-space: normal !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    text-overflow: ellipsis !important;
    min-height: 38px !important;
}

.cardprod .card-body h6.text-truncate a,
.cardprod .card-body a {
    color: #222222 !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.cardprod .card-body a:hover {
    color: #e85d04 !important;
}

/* ---------- Price area ---------- */
.cardprod .card-body .justify-content-center,
.cardprod .card-body h6.text-bold {
    font-family: 'Outfit', sans-serif !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    margin-bottom: 8px !important;
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
}

.cardprod .card-body h6.text-bold s,
.cardprod .card-body .justify-content-center s {
    font-size: 13px !important;
    font-weight: 400 !important;
    color: #999999 !important;
    text-decoration: line-through !important;
}

/* ---------- Add to Cart — floating icon on image hover ---------- */
.cardprod .add_to_cart,
.cardprod button.add_to_cart {
    /* Reset to icon button */
    position: absolute !important;
    top: auto !important;
    bottom: 12px !important;
    right: 12px !important;
    left: auto !important;
    z-index: 6 !important;
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #ffffff !important;
    color: transparent !important;
    font-size: 0 !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transform: translateY(6px) !important;
    transition: opacity 0.25s ease, transform 0.25s ease, background 0.2s ease, box-shadow 0.2s ease !important;
}

/* Cart icon via Font Awesome unicode */
.cardprod .add_to_cart::before,
.cardprod button.add_to_cart::before {
    content: '\f07a' !important;
    font-family: 'Font Awesome 6 Free' !important;
    font-weight: 900 !important;
    font-size: 16px !important;
    color: #333 !important;
    transition: color 0.2s ease !important;
}

/* Show on card hover */
.cardprod:hover .add_to_cart,
.cardprod:hover button.add_to_cart {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.cardprod .add_to_cart:hover,
.cardprod button.add_to_cart:hover {
    background: #e85d04 !important;
    border-color: #e85d04 !important;
    box-shadow: 0 4px 14px rgba(232, 93, 4, 0.30) !important;
}

.cardprod .add_to_cart:hover::before,
.cardprod button.add_to_cart:hover::before {
    color: #ffffff !important;
}




/* Out of stock — circular red stamp overlay */
.cardprod .btn-secondary,
.cardprod button.btn-secondary {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(-50%, -50%) rotate(-18deg) !important;
    z-index: 10 !important;
    width: 120px !important;
    height: 120px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(220, 220, 220, 0.85) !important;
    color: #6b0000 !important;
    border: 4px double #6b0000 !important;
    border-radius: 50% !important;
    padding: 10px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase !important;
    line-height: 1.3 !important;
    text-align: center !important;
    margin: 0 !important;
    cursor: not-allowed !important;
    box-shadow: inset 0 0 0 3px rgba(107, 0, 0, 0.25), 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    pointer-events: none !important;
}

/* ---------- Overlay / Quick View ---------- */
.cardprod .overlay-blur {
    background: rgba(255, 255, 255, 0.7) !important;
    backdrop-filter: blur(4px) !important;
}

.cardprod .overlay .btn {
    background: #ffffff !important;
    color: #e85d04 !important;
    border: 1px solid #e85d04 !important;
    border-radius: 6px !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 500 !important;
    transition: all 0.25s ease !important;
}

.cardprod .overlay .btn:hover {
    background: #e85d04 !important;
    color: #fff !important;
}

/* ---------- View All card ---------- */
.cardprod.view-all-card,
li.cardprod.view-all-card {
    background: #fafafa !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px dashed #ccc !important;
    transition: border-color 0.3s ease, transform 0.3s ease !important;
    align-self: stretch !important;
}

.cardprod.view-all-card:hover,
li.cardprod.view-all-card:hover {
    border-color: #e85d04 !important;
}

.cardprod.view-all-card h5 {
    color: #e85d04 !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 600 !important;
    font-size: 17px !important;
    margin-top: 0 !important;
}

.cardprod.view-all-card .card-header_prod {
    background: transparent !important;
    border: none !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
}

.cardprod.view-all-card .card-body {
    display: none !important;
}

.cardprod.view-all-card i.fas.fa-arrow-right {
    color: #e85d04 !important;
    font-size: 18px !important;
}

/* ---------- Section titles ---------- */
.section-title {
    font-family: 'Outfit', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.6rem !important;
    letter-spacing: 0.3px !important;
    color: #1a1a1a !important;
}

/* ---------- Card container tweaks ---------- */
.card-container {
    display: flex !important;
    flex-wrap: wrap !important;
    /* ALLOW WRAPPING! */
    padding-left: 40px !important;
    padding-right: 40px !important;
    gap: 16px !important;
    justify-content: center !important;
    position: relative !important;
    align-items: stretch !important;
}

/* Prev / Next buttons — position them outside the card flow */
.card-container>.text-center {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 20 !important;
}

.card-container>.text-center:first-child {
    left: 0 !important;
}

.card-container>.text-center:last-child {
    right: 0 !important;
}

/* All cards — flex sizing based on col classes natively */
.card-container .card.cardprod,
.card-container .card.cardprod.col-lg-3 {
    max-width: 260px !important;
    min-width: 0 !important;
}

/* ---------- Responsive ---------- */

/* Large tablets / small desktops */
@media (max-width: 1200px) {

    .card-container .card.cardprod,
    .card-container .card.cardprod.col-lg-3 {
        max-width: 220px !important;
    }
}

/* Tablets */
@media (max-width: 992px) {
    .card-container {
        justify-content: center !important;
    }

    .card-container .card.cardprod,
    .card-container .card.cardprod.col-lg-3 {
        max-width: 200px !important;
        margin: 0 !important;
    }

    .cardprod .card-header_prod,
    .cardprod .card-header.card-header_prod {
        height: 220px !important;
    }

    .cardprod .btn-secondary,
    .cardprod button.btn-secondary {
        width: 100px !important;
        height: 100px !important;
        font-size: 10px !important;
    }
}

/* Mobile landscape / large phones */
@media (max-width: 768px) {
    /* Reset container padding for symmetry */
    .container-fluid {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Center the gallery wrapper */
    #gallery {
        width: 100% !important;
        margin: 0 auto !important;
        padding: 0 !important;
    }

    .card-container,
    .card-container1 {
        flex-wrap: wrap !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
        gap: 10px !important;
        justify-content: center !important;
        /* Reset Bootstrap .row negative margins */
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Reset outer .row padding on mobile */
    .row.px-xl-5 {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .card-container .card.cardprod,
    .card-container .card.cardprod.col-lg-3,
    .card-container1 .card.cardprod,
    .card-container1 .card.cardprod.col-lg-3 {
        flex: 0 0 calc(50% - 10px) !important;
        width: calc(50% - 10px) !important;
        max-width: calc(50% - 10px) !important;
        min-width: 0 !important;
        margin: 0 !important;
        height: auto !important;
        flex-direction: column !important;
    }

    .cardprod .card-header_prod,
    .cardprod .card-header.card-header_prod {
        height: 200px !important;
        max-width: 100% !important;
        border-right: none !important;
    }

    .cardprod>.card-body {
        padding: 10px 12px 12px !important;
    }

    .cardprod .card-body h6.text-truncate {
        font-size: 12.5px !important;
        min-height: 34px !important;
    }

    .cardprod .card-body h6.text-bold {
        font-size: 15px !important;
        display: flex !important;
        flex-wrap: wrap !important;
        align-items: baseline !important;
        gap: 4px !important;
        line-height: 1.4 !important;
        overflow: visible !important;
        justify-content: flex-start !important; /* Align prices to the left on mobile */
    }

    .cardprod .card-body .justify-content-center {
        overflow: visible !important;
        height: auto !important;
        min-height: auto !important;
        justify-content: flex-start !important; /* Align prices to the left on mobile */
    }

    /* Out of stock stamp — smaller on mobile */
    .cardprod .btn-secondary,
    .cardprod button.btn-secondary {
        width: 90px !important;
        height: 90px !important;
        font-size: 9px !important;
        border-width: 3px !important;
        padding: 6px !important;
    }

    /* View All card */
    .cardprod.view-all-card,
    li.cardprod.view-all-card {
        flex: 0 0 calc(50% - 12px) !important;
        width: calc(50% - 12px) !important;
        max-width: calc(50% - 12px) !important;
    }

    /* Floating icons — always visible on touch devices */
    .cardprod .add_to_cart,
    .cardprod button.add_to_cart {
        opacity: 1 !important;
        transform: translateY(0) !important;
    }

    .cardprod .card-header_prod::after {
        opacity: 1 !important;
        transform: translateY(0) !important;
    }

    /* Show wishlist always on mobile */
    .cardprod .wishlist-icon {
        opacity: 1 !important;
    }
}

/* Mobile portrait */
@media (max-width: 576px) {

    .card-container .card.cardprod,
    .card-container .card.cardprod.col-lg-3,
    .card-container1 .card.cardprod,
    .card-container1 .card.cardprod.col-lg-3 {
        flex: 0 0 calc(50% - 10px) !important;
        width: calc(50% - 10px) !important;
        max-width: calc(50% - 10px) !important;
        height: auto !important;
        flex-direction: column !important;
    }

    .cardprod .card-header_prod,
    .cardprod .card-header.card-header_prod {
        height: 170px !important;
        max-width: 100% !important;
        border-right: none !important;
    }

    .cardprod>.card-body {
        padding: 8px 10px 10px !important;
    }

    .cardprod .card-body h6.text-truncate {
        font-size: 11.5px !important;
        min-height: 30px !important;
    }

    .cardprod .card-body h6.text-bold {
        font-size: 13px !important;
        flex-wrap: wrap !important;
        gap: 3px !important;
    }

    .cardprod .card-body h6.text-bold s {
        font-size: 11px !important;
    }

    .cardprod .card-body .text-muted {
        font-size: 10px !important;
    }

    .cardprod .btn-secondary,
    .cardprod button.btn-secondary {
        width: 80px !important;
        height: 80px !important;
        font-size: 8px !important;
        letter-spacing: 0.5px !important;
    }

    .cardprod.view-all-card,
    li.cardprod.view-all-card {
        flex: 0 0 calc(50% - 10px) !important;
        width: calc(50% - 10px) !important;
        max-width: calc(50% - 10px) !important;
    }

    .cardprod.view-all-card h5 {
        font-size: 14px !important;
    }
}

/* Very small phones */
@media (max-width: 400px) {
    .card-container,
    .card-container1 {
        gap: 8px !important;
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .card-container .card.cardprod,
    .card-container .card.cardprod.col-lg-3,
    .card-container1 .card.cardprod,
    .card-container1 .card.cardprod.col-lg-3 {
        flex: 0 0 calc(50% - 8px) !important;
        width: calc(50% - 8px) !important;
        max-width: calc(50% - 8px) !important;
        height: auto !important;
        flex-direction: column !important;
    }

    .cardprod .card-header_prod,
    .cardprod .card-header.card-header_prod {
        height: 140px !important;
        max-width: 100% !important;
        border-right: none !important;
    }

    .cardprod .card-body h6.text-truncate {
        font-size: 11px !important;
    }

    .cardprod .card-body h6.text-bold {
        font-size: 12px !important;
        flex-wrap: wrap !important;
        gap: 2px !important;
    }

    .cardprod .card-body h6.text-bold s {
        font-size: 10px !important;
    }

    .cardprod .btn-secondary,
    .cardprod button.btn-secondary {
        width: 70px !important;
        height: 70px !important;
        font-size: 7px !important;
    }

    .cardprod.view-all-card h5 {
        font-size: 13px !important;
    }
}

/* ---------- Page load stagger animation ---------- */
@keyframes cardFadeUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.cardprod {
    animation: cardFadeUp 0.45s ease-out both;
}

.cardprod:nth-child(1) {
    animation-delay: 0.03s;
}

.cardprod:nth-child(2) {
    animation-delay: 0.08s;
}

.cardprod:nth-child(3) {
    animation-delay: 0.13s;
}

.cardprod:nth-child(4) {
    animation-delay: 0.18s;
}

.cardprod:nth-child(5) {
    animation-delay: 0.23s;
}

.cardprod:nth-child(6) {
    animation-delay: 0.28s;
}

.cardprod:nth-child(7) {
    animation-delay: 0.33s;
}

/* ============================================================
   END MODERN PRODUCT CARD
   ============================================================ */