/* Contact form – responsive & accessible */
.contact-form {
  max-width: 720px;
  margin: 1rem auto 0;
  display: grid;
  gap: 1rem;
}
.form-row { display: grid; gap: .4rem; }
.contact-form label { font-weight: 700; font-size: .95rem; }

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1.5px solid #e7e7e7;
  border-radius: 10px;
  padding: .85rem 1rem;
  font: inherit;
  background: #fff;
  transition: border-color .2s, box-shadow .2s;
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(230,126,34,.12);
}

.contact-form .error { color: #b00020; min-height: 1em; font-size: .85rem; }

.form-actions {
  display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; margin-top: .25rem;
}
.form-note { margin: 0; color: var(--muted); font-size: .95rem; }

.button#cf-submit { position: relative; min-width: 160px; }
.btn-spinner {
  display: inline-block; width: 1rem; height: 1rem;
  border: 2px solid rgba(255,255,255,.35); border-top-color: #fff;
  border-radius: 50%; margin-left: .6rem; transform: translateY(2px);
  opacity: 0; transition: opacity .2s;
}
.button[aria-busy="true"] .btn-spinner { opacity: 1; animation: spin .9s linear infinite; }
@keyframes spin { to { transform: translateY(2px) rotate(360deg); } }

.form-status { margin-top: .25rem; font-size: .95rem; }
.form-status.success { color: #1b7f3b; }
.form-status.error { color: #b00020; }

/* Honeypot hidden */
.hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }

/* Tablet/Desktop refinements */
@media (min-width: 640px) {
  .contact-form { gap: 1.1rem; }
  .form-row { gap: .45rem; }
}
