.fhv-regions-map {
  width: 100%;
}

.fhv-regions-map__canvas {
  width: 100%;
  min-height: min(640px, 100vh);
  max-height: 100vh;
}

.fhv-regions-map--home .fhv-regions-map__canvas {
  min-height: min(640px, 100vh);
  max-height: 100vh;
}

.fhv-regions-map .leaflet-container {
  width: 100%;
  min-height: min(640px, 100vh);
  max-height: 100vh;
  background: #d7edf7;
}

.fhv-regions-map__marker {
  background: transparent;
  border: 0;
}

.fhv-regions-map__marker-pin {
  display: block;
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 4px 10px rgba(16, 61, 91, 0.2));
  transform-origin: 50% 100%;
  transition: transform 160ms ease, filter 160ms ease;
}

.fhv-regions-map__marker svg {
  display: block;
  width: 100%;
  height: 100%;
}

.fhv-regions-map__marker.is-hovered .fhv-regions-map__marker-pin,
.fhv-regions-map__marker:hover .fhv-regions-map__marker-pin {
  filter: drop-shadow(0 8px 16px rgba(16, 61, 91, 0.28));
  transform: scale(1.08);
}

.fhv-regions-map--home .leaflet-container {
  min-height: min(640px, 100vh);
  max-height: 100vh;
}

.fhv-regions-map__popup {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 180px;
}

.fhv-regions-map__popup-link {
  display: inline-block;
  padding: 8px 12px;
  border-radius: 999px;
  background: #76b82a;
  color: #fff;
  font-size: 13px;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
}

.fhv-regions-map__popup-link:hover,
.fhv-regions-map__popup-link:focus {
  background: #5c9720;
  color: #fff;
}

.fhv-regions-map__tooltip {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fhv-regions-map__tooltip strong {
  font-size: 13px;
  line-height: 1.2;
}

.fhv-regions-map__tooltip span {
  font-size: 12px;
  line-height: 1.25;
}

.fhv-regions-map__tooltip-wrap {
  border: 0;
  border-radius: 10px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
  color: #1f2d3d;
  padding: 8px 10px;
}
