/* ── custom properties ───────────────────────────────────────────── */
:root {
  --sr-rp-accent:    #0d8065;
  --sr-rp-danger:    #c2412d;
  --sr-rp-dark:      #172033;
  --sr-rp-muted:     #607086;
  --sr-rp-border:    rgba(23, 32, 51, 0.1);
  --sr-rp-shadow-sm: 0 4px 16px rgba(23, 32, 51, 0.07);
  --sr-rp-shadow-md: 0 16px 40px rgba(23, 32, 51, 0.13);
  --sr-rp-radius:    10px;
  --sr-rp-ease:      180ms ease;
}

/* ── section wrapper ─────────────────────────────────────────────── */
.sr-related-products {
  position: relative;
  width: min(100%, 1440px);
  margin: 48px auto 0;
  /* padding-right à 0 : les cartes peuvent déborder légèrement */
  padding: 0 24px 16px 24px;
  color: var(--sr-rp-dark);
}

/* gradient de fade-out à droite — indique qu'il y a du contenu à scroller */
.sr-related-products::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 60px;
  background: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.92));
  pointer-events: none;
  z-index: 1;
}

/* ── header ──────────────────────────────────────────────────────── */
.sr-related-products__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--sr-rp-border);
}

.sr-related-products__title {
  position: relative;
  margin: 0;
  color: var(--sr-rp-dark);
  font-size: 26px;
  font-weight: 800;
  line-height: 1.2;
}

/* ── carousel (toutes tailles) ───────────────────────────────────── */
.sr-related-products__grid {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 24px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
}

.sr-related-products__grid::-webkit-scrollbar {
  display: none;
}

/* ── carte — desktop : 4 visibles ───────────────────────────────── */
/* calc : (100% du conteneur - 3 gaps) / 4 colonnes                 */
.sr-related-products__card {
  position: relative;
  display: flex;
  flex: 0 0 calc((100% - 3 * 20px) / 4);
  min-width: 0;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--sr-rp-border);
  border-radius: var(--sr-rp-radius);
  background: #fff;
  box-shadow: var(--sr-rp-shadow-sm);
  scroll-snap-align: start;
  transition:
    transform      var(--sr-rp-ease),
    box-shadow     var(--sr-rp-ease),
    border-color   var(--sr-rp-ease);
}

.sr-related-products__card,
.sr-related-products__card * {
  box-sizing: border-box;
}

.sr-related-products__card form,
.sr-related-products__card button {
  float: none;
}

.sr-related-products__card .button-action,
.sr-related-products__card .button-action-bottom,
.sr-related-products__card .sr-product-actions,
.sr-related-products__card .sr-card-action-form,
.sr-related-products__card .sr-card-action-hook,
.sr-related-products__card .sr-card-action-btn,
.sr-related-products__card .quick-view:not(.sr-rp-quickview-btn),
.sr-related-products__card .add_to_compare,
.sr-related-products__card .wishlist,
.sr-related-products__card .wishlist-button,
.sr-related-products__card .wishlist-button-add {
  display: none !important;
}

.sr-related-products__card:hover {
  border-color: rgba(13, 128, 101, 0.3);
  box-shadow: var(--sr-rp-shadow-md);
  transform: translateY(-3px);
}

/* espace respiration après la dernière carte */
.sr-related-products__card:last-child {
  margin-right: 24px;
}

/* ── media / image ───────────────────────────────────────────────── */
.sr-related-products__media {
  position: relative;
  display: flex;
  aspect-ratio: 1 / 1;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  background: #f4f6f9;
  overflow: hidden;
}

.sr-related-products__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 16px;
  transition: transform 260ms ease;
}

.sr-related-products__card:hover .sr-related-products__media img {
  transform: scale(1.06);
}

/* overlay on hover */
.sr-related-products__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(13, 128, 101, 0.08);
  opacity: 0;
  transition: opacity var(--sr-rp-ease);
}

.sr-related-products__card:hover .sr-related-products__media::after {
  opacity: 1;
}

/* ── flags / badges ──────────────────────────────────────────────── */
.sr-related-products__flags {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: flex;
  max-width: calc(100% - 20px);
  flex-wrap: wrap;
  gap: 5px;
}

.sr-related-products__flag {
  border-radius: 999px;
  background: var(--sr-rp-dark);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  line-height: 1;
  padding: 5px 9px;
  text-transform: uppercase;
}

.sr-related-products__flag--new {
  background: var(--sr-rp-accent);
}

.sr-related-products__flag--discount,
.sr-related-products__flag--on-sale {
  background: var(--sr-rp-danger);
}

/* ── card body ───────────────────────────────────────────────────── */
.sr-related-products__body {
  display: flex;
  min-height: 148px;
  flex: 1;
  min-width: 0;
  flex-direction: column;
  padding: 16px;
}

.sr-related-products__name {
  margin: 0 0 auto;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  min-width: 0;
}

.sr-related-products__name a {
  color: var(--sr-rp-dark);
  text-decoration: none;
  transition: color var(--sr-rp-ease);
}

.sr-related-products__name a:hover {
  color: var(--sr-rp-accent);
}

/* ── price ───────────────────────────────────────────────────────── */
.sr-related-products__price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 14px;
}

.sr-related-products__regular-price {
  color: #a0aab5;
  font-size: 12px;
  text-decoration: line-through;
}

.sr-related-products__current-price {
  color: var(--sr-rp-dark);
  font-size: 18px;
  font-weight: 800;
}

.sr-related-products__current-price--promo {
  color: var(--sr-rp-danger);
}

/* ── cart form wrapper ───────────────────────────────────────────── */
.sr-related-products__cart-form {
  margin: 0;
  padding: 0;
}

/* ── CTA button ──────────────────────────────────────────────────── */
.sr-related-products__link {
  display: inline-flex;
  width: 100%;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--sr-rp-accent);
  border-radius: 6px;
  background: var(--sr-rp-accent);
  color: #fff;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-decoration: none;
  transition:
    background    var(--sr-rp-ease),
    color         var(--sr-rp-ease),
    border-color  var(--sr-rp-ease),
    box-shadow    var(--sr-rp-ease);
}

.sr-related-products__link:hover,
.sr-related-products__link:focus {
  background: #0a6e57;
  border-color: #0a6e57;
  box-shadow: 0 4px 14px rgba(13, 128, 101, 0.35);
  color: #fff;
  text-decoration: none;
  outline: none;
}

/* "Voir le produit" — ghost */
.sr-related-products__link--view {
  background: transparent;
  color: var(--sr-rp-accent);
}

.sr-related-products__link--view:hover,
.sr-related-products__link--view:focus {
  background: var(--sr-rp-accent);
  color: #fff;
}

/* Rupture de stock */
.sr-related-products__link--disabled {
  background: #e5e8ec;
  border-color: #e5e8ec;
  color: #8793a3;
  cursor: not-allowed;
}

.sr-related-products__link--disabled:hover,
.sr-related-products__link--disabled:focus {
  background: #e5e8ec;
  border-color: #e5e8ec;
  box-shadow: none;
  color: #8793a3;
}

/* ── tablette : 3 visibles ── 1199px ─────────────────────────────── */
@media (max-width: 1199px) {
  .sr-related-products__card {
    flex: 0 0 calc((100% - 2 * 20px) / 3);
  }
}

/* ── mobile : ~1.5 visibles ── 767px ─────────────────────────────── */
@media (max-width: 767px) {
  .sr-related-products {
    margin-top: 32px;
    padding-inline: 16px 0;
  }

  .sr-related-products::after {
    width: 48px;
  }

  .sr-related-products__header {
    display: block;
    margin-bottom: 20px;
    padding-right: 16px;
  }

  .sr-related-products__title {
    font-size: 22px;
  }

  .sr-related-products__grid {
    gap: 12px;
    scroll-padding-left: 16px;
  }

  .sr-related-products__card {
    flex: 0 0 72vw;
    max-width: 260px;
  }

  .sr-related-products__card:last-child {
    margin-right: 16px;
  }

  .sr-related-products__body {
    min-height: 130px;
    padding: 12px;
  }

  .sr-related-products__name {
    font-size: 13px;
  }

  .sr-related-products__current-price {
    font-size: 16px;
  }

  .sr-related-products__link {
    min-height: 38px;
    font-size: 12px;
  }
}
