.contact__wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}

.contact__text {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}

.contact__details {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact__details li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.contact__details svg {
  flex-shrink: 0;
  color: var(--color-blue-dark);
}

.contact__details a {
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition-fast);
}

.contact__details a:hover {
  border-bottom-color: var(--color-blue-dark);
}

/* ─── Form ────────────────────────────────────── */
.contact__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.form__group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form__group label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.form__group input,
.form__group textarea {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-stone);
  border-radius: var(--radius-sm);
  background-color: var(--color-cream);
  font-size: var(--text-base);
  transition: border-color var(--transition-fast),
              box-shadow var(--transition-fast);
}

.form__group input:focus,
.form__group textarea:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(184, 207, 224, 0.3);
}

.form__group textarea {
  resize: vertical;
  min-height: 120px;
}

.form__success {
  display: none;
  color: var(--color-blue-dark);
  padding: var(--space-4);
  border-left: 3px solid var(--color-blue);
  margin-top: var(--space-2);
  font-style: italic;
}

.form__success.is-visible {
  display: block;
}

@media (max-width: 767px) {
  .contact__wrapper {
    gap: var(--space-8);
  }

  .contact__text {
    font-size: var(--text-base);
  }

  .contact__details a {
    font-size: var(--text-sm);
    word-break: break-all;
  }
}

@media (min-width: 768px) {
  .contact__wrapper {
    grid-template-columns: 2fr 3fr;
    gap: var(--space-16);
  }
}
