/* Page-specific styles for Contact (scoped under .page-contact) */
.page-contact .contact-page {
  min-height: calc(100vh - 6.2rem);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: clamp(1.5rem, 5vh, 3rem);
}

.page-contact .contact-page .contact-card {
  width: min(840px, 100%);
  padding: clamp(1.25rem, 3vw, 2rem);
}

.page-contact .contact-page .section-head {
  text-align: center;
  margin-bottom: 1.25rem;
}

.page-contact .contact-page .section-head p {
  max-width: 52ch;
  margin-inline: auto;
}

.page-contact .contact-page .form {
  gap: 0.8rem;
}

.page-contact .contact-page textarea {
  min-height: 220px;
  resize: vertical;
}

.page-contact .contact-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 0.25rem;
}

@media (max-width: 640px) {
  .page-contact .contact-page {
    min-height: auto;
    padding-block: 1.25rem 2rem;
  }

  .page-contact .contact-actions {
    justify-content: stretch;
  }

  .page-contact .contact-actions .btn {
    width: 100%;
  }
}
