/* ============================================================
   sections/contact.css  —  Contact Us form
   Scoped under .contact. Light section (bg-soft); white fields.
   ============================================================ */

#contact .container {
    border: 1px solid;
    padding-bottom: 20px;
    padding-top: 20px;
    background-color: white;
}
.contact__head { text-align: center; margin-bottom: clamp(2rem, 5vw, 3rem); }
.contact__intro {
  margin-top: 0.75rem; color: var(--ink-soft);
  font-size: 1.05rem; max-width: 46ch; margin-inline: auto;
}

.contact__form {
  max-width: 640px; margin-inline: auto;
  display: flex; flex-direction: column; gap: 1.5rem;
}

/* Name row: Title (narrow) + First + Last */
.contact__row--name {
  display: grid; grid-template-columns: minmax(96px, 0.6fr) 1fr 1fr; gap: 1rem;
}
@media (max-width: 600px) { .contact__row--name { grid-template-columns: 1fr; } }

.contact__field { display: flex; flex-direction: column; gap: 0.4rem; }
.contact__field label {
  font-size: 0.76rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft);
}
.req { color: var(--orange-red); }

.contact input[type="text"],
.contact input[type="email"],
.contact select,
.contact textarea {
  font-family: var(--font-body); font-size: 1rem; color: var(--ink);
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 0.7rem 0.85rem; width: 100%;
  transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.contact input:focus,
.contact select:focus,
.contact textarea:focus {
  outline: none; border-color: var(--maroon);
  box-shadow: 0 0 0 3px rgba(122, 31, 43, 0.12);
}
.contact textarea { resize: vertical; min-height: 7rem; }

/* Checkbox groups */
.contact__group { border: none; padding: 0; margin: 0; }
.contact__group legend {
  font-family: var(--font-display); font-size: 1.1rem; color: var(--brown-deep);
  margin-bottom: 0.8rem; padding: 0;
}
.contact__checks {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.6rem 1rem;
}
.contact__check {
  display: flex; align-items: center; gap: 0.55rem;
  font-size: 0.96rem; color: var(--ink-soft); cursor: pointer;
}
.contact__check input {
  width: 1.1rem; height: 1.1rem; accent-color: var(--maroon); flex-shrink: 0;
}

/* Honeypot (hidden spam trap) */
.contact__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.cf-turnstile { margin-top: 0.25rem; }
.contact__submit { margin-top: 0.5rem; }
