/* ══════════════════════════════════════════
   CONTACT US — CommunityDX
   Page-specific styles only. Shared reset,
   buttons, header, footer, etc. are in layout.css.
   ══════════════════════════════════════════ */

/* ── Contact Hero ── */
.contact-hero {
  display: flex;
  justify-content: center;
  padding: var(--space-4xl) var(--space-4xl) 0;
  text-align: center;
}

.contact-hero .page-hero__inner {
  width: 100%;
  max-width: 700px;
  margin: 0;
  padding: clamp(24px, 4vw, 40px) clamp(24px, 4vw, 40px) var(--space-lg);
  border: 1px solid rgba(61, 92, 108, 0.14);
  border-bottom: 0;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 54px rgba(18, 32, 44, 0.08);
}

.contact-hero__title {
  font-family: var(--font-family);
  font-size: var(--font-size-section-title);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-gray-90);
}

/* ── Contact Form Section ── */
.contact-form-section {
  display: flex;
  justify-content: center;
  padding: 0 var(--space-4xl) var(--space-4xl);
}

.contact-form {
  width: 100%;
  max-width: 700px;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: 0 clamp(24px, 4vw, 40px) clamp(24px, 4vw, 40px);
  border: 1px solid rgba(61, 92, 108, 0.14);
  border-top: 0;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 54px rgba(18, 32, 44, 0.08);
}

/* ── Form Fields ── */
.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.form-field__label {
  font-size: var(--font-size-body-sm);
  line-height: var(--line-height-normal);
  color: var(--color-gray-90);
}

.form-field__input,
.form-field__textarea {
  background: rgba(247, 244, 238, 0.74);
  border: 1px solid rgba(61, 92, 108, 0.16);
  border-radius: 0;
  padding: 12px var(--space-md);
  font-family: var(--font-family);
  font-size: var(--font-size-body);
  line-height: var(--line-height-normal);
  color: var(--color-gray-90);
  width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.form-field__input::placeholder,
.form-field__textarea::placeholder {
  color: var(--color-gray-60);
}

.form-field__input:focus,
.form-field__textarea:focus {
  outline: none;
  background: var(--color-white);
  border-color: rgba(61, 92, 108, 0.36);
  box-shadow: 0 0 0 4px rgba(61, 92, 108, 0.08);
}

.form-field__textarea {
  resize: vertical;
  min-height: 96px;
}

/* ── Actions ── */
.contact-form__actions {
  display: flex;
  justify-content: center;
  padding-top: var(--space-md);
}

/* ══════════════════════════════════════════
   RESPONSIVE — Tablet (≤ 1024px)
   ══════════════════════════════════════════ */
@media (max-width: 1024px) {
  .contact-hero {
    padding: var(--space-3xl) 40px 0;
  }

  .contact-form-section {
    padding: 0 40px var(--space-3xl);
  }
}

/* ══════════════════════════════════════════
   RESPONSIVE — Mobile (≤ 640px)
   ══════════════════════════════════════════ */
@media (max-width: 640px) {
  .contact-hero {
    padding: var(--space-2xl) 20px 0;
  }

  .contact-form-section {
    padding: 0 20px var(--space-2xl);
  }
}
