/* ========== КОНТАКТЫ ========== */
.contacts {
  position: relative;
  background-color: #f9f9f9;
}

.contacts__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xxl);
}

.contacts__details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.contact-item__icon {
  width: 50px;
  height: 50px;
  background-color: rgba(240, 41, 48, 0.1);
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--primary-color);
  font-size: 1.8rem;
  flex-shrink: 0;
}

.contact-item__title {
  font-size: 1.8rem;
  margin-bottom: var(--space-xs);
}

.contact-item__link {
  display: block;
  margin-bottom: var(--space-xs);
  transition: color 0.2s ease;
  font-size: 1.6rem;
}

.contact-item__link:hover,
.contact-item__link:focus {
  color: var(--primary-color);
  outline: none;
}

.contact-item__text {
  font-size: 1.5rem;
  color: var(--gray-color);
  line-height: 1.6;
}

.contacts__social {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-xl);
  justify-content: center;
}

.contacts__social .social-link {
  width: 60px;
  height: 60px;
  font-size: 2.4rem;
  margin: 0;
}

.contacts__form {
  background-color: var(--light-color);
  border-radius: var(--border-radius);
  padding: var(--space-xl);
  box-shadow: var(--box-shadow);
}

.form__title {
  font-size: 2.4rem;
  margin-bottom: var(--space-xs);
  text-align: center;
}

.form__subtitle {
  text-align: center;
  color: var(--gray-color);
  margin-bottom: var(--space-lg);
  font-size: 1.6rem;
}

.contacts__map {
  height: 400px;
  margin-top: var(--space-xxl);
  border-radius: var(--border-radius);
  overflow: hidden;
  background-color: #f5f5f5;
}

.map-fallback {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: var(--space-lg);
}

.map-fallback p {
  font-size: 1.6rem;
  margin-bottom: var(--space-sm);
}

.map-fallback a {
  color: var(--primary-color);
  font-weight: 600;
  text-decoration: underline;
}