/* Support image produit (Divi shop loop) */
.woocommerce ul.products li.product .et_shop_image {
  position: relative;
  display: block;
  overflow: hidden;
  /* Taille de police de base définie dynamiquement par JavaScript selon la largeur de l'image */
  font-size: 120px !important; /* Valeur par défaut, sera remplacée par JS */
}

/* TRANSPORT OFFERT via classe de livraison */
.woocommerce ul.products li.product.shipping-transport-offert .et_shop_image::before {
  content: "TRANSPORT OFFERT";
  position: absolute;
  top: 1.6em;
  left: 3.5em;
  min-width: 12em;
  padding: 0.04em 3em;
  font-size: 0.11em;
  line-height: 0.85;
  font-weight: 600;
  background: rgba(46, 204, 113, 0.9);
  color: #fff;
  transform: rotate(45deg);
  transform-origin: center;
  z-index: 10;
  text-transform: uppercase;
  white-space: pre-wrap;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  pointer-events: none;
}

/* Bandeau Promo (.onsale) — même taille de texte que Transport offert (--opw-badge-font par JS) */
.woocommerce ul.products li.product .onsale,
.woocommerce-page ul.products li.product .onsale {
  left: 10px !important;
  right: auto !important;
  top: 0.625em !important;
  margin: 0 !important;
  padding: 0em 0.2em !important;
  font-size: var(--opw-badge-font, 1.25em);
  line-height: 2em !important;
  border-radius: 0.1875em !important;
  text-align: left !important;
}

/* Livraison rapide (tag livraison-rapide) — même technique que .onsale, tailles en em */
/* Seul : prend la place de .onsale (haut gauche). Avec .onsale : en dessous. */
.woocommerce ul.products li.product .opw-livraison-badge,
.woocommerce-page ul.products li.product .opw-livraison-badge {
  z-index: 2;
  position: absolute;
  left: 10px !important;
  right: auto !important;
  top: 0.625em !important;
  bottom: auto !important;
  margin: 0 !important;
  padding: 0em 0.2em !important;
  border-radius: 0.1875em !important;
  box-shadow: none !important;
  color: #fff;
  font-size: var(--opw-badge-font, 1.25em);
  font-weight: 500 !important;
  line-height: 2em !important;
  min-height: 0 !important;
  min-width: 0 !important;
  text-shadow: none !important;
  border-style: solid;
  text-align: left !important;
}
/* Quand .onsale existe sur le même produit : livraison en dessous, même position à gauche que promo (10px) */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link:has(.onsale) .opw-livraison-badge,
.woocommerce-page ul.products li.product .woocommerce-LoopProduct-link:has(.onsale) .opw-livraison-badge {
  left: 10px !important;
  right: auto !important;
  top: 3em !important;
  bottom: auto !important;
}
.et_pb_shop .opw-livraison-badge {
  border-style: solid;
}
