/**
 * Single produit — Direction D2 "Showroom contemporain"
 *
 * Aligné sur la maquette validée (single-product-d2-showroom.html).
 *
 * Structure :
 *   - macq-product               : article racine (.product Woo + .macq-product--showroom)
 *   - macq-product__layout       : grid 3 cols desktop : thumbs | image | summary
 *   - macq-product__thumbs       : cercles "Lentille de couleur"
 *   - macq-product__main-image   : image principale
 *   - macq-product__summary      : reprend les hooks Woo natifs (.summary .entry-summary)
 *   - macq-product__tabs-section : tabs Description/Livraison (.woocommerce-tabs)
 *   - macq-product__sticky-bar   : prix + ATC fixés en bas du viewport (mobile only)
 *
 * Override des classes Woo natives :
 *   .summary .entry-summary, .quantity, .single_add_to_cart_button, etc.
 *   sont stylées via .macq-product en cascade pour garder la spécificité maîtrisée.
 *
 * Contrainte créative : "Lentille de couleur"
 *   → thumbs cercles 64px, hover scale 1.08 + halo rose pâle 6px
 */

/* ═══════════════════════════════════════════════════════════════
 *  CONTENEUR PRINCIPAL
 * ═══════════════════════════════════════════════════════════════ */

.macq-product {
  /* max-width retiré v1.5.13 (edge-to-edge) */
  max-width: none;
  margin-inline: auto;
  padding-block: clamp(1.5rem, 3vw, 2.5rem) clamp(3rem, 6vw, 5rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  font-family: var(--font-body);
  color: var(--color-ink);
}

/* Breadcrumb Woo (woocommerce_breadcrumb) */
.macq-product .woocommerce-breadcrumb,
.woocommerce-breadcrumb {
  /* max-width retiré v1.5.13 (edge-to-edge) */
  max-width: none;
  margin-inline: auto;
  padding: 1.25rem clamp(1.25rem, 4vw, 3rem);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: var(--color-ink-mute);
}

.woocommerce-breadcrumb a {
  color: var(--color-ink-mute);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}

.woocommerce-breadcrumb a:hover {
  color: var(--color-primary);
}

/* ═══════════════════════════════════════════════════════════════
 *  LAYOUT 3 COLONNES
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}

@media (min-width: 980px) {
  .macq-product__layout {
    grid-template-columns: 80px 1fr 380px;
    gap: clamp(1.5rem, 3vw, 2.5rem);
    align-items: start;
  }
}

@media (min-width: 1200px) {
  .macq-product__layout {
    grid-template-columns: 100px 1fr 420px;
  }
}

/* ═══════════════════════════════════════════════════════════════
 *  THUMBS — "Lentille de couleur"
 *
 *  Cercles 64px qui s'agrandissent au hover avec halo rose pâle.
 *  Active : anneau noir 2px. Évoque diaphragme photo / macro de fleur.
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__thumbs {
  display: flex;
  flex-direction: row;
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
  /* Mobile : on affiche les thumbs sous l'image en horizontal */
  order: 2;
}

@media (min-width: 980px) {
  .macq-product__thumbs {
    flex-direction: column;
    flex-wrap: nowrap;
    order: 1;
    position: sticky;
    top: calc(var(--macq-header-height, 88px) + 1rem);
  }
}

.macq-product__thumb {
  width: 64px;
  height: 64px;
  padding: 0;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  background: var(--color-pink-pale);
  border: 2px solid transparent;
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out);
}

.macq-product__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

.macq-product__thumb:hover {
  transform: scale(1.08);
  box-shadow: 0 0 0 6px var(--color-primary-tint);
}

.macq-product__thumb:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 6px var(--color-primary-tint), 0 0 0 8px var(--color-primary);
}

.macq-product__thumb.is-active {
  border-color: var(--color-ink);
  transform: scale(1.04);
}

/* ═══════════════════════════════════════════════════════════════
 *  IMAGE PRINCIPALE
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__main-image {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 0;
  background: var(--color-pink-pale);
  order: 1;
  isolation: isolate;
}

@media (min-width: 980px) {
  .macq-product__main-image {
    order: 2;
  }
}

.macq-product__main-image img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  transition: opacity var(--dur-base) var(--ease-out);
}

.macq-product__main-image.is-loading img {
  opacity: 0.5;
}

/* Badge stock/promo */
.macq-product__badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 2;
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--color-ink);
  color: var(--color-surface);
  padding: 0.5rem 0.75rem;
}

.macq-product__badge--sale {
  background: var(--color-primary);
}

/* ═══════════════════════════════════════════════════════════════
 *  SUMMARY — colonne droite
 *
 *  Reprend les hooks Woo natifs : titre, prix, excerpt, ATC, meta.
 *  On surcharge les classes Woo standard via .macq-product__summary.
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__summary {
  order: 3;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 980px) {
  .macq-product__summary {
    position: sticky;
    top: calc(var(--macq-header-height, 88px) + 1rem);
  }
}

/* Titre (woocommerce_template_single_title @ 5) */
.macq-product__summary .product_title,
.macq-product__summary h1.product_title {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  margin: 0;
}

/* Catégorie au-dessus du titre — on la rend manuellement via inc/woocommerce.php */
.macq-product__category {
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin: 0;
  display: block;
}

/* Prix (woocommerce_template_single_price @ 10) */
.macq-product__summary .price,
.macq-product__summary p.price {
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: 1.5rem;
  color: var(--color-primary);
  margin: 0;
}

.macq-product__summary .price del,
.macq-product__summary p.price del {
  color: var(--color-ink-mute);
  font-weight: var(--fw-light);
  margin-right: 0.375rem;
  font-size: 0.8em;
  text-decoration: line-through;
}

.macq-product__summary .price ins,
.macq-product__summary p.price ins {
  background: none;
  text-decoration: none;
  color: var(--color-primary);
}

/* Excerpt / short description (woocommerce_template_single_excerpt @ 20) */
.macq-product__summary .woocommerce-product-details__short-description {
  font-family: var(--font-body);
  font-weight: var(--fw-regular);
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-ink-soft);
}

.macq-product__summary .woocommerce-product-details__short-description p {
  margin: 0 0 0.75rem;
}

.macq-product__summary .woocommerce-product-details__short-description p:last-child {
  margin-bottom: 0;
}

/* Avis (woocommerce_template_single_rating @ 10 si on les active) — on les style sobrement */
.macq-product__summary .woocommerce-product-rating {
  font-size: 0.875rem;
}

/* ═══════════════════════════════════════════════════════════════
 *  ATC + variations + quantity
 *  Form Woo : <form class="cart variations_form"> ou <form class="cart">
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__summary form.cart {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 0;
}

/* Variations table (Woo génère un <table class="variations">) */
.macq-product__summary .variations {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}

.macq-product__summary .variations th,
.macq-product__summary .variations td {
  border: 0;
  padding: 0.375rem 0;
  vertical-align: middle;
}

.macq-product__summary .variations th.label {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 0.8125rem;
  color: var(--color-ink);
  letter-spacing: 0.02em;
  width: 35%;
  padding-right: 0.75rem;
}

.macq-product__summary .variations td.value {
  width: 65%;
}

.macq-product__summary .variations select {
  width: 100%;
  padding: 0.625rem 2rem 0.625rem 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: 0;
  background: var(--color-surface)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%231C1C1C' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E")
    no-repeat right 0.75rem center;
  appearance: none;
  -webkit-appearance: none;
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-ink);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out);
}

.macq-product__summary .variations select:hover,
.macq-product__summary .variations select:focus {
  border-color: var(--color-primary);
  outline: 0;
}

/* Lien "Effacer la sélection" */
.macq-product__summary .reset_variations {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-ink-mute);
  text-decoration: underline;
}

.macq-product__summary .reset_variations:hover {
  color: var(--color-primary);
}

/* Single variation wrap (description + prix dynamique) */
.macq-product__summary .single_variation_wrap {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.macq-product__summary .woocommerce-variation-description {
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-ink-soft);
}

.macq-product__summary .woocommerce-variation-price {
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: 1.25rem;
  color: var(--color-primary);
}

.macq-product__summary .woocommerce-variation-availability {
  font-size: 0.8125rem;
  color: var(--color-ink-mute);
}

/* Wrap quantity + ATC button */
.macq-product__summary .woocommerce-variation-add-to-cart,
.macq-product__summary .cart .quantity,
.macq-product__summary .cart .single_add_to_cart_button {
  /* Layout flex pour aligner qty + bouton */
}

.macq-product__summary form.cart > .quantity,
.macq-product__summary .woocommerce-variation-add-to-cart .quantity {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--color-border);
  border-radius: 0;
  overflow: hidden;
  flex: 0 0 auto;
}

.macq-product__summary .quantity input[type="number"],
.macq-product__summary .quantity .qty {
  width: 64px;
  height: 60px;
  border: 0;
  text-align: center;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 1rem;
  background: transparent;
  -moz-appearance: textfield;
  color: var(--color-ink);
}

.macq-product__summary .quantity input[type="number"]::-webkit-outer-spin-button,
.macq-product__summary .quantity input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Boutons +/- (si activés par un plugin ou manuellement) */
.macq-product__summary .quantity .minus,
.macq-product__summary .quantity .plus {
  width: 44px;
  height: 60px;
  background: transparent;
  border: 0;
  font-family: var(--font-body);
  font-size: 1.125rem;
  color: var(--color-ink);
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out);
}

.macq-product__summary .quantity .minus:hover,
.macq-product__summary .quantity .plus:hover {
  background: var(--color-pink-pale);
}

/* Bouton ATC */
.macq-product__summary .single_add_to_cart_button {
  flex: 1;
  background: var(--color-primary);
  color: var(--color-primary-ink);
  border: 2px solid var(--color-primary);
  border-radius: 0;
  padding: 0 1.75rem;
  height: 60px;
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: 1rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    background-color var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  white-space: nowrap;
  margin-left: 0.5rem; /* gap entre qty et ATC */
}

/* Hover : inversion des couleurs (fond blanc, texte rose, border rose) */
.macq-product__summary .single_add_to_cart_button:hover,
.macq-product__summary .single_add_to_cart_button:focus-visible {
  background: var(--color-surface);
  color: var(--color-primary);
  border-color: var(--color-primary);
  outline: 0;
}

.macq-product__summary .single_add_to_cart_button[disabled],
.macq-product__summary .single_add_to_cart_button.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ─── Trust signals (rendus via inc/woocommerce.php hook) ─── */
.macq-product__trust {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
}

.macq-product__trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.75rem;
  background: var(--color-pink-pale);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-ink);
}

.macq-product__trust-pill svg {
  width: 14px;
  height: 14px;
  color: var(--color-primary);
  flex: 0 0 auto;
}

/* ─── Product meta (woocommerce_template_single_meta @ 40) ─── */
.macq-product__summary .product_meta {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: var(--color-ink-mute);
  border-top: 1px solid var(--color-border);
  padding-top: 1rem;
  margin-top: 0.5rem;
}

.macq-product__summary .product_meta > span {
  display: block;
  margin-bottom: 0.25rem;
}

.macq-product__summary .product_meta a {
  color: var(--color-ink-mute);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}

.macq-product__summary .product_meta a:hover {
  color: var(--color-primary);
}

/* ═══════════════════════════════════════════════════════════════
 *  TABS — Description / Livraison
 *
 *  Markup Woo natif : <div class="woocommerce-tabs wc-tabs-wrapper">
 *    <ul class="tabs wc-tabs">
 *      <li class="description_tab active"><a>...</a></li>
 *      <li class="livraison_tab"><a>...</a></li>
 *    </ul>
 *    <div class="woocommerce-Tabs-panel woocommerce-Tabs-panel--description">...</div>
 *  </div>
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__tabs-section {
  /* max-width retiré v1.5.13 (edge-to-edge) */
  max-width: none;
  margin: clamp(2rem, 4vw, 4rem) auto 0;
  padding-inline: clamp(1.25rem, 4vw, 3rem);
}

.macq-product__tabs-section .woocommerce-tabs {
  border-top: 1px solid var(--color-border);
}

.macq-product__tabs-section .tabs.wc-tabs {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  border-bottom: 1px solid var(--color-border);
  overflow-x: auto;
  scrollbar-width: none;
}

.macq-product__tabs-section .tabs.wc-tabs::-webkit-scrollbar {
  display: none;
}

.macq-product__tabs-section .tabs.wc-tabs li {
  margin: 0;
  padding: 0;
  list-style: none;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.macq-product__tabs-section .tabs.wc-tabs li::before,
.macq-product__tabs-section .tabs.wc-tabs li::after {
  display: none !important;
}

.macq-product__tabs-section .tabs.wc-tabs li a {
  display: block;
  padding: 1rem 1.25rem;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 0.875rem;
  color: var(--color-ink-mute);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition:
    color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}

.macq-product__tabs-section .tabs.wc-tabs li a:hover {
  color: var(--color-ink);
}

.macq-product__tabs-section .tabs.wc-tabs li.active a {
  color: var(--color-ink);
  border-bottom-color: var(--color-primary);
}

/* Panels */
.macq-product__tabs-section .woocommerce-Tabs-panel {
  padding: clamp(1.5rem, 3vw, 2.5rem) 0;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-ink-soft);
}

.macq-product__tabs-section .woocommerce-Tabs-panel h2 {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 1.25rem;
  color: var(--color-ink);
  margin: 0 0 0.75rem;
  letter-spacing: -0.01em;
}

.macq-product__tabs-section .woocommerce-Tabs-panel p {
  margin: 0 0 0.75rem;
}

.macq-product__tabs-section .woocommerce-Tabs-panel p:last-child {
  margin-bottom: 0;
}

.macq-product__tabs-section .woocommerce-Tabs-panel ul {
  list-style: none;
  padding-left: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 1rem 0;
}

.macq-product__tabs-section .woocommerce-Tabs-panel ul li {
  position: relative;
  padding-left: 1.25rem;
}

.macq-product__tabs-section .woocommerce-Tabs-panel ul li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}

/* ═══════════════════════════════════════════════════════════════
 *  RELATED PRODUCTS — section "Vous pourriez aussi aimer"
 *
 *  Markup généré par notre override `woocommerce/content-product.php` :
 *    <section class="related products">
 *      <h2>Vous pourriez aussi aimer…</h2>
 *      <ul class="products">
 *        <li class="macq-related-card type-product ...">
 *          <a class="macq-related-card__link">
 *            <div class="macq-related-card__media">
 *              <span class="macq-related-card__badge">...</span>
 *              <img class="macq-related-card__image">
 *            </div>
 *            <div class="macq-related-card__body">
 *              <span class="macq-related-card__category">...</span>
 *              <h3 class="macq-related-card__title">...</h3>
 *              <p class="macq-related-card__price">...</p>
 *            </div>
 *          </a>
 *        </li>
 *      </ul>
 *    </section>
 *
 *  IMPORTANT : le CSS Woo natif est dequeued sur is_product() (cf inc/woocommerce.php),
 *  donc plus aucune règle `ul.products li.product` ne s'applique. CSS BEM propre,
 *  zéro !important, zéro héritage.
 * ═══════════════════════════════════════════════════════════════ */

.related.products,
.upsells.products {
  /* max-width retiré v1.5.13 (edge-to-edge) */
  max-width: none;
  margin: clamp(3rem, 6vw, 5rem) auto 0;
  padding-block: clamp(2rem, 4vw, 3rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  border-top: 1px solid var(--color-border);
}

.related.products > h2,
.upsells.products > h2 {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  color: var(--color-ink);
  text-align: center;
  margin: 0 0 clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.01em;
}

.related.products ul.products,
.upsells.products ul.products {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 2rem);
}

@media (min-width: 768px) {
  .related.products ul.products,
  .upsells.products ul.products {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* ─── Card ─── */
.macq-related-card {
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 0;
  max-width: 100%;
  background: transparent;
  border: 0;
}

.macq-related-card__link {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  text-decoration: none;
  color: inherit;
  border-radius: 0;
  outline-offset: 2px;
  transition: transform var(--dur-fast) var(--ease-out);
}

.macq-related-card__link:hover {
  transform: translateY(-2px);
}

.macq-related-card__link:focus-visible {
  outline: 2px solid var(--color-primary);
}

.macq-related-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 0;
  background: var(--color-pink-pale);
  isolation: isolate;
}

.macq-related-card__image {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  transition: transform var(--dur-base) var(--ease-out);
}

.macq-related-card__link:hover .macq-related-card__image {
  transform: scale(0.96);
}

.macq-related-card__badge {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 2;
  font-family: var(--font-display);
  font-size: 0.625rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--color-ink);
  color: var(--color-surface);
  padding: 0.25rem 0.5rem;
}

.macq-related-card__badge--sale {
  background: var(--color-primary);
}

.macq-related-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  padding-top: 0.25rem;
}

.macq-related-card__category {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

.macq-related-card__title {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 0.9375rem;
  line-height: 1.3;
  color: var(--color-ink);
  margin: 0;
}

.macq-related-card__price {
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: 0.9375rem;
  color: var(--color-primary);
  margin: 0;
}

.macq-related-card__price del {
  color: var(--color-ink-mute);
  font-weight: var(--fw-light);
  margin-right: 0.375rem;
  font-size: 0.85em;
  text-decoration: line-through;
}

.macq-related-card__price ins {
  background: none;
  text-decoration: none;
  color: var(--color-primary);
}

/* ═══════════════════════════════════════════════════════════════
 *  STICKY BAR MOBILE
 *
 *  Visible uniquement sous 768px.
 *  Apparaît au scroll quand l'ATC d'origine sort du viewport
 *  (toggle via JS + IntersectionObserver).
 * ═══════════════════════════════════════════════════════════════ */

.macq-product__sticky-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -4px 16px rgb(28 28 28 / 0.08);
  transform: translateY(100%);
  transition: transform var(--dur-base) var(--ease-out);
  /* hidden par défaut (set par PHP) — JS retire l'attribut + ajoute is-visible */
}

.macq-product__sticky-bar.is-visible {
  transform: translateY(0);
}

/* On ne montre la sticky bar QUE sur mobile/tablette */
@media (min-width: 768px) {
  .macq-product__sticky-bar {
    display: none !important;
  }
}

.macq-product__sticky-bar-inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  max-width: 100%;
}

.macq-product__sticky-bar-info {
  flex: 1;
  min-width: 0;
}

.macq-product__sticky-bar-title {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 0.8125rem;
  color: var(--color-ink);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.macq-product__sticky-bar-price {
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: 0.9375rem;
  color: var(--color-primary);
  margin: 0;
  line-height: 1.2;
}

.macq-product__sticky-bar-price del {
  color: var(--color-ink-mute);
  font-weight: var(--fw-light);
  font-size: 0.8em;
  margin-right: 0.25rem;
  text-decoration: line-through;
}

.macq-product__sticky-bar-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding-inline: 1rem;
  background: var(--color-primary);
  color: var(--color-primary-ink);
  border: 0;
  border-radius: 0;
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  font-size: 0.8125rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}

.macq-product__sticky-bar-btn:hover,
.macq-product__sticky-bar-btn:focus-visible {
  background: var(--color-primary-hover);
  outline: 0;
}

/* ═══════════════════════════════════════════════════════════════
 *  REDUCED MOTION
 * ═══════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  .macq-product__thumb,
  .macq-product__main-image img,
  .macq-product__sticky-bar,
  .macq-related-card__link,
  .macq-related-card__image,
  .macq-product__summary .single_add_to_cart_button,
  .macq-product__tabs-section .tabs.wc-tabs li a {
    transition: none !important;
  }
  .macq-product__thumb:hover {
    transform: none;
    box-shadow: none;
  }
  .macq-related-card__link:hover {
    transform: none;
  }
  .macq-related-card__link:hover .macq-related-card__image {
    transform: none;
  }
}

/* ═══════════════════════════════════════════════════════════════
 *  RESET MINIMAL POUR WOO
 *
 *  On a dequeue woocommerce-general.css + woocommerce-layout.css.
 *  On réintroduit ici uniquement le strict nécessaire (notices, messages).
 *  Tout le reste (.product, .summary, .single_add_to_cart_button, .variations)
 *  est styled par notre CSS plus haut.
 * ═══════════════════════════════════════════════════════════════ */

/* Notices Woo (Ajouté au panier, erreurs, etc.) */
.woocommerce-notices-wrapper {
  /* max-width retiré v1.5.13 (edge-to-edge) */
  max-width: none;
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 3rem);
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  list-style: none;
  margin: 1rem 0;
  padding: 1rem 1.25rem;
  border-radius: 0;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.woocommerce-message {
  background: var(--color-pink-pale);
  border-left: 3px solid var(--color-primary);
  color: var(--color-ink);
}

.woocommerce-info {
  background: #f4f6f8;
  border-left: 3px solid #4a90e2;
  color: var(--color-ink);
}

.woocommerce-error {
  background: #fff2f2;
  border-left: 3px solid #d32f2f;
  color: var(--color-ink);
}

.woocommerce-message a,
.woocommerce-info a,
.woocommerce-error a {
  color: var(--color-primary);
  text-decoration: underline;
}

.woocommerce-message a.button,
.woocommerce-info a.button {
  margin-left: auto;
  display: inline-block;
  padding: 0.5rem 1rem;
  background: var(--color-primary);
  color: var(--color-primary-ink);
  border-radius: 0;
  text-decoration: none;
  font-weight: var(--fw-medium);
  font-size: 0.8125rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: background-color var(--dur-fast) var(--ease-out);
}

.woocommerce-message a.button:hover,
.woocommerce-info a.button:hover {
  background: var(--color-primary-hover);
}

/* Stock messages */
.macq-product__summary .stock {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: var(--fw-medium);
  margin-top: 0.5rem;
}

.macq-product__summary .stock.in-stock {
  color: #2e7d32;
}

.macq-product__summary .stock.out-of-stock,
.macq-product__summary .stock.available-on-backorder {
  color: var(--color-ink-mute);
}
