.housing-hero-card {
  background:
    linear-gradient(135deg, rgba(255, 248, 243, 0.94), rgba(255, 252, 249, 0.82)),
    radial-gradient(circle at 88% 18%, rgba(182, 90, 58, 0.13), transparent 28%);
}

.housing-area-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.housing-area-card {
  min-height: 100%;
}

.housing-area-card .child-card-title {
  font-size: clamp(24px, 2.5vw, 32px);
}

.housing-map-shell {
  display: grid;
  gap: 22px;
}

.housing-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(260px, 0.8fr);
  gap: 18px;
  align-items: stretch;
}

.housing-map-card,
.housing-map-summary,
.housing-region-details {
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(47, 42, 38, 0.07);
}

.housing-map-card {
  padding: 18px;
}

.housing-real-map {
  position: relative;
  z-index: 0;
  width: 100%;
  min-height: 520px;
  overflow: hidden;
  border-radius: 18px;
  background: rgba(255, 251, 248, 0.92);
  border: 1px solid rgba(52, 37, 31, 0.08);
}

.housing-real-map .leaflet-pane,
.housing-real-map .leaflet-top,
.housing-real-map .leaflet-bottom {
  z-index: 1;
}

.housing-real-map .leaflet-control {
  z-index: 2;
}

.housing-real-map.has-tile-error::after {
  content: "Подложка карты не загрузилась. Районы можно выбрать кнопками ниже.";
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 500;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255, 251, 248, 0.92);
  border: 1px solid rgba(182, 90, 58, 0.2);
  box-shadow: 0 12px 28px rgba(85, 42, 26, 0.12);
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.housing-real-map .leaflet-container {
  font: inherit;
}

.housing-map-tooltip {
  padding: 4px 8px;
  border: 0;
  border-radius: 999px;
  background: rgba(143, 64, 40, 0.9);
  box-shadow: 0 8px 18px rgba(85, 42, 26, 0.18);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.housing-map-tooltip::before {
  display: none;
}

.housing-map-fallback {
  min-height: 520px;
  display: grid;
  place-items: center;
  padding: 24px;
  color: var(--muted);
  text-align: center;
  line-height: 1.6;
}

.housing-map-note {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
  text-align: center;
}

.housing-map-summary {
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.housing-region-buttons {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.housing-region-button {
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid rgba(47, 42, 38, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  color: var(--muted);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.housing-region-button:hover,
.housing-region-button:focus,
.housing-region-button.is-active {
  background: rgba(182, 90, 58, 0.12);
  border-color: rgba(182, 90, 58, 0.32);
  color: var(--accent-dark);
  outline: none;
  transform: translateY(-1px);
}

.housing-region-details {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
  gap: 28px;
  align-items: start;
}

.housing-score-grid {
  margin: 0;
  display: grid;
  gap: 14px;
}

.housing-score {
  display: grid;
  gap: 8px;
}

.housing-score dt {
  color: var(--text);
  font-weight: 700;
}

.housing-score dd {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(110px, auto);
  gap: 12px;
  align-items: center;
}

.housing-score-track {
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(52, 37, 31, 0.09);
}

.housing-score-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(182, 90, 58, 0.46), rgba(182, 90, 58, 0.95));
}

.housing-score-value {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}

.housing-points-card {
  background:
    linear-gradient(180deg, rgba(255, 248, 243, 0.9), rgba(255, 252, 249, 0.82)),
    radial-gradient(circle at 12% 0%, rgba(182, 90, 58, 0.08), transparent 26%);
}

.housing-points-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.housing-point {
  display: grid;
  align-content: start;
  min-height: 100%;
}

.housing-point--wide {
  grid-column: 1 / -1;
}

.housing-point .child-card-title {
  font-size: clamp(24px, 2.5vw, 32px);
}

.housing-check-list {
  gap: 14px;
}

.housing-link-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 14px;
}

.housing-link-card {
  min-height: 118px;
  justify-content: center;
  text-decoration: none;
}

.housing-link-title {
  font-size: 16px;
  font-weight: 600;
  color: #3e2c23;
}

.housing-link-desc {
  display: block;
  margin-top: 4px;
  font-size: 13px;
  color: rgba(62, 44, 35, 0.6);
}

.housing-final-note {
  margin-top: 24px;
  padding: 24px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(47, 42, 38, 0.07);
}

@media (max-width: 820px) {
  .housing-area-grid,
  .housing-map-layout,
  .housing-region-details,
  .housing-points-grid,
  .housing-link-grid {
    grid-template-columns: 1fr;
  }

  .housing-point--wide {
    grid-column: auto;
  }

  .housing-map-summary {
    padding: 24px;
  }

  .housing-region-buttons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .housing-region-button {
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .housing-map-layout {
    display: block;
  }

  .housing-map-summary {
    display: none;
  }
}

@media (max-width: 640px) {
  .housing-region-buttons {
    gap: 8px;
  }

  .housing-map-card {
    padding: 12px;
  }

  .housing-real-map,
  .housing-map-fallback {
    min-height: 440px;
  }

  .housing-score dd {
    grid-template-columns: 1fr;
    gap: 7px;
  }

  .housing-region-button {
    min-height: 38px;
    padding: 0 12px;
    font-size: 14px;
  }
}
