/* ============================================================
   BOUTIQUE — Page Archive WooCommerce v4
   Approche : display:block sur les cartes pour eviter
   tout probleme d'espacement lie au flex/matchHeight d'Astra
   ============================================================ */

/* ============================================================
   HERO BOUTIQUE
   ============================================================ */
.scl-shop-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, var(--scl-bg2) 0%, var(--scl-bg) 100%);
    border-bottom: 1px solid var(--scl-border);
    padding: 56px 0 40px;
    text-align: center;
}

.scl-shop-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 50% 100%, rgba(124,58,237,0.18) 0%, transparent 70%),
        radial-gradient(ellipse 40% 50% at 20% 0%, rgba(96,165,250,0.08) 0%, transparent 60%),
        radial-gradient(ellipse 30% 40% at 80% 0%, rgba(52,211,153,0.06) 0%, transparent 60%);
    pointer-events: none;
}

.scl-shop-hero::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 1px;
    background: var(--scl-holo-grad);
    opacity: 0.4;
}

.scl-shop-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--scl-font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--scl-purple-lt);
    margin-bottom: 14px;
    padding: 5px 14px;
    border: 1px solid var(--scl-border-md);
    border-radius: 100px;
    background: rgba(124,58,237,0.08);
}

.scl-shop-hero__eyebrow::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--scl-purple-lt);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--scl-purple-lt);
    animation: scl-pulse 2s ease-in-out infinite;
}

.scl-shop-hero__title {
    font-family: var(--scl-font-head) !important;
    font-size: clamp(32px, 4.5vw, 56px) !important;
    font-weight: 900 !important;
    color: var(--scl-white) !important;
    margin: 0 0 12px !important;
    letter-spacing: -0.02em;
    line-height: 1.05 !important;
}

.scl-shop-hero__title span {
    background: var(--scl-holo-grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.scl-shop-hero__subtitle {
    font-size: 14px;
    color: var(--scl-grey-lt);
    max-width: 520px;
    margin: 0 auto 28px;
    line-height: 1.6;
}

.scl-shop-hero__stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
    flex-wrap: wrap;
}

.scl-shop-hero__stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.scl-shop-hero__stat-value {
    font-family: var(--scl-font-head);
    font-size: 22px;
    font-weight: 800;
    background: var(--scl-gold-grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.scl-shop-hero__stat-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--scl-grey);
    font-family: var(--scl-font-mono);
}

.scl-shop-hero__stat-sep {
    width: 1px;
    height: 32px;
    background: var(--scl-border-md);
}

/* ============================================================
   TOOLBAR
   ============================================================ */
.scl-shop-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 24px 0 28px;
    flex-wrap: wrap;
}

.scl-shop-toolbar__left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.scl-shop-toolbar__label {
    font-size: 11px;
    font-family: var(--scl-font-mono);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--scl-grey);
    margin-right: 4px;
}

.scl-cat-filter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: 100px;
    font-size: 12px;
    font-family: var(--scl-font-mono);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--scl-border-md);
    background: transparent;
    color: var(--scl-grey-lt);
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none !important;
}

.scl-cat-filter:hover,
.scl-cat-filter.active {
    border-color: var(--scl-purple-lt);
    background: rgba(124,58,237,0.12);
    color: var(--scl-purple-lt) !important;
}

.scl-cat-filter.active {
    box-shadow: 0 0 12px rgba(124,58,237,0.2);
}

.scl-cat-filter__count {
    background: rgba(124,58,237,0.2);
    color: var(--scl-purple-lt);
    border-radius: 100px;
    padding: 1px 7px;
    font-size: 10px;
}

/* ============================================================
   GRILLE PRODUITS — utiliser grid externe seulement
   ============================================================ */
.woocommerce-page ul.products,
.woocommerce ul.products,
ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

@media (max-width: 900px) {
    .woocommerce-page ul.products,
    .woocommerce ul.products,
    ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 16px !important;
    }
}

@media (max-width: 560px) {
    .woocommerce-page ul.products,
    .woocommerce ul.products,
    ul.products {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   CARDS PRODUITS
   APPROCHE : display:block + override Astra matchHeight
   ============================================================ */
.woocommerce-page ul.products li.product,
.woocommerce ul.products li.product,
ul.products li.product {
    /* RESET TOTAL du layout interne */
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    float: none !important;
    clear: none !important;

    /* Style visuel */
    background: var(--scl-bg3) !important;
    border: 1px solid var(--scl-border) !important;
    border-radius: var(--scl-radius-lg) !important;
    overflow: hidden !important;
    position: relative !important;
    transition: border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease !important;
}

.woocommerce ul.products li.product:hover {
    border-color: rgba(167,139,250,0.45) !important;
    transform: translateY(-5px) !important;
    box-shadow: 0 12px 48px rgba(0,0,0,0.5), 0 0 40px rgba(124,58,237,0.12) !important;
}

/* RESET TOUS les enfants directs */
.woocommerce ul.products li.product > * {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* === IMAGE === */
/* Le wrapper <a> de l'image */
.woocommerce ul.products li.product > a:first-of-type,
.woocommerce ul.products li.product .woocommerce-LoopProduct-link {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
    aspect-ratio: 1 / 1.25 !important;
    background: var(--scl-bg2) !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* L'image elle-meme */
.woocommerce ul.products li.product img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail,
.woocommerce ul.products li.product .wp-post-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: transform 0.5s ease !important;
}

.woocommerce ul.products li.product:hover img {
    transform: scale(1.05) !important;
}

/* === HIDE RATINGS — CRITIQUE === */
.woocommerce ul.products li.product .star-rating,
.woocommerce ul.products li.product .woocommerce-loop-product__rating,
.woocommerce ul.products li.product .woocommerce-product-rating,
.woocommerce ul.products li.product .star-rating-container,
.woocommerce-page .star-rating,
.products .star-rating {
    display: none !important;
    height: 0 !important;
    width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 0 !important;
    font-size: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    left: -9999px !important;
}

/* === TITRE === */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
    font-family: var(--scl-font-head) !important;
    font-weight: 700 !important;
    color: var(--scl-white) !important;
    font-size: 15px !important;
    line-height: 1.25 !important;
    padding: 14px 16px 2px !important;
    margin: 0 !important;
    display: block !important;
    min-height: 0 !important;
}

/* === PRIX === */
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product span.price,
.woocommerce ul.products li.product .woocommerce-Price-amount {
    background: var(--scl-gold-grad) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-family: var(--scl-font-head) !important;
    font-weight: 700 !important;
    font-size: 20px !important;
    padding: 2px 16px 12px !important;
    margin: 0 !important;
    display: block !important;
    min-height: 0 !important;
    line-height: 1.2 !important;
}

.woocommerce ul.products li.product .price del,
.woocommerce ul.products li.product .price del .amount {
    color: var(--scl-grey) !important;
    -webkit-text-fill-color: var(--scl-grey) !important;
    font-size: 14px !important;
    margin-right: 5px !important;
}

/* === BOUTON === */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .add_to_cart_button {
    display: block !important;
    margin: 0 16px 16px !important;
    width: calc(100% - 32px) !important;
    padding: 11px 20px !important;
    font-family: var(--scl-font-body) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    border-radius: var(--scl-radius-sm) !important;
    background: var(--scl-purple) !important;
    color: #fff !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-align: center !important;
    text-decoration: none !important;
    min-height: 0 !important;
    height: auto !important;
    box-sizing: border-box !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover {
    background: #6D28D9 !important;
    box-shadow: 0 0 20px rgba(124,58,237,0.4) !important;
    transform: translateY(-1px) !important;
}

.woocommerce ul.products li.product a.button.product_type_simple {
    background: transparent !important;
    border: 1px solid var(--scl-border-md) !important;
    color: var(--scl-grey-lt) !important;
}

.woocommerce ul.products li.product a.button.product_type_simple:hover {
    border-color: var(--scl-purple-lt) !important;
    color: var(--scl-purple-lt) !important;
    background: rgba(124,58,237,0.08) !important;
    box-shadow: none !important;
}

/* === BADGES === */
.woocommerce span.onsale {
    background: var(--scl-gold) !important;
    color: var(--scl-bg) !important;
    font-family: var(--scl-font-mono) !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    border-radius: 4px !important;
    padding: 3px 9px !important;
    min-height: unset !important;
    line-height: 1.4 !important;
    min-width: unset !important;
    top: 12px !important;
    left: 12px !important;
    right: auto !important;
    box-shadow: 0 0 12px rgba(245,158,11,0.35) !important;
    z-index: 3 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    position: absolute !important;
}

.scl-product-card__badge--limited {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    left: auto !important;
    z-index: 3 !important;
    font-family: var(--scl-font-mono) !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    padding: 3px 10px !important;
    border-radius: 4px !important;
    background: linear-gradient(135deg, #F97316 0%, #FACC15 50%, #65A30D 100%) !important;
    color: var(--scl-bg) !important;
    border: none !important;
    box-shadow: 0 0 12px rgba(249, 115, 22, 0.3) !important;
    backdrop-filter: none !important;
}

.scl-product-card__badge--outofstock {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    left: auto !important;
    z-index: 3 !important;
    font-family: var(--scl-font-mono) !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    padding: 3px 10px !important;
    border-radius: 4px !important;
    background: linear-gradient(135deg, #EF4444 0%, #FECACA 50%, #DC2626 100%) !important;
    color: #fff !important;
    text-shadow: 0 1px 2px rgba(0,0,0,0.25) !important;
    border: none !important;
    box-shadow: 0 0 12px rgba(239, 68, 68, 0.3) !important;
    backdrop-filter: none !important;
}

/* ============================================================
   TRI WOOCOMMERCE
   ============================================================ */
.woocommerce-ordering select {
    background: var(--scl-bg3) !important;
    border: 1px solid var(--scl-border-md) !important;
    color: var(--scl-text) !important;
    border-radius: var(--scl-radius-sm) !important;
    padding: 8px 14px !important;
    font-family: var(--scl-font-body) !important;
    font-size: 13px !important;
    cursor: pointer;
    outline: none;
}

.woocommerce-ordering select:focus {
    border-color: var(--scl-purple-lt) !important;
    box-shadow: 0 0 0 3px rgba(124,58,237,0.15) !important;
}

.woocommerce-result-count {
    font-size: 12px !important;
    color: var(--scl-grey) !important;
    font-family: var(--scl-font-mono) !important;
    margin: 0 !important;
    align-self: center;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.woocommerce-pagination {
    margin-top: 48px !important;
    text-align: center;
}

.woocommerce-pagination ul.page-numbers {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    list-style: none;
    padding: 0; margin: 0;
}

.woocommerce-pagination ul.page-numbers li {
    display: flex;
    margin: 0;
}

.woocommerce-pagination ul.page-numbers li a,
.woocommerce-pagination ul.page-numbers li span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    border-radius: var(--scl-radius-sm);
    font-family: var(--scl-font-mono);
    font-size: 13px;
    font-weight: 600;
    background: var(--scl-bg3);
    border: 1px solid var(--scl-border);
    color: var(--scl-grey-lt);
    text-decoration: none;
    transition: all 0.2s ease;
}

.woocommerce-pagination ul.page-numbers li a:hover {
    border-color: var(--scl-purple-lt);
    color: var(--scl-purple-lt);
    background: rgba(124,58,237,0.1);
}

.woocommerce-pagination ul.page-numbers li span.current {
    background: var(--scl-purple);
    border-color: var(--scl-purple);
    color: #fff;
    box-shadow: 0 0 16px rgba(124,58,237,0.4);
}

/* ============================================================
   MASQUE LE HEADER WOO NATIF (on a notre hero)
   ============================================================ */
body.post-type-archive-product .ast-breadcrumbs-wrapper,
body.tax-product_cat .ast-breadcrumbs-wrapper,
body.post-type-archive-product .woocommerce-products-header,
body.tax-product_cat .woocommerce-products-header {
    display: none !important;
}

/* ============================================================
   BANDEAU CONFIANCE
   ============================================================ */
.scl-shop-trust {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 56px;
    padding: 26px;
    background: var(--scl-bg2);
    border: 1px solid var(--scl-border);
    border-radius: var(--scl-radius-lg);
}

@media (max-width: 768px) {
    .scl-shop-trust { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .scl-shop-trust { grid-template-columns: 1fr; }
}

.scl-shop-trust__item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.scl-shop-trust__icon {
    font-size: 22px;
    flex-shrink: 0;
    margin-top: 2px;
}

.scl-shop-trust__text strong {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--scl-white);
    margin-bottom: 2px;
    font-family: var(--scl-font-head);
}

.scl-shop-trust__text span {
    font-size: 12px;
    color: var(--scl-grey-lt);
    line-height: 1.4;
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes scl-card-in {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.woocommerce ul.products li.product {
    animation: scl-card-in 0.4s ease both;
}

.woocommerce ul.products li.product:nth-child(1) { animation-delay: 0.04s; }
.woocommerce ul.products li.product:nth-child(2) { animation-delay: 0.08s; }
.woocommerce ul.products li.product:nth-child(3) { animation-delay: 0.12s; }
.woocommerce ul.products li.product:nth-child(4) { animation-delay: 0.16s; }
.woocommerce ul.products li.product:nth-child(5) { animation-delay: 0.20s; }
.woocommerce ul.products li.product:nth-child(6) { animation-delay: 0.24s; }
.woocommerce ul.products li.product:nth-child(7) { animation-delay: 0.28s; }
.woocommerce ul.products li.product:nth-child(8) { animation-delay: 0.32s; }
.woocommerce ul.products li.product:nth-child(9) { animation-delay: 0.36s; }

/* ============================================================
   WRAPPER LAYOUT
   ============================================================ */
.scl-shop-layout {
    max-width: var(--scl-max-w);
    margin: 0 auto;
    padding: 0 32px 80px;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .scl-shop-layout { padding: 0 16px 48px; }
    .scl-shop-hero { padding: 36px 16px 28px; }
    .scl-shop-hero__stats { gap: 14px; }
    .scl-shop-hero__stat-sep { display: none; }
}


/* ============================================================
   PATCH v3.2 — Cards uniformes + retour boutique sans grand hero
   ============================================================ */
body.post-type-archive-product .scl-shop-layout,
body.tax-product_cat .scl-shop-layout,
body.tax-product_tag .scl-shop-layout {
    padding-top: 36px !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title {
    margin-bottom: 0 !important;
    padding-bottom: 4px !important;
    min-height: 0 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product span.price {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    min-height: 0 !important;
}

.woocommerce ul.products li.product .star-rating,
.related.products ul.products li.product .star-rating,
.up-sells.products ul.products li.product .star-rating {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
}

@media (max-width: 768px) {
    .scl-shop-toolbar {
        align-items: flex-start !important;
    }
    .woocommerce-ordering {
        width: 100% !important;
    }
    .woocommerce-ordering select {
        width: 100% !important;
        min-height: 44px !important;
    }
}


/* ============================================================
   PATCH v3.4 — Bandeau violet d'ajout au panier en bas de l'image
   Cible le bouton overlay Astra sans déplacer le bouton classique sous le prix.
   ============================================================ */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap,
.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap {
    position: relative !important;
    overflow: hidden !important;
}

.woocommerce ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button,
.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button {
    top: auto !important;
    bottom: 14px !important;
    left: 16px !important;
    right: 16px !important;
    width: calc(100% - 32px) !important;
    min-width: 0 !important;
    height: 42px !important;
    border-radius: var(--scl-radius-sm) !important;
    background: var(--scl-purple) !important;
    color: #fff !important;
    border: 1px solid rgba(167,139,250,0.38) !important;
    box-shadow: 0 10px 28px rgba(124,58,237,0.32) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transform: none !important;
    z-index: 8 !important;
}

.woocommerce ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button:hover,
.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button:hover {
    background: #6D28D9 !important;
    color: #fff !important;
    box-shadow: 0 12px 34px rgba(124,58,237,0.46) !important;
}

@media (max-width: 560px) {
    .woocommerce ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button,
    .woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button {
        bottom: 12px !important;
        left: 12px !important;
        right: 12px !important;
        width: calc(100% - 24px) !important;
    }
}

/* ============================================================
   PATCH v3.5 — Centrage precis du bandeau violet hover panier
   Objectif : garder le placement bas d'image, sans decalage lateral.
   ============================================================ */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button,
.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button {
    left: 50% !important;
    right: auto !important;
    width: calc(100% - 32px) !important;
    max-width: calc(100% - 32px) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    transform: translateX(-50%) !important;
}

@media (max-width: 560px) {
    .woocommerce ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button,
    .woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap .ast-on-card-button {
        left: 50% !important;
        right: auto !important;
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
        transform: translateX(-50%) !important;
    }
}

/* ============================================================
   PATCH v3.6 — Bandeau panier overlay centre sur TOUS les produits vendables
   + suppression logique sur les produits en rupture de stock.
   Patch volontairement ciblé : ne modifie pas les cards, le prix ou les boutons classiques.
   ============================================================ */
body.woocommerce-shop ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.post-type-archive-product ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.tax-product_cat ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.tax-product_tag ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.single-product ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button {
    position: absolute !important;
    top: auto !important;
    bottom: 14px !important;
    left: 50% !important;
    right: auto !important;
    inset-inline-start: 50% !important;
    inset-inline-end: auto !important;
    width: calc(100% - 32px) !important;
    max-width: calc(100% - 32px) !important;
    min-width: 0 !important;
    margin-top: 0 !important;
    margin-right: 0 !important;
    margin-bottom: 0 !important;
    margin-left: 0 !important;
    transform: translate3d(-50%, 0, 0) !important;
    translate: none !important;
    box-sizing: border-box !important;
    z-index: 8 !important;
}

/* Certains styles Astra/WooCommerce réinjectent une marge via .button/.add_to_cart_button.
   On neutralise spécifiquement l'overlay, pas le bouton classique sous le prix. */
body.woocommerce-shop ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.button,
body.woocommerce-shop ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.add_to_cart_button,
body.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.button,
body.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.add_to_cart_button,
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.button,
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button.add_to_cart_button {
    margin: 0 !important;
    left: 50% !important;
    right: auto !important;
    transform: translate3d(-50%, 0, 0) !important;
}

/* En rupture de stock, seul le bandeau blanc "EN RUPTURE DE STOCK" reste visible. */
body.woocommerce-shop ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.post-type-archive-product ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.tax-product_cat ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.tax-product_tag ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.single-product ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
body.woocommerce-page ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
.woocommerce ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button,
.woocommerce-page ul.products li.product.outofstock .astra-shop-thumbnail-wrap > a.ast-on-card-button {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

@media (max-width: 560px) {
    body.woocommerce-shop ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    body.post-type-archive-product ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    body.tax-product_cat ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    body.tax-product_tag ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    body.single-product ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    body.woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    .woocommerce ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button,
    .woocommerce-page ul.products li.product .astra-shop-thumbnail-wrap > a.ast-on-card-button {
        bottom: 12px !important;
        left: 50% !important;
        right: auto !important;
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
        margin: 0 !important;
        transform: translate3d(-50%, 0, 0) !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════
   BOUTIQUE — Cards identiques à la page d'accueil
   Le template archive-product.php génère désormais directement le HTML
   .scl-products-grid > .scl-product-card (même structure que front-page).
   Le style de base vient de style.css. On ajoute seulement quelques
   ajustements spécifiques à la boutique.
   ═══════════════════════════════════════════════════════════════════════ */

/* Grid avec les mêmes proportions que sur l'accueil */
.scl-shop-grid {
    margin-top: 0;
}

/* Bouton "Voir →" compact dans le footer de la card */
.scl-product-card .scl-shop-card-btn {
    padding: 7px 14px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

/* ── Masquer agressivement les anciens éléments WooCommerce ──────────────
   Au cas où Astra ou un plugin injecterait encore quelque chose. */
.scl-shop-layout .woocommerce-result-count,
.scl-shop-layout .woocommerce-ordering,
.scl-shop-layout ul.products,            /* l'ancien <ul class="products"> */
.scl-shop-layout .ast-woocommerce-container > .woocommerce-result-count,
.scl-shop-layout .ast-woocommerce-container > .woocommerce-ordering,
body.woocommerce-shop .woocommerce-ordering,
body.woocommerce-shop .woocommerce-result-count,
body.tax-product_cat .woocommerce-ordering,
body.tax-product_cat .woocommerce-result-count {
    display: none !important;
}

/* ── Responsive : la grille passe à 2 puis 1 colonne ─────────────────── */
@media (max-width: 960px) {
    .scl-shop-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 560px) {
    .scl-shop-grid { grid-template-columns: 1fr !important; }
}
