/* ============================================================
   Restaurants-lijst — volledige filterbare lijst
   ============================================================ */

/* Map-section boven de filters. Op desktop staat de kaart standaard open
   (toggle verborgen). Op mobile is de kaart hidden achter een 'Toon kaart'
   knop zodat de filter-pills bovenaan blijven en de UI rustig oogt. */
.restaurants-map-section {
  margin-block: var(--space-5) 0;
}

.restaurants-map-toggle {
  display: none;
  width: 100%;
  padding: var(--space-3);
  background: var(--color-cream-warm);
  border: var(--border-hairline);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-burgundy);
  cursor: pointer;
  transition: background var(--ease-std);
}

.restaurants-map-toggle:hover {
  background: var(--color-cream-deep);
}

.restaurants-map {
  position: relative;
  width: 100%;
  height: 460px;
  background: var(--color-cream-warm);
  border: var(--border-hairline);
  overflow: hidden;
}

@media (max-width: 760px) {
  .restaurants-map-toggle {
    display: block;
  }
  .restaurants-map {
    display: none;
    height: 360px;
  }
  .restaurants-map-section.is-open .restaurants-map {
    display: block;
    margin-top: var(--space-2);
  }
}

.restaurants-filters {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-block: var(--space-5) var(--space-6);
  padding-block: var(--space-4);
  border-top: var(--border-hairline);
  border-bottom: var(--border-hairline);
}

.restaurants-search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 10px 16px;
  background: var(--color-cream-warm);
  border: var(--border-hairline);
  max-width: 480px;
}

.restaurants-search svg {
  width: 18px;
  height: 18px;
  color: var(--color-ink-muted);
  flex-shrink: 0;
}

.restaurants-search input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: var(--fs-base);
  color: var(--color-ink);
}

.restaurants-filters__row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.restaurants-filters__row > .label-caps {
  flex-shrink: 0;
  min-width: 90px;
  font-size: var(--fs-xs);
}

/* .filter-pills en .filter-pill staan nu in components.css zodat ze
   gedeeld zijn met /vleessoort/. Geen duplicatie meer hier. */

/* Op mobile: label boven, pills daaronder in een horizontaal scrollende
   strip zodat lange filter-rijen (provincies, sort-opties) niet wrappen
   en op meerdere regels de hele filterbar opblazen. */
@media (max-width: 640px) {
  /* min-width:0 op zowel filters-wrap als de row breekt de default
     flex-item min-width:auto-keten, zodat een nowrap pills-strip
     écht kan overflowen i.p.v. zijn parents wijder te duwen (waarna
     body's overflow-x:clip de rest gewoon afkapt zonder scrollbar). */
  .restaurants-filters {
    min-width: 0;
  }

  .restaurants-filters__row {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-2);
    min-width: 0;
  }

  .restaurants-filters__row > .label-caps {
    min-width: 0;
  }

  .restaurants-filters__row > .filter-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    /* Scrollbar visueel verborgen, swipe blijft werken — strip oogt zo
       als een rustige rij zonder OS-balkje dat onder de pills hangt. */
    scrollbar-width: none;
    /* min-width:0 is hier cruciaal: zonder zou de pills-strip nooit
       smaller worden dan zijn content en zou overflow-x:auto nooit
       triggeren. */
    min-width: 0;
    max-width: 100%;
    /* Negatieve marge + padding zodat de eerste/laatste pill volledig
       in beeld is, en zodat de scroll-strip visueel breekt uit de
       container-padding (geeft rust dat er nog meer rechts staat). */
    padding-inline: var(--space-4);
    margin-inline: calc(var(--space-4) * -1);
  }

  .restaurants-filters__row > .filter-pills::-webkit-scrollbar {
    display: none;
  }

  .restaurants-filters__row > .filter-pills > .filter-pill {
    flex-shrink: 0;
  }
}

.restaurants-results-count {
  margin: 0;
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  color: var(--color-ink-muted);
  text-transform: uppercase;
}

/* ---- Rows ----------------------------------------------- */

.restaurants-grid {
  display: flex;
  flex-direction: column;
  border: var(--border-hairline);
}

.restaurant-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  color: var(--color-ink);
  text-decoration: none;
  border-top: var(--border-hairline);
  background: var(--color-cream-warm);
  transition: background 0.15s ease;
}

.restaurant-row:first-child { border-top: none; }

.restaurant-row:hover,
.restaurant-row:focus {
  background: var(--color-cream);
}

.restaurant-row__main {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.restaurant-row__name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-md);
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--color-ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.restaurant-row__meta {
  margin: 0;
  font-size: var(--fs-xs);
  color: var(--color-ink-muted);
  letter-spacing: 0.04em;
}

.restaurant-row__breeds {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}

.restaurant-row__breed {
  display: inline-block;
  padding: 2px 8px;
  background: var(--color-cream-deep);
  color: var(--color-ink-soft);
  font-size: var(--fs-xs);
  letter-spacing: 0.02em;
}

.restaurant-row__price-col {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  flex-shrink: 0;
}

.restaurant-row__price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-xl);
  color: var(--color-burgundy);
  line-height: 1;
}

.restaurant-row__price-unit {
  font-size: var(--fs-xs);
  color: var(--color-ink-muted);
  letter-spacing: 0.04em;
}

@media (max-width: 640px) {
  .restaurant-row {
    padding: var(--space-3);
    gap: var(--space-3);
  }
  .restaurant-row__price {
    font-size: var(--fs-lg);
  }
}
