/* ── Contact form ──────────────────────────────────────── */

.contact-form {
  margin-top: 3rem;
  display: grid;
  gap: 1.25rem;
  max-width: 560px;
}

.contact-form .field { display: flex; flex-direction: column; gap: 0.5rem; }

.contact-form label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--faint);
}

.contact-form input,
.contact-form textarea {
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--ink);
  background: var(--card);
  border: 0.5px solid var(--line);
  border-radius: 3px;
  padding: 0.75rem 0.9rem;
  width: 100%;
  transition: border-color 0.2s;
}
.contact-form input:focus,
.contact-form textarea:focus { outline: none; border-color: var(--ink); }
.contact-form textarea { resize: vertical; min-height: 130px; line-height: 1.6; }

/* Honeypot: off-screen for humans, tempting for bots */
.cf-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.cf-submit {
  justify-self: start;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--paper);
  background: var(--ink);
  border: none;
  border-radius: 4px;
  padding: 0.85rem 1.7rem;
  cursor: pointer;
  transition: opacity 0.2s;
}
.cf-submit:hover { opacity: 0.85; }
.cf-submit:disabled { opacity: 0.5; cursor: default; }

.cf-status { font-size: 14px; line-height: 1.6; margin: 0; min-height: 1.2em; }
.cf-status.is-success { color: #427b58; }
.cf-status.is-error { color: #b42318; }
