.contact-section {
  padding-bottom: 20px;
}

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
  gap: 30px;
}

.contact-grid > :last-child {
  display: grid;
  gap: 12px;
}

.contact-image {
  margin: 0 0 33px;
}

.contact-image img {
  display: block;
  width: 100%;
  height: auto;
}

.contact-email {
  margin: 0;
  line-height: 1.5;
}

.contact-email a {
  color: var(--site-accent-strong);
}

.contact-info-list {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 7px;
  padding-top: 0;
}

.contact-info-list p,
.contact-info-list address {
  margin: 0;
  color: var(--site-text);
}

.contact-info-list address {
  font-style: normal;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.contact-info-list p {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.contact-info-list a {
  color: inherit;
}

.contact-info-icon {
  flex: 0 0 auto;
  margin-top: 2px;
  color: var(--site-accent-strong);
  font-size: 18px;
  line-height: 1;
}

.contact-map {
  overflow: hidden;
  border: 1px solid var(--site-border-soft);
  background: var(--site-surface-muted);
}

.contact-map__embed {
  position: relative;
  height: 435px;
}

.contact-map iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.contact-map__placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  gap: 16px;
  padding: 28px;
  box-sizing: border-box;
  text-align: center;
  color: var(--site-heading);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.94)),
    radial-gradient(circle at top left, rgba(161, 32, 100, 0.12), transparent 46%);
}

.contact-map__placeholder[hidden] {
  display: none;
}

.contact-map__placeholder p {
  max-width: 420px;
  margin: 0;
  line-height: 1.6;
}

.contact-map__button {
  min-width: 0;
  min-height: 46px;
  padding: 0 20px;
  border-width: 0;
  letter-spacing: 0;
  text-transform: none;
  cursor: pointer;
  transition: transform 0.18s ease;
}

.contact-map__button:hover,
.contact-map__button:focus-visible {
  transform: translateY(-1px);
}

@media (max-width: 760px) {
  .contact-grid,
  .contact-info-list {
    grid-template-columns: 1fr;
  }

  .contact-info-list {
    gap: 7px;
    padding-top: 0;
  }

  .contact-image {
    margin-bottom: 20px;
  }

  .contact-map iframe {
    height: 100%;
  }

  .contact-map__placeholder {
    padding: 24px 20px;
  }

  .contact-map__embed {
    height: 260px;
  }

}
