/* Form container */
.contact-form-wrap { max-width: 640px; margin: 0 auto; }

/* Labels */
.contact-form-wrap label { display: block; font-size: 0.8rem; font-weight: 600;
  color: var(--text-primary); margin-bottom: 0.35rem; margin-top: 1rem; }
.contact-form-wrap label .optional { font-weight: 400; color: var(--text-muted);
  font-size: 0.75rem; }

/* Inputs, selects, textarea */
.contact-form-wrap input,
.contact-form-wrap select,
.contact-form-wrap textarea {
  width: 100%; padding: 0.65rem 0.85rem; border: 1px solid var(--border);
  border-radius: 2px; font-family: 'Montserrat', sans-serif; font-size: 0.9rem;
  color: var(--text-primary); background: var(--white);
  transition: border-color 0.2s; }
.contact-form-wrap input:focus,
.contact-form-wrap select:focus,
.contact-form-wrap textarea:focus {
  outline: none; border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.15); }
.contact-form-wrap textarea { resize: vertical; min-height: 100px; }

/* Submit button — use class="btn btn-primary btn-submit" on the <button> element */
.contact-form-wrap .btn-submit { width: 100%; margin-top: 1.5rem; }

/* Success message */
.contact-success { text-align: center; padding: 2rem; }
.contact-success h3 { font-size: 1.3rem; color: var(--text-primary); margin-bottom: 1rem; }

/* Error message */
.form-error { color: var(--warning); font-size: 0.82rem; margin-top: 0.75rem; }

/* Contact page hero */
.contact-hero h1 { font-size: 2.5rem; }
.contact-body { padding: 5rem 3rem; background: var(--white); }
@media (max-width: 1024px) { .contact-body { padding: 4rem 2rem; } }
@media (max-width: 767px)  { .contact-body { padding: 3rem 1.25rem; } }
