body {
  margin: 0;
}
.map-container {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: auto;
}
.responsive-map {
  width: 100%;
  height: auto;
}
.tooltip {
  position: absolute;
  background: rgba(0, 0, 0, 0.85);
  color: white;
  padding: 10px;
  border-radius: 5px;
  display: none;
  max-width: 250px;
  font-size: 14px;
  pointer-events: none;
  z-index: 100;
}
/* Homepage SEO intro block (H1 + paragraph) */
.page-intro {
  max-width: 1100px;
  margin: 10px auto 10px;
  padding: 0 16px;
}

.page-intro h1 {
  margin: 0 0 8px;
  font-size: 32px;
  line-height: 1.2;
}

.page-intro .intro-text {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: #555;
}
/* Reduce top gap before hero (homepage only) */
.page-intro + .hero {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
/* Visually hide homepage SEO intro but keep it for SEO */
.page-intro {
  position: absolute !important;
  left: -9999px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}