/* IPTV Charleroi v1.3.8 — review carousel + schema-ready review block. */
.reviews-carousel {
  --review-gap: 22px;
  position: relative;
}

.reviews-carousel .reviews-head {
  padding-right: 124px;
}

.reviews-carousel .reviews-viewport {
  overflow: hidden;
  border-radius: 18px;
}

.reviews-carousel .reviews {
  display: flex;
  gap: var(--review-gap);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: 2px 2px 8px;
  margin: 0;
}

.reviews-carousel .reviews::-webkit-scrollbar {
  display: none;
}

.reviews-carousel .review-card {
  flex: 0 0 calc((100% - (var(--review-gap) * 2)) / 3);
  min-width: 0;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}

.reviews-carousel .review-controls {
  position: absolute;
  top: 8px;
  right: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 10px;
}

.reviews-carousel .review-controls button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid rgba(17,17,22,.12);
  background: rgba(255,255,255,.82);
  box-shadow: 0 12px 30px rgba(17,17,22,.08);
  backdrop-filter: blur(10px);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.reviews-carousel .review-controls button:hover,
.reviews-carousel .review-controls button:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(229,9,20,.35);
  background: #fff;
  box-shadow: 0 18px 38px rgba(229,9,20,.14);
  outline: none;
}

.reviews-carousel .review-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
}

.reviews-carousel .review-dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(17,17,22,.18);
  cursor: pointer;
  transition: width .25s ease, background .25s ease, transform .25s ease;
}

.reviews-carousel .review-dot.is-active {
  width: 24px;
  background: linear-gradient(135deg, #e50914, #a90008);
  box-shadow: 0 8px 18px rgba(229,9,20,.22);
}

.reviews-carousel .review-dot:focus-visible {
  outline: 2px solid rgba(229,9,20,.35);
  outline-offset: 3px;
}

.reviews-carousel .reviews-summary {
  max-width: min(100%, 720px);
}

.reviews-carousel .review-card {
  background: linear-gradient(145deg, #fff, #fbfbfc);
  border: 1px solid rgba(17,17,22,.08);
  box-shadow: 0 18px 48px rgba(17,17,22,.08);
}

.reviews-carousel .review-card::before {
  opacity: .72;
}

.reviews-carousel .review-card:hover {
  border-color: rgba(229,9,20,.18);
  transform: translateY(-3px);
}

.ipch-page-reviews-section {
  padding-top: 28px;
  padding-bottom: 50px;
  background:
    radial-gradient(circle at 12% 0%, rgba(229,9,20,.045), transparent 36%),
    linear-gradient(180deg, #fff, #f7f7f8);
}

.ipch-page-reviews {
  padding: 28px;
  border-radius: 24px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(17,17,22,.08);
  box-shadow: 0 24px 70px rgba(17,17,22,.08);
}

.ipch-page-reviews .reviews-head {
  margin-bottom: 18px;
}

@media (max-width: 1040px) {
  .reviews-carousel .review-card {
    flex-basis: calc((100% - var(--review-gap)) / 2);
  }
}

@media (max-width: 720px) {
  .reviews-carousel .reviews-head {
    padding-right: 0;
  }

  .reviews-carousel .review-controls {
    position: static;
    justify-content: flex-end;
    margin: 12px 0 10px;
  }

  .reviews-carousel .review-card {
    flex-basis: min(86vw, 330px);
  }

  .ipch-page-reviews {
    padding: 20px;
    border-radius: 18px;
  }
}
.fa-star::before { --ipch-icon: url("../../img/icons/star.svg"); }
