/**
 * Boutique (archive produits, catégories, étiquettes) — design dédié.
 *
 * Override la grille 4-col par 3-col, ajoute le hero d'archive, pills
 * catégories, ratio 1:1 sur les vignettes, badges, empty state.
 * Reprend les variables CSS du thème enfant — pas de couleur hardcodée.
 *
 * Chargé conditionnellement via functions.php sur :
 *   is_shop() || is_product_category() || is_product_tag()
 */

/* ============================================================
 * Cadre général : on s'imbrique dans le wrapper .sfc-shop-wrap
 * ============================================================ */
.sfc-shop-archive {
    margin: 0;
}

/* ============================================================
 * Hero d'archive (titre + sous-titre + filet doré)
 * ============================================================ */
.sfc-shop-archive__hero {
    text-align: center;
    margin: 0 auto 32px;
    max-width: 760px;
    padding-inline: 16px;
}

.sfc-shop-archive__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 12px;
}

.sfc-shop-archive__eyebrow::before,
.sfc-shop-archive__eyebrow::after {
    content: "";
    width: 24px;
    height: 1px;
    background: var(--color-gold);
}

.sfc-shop-archive__title.page-title,
.sfc-shop-archive__title.woocommerce-products-header__title {
    font-family: var(--font-heading);
    font-size: clamp(28px, 3.6vw, 44px);
    font-weight: 600;
    color: var(--color-primary);
    line-height: 1.15;
    letter-spacing: -0.01em;
    margin: 0 0 12px;
}

.sfc-shop-archive__subtitle {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-text-muted);
    margin: 0;
}

.sfc-shop-archive__subtitle p:last-child { margin-bottom: 0; }

/* Cache la description de catégorie native quand on l'a déjà rendue dans le subtitle */
.sfc-shop-archive .term-description { display: none; }

/* ============================================================
 * Pills catégories
 * ============================================================ */
/* Conteneur : positionne les flèches desktop de part et d'autre du carrousel. */
.sfc-shop-pills-wrap {
    position: relative;
    margin: 0 auto 36px;
}

/* Barre de catégories — carrousel une seule ligne à défilement latéral.
 * Centrée quand elle tient (justify: safe center), bascule en scroll dès
 * qu'elle déborde — sans jamais rendre les premiers items inaccessibles.
 * Fondus dégradés aux bords (mask) pour signaler le défilement. */
.sfc-shop-pills {
    display: flex;
    flex-wrap: nowrap;
    justify-content: safe center;
    gap: 10px;
    margin: 0;
    padding: 6px 28px;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    scroll-padding-inline: 28px;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge legacy */
    -webkit-mask-image: linear-gradient(to right, transparent 0, #000 28px, #000 calc(100% - 28px), transparent 100%);
            mask-image: linear-gradient(to right, transparent 0, #000 28px, #000 calc(100% - 28px), transparent 100%);
}

.sfc-shop-pills::-webkit-scrollbar { /* Chrome/Safari */
    display: none;
}

.sfc-shop-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    scroll-snap-align: center;
    white-space: nowrap;
    padding: 10px 18px;
    border-radius: 10px;
    background: var(--color-white);
    color: var(--color-primary);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-decoration: none;
    border: 1.5px solid transparent;
    transition: background-color 200ms ease, color 200ms ease,
                border-color 200ms ease, transform 200ms ease,
                box-shadow 200ms ease;
}

/* Icône Lucide de la pill : dorée, pour ressortir aussi bien sur blanc
 * que sur le navy de l'état actif. */
.sfc-shop-pill__icon {
    width: 16px;
    height: 16px;
    flex: 0 0 auto;
    color: var(--color-gold);
    /* Normalise l'épaisseur de trait (certaines icônes réutilisées de la home
       sont en 1.2) : le CSS prime sur l'attribut SVG et s'hérite aux <path>. */
    stroke-width: 1.5;
    transition: color 200ms ease, transform 200ms ease;
}

.sfc-shop-pill:hover .sfc-shop-pill__icon,
.sfc-shop-pill:focus-visible .sfc-shop-pill__icon {
    transform: scale(1.08);
}

/* Flèches de navigation — desktop uniquement (sur mobile/tablette : scroll
 * tactile). Affichées/masquées par le JS selon le débordement et la position
 * de scroll (attribut [hidden]). */
.sfc-shop-pills__arrow {
    display: none; /* activé en desktop via media query */
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1.5px solid var(--color-secondary);
    border-radius: 10px;
    background: var(--color-white);
    color: var(--color-primary);
    cursor: pointer;
    box-shadow: 0 6px 18px -8px rgba(26, 38, 64, 0.35);
    transition: background-color 200ms ease, color 200ms ease,
                border-color 200ms ease, box-shadow 200ms ease, opacity 200ms ease;
}

.sfc-shop-pills__arrow--prev { left: -6px; }
.sfc-shop-pills__arrow--next { right: -6px; }

.sfc-shop-pills__arrow:hover,
.sfc-shop-pills__arrow:focus-visible {
    background: var(--color-primary);
    color: var(--color-cream);
    border-color: var(--color-primary);
    box-shadow: 0 8px 20px -6px rgba(26, 38, 64, 0.45);
    outline: none;
}

.sfc-shop-pills__arrow svg {
    width: 18px;
    height: 18px;
    stroke-width: 1.75;
}

/* Le bouton n'apparaît qu'en desktop ET seulement quand le JS l'a démasqué. */
@media (min-width: 1025px) {
    .sfc-shop-pills__arrow:not([hidden]) {
        display: inline-flex;
    }
    /* Réserve un peu d'espace pour que les flèches ne couvrent pas le contenu. */
    .sfc-shop-pills-wrap {
        padding-inline: 12px;
    }
}

.sfc-shop-pill:hover,
.sfc-shop-pill:focus-visible {
    background: var(--color-cream);
    border-color: var(--color-gold);
    transform: translateY(-2px);
    box-shadow: 0 6px 14px -4px rgba(201, 169, 97, 0.4);
    outline: none;
}

.sfc-shop-pill.is-active {
    background: var(--color-primary);
    color: var(--color-cream);
    border-color: var(--color-primary);
    box-shadow:
        0 0 0 3px rgba(26, 38, 64, 0.08),
        0 8px 20px -6px rgba(26, 38, 64, 0.35);
}

/* ============================================================
 * Result-count + ordering — toolbar sous les pills
 * ============================================================ */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
    font-family: var(--font-body);
    font-size: 12px;
    color: var(--color-text-muted);
    font-style: italic;
    margin-bottom: 24px;
}

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering {
    margin-bottom: 24px;
}

.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
    appearance: none;
    -webkit-appearance: none;
    padding: 10px 36px 10px 16px;
    border: 1.5px solid rgba(26, 38, 64, 0.1);
    border-radius: 100px;
    background-color: var(--color-white);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23C9A961' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 6 8 10 12 6'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 14px 14px;
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--color-primary);
    cursor: pointer;
    transition: border-color 200ms ease, box-shadow 200ms ease;
}

.woocommerce .woocommerce-ordering select:focus {
    outline: none;
    border-color: var(--color-gold);
    box-shadow: 0 0 0 3px rgba(201, 169, 97, 0.18);
}

/* T8 — Storefront rend DEUX blocs .storefront-sorting (tri + pagination),
 * un avant la grille et un après → doublons. On garde :
 *   - le tri UNE fois, en haut à droite ;
 *   - la pagination UNE fois, en bas, centrée. */
.woocommerce .storefront-sorting {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin: 0 0 22px;
}
.woocommerce .storefront-sorting::before,
.woocommerce .storefront-sorting::after { content: none; } /* neutralise le clearfix Storefront */
.woocommerce .storefront-sorting .woocommerce-ordering { margin: 0; }

/* Pagination : masquée dans le bloc du HAUT, affichée dans celui du BAS. */
.woocommerce .storefront-sorting .woocommerce-pagination { display: none; }
.woocommerce ul.products ~ .storefront-sorting .woocommerce-pagination { display: flex; }
/* Tri : masqué dans le bloc du BAS (après la grille). */
.woocommerce ul.products ~ .storefront-sorting .woocommerce-ordering { display: none; }
/* Le bloc du bas ne contient plus que la pagination → on la centre. */
.woocommerce ul.products ~ .storefront-sorting { justify-content: center; margin: 0; }

/* ============================================================
 * Grille produits — 3 col desktop / 2 tablette / 1 mobile
 * Override de la grille 4-col définie dans woocommerce.css
 * ============================================================ */
.woocommerce ul.products,
.woocommerce-page ul.products {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(20px, 2.5vw, 36px);
    margin: 0 0 40px;
}

/* Neutralise les pseudo-éléments clearfix du parent Storefront
   (ul.products::before / ::after) qui, en mode grid, deviennent
   des grid items fantômes et déforment la disposition (2-3-3-2). */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
    content: none;
    display: none;
}

/* ============================================================
 * Card produit
 * ============================================================ */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.sfc-product-card {
    display: flex;
    flex-direction: column;
    text-align: left;
    background: var(--color-white);
    border-radius: 12px;
    overflow: hidden;
    box-shadow:
        0 1px 2px rgba(26, 38, 64, 0.04),
        0 12px 28px -18px rgba(26, 38, 64, 0.18);
    transition: transform 350ms ease, box-shadow 350ms ease;
    position: relative;
    margin: 0;
}

.woocommerce ul.products li.product:hover,
.woocommerce ul.products li.product:focus-within,
.sfc-product-card:hover,
.sfc-product-card:focus-within {
    transform: translateY(-4px);
    box-shadow:
        0 1px 2px rgba(26, 38, 64, 0.04),
        0 20px 40px -16px rgba(26, 38, 64, 0.25);
}

.woocommerce ul.products li.product > a.woocommerce-LoopProduct-link,
.sfc-product-card > a.woocommerce-LoopProduct-link {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-decoration: none;
    color: inherit;
}

/* ============================================================
 * Zone media (badges + image) — ratio carré 1:1
 * ============================================================ */
.sfc-product-card__media {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    background: var(--color-cream);
    overflow: hidden;
}

.woocommerce ul.products li.product .sfc-product-card__media img,
.sfc-product-card__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
    margin: 0;
    padding: 0;
    border-radius: 0;
}

.sfc-product-card:hover .sfc-product-card__media img,
.sfc-product-card:focus-within .sfc-product-card__media img,
.woocommerce ul.products li.product:hover .sfc-product-card__media img,
.woocommerce ul.products li.product:focus-within .sfc-product-card__media img {
    transform: scale(1.04);
}

/* 2e image (gallery[0]) au hover — superposée sur la 1re, opacité 0 → 1 */
.sfc-product-card__media .sfc-product-card__img--hover {
    opacity: 0;
    transition:
        opacity var(--duration-slow) var(--ease-out),
        transform 700ms var(--ease-out);
}

.sfc-product-card:hover .sfc-product-card__media .sfc-product-card__img--hover,
.sfc-product-card:focus-within .sfc-product-card__media .sfc-product-card__img--hover,
.woocommerce ul.products li.product:hover .sfc-product-card__media .sfc-product-card__img--hover {
    opacity: 1;
}

/* Accessibilité : pas de mouvement (lift/zoom) si l'utilisateur le refuse —
   l'ombre au survol reste comme repère (ce n'est pas du mouvement). */
@media (prefers-reduced-motion: reduce) {
    .sfc-product-card,
    .sfc-product-card__media img,
    .sfc-product-card__media .sfc-product-card__img--hover {
        transition: box-shadow 350ms ease;
    }
    .woocommerce ul.products li.product:hover,
    .woocommerce ul.products li.product:focus-within,
    .sfc-product-card:hover,
    .sfc-product-card:focus-within {
        transform: none;
    }
    /* !important : neutralise aussi le zoom de __img--main (sélecteur :not(:has())
       très spécifique) — uniquement sous reduced-motion, sans effet ailleurs. */
    .sfc-product-card:hover .sfc-product-card__media img,
    .sfc-product-card:focus-within .sfc-product-card__media img,
    .woocommerce ul.products li.product:hover .sfc-product-card__media img,
    .woocommerce ul.products li.product:focus-within .sfc-product-card__media img {
        transform: none !important;
    }
}

/* ============================================================
 * UNIFORMITÉ DES CARDS PRODUIT (toutes grilles WC)
 *
 * Pattern : grid avec align-items: stretch → toutes les cards prennent la
 * même hauteur. Dans chaque <li>, le <a> WC wrap est en flex column flex:1,
 * la zone media a un aspect-ratio rigide (carré), le body grandit avec
 * flex:1, le bouton add-to-cart est poussé en bas via margin-top: auto.
 *
 * S'applique aux grilles :
 *   - boutique principale (.sfc-shop-archive .products)
 *   - catégorie / tag produit
 *   - produits liés en single (.related .products, .upsells .products)
 *   - section « Shop the look » sur single-sfc_look (.sfc-look-single__products)
 *   - bundle « bundled products » du plugin WC PB
 * ============================================================ */
.woocommerce ul.products,
.woocommerce-page ul.products,
.sfc-look-single__products,
.related ul.products,
.upsells ul.products,
.up-sells ul.products,
.cross-sells ul.products {
    align-items: stretch;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.sfc-product-card {
    height: 100%;
    align-self: stretch;
}

/* Le <a> WC qui wrappe media + body : doit prendre toute la hauteur du <li>. */
.woocommerce ul.products li.product > a.woocommerce-LoopProduct-link,
.sfc-product-card > a.woocommerce-LoopProduct-link {
    height: auto;
    min-height: 0;
}

/* Zone media : aspect-ratio rigide, flex-shrink: 0 → ne se compresse jamais. */
.sfc-product-card__media,
.woocommerce ul.products li.product .sfc-product-card__media {
    flex-shrink: 0;
    aspect-ratio: 1 / 1;
}

/* Body : flex column qui grandit pour combler l'espace restant. */
.sfc-product-card__body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    /* Prix en bas du body même si titre court */
    justify-content: space-between;
}

/* Bouton add-to-cart (hors <a> WC) : pousser en bas du <li>. */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart,
.sfc-product-card > .button,
.sfc-product-card > .added_to_cart {
    margin-top: auto;
}

/* ============================================================
 * Zoom de fallback au hover quand le produit n'a PAS de 2e image gallery.
 * Le hover devient ainsi visuellement homogène avec les produits qui ont
 * une 2e image (scale 1.04 déjà appliqué) — pas de "rien ne se passe".
 * ============================================================ */
.sfc-product-card__media:not(:has(.sfc-product-card__img--hover))
    .sfc-product-card__img--main {
    transition: transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.sfc-product-card:hover .sfc-product-card__media:not(:has(.sfc-product-card__img--hover)) .sfc-product-card__img--main,
.woocommerce ul.products li.product:hover .sfc-product-card__media:not(:has(.sfc-product-card__img--hover)) .sfc-product-card__img--main {
    transform: scale(1.08);
}

/* Fallback pour navigateurs sans :has() — appliquer le zoom à toutes les
   images principales (les cards à 2 images font déjà du scale via la règle
   plus haut, c'est compatible). */
@supports not selector(:has(*)) {
    .sfc-product-card__media .sfc-product-card__img--main {
        transition: transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
    }
    .sfc-product-card:hover .sfc-product-card__media .sfc-product-card__img--main {
        transform: scale(1.04);
    }
}

/* ============================================================
 * Badges (Sélection, Nouveau) — superposés en haut à gauche
 * ============================================================ */
.sfc-product-card__media .onsale,
.sfc-product-card__media .sfc-badge {
    position: absolute;
    z-index: 2;
    top: 12px;
    margin: 0;
    min-height: auto;
    min-width: auto;
    padding: 5px 12px;
    border-radius: 100px;
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    line-height: 1.3;
}

/* Badge "Sélection" — terracotta à gauche */
.sfc-product-card__media .onsale,
.sfc-product-card__media .sfc-badge--selection {
    left: 12px;
    background: var(--color-accent);
    color: var(--color-white);
    box-shadow: 0 4px 12px -2px rgba(201, 116, 86, 0.45);
}

/* ============================================================
 * Filtre boutique (Themify) — habillage DA Madame's Home (T6).
 * Barre liquid-glass crème : Recherche + Prix côte à côte, slider rose.
 * ============================================================ */
.sfc-shop-filters {
    margin: 0 0 clamp(28px, 4vw, 40px);
    padding: clamp(18px, 2.4vw, 26px) clamp(20px, 3vw, 30px);
    background: color-mix(in srgb, var(--color-white) 70%, transparent);
    -webkit-backdrop-filter: blur(16px) saturate(1.15);
            backdrop-filter: blur(16px) saturate(1.15);
    border: 1px solid color-mix(in srgb, var(--color-primary) 14%, transparent);
    border-radius: var(--radius-lg, 18px);
    box-shadow:
        0 1px 0 0 color-mix(in srgb, var(--color-white) 85%, transparent) inset,
        0 18px 40px -28px color-mix(in srgb, var(--color-primary-deep, #A8525A) 26%, transparent);
}

/* Disposition horizontale, alignée en bas, responsive (stack si étroit). */
.sfc-shop-filters .wpf_items_wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: clamp(18px, 3vw, 36px);
    margin: 0;
}
.sfc-shop-filters .wpf_item {
    position: relative;
    flex: 1 1 240px;
    min-width: 0;
    margin: 0;
    padding: 0 0 4px;
    border: 0;
}
.sfc-shop-filters .wpf_item_price { flex: 1 1 300px; }

/* Libellés de champ — eyebrow DA (rose poudré, capitales, tracking large). */
/* .wpf_item ajouté pour battre la spécificité de Themify (.wpf_item .wpf_item_name). */
.sfc-shop-filters .wpf_item .wpf_item_name {
    margin: 0 0 12px;
    padding: 0; /* retire aussi le padding-bottom .8em de Themify */
    border: 0;  /* retire le filet gris par défaut de Themify */
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: var(--tracking-wider, 0.16em);
    text-transform: uppercase;
    color: var(--color-primary);
}

/* Champ recherche — pilule crème, focus rose. */
.sfc-shop-filters .wpf_autocomplete { position: relative; }
.sfc-shop-filters .wpf_autocomplete input[type="text"] {
    box-sizing: border-box;
    width: 100%;
    height: 44px;
    padding: 0 18px;
    background: var(--color-cream);
    border: 1px solid color-mix(in srgb, var(--color-primary) 16%, transparent);
    border-radius: 999px;
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--color-ink);
    transition: border-color var(--duration-base, 240ms) var(--ease-out, ease),
                box-shadow var(--duration-base, 240ms) var(--ease-out, ease),
                background var(--duration-base, 240ms) var(--ease-out, ease);
}
.sfc-shop-filters .wpf_autocomplete input[type="text"]::placeholder { color: var(--color-text-muted); }
.sfc-shop-filters .wpf_autocomplete input[type="text"]:focus {
    outline: none;
    background: var(--color-white);
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 55%, transparent);
}

/* Slider prix (jQuery UI). NB : on cible `.wpf_slider.ui-slider [...]` pour passer
   AU-DESSUS des règles Themify (qui se chargent après et stylent en violet). */
.sfc-shop-filters .wpf_slider.ui-slider {
    position: relative;
    height: 5px;
    margin: 20px 9px 14px;
    background: color-mix(in srgb, var(--color-primary) 16%, transparent);
    border: 0;
    border-radius: 999px;
}
.sfc-shop-filters .wpf_slider.ui-slider .ui-slider-range {
    position: absolute;
    top: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-deep, #A8525A));
    border-radius: 999px;
}
.sfc-shop-filters .wpf_slider.ui-slider .ui-slider-handle {
    position: absolute;
    top: 50%;
    width: 18px;
    height: 18px;
    margin-left: -9px;
    transform: translateY(-50%);
    background: var(--color-white);
    border: 2px solid var(--color-primary);
    border-radius: 50%;
    box-shadow: 0 2px 6px -1px color-mix(in srgb, var(--color-primary-deep, #A8525A) 50%, transparent);
    cursor: grab;
    transition: border-color var(--duration-base, 240ms) var(--ease-out, ease),
                box-shadow var(--duration-base, 240ms) var(--ease-out, ease);
}
.sfc-shop-filters .wpf_slider.ui-slider .ui-slider-handle:hover,
.sfc-shop-filters .wpf_slider.ui-slider .ui-slider-handle:focus {
    border-color: var(--color-primary-deep, #A8525A);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 50%, transparent);
    outline: none;
}
.sfc-shop-filters .wpf_slider.ui-slider .ui-slider-handle:active { cursor: grabbing; }

/* Bornes min–max du prix. */
.sfc-shop-filters .wpf-slider-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--color-ink);
}
.sfc-shop-filters .wpf-slider-label .woocommerce-Price-amount { color: var(--color-accent); }

/* Boutons « Réinitialiser » — petits liens discrets, en haut à droite du champ. */
.sfc-shop-filters .wpf_reset_btn {
    position: absolute;
    top: 0;
    right: 0;
}
.sfc-shop-filters .wpf_reset_btn input[type="reset"] {
    margin: 0;
    padding: 0;
    background: none;
    border: 0;
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 0.03em;
    text-decoration: underline;
    text-underline-offset: 3px;
    cursor: pointer;
    transition: color var(--duration-base, 240ms) var(--ease-out, ease);
}
.sfc-shop-filters .wpf_reset_btn input[type="reset"]:hover,
.sfc-shop-filters .wpf_reset_btn input[type="reset"]:focus-visible {
    color: var(--color-primary);
    outline: none;
}

/* Message « aucun produit » dans le filtre. */
.sfc-shop-filters .wpf-no-products-found { margin: 14px 0 0; }
.sfc-shop-filters .wpf-no-products-found .woocommerce-info {
    margin: 0;
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--color-text-muted);
}

/* ---- T7 : bouton « Filtrer » + drawer mobile ----
 * Desktop : filtre inline (ci-dessus) ; bouton/en-tête/overlay masqués. */
.sfc-filters-toggle { display: none; }
.sfc-shop-filters__head { display: none; }
.sfc-shop-filters__overlay { display: none; }

@media (max-width: 1024px) {
    /* Déclencheur : pilule rose, alignée à droite sous les pills. */
    .sfc-filters-toggle {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        margin: 0 0 clamp(20px, 4vw, 28px);
        padding: 11px 20px;
        background: var(--color-white);
        color: var(--color-primary-deep, #A8525A);
        border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);
        border-radius: 999px;
        font-family: var(--font-body);
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        cursor: pointer;
        box-shadow: 0 2px 8px -4px color-mix(in srgb, var(--color-primary-deep, #A8525A) 40%, transparent);
        transition: background var(--duration-base, 240ms) var(--ease-out, ease),
                    color var(--duration-base, 240ms) var(--ease-out, ease),
                    border-color var(--duration-base, 240ms) var(--ease-out, ease);
    }
    .sfc-filters-toggle:hover,
    .sfc-filters-toggle[aria-expanded="true"] {
        background: var(--color-primary);
        color: var(--color-cream);
        border-color: var(--color-primary);
    }

    /* L'aside devient un drawer off-canvas (droite). */
    .sfc-shop-filters {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(88vw, 360px);
        margin: 0;
        padding: 0 22px 28px;
        border: 0;
        border-radius: 0;
        background: var(--color-cream);
        -webkit-backdrop-filter: none;
                backdrop-filter: none;
        box-shadow: -12px 0 40px -8px rgba(26, 38, 64, 0.28);
        z-index: 200;
        overflow-y: auto;
        overscroll-behavior: contain;
        transform: translateX(100%);
        visibility: hidden;
        transition: transform 380ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 380ms;
    }
    .sfc-shop-filters.is-open {
        transform: translateX(0);
        visibility: visible;
        transition: transform 380ms cubic-bezier(0.22, 1, 0.36, 1);
    }

    /* En-tête du drawer (titre + fermeture), collant en haut. */
    .sfc-shop-filters__head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        position: sticky;
        top: 0;
        margin: 0 -22px 18px;
        padding: 18px 22px;
        background: var(--color-cream);
        border-bottom: 1px solid color-mix(in srgb, var(--color-primary) 14%, transparent);
        z-index: 1;
    }
    .sfc-shop-filters__head-title {
        font-family: var(--font-display);
        font-size: var(--text-lg, 19px);
        color: var(--color-ink);
    }
    .sfc-shop-filters__close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        padding: 0;
        background: none;
        border: 0;
        border-radius: 50%;
        color: var(--color-ink);
        cursor: pointer;
        transition: background var(--duration-base, 240ms) var(--ease-out, ease),
                    color var(--duration-base, 240ms) var(--ease-out, ease);
    }
    .sfc-shop-filters__close:focus { outline: none; }
    .sfc-shop-filters__close:hover,
    .sfc-shop-filters__close:focus-visible {
        background: color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 50%, transparent);
        color: var(--color-primary-deep, #A8525A);
        outline: none;
    }
    .sfc-shop-filters__close:focus-visible {
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 60%, transparent);
    }

    /* Dans le drawer étroit : champs empilés. */
    .sfc-shop-filters .wpf_items_wrapper { flex-direction: column; align-items: stretch; gap: 24px; }
    .sfc-shop-filters .wpf_item { flex: 1 1 auto; }

    /* Overlay sombre derrière le drawer. */
    .sfc-shop-filters__overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(26, 38, 64, 0.45);
        z-index: 199;
        opacity: 0;
        /* ANIM-62 : synchronisé sur le glissement du drawer filtres (380ms + --ease-out). */
        transition: opacity 380ms var(--ease-out, cubic-bezier(0.22, 1, 0.36, 1));
    }
    .sfc-shop-filters__overlay.is-open { opacity: 1; }
    .sfc-shop-filters__overlay[hidden] { display: none; }
}

/* ============================================================
 * Body (eyebrow catégorie + titre + prix) — Madame's Home v3
 * ============================================================ */
.sfc-product-card__body {
    display: flex;
    flex-direction: column;
    padding: 20px 20px 18px;
    flex: 1;
}

/* Eyebrow catégorie — signature MH, rose poudré, tracking large. */
.sfc-product-card__cat {
    display: block;
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: var(--space-2);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
    font-family: var(--font-display);    /* Frank Ruhl Libre */
    font-size: var(--text-lg);
    font-weight: 400;
    color: var(--color-ink);
    padding: 0;
    margin: 0 0 var(--space-2);
    line-height: var(--leading-snug);
    text-align: left;
    transition: color var(--duration-base) var(--ease-out);
}

.woocommerce ul.products li.product:hover .woocommerce-loop-product__title {
    color: var(--color-primary);
}

.woocommerce ul.products li.product .price {
    font-family: var(--font-body);
    font-size: 15px;
    font-weight: 600;
    color: var(--color-accent);
    padding: 0;
    margin: 0;
    display: block;
    text-align: left;
}

.woocommerce ul.products li.product .price del {
    color: var(--color-text-muted);
    font-weight: 400;
    margin-right: 6px;
}

.woocommerce ul.products li.product .price ins {
    background: transparent;
    color: var(--color-accent);
    text-decoration: none;
    font-weight: 600;
}

/* Note moyenne (étoiles) */
.woocommerce ul.products li.product .star-rating {
    font-size: 12px;
    margin: 4px 0 6px;
    color: var(--color-gold);
}

/* ============================================================
 * Bouton "Ajouter au panier"
 * ============================================================ */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: center; /* centrage horizontal dans la carte (flex column), tous écrans */
    gap: 6px;
    width: calc(100% - 36px);
    margin: 0 18px 18px;
    padding: 12px 18px;
    background: var(--color-primary);
    color: var(--color-cream);
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border: 0;
    border-radius: 100px;
    text-decoration: none;
    box-shadow: 0 6px 16px -8px rgba(26, 38, 64, 0.45);
    transition: background-color 220ms ease, transform 220ms ease,
                box-shadow 220ms ease, color 220ms ease;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .button:focus-visible,
.woocommerce ul.products li.product .added_to_cart:hover {
    background: var(--color-accent);
    color: var(--color-white);
    transform: translateY(-1px);
    box-shadow: 0 10px 22px -8px rgba(201, 116, 86, 0.5);
    outline: none;
}

/* État "Ajouté !" */
.woocommerce ul.products li.product .button.added,
.woocommerce ul.products li.product .button.loading {
    background: var(--color-forest);
    color: var(--color-cream);
}

.woocommerce ul.products li.product .button.loading::before {
    margin-right: 6px;
}

.woocommerce ul.products li.product .added_to_cart {
    background: var(--color-forest);
}

/* ============================================================
 * Pagination
 * ============================================================ */
.woocommerce nav.woocommerce-pagination {
    margin: clamp(36px, 5vw, 56px) 0 16px;
    display: flex;
    justify-content: center;
}

/* Piste "liquid glass" : conteneur en pilule translucide, blur + reflet, centré. */
.woocommerce nav.woocommerce-pagination ul {
    border: 1px solid color-mix(in srgb, var(--color-primary) 14%, transparent);
    margin: 0;
    padding: 6px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-white) 60%, transparent);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
            backdrop-filter: blur(16px) saturate(1.2);
    box-shadow:
        0 1px 0 0 color-mix(in srgb, var(--color-white) 85%, transparent) inset,
        0 18px 40px -24px color-mix(in srgb, var(--color-primary-deep, #A8525A) 28%, transparent);
}

.woocommerce nav.woocommerce-pagination ul li {
    border: 0;
    margin: 0;
    display: flex;
}

/* NB : on cible .page-numbers explicitement pour battre la spécificité de
   WooCommerce core (chargé après, qui force display:block + padding sur ul li a/span). */
.woocommerce nav.woocommerce-pagination ul li a.page-numbers,
.woocommerce nav.woocommerce-pagination ul li span.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    box-sizing: border-box;
    width: 40px;
    min-width: 40px;
    height: 40px;
    /* padding-top 2px : compense le métrique Josefin Sans (chiffres sans descendante
       qui remontent de ~1px). Mesuré : recentre l'encre pile au centre du rond. */
    padding: 5px 0 0;
    margin: 0;
    border: 0;
    float: none;
    border-radius: 999px;
    background: transparent;
    color: var(--color-primary-deep, #A8525A);
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.02em;
    transition:
        background var(--duration-base, 240ms) var(--ease-out, ease),
        color var(--duration-base, 240ms) var(--ease-out, ease),
        transform var(--duration-base, 240ms) var(--ease-spring, ease),
        box-shadow var(--duration-base, 240ms) var(--ease-out, ease);
}

/* Survol / focus des liens : halo rose poudré doux. */
.woocommerce nav.woocommerce-pagination ul li a.page-numbers:hover,
.woocommerce nav.woocommerce-pagination ul li a.page-numbers:focus-visible {
    background: color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 60%, transparent);
    color: var(--color-primary-deep, #A8525A);
    transform: translateY(-1px);
    outline: none;
}

/* Page courante : blush doux — fond rose pâle translucide, chiffre rose profond. */
.woocommerce nav.woocommerce-pagination ul li span.page-numbers.current {
    background: color-mix(in srgb, var(--color-primary-soft, #FFCBCC) 55%, transparent);
    color: var(--color-primary-deep, #A8525A);
    font-weight: 600;
    box-shadow:
        0 1px 0 0 color-mix(in srgb, var(--color-white) 50%, transparent) inset;
}

/* Flèches précédent / suivant : touche rose, légèrement plus grandes. */
.woocommerce nav.woocommerce-pagination ul li a.page-numbers.prev,
.woocommerce nav.woocommerce-pagination ul li a.page-numbers.next {
    color: var(--color-primary);
    font-size: 17px;
}

/* ============================================================
 * Empty state (catégorie vide ou recherche sans résultat)
 * ============================================================ */
.sfc-shop-empty {
    text-align: center;
    padding: 56px 24px;
    background: var(--color-white);
    border-radius: 14px;
    max-width: 560px;
    margin: 0 auto;
    box-shadow:
        0 1px 2px rgba(26, 38, 64, 0.05),
        0 20px 40px -22px rgba(26, 38, 64, 0.18);
}

.sfc-shop-empty__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    color: var(--color-gold);
    display: block;
    opacity: 0.75;
}

.sfc-shop-empty__title {
    font-family: var(--font-heading);
    font-size: clamp(20px, 2.4vw, 26px);
    font-weight: 600;
    color: var(--color-primary);
    margin: 0 0 8px;
}

.sfc-shop-empty__text {
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0 0 22px;
}

.sfc-shop-empty__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-accent);
    color: var(--color-white);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 12px 24px;
    border-radius: 100px;
    text-decoration: none;
    box-shadow: 0 8px 20px -8px rgba(201, 116, 86, 0.5);
    transition: background-color 220ms ease, transform 220ms ease,
                box-shadow 220ms ease;
}

.sfc-shop-empty__cta:hover {
    background: var(--color-primary);
    transform: translateY(-1px);
    box-shadow: 0 12px 28px -8px rgba(26, 38, 64, 0.45);
}

.sfc-shop-empty__cta svg { transition: transform 200ms ease; }
.sfc-shop-empty__cta:hover svg { transform: translateX(3px); }

/* ============================================================
 * Responsive
 * 3 col : desktop & laptop (>900px)
 * 2 col : tablette (≤900px)
 * 1 col : mobile (≤640px)
 * ============================================================ */
@media (max-width: 900px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }

    .sfc-shop-pill { padding: 8px 14px; font-size: 12px; }
}

@media (max-width: 640px) {
    .sfc-shop-archive__hero { margin-bottom: 24px; }

    .woocommerce ul.products,
    .woocommerce-page ul.products {
        grid-template-columns: 1fr;
        max-width: 420px;
        margin-inline: auto;
        gap: 16px;
    }

    /* Catégories : on conserve le carrousel 1 ligne à défilement latéral.
       Aligné à gauche (la pill « Toutes » démarre au bord) et fondus réduits. */
    .sfc-shop-pills {
        justify-content: flex-start;
        gap: 8px;
        padding: 4px 20px;
        scroll-padding-inline: 20px;
        -webkit-mask-image: linear-gradient(to right, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
                mask-image: linear-gradient(to right, transparent 0, #000 20px, #000 calc(100% - 20px), transparent 100%);
    }

    .sfc-shop-pill__icon { width: 15px; height: 15px; }

    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product .added_to_cart {
        width: calc(100% - 28px);
        margin: 0 14px 14px;
    }

    .sfc-product-card__body { padding: 14px 14px 10px; }
}

@media (prefers-reduced-motion: reduce) {
    .woocommerce ul.products li.product,
    .sfc-product-card,
    .sfc-product-card__media img,
    .sfc-shop-pill,
    .sfc-shop-pill__icon,
    .sfc-shop-empty__cta,
    .woocommerce ul.products li.product .button {
        transition: none;
    }
    .sfc-shop-pills { scroll-behavior: auto; }
}

/* ============================================================
 * Encart « Découvrir les coffrets » (boutique principale)
 * ============================================================ */
.sfc-shop-coffrets {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 24px;
    margin: 4px 0 36px;
    padding: 30px 36px;
    overflow: hidden;
    background: var(--color-primary);
    border: 1px solid rgba(201, 169, 97, 0.4);
    border-radius: var(--radius-ui);
}

.sfc-shop-coffrets::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--color-gold);
}

.sfc-shop-coffrets__content {
    min-width: 0;
}

.sfc-shop-coffrets__eyebrow {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 6px;
}

.sfc-shop-coffrets__title {
    font-family: var(--font-heading);
    font-size: clamp(22px, 2.6vw, 30px);
    font-weight: 600;
    color: var(--color-white);
    margin: 0 0 6px;
    line-height: 1.15;
}

.sfc-shop-coffrets__text {
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.6;
    color: var(--color-cream);
    margin: 0;
    max-width: 520px;
}

.sfc-shop-coffrets__cta {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-primary);
    background: var(--color-gold);
    border: 1px solid var(--color-gold);
    border-radius: var(--radius-ui);
    text-decoration: none;
    transition: var(--transition-base);
}

.sfc-shop-coffrets__cta:hover {
    background: transparent;
    color: var(--color-gold);
}

.sfc-shop-coffrets__cta svg {
    transition: transform 200ms ease;
}

.sfc-shop-coffrets__cta:hover svg {
    transform: translateX(4px);
}

@media (max-width: 640px) {
    .sfc-shop-coffrets { padding: 24px; }
    .sfc-shop-coffrets__cta { width: 100%; justify-content: center; }
}

/* Encart « Looks » (.sfc-shop-looks) : styles déplacés dans main.css —
 * composant désormais partagé entre la boutique et la page 404. */
