/* ==========================================================================
   Generic Slider — Track/Pfeile/Dots/Touch
   Inhalt-Styling + WIE-VIELE-SLIDES-SICHTBAR kommt aus dem jeweiligen
   Frame-CSS (Quality, Team, Immo, Reviews) via @container-Queries auf
   `.r2g-slider`. Dieses File liefert nur die Mechanik + sinnvollen
   Viewport-Fallback für Slider ohne eigene Inhalt-Logik.
   ========================================================================== */

.r2g-slider {
  position: relative;
  container-type: inline-size;
  --slider-gap: 2rem;
}

/* Default --slider-visible auf dem Track. Frame-CSS setzt es per
   @container-Queries auf demselben Selector neu — @container queries den
   .r2g-slider als Ancestor (das ist der Container), der .r2g-slider__track
   ist ein descendant und damit ein valides Target. */
.r2g-slider__track {
  --slider-visible: 3;
}

/* Viewport-Fallback wenn das Frame-CSS keine eigene Container-Query-Logik
   für `--slider-visible` mitbringt. */
@media (max-width: 1024px) { .r2g-slider__track { --slider-visible: 2; } }
@media (max-width: 640px)  { .r2g-slider__track { --slider-visible: 1; } }

.r2g-slider__viewport {
  overflow: hidden;
  /* horizontale Swipe-Gesten gehen an unser JS, vertikales Scrolling bleibt
     beim Browser → User kann mobil weiterscrollen, Slider wischen geht ebenfalls */
  touch-action: pan-y;
}

.r2g-slider__track {
  display: flex;
  transition: transform 0.4s ease;
  margin: 0 calc(var(--slider-gap) / -2);
}

.r2g-slider__slide {
  flex: 0 0 calc(100% / var(--slider-visible));
  padding: 0 calc(var(--slider-gap) / 2);
  box-sizing: border-box;
  display: flex;
}

/* Direkter Slide-Inhalt streckt sich auf volle Höhe (gleiche Card-Höhen
   ohne JS-Höhenbalance). */
.r2g-slider__slide > * {
  flex: 1 1 auto;
  min-width: 0;
}

/* ── Pfeile ─────────────────────────────────────────────────────────── */

.r2g-slider__arrow {
  position: absolute;
  /* Mittig zur Viewport-Höhe — die Dots unter dem Viewport ziehen 50% der
     Slider-Gesamthöhe optisch nach unten, daher um ihre halbe Höhe nach
     oben kompensieren. */
  top: calc(50% - 1rem);
  transform: translateY(-50%);
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  background: var(--color-white, #fff);
  border: 1px solid var(--color-border, #e5e7eb);
  color: var(--color-primary, #1f2937);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: opacity 0.2s ease, background 0.2s ease;
}

.r2g-slider__arrow svg {
  width: 1.25rem;
  height: 1.25rem;
}

.r2g-slider__arrow:hover {
  background: var(--color-primary, #1f2937);
  color: var(--color-white, #fff);
}

.r2g-slider__arrow--prev { left: -4rem; }
.r2g-slider__arrow--next { right: -4rem; }

/* ── Dots ───────────────────────────────────────────────────────────── */

.r2g-slider__dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1.5rem;
}

.r2g-slider__dot {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  border: none;
  background: var(--color-border, #d1d5db);
  cursor: pointer;
  padding: 0;
  transition: background 0.2s ease;
}

.r2g-slider__dot.is-active {
  background: var(--color-primary, #1f2937);
}

@media (max-width: 767px) {
  .r2g-slider__dots {
    gap: 0.625rem;
    margin-top: 1.5rem;
  }
  .r2g-slider__dot {
    width: 0.75rem;
    height: 0.75rem;
  }
}

/* ── Responsive ─────────────────────────────────────────────────────── */

@media (max-width: 1199px) {
  .r2g-slider__arrow--prev { left: 0.5rem; }
  .r2g-slider__arrow--next { right: 0.5rem; }
}

@media (max-width: 640px) {
  .r2g-slider__arrow { display: none; }
}

/* ── Modifier: --on-dark ────────────────────────────────────────────────
   Für Slider auf dunklem Section-Hintergrund (Quality, Reviews-v2).
   Pfeile transparent-weiß, Hover solid weiß. Dots weiß-transparent / beige aktiv. */

.r2g-slider--on-dark .r2g-slider__arrow {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.5);
  color: var(--color-white, #fff);
}

.r2g-slider--on-dark .r2g-slider__arrow:hover {
  background: var(--color-white, #fff);
  color: var(--color-primary, #b8a98e);
  border-color: var(--color-white, #fff);
}

.r2g-slider--on-dark .r2g-slider__dot {
  background: rgba(255, 255, 255, 0.4);
}

.r2g-slider--on-dark .r2g-slider__dot.is-active {
  background: var(--color-primary, #b8a98e);
}
