/* Theme2 Home: Minimap nutzt verfügbare Höhe wie .dl-card__image (gleiche Höhe wie Dish-Bild) */

.dl-card__media .leaflet-map-container,
.dl-card__media .home-restaurant-minimap,
.dl-card__media .home-dish-minimap {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 120px;
  overflow: hidden;
  border-radius: var(--dl-radius-sm, 10px);
}

.home-sort-button {
  /* Styles für Sort-Buttons werden über dl-chip Klasse definiert */
}

.dl-results__empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--dl-text-soft);
  font-size: 1rem;
}

/* KRITISCH: Überschreibe Leaflet's Standard-Styles für Marker-Icons */
.home-restaurant-minimap-marker,
.home-restaurant-minimap-marker.leaflet-div-icon,
.leaflet-div-icon.home-restaurant-minimap-marker {
  background: transparent !important;
  border: none !important;
  width: 20px !important;
  height: 30px !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}

.home-restaurant-minimap-marker-inner {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: transparent !important;
}

.home-restaurant-minimap-marker-inner svg {
  display: block !important;
  width: 20px !important;
  height: 30px !important;
  pointer-events: none;
  visibility: visible !important;
  opacity: 1 !important;
}

.leaflet-zoom-hide {
  /* Leaflet-Klasse für versteckte Zoom-Controls wird von Leaflet selbst hinzugefügt */
  display: none;
}

/* Pagination: mittig, hochwertig, CI-konform (dl-Theme) */
.base-pagination {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--dl-border);
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.base-pagination-controls {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

.base-pagination-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-small);
  font-weight: 600;
  line-height: var(--line-height-base);
  text-align: center;
  text-decoration: none;
  color: var(--dl-text);
  background: var(--dl-bg-alt);
  border: 1px solid var(--dl-border);
  border-radius: var(--dl-radius-sm);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.base-pagination-link:hover {
  background: var(--dl-chip-active-bg);
  border-color: var(--dl-accent);
  color: var(--dl-text);
}

@media (min-width: 600px) {
  .base-pagination-link {
    padding: 8px 12px;
    min-width: 36px;
    min-height: auto;
  }
}

.base-pagination-current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-small);
  font-weight: 700;
  line-height: var(--line-height-base);
  text-align: center;
  color: var(--dl-accent);
  background: var(--dl-chip-active-bg);
  border: 1px solid var(--dl-accent);
  border-radius: var(--dl-radius-sm);
}

@media (min-width: 600px) {
  .base-pagination-current {
    padding: 8px 12px;
    min-width: 36px;
    min-height: auto;
  }
}
