.site-footer {
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(36, 107, 185, 0.2) 0%, rgba(36, 107, 185, 0) 72%),
    linear-gradient(155deg, #07090f 0%, #0a0d14 44%, #130d1a 100%);
  color: var(--smart-white);
  border-top: 1px solid rgba(246, 245, 245, 0.12);
}

.site-footer__inner {
  width: min(1280px, 94%);
  margin: 0 auto;
  padding: 84px 0 60px;
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.25fr);
  gap: 36px;
  align-items: start;
}

.site-footer__title {
  margin: 0;
  font-size: clamp(1.4rem, 2.1vw, 2.1rem);
  line-height: 1.12;
}

.site-footer__address {
  margin: 18px 0 0;
  max-width: 42ch;
  color: rgba(246, 245, 245, 0.86);
  line-height: 1.7;
}

.site-footer__contacts {
  margin-top: 32px;
}

.site-footer__contacts-title {
  margin: 0 0 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #f5e608;
}

.site-footer__contact-line {
  margin: 0 0 10px;
  color: rgba(246, 245, 245, 0.9);
}

.site-footer__contact-line span {
  font-weight: 700;
}

.site-footer__contact-line a {
  color: var(--smart-white);
  text-decoration: none;
  border-bottom: 1px solid rgba(246, 245, 245, 0.32);
  transition: color 0.22s ease, border-color 0.22s ease;
}

.site-footer__contact-line a:hover,
.site-footer__contact-line a:focus-visible {
  color: #f5e608;
  border-color: rgba(245, 230, 8, 0.88);
}

.site-footer__map-wrap {
  min-height: 360px;
}

.smart-footer__map {
  width: 100%;
  height: 100%;
  min-height: 360px;
  border: 0;
  border-radius: 14px;
  filter: saturate(0.92) contrast(1.02);
}

.site-footer__bottom {
  border-top: 1px solid rgba(246, 245, 245, 0.1);
}

.site-footer__bottom p {
  width: min(1280px, 94%);
  margin: 0 auto;
  padding: 18px 0 22px;
  font-size: 0.92rem;
  color: rgba(246, 245, 245, 0.78);
}

.site-footer__separator {
  margin: 0 10px;
  color: rgba(246, 245, 245, 0.38);
}

.site-footer__bottom a {
  color: #f5e608;
  text-decoration: none;
  border-bottom: 1px solid rgba(245, 230, 8, 0.46);
}

.site-footer__bottom a:hover,
.site-footer__bottom a:focus-visible {
  color: #fff178;
  border-bottom-color: rgba(255, 241, 120, 0.84);
}

@media (max-width: 960px) {
  .site-footer__inner {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 62px 0 42px;
  }

  .site-footer__map-wrap,
  .smart-footer__map {
    min-height: 300px;
  }
}

@media (max-width: 640px) {
  .site-footer__inner {
    width: min(1280px, 90%);
    padding: 54px 0 36px;
  }

  .site-footer__contacts {
    margin-top: 26px;
  }

  .site-footer__map-wrap,
  .smart-footer__map {
    min-height: 260px;
  }
}
