/* Card Scroller — horizontal card strip (Featured, Latest, Laufband).
   Shared class .card-section on the wrapping <section>.
   The card itself (.property-card) is defined in components/property-card.css.
   This file only handles the scroller container (grid/flex, background, snap). */

.card-section {
  max-width: var(--content-width);
  margin-inline: auto;
  padding-inline: var(--padding-page);
  text-align: center;
}

.card-section > header {
  margin-block-start: var(--gap-section);
  margin-block-end: var(--gap-section);
}

.card-section > header span {
  display: block;
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-primary);
  margin-block-end: var(--space-3);
}

.card-section > p {
  margin-block-start: var(--gap-block);
}

/* --- Mobile: vertical card grid --- */

.card-scroller {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap-block);
  padding-block: var(--space-4);
  text-align: left;
}

/* --- Tablet: 2 columns --- */

@media (min-width: 45rem) {
  .card-scroller {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* --- Desktop: horizontal scroller --- */

@media (min-width: 79.5rem) {
  .card-scroller {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding-block: var(--space-5);
    padding-inline: var(--padding-card);
    scroll-padding-inline: var(--padding-card);
    background: var(--color-bg-alt);
    border: 0.0625rem solid var(--color-panel-border);
    border-radius: var(--radius);
  }

  .card-scroller::-webkit-scrollbar {
    display: none;
  }

  .card-scroller > .property-card {
    scroll-snap-align: start;
    flex: 0 0 22rem;
  }

  .card-scroller:not(:has(> :nth-child(4))) {
    justify-content: center;
  }
}
