/* ==========================================================================
   R2GO4-Team – Team Slider + Grid
   Card-Markup: <div class="team-card"> mit <div.team-card__image> (Container
   für absolut positioniertes role-badge) und <div.team-card__body>
   (padded text area). Innen plain <h3>, <p>, <div class="actions">.
   ========================================================================== */

/* Slider-Mechanik (.r2g-slider*) kommt aus slider.css.
   Wie viele Cards im Slider sichtbar sind, hängt von der ECHTEN
   Slider-Spalten-Breite ab. Team-Card hat aspect-ratio 391/303
   → bei <600px nur 1, ab 600px 2, ab 900px 3. */

.section--team .r2g-slider__track { --slider-visible: 1; }

@container (min-width: 600px) {
  .section--team .r2g-slider__track { --slider-visible: 2; }
}

@container (min-width: 900px) {
  .section--team .r2g-slider__track { --slider-visible: 3; }
}

/* Card-Layout — gleich-hohe Karten unabhängig vom Container (Slider, Grid).
   Single Source of Truth: hier in section/team.css. modules/team-list.css
   enthält NUR noch Grid-Container-Mechanik, KEINE Card-Layout-Regeln (DRY). */
.team-card {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.team-card__image {
  position: relative;
  z-index: 2;
}

.team-card__image img {
  width: 100%;
  aspect-ratio: 391 / 303;
  object-fit: cover;
  display: block;
}

.role-badge {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
  z-index: 3;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.8rem;
  font-weight: 500;
  text-transform: uppercase;
  padding: 0.1875rem var(--space-sm) 0.125rem;
  white-space: nowrap;
}

.team-card__body {
  position: relative;
  z-index: 1;
  padding: var(--space-2xl) var(--space-sm) var(--space-md);
  text-align: center;
  background: var(--color-bg-warm);
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

.team-card__body h3 {
  margin: 0 0 var(--space-xs);
}

.team-card__body p {
  flex: 1 1 auto;
  margin: 0 0 var(--space-sm);
}

.team-card__body .actions {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: auto;
}

.team-card__body .actions a {
  color: var(--color-text-dark);
  transition: color var(--transition);
}

.team-card__body .actions a:hover {
  color: var(--color-primary-dark);
}

/* Team-Grid (Team-Unterseite) */

.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

@media (max-width: 991px) {
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .team-grid {
    grid-template-columns: 1fr;
  }
}
