/* ============================================================================
   standort-dienstleister-map.css
   ----------------------------------------------------------------------------
   ADDITIV. Komponenten-CSS der stadt-zentrierten Dienstleister-Karte.
   Eigener Namespace .rd-dlmap - überschreibt KEINEN bestehenden Selektor.
   Erbt rd-Tokens (--rd-*) aus rundum.css :root. Motion nur transform/opacity,
   reduced-motion-Gate. Lädt NACH leaflet.css.
   ============================================================================ */

.rd-dlmap {
  margin: 0 0 1.6rem;
}

/* ---- Steuerleiste: Radius-Chips links, Gross-Karten-Link rechts ---- */
.rd-dlmap__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  flex-wrap: wrap;
  margin-bottom: .9rem;
}
.rd-dlmap__radius {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.rd-dlmap__radius-lbl {
  font-size: .82rem;
  font-weight: 600;
  color: var(--rd-text-secondary);
  margin-right: .15rem;
}
.rd-dlmap__chip {
  font: inherit;
  font-size: .86rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--rd-text);
  background: var(--rd-bg-soft);
  border: 1px solid var(--rd-border-strong);
  border-radius: var(--rd-r-pill);
  padding: .42rem .95rem;
  min-height: 40px;
  cursor: pointer;
  transition: background-color 160ms var(--ease-out, cubic-bezier(0.22,1,0.36,1)),
              border-color 160ms var(--ease-out, cubic-bezier(0.22,1,0.36,1)),
              color 160ms var(--ease-out, cubic-bezier(0.22,1,0.36,1));
}
@media (hover: hover) and (pointer: fine) {
  .rd-dlmap__chip:hover { border-color: var(--rd-accent); color: var(--rd-accent-strong); }
}
.rd-dlmap__chip.is-active {
  color: #fff;
  background: var(--rd-accent);
  border-color: var(--rd-accent);
}
.rd-dlmap__chip:focus-visible {
  outline: 2px solid var(--rd-accent-strong);
  outline-offset: 2px;
}

.rd-dlmap__all {
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: .35em;
  font-weight: 600;
  font-size: .92rem;
  color: var(--rd-accent-strong);
  text-decoration: none;
  white-space: nowrap;
  min-height: 40px;
  padding: .4rem .2rem;
  transition: gap 140ms var(--ease-out, cubic-bezier(0.22,1,0.36,1));
}
@media (hover: hover) {
  .rd-dlmap__all:hover { gap: .6em; text-decoration: underline; }
}
.rd-dlmap__all:focus-visible {
  outline: 2px solid var(--rd-accent-strong);
  outline-offset: 2px;
  border-radius: var(--rd-r-sm);
}

/* ---- Karten-Fläche ---- */
.rd-dlmap__canvas {
  position: relative;
  border: 1px solid var(--rd-border);
  border-radius: var(--rd-r-md);
  overflow: hidden;
  background: var(--rd-bg-alt);
  box-shadow: var(--rd-shadow-sm);
}
.rd-dlmap__map {
  width: 100%;
  height: 22rem;
  background: var(--rd-bg-alt);
}
@media (max-width: 600px) {
  .rd-dlmap__map { height: 18rem; }
}

/* Leerzustand: Karte bleibt sichtbar, Hinweis schwebt dezent oben mittig. */
.rd-dlmap__empty {
  position: absolute;
  z-index: 500; /* über Tiles, unter Leaflet-Controls (≥1000) */
  top: .8rem;
  left: 50%;
  transform: translateX(-50%);
  max-width: calc(100% - 1.6rem);
  margin: 0;
  padding: .6rem .9rem;
  font-size: .86rem;
  line-height: 1.45;
  color: var(--rd-text-secondary);
  background: var(--rd-bg-soft);
  border: 1px solid var(--rd-border);
  border-radius: var(--rd-r-sm);
  box-shadow: var(--rd-shadow-md);
  text-align: center;
}
.rd-dlmap__empty a { color: var(--rd-accent-strong); font-weight: 600; text-decoration: none; white-space: nowrap; }
.rd-dlmap__empty a:hover { text-decoration: underline; }

.rd-dlmap__noscript {
  margin: 0;
  padding: 1.2rem;
  text-align: center;
  font-size: .9rem;
  color: var(--rd-text-secondary);
}
.rd-dlmap__noscript a { color: var(--rd-accent-strong); font-weight: 600; }

/* ---- Marker (divIcon) ---- */
.rd-dlmap-center__dot {
  display: block;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--rd-accent-strong, #944F22);
  border: 3px solid #fff;
  box-shadow: 0 0 0 1px rgba(20,19,17,.18);
}
.rd-dlmap-pin__dot {
  display: block;
  width: 16px; height: 16px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  background: var(--rd-accent, #B56A34);
  border: 2px solid #fff;
  box-shadow: 0 1px 3px rgba(20,19,17,.3);
}

/* Leaflet-Popup an rd-Sprache angleichen (gescoped via Marker-Klassen-Kontext
   nicht möglich; daher generischer, aber dezenter Inhalt-Stil im Popup-Body). */
.rd-dlmap-popup strong { font-weight: 700; color: var(--rd-text); }
.rd-dlmap-popup a { color: var(--rd-accent-strong); font-weight: 600; text-decoration: none; }
.rd-dlmap-popup a:hover { text-decoration: underline; }

/* ---- Motion-Gate ---- */
@media (prefers-reduced-motion: reduce) {
  .rd-dlmap__chip,
  .rd-dlmap__all { transition: none; }
}
