/* Contact page styles. Imported AFTER legal-styles.css which imports
   the main styles.css. So we have all design tokens available.
   The contact form is on a white background so we redo the field
   styling for light mode (book-form on the homepage is dark). */

.contact-main { padding-top: 130px; padding-bottom: 80px; }
.contact-wrap { max-width: 1080px; }

.contact-lead {
  font-family: var(--body);
  font-size: 19px; line-height: 1.55;
  color: var(--neutral-700);
  max-width: 640px;
  margin: 0 0 56px;
}

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 56px;
  align-items: start;
}

/* ------------ form ------------ */
.contact-form {
  display: flex; flex-direction: column; gap: 22px;
}
.contact-form .field { display: flex; flex-direction: column; gap: 8px; }
.contact-form .field label {
  font-family: var(--body); font-size: 13px; font-weight: 500;
  color: var(--neutral-700);
  letter-spacing: -0.005em;
}
.contact-form .field .req { color: var(--bright); margin-left: 2px; }
.contact-form .field .optional { color: var(--neutral-500); font-weight: 400; margin-left: 4px; font-size: 12px; }

.contact-form .field input,
.contact-form .field textarea {
  font: inherit;
  font-family: var(--body); font-size: 16px; color: var(--neutral-900);
  background: #fff;
  border: 1px solid var(--neutral-300);
  border-radius: 10px;
  padding: 14px 16px;
  transition: border-color 200ms var(--ease-out), box-shadow 200ms var(--ease-out);
  width: 100%;
}
.contact-form .field input { height: 52px; }
.contact-form .field input::placeholder,
.contact-form .field textarea::placeholder { color: var(--neutral-400); }
.contact-form .field input:focus,
.contact-form .field textarea:focus {
  outline: none;
  border-color: var(--bright);
  box-shadow: 0 0 0 3px rgba(33,181,232,0.20);
}
.contact-form .field textarea { resize: vertical; min-height: 140px; line-height: 1.55; }

.contact-form .field input[aria-invalid="true"],
.contact-form .field textarea[aria-invalid="true"] {
  border-color: #DC2626;
}
.contact-form .field-err {
  color: #DC2626; font-size: 13px; font-weight: 500;
  margin: 0;
}

.contact-form .turnstile-field { min-height: 70px; }
.contact-form .cf-turnstile { min-height: 65px; }

.contact-form .form-row {
  display: flex; align-items: center; gap: 22px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.contact-submit {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--body); font-size: 15px; font-weight: 600;
  background: var(--navy);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 14px 26px;
  cursor: pointer;
  transition: background 200ms var(--ease-out), transform 200ms var(--ease-out), box-shadow 200ms var(--ease-out);
}
.contact-submit:hover { background: var(--bright); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(33,181,232,0.25); }
.contact-submit:disabled { opacity: 0.6; cursor: wait; transform: none; }
.contact-submit .arrow { transition: transform 200ms var(--ease-out); }
.contact-submit:hover .arrow { transform: translateX(2px); }

.contact-form .form-fineprint {
  font-family: var(--body); font-size: 13px; color: var(--neutral-500);
  margin: 0;
  flex: 1; min-width: 200px;
}

/* ------------ aside ------------ */
.contact-aside {
  display: flex; flex-direction: column; gap: 16px;
  position: sticky; top: 100px;
}
.contact-card {
  background: var(--neutral-50);
  border: 1px solid var(--neutral-200);
  border-radius: 14px;
  padding: 22px;
}
.contact-card-quiet { background: #fff; }
.contact-card-h {
  font-family: var(--body); font-size: 13px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--neutral-600);
  margin: 0 0 8px;
}
.contact-card-body {
  font-family: var(--body); font-size: 15px; line-height: 1.55;
  color: var(--neutral-700);
  margin: 0 0 14px;
}
.contact-card-meta {
  font-family: var(--body); font-size: 12px; color: var(--neutral-500);
  margin: 0;
}
.contact-card-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--body); font-size: 14px; font-weight: 600;
  color: var(--navy);
  text-decoration: none;
  transition: gap 200ms var(--ease-out), color 200ms var(--ease-out);
}
.contact-card-cta:hover { color: var(--bright); gap: 12px; }

/* ------------ success ------------ */
.contact-success {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: 60px 20px;
  max-width: 560px;
  margin: 0 auto;
}
.contact-success .success-tick {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 999px;
  background: rgba(33,181,232,0.14);
  color: var(--bright);
  margin-bottom: 22px;
}
.contact-success h2 {
  font-family: var(--display); font-weight: 500;
  font-size: 32px; line-height: 1.15;
  color: var(--neutral-900);
  margin: 0 0 12px;
}
.contact-success p {
  font-family: var(--body); font-size: 17px; line-height: 1.55;
  color: var(--neutral-700);
  margin: 0 0 28px;
}
.contact-success .hl { color: var(--navy); font-weight: 500; }

.contact-footer {
  background: var(--neutral-50);
  color: var(--neutral-700);
}
.contact-footer .footer-bar { color: var(--neutral-600); }
.contact-footer .footer-bar a { color: var(--neutral-700); }
.contact-footer .footer-rule { background: var(--neutral-200); }

/* ------------ responsive ------------ */
@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .contact-aside { position: static; }
}
@media (max-width: 600px) {
  .contact-main { padding-top: 100px; padding-bottom: 56px; }
  .contact-lead { font-size: 17px; margin-bottom: 36px; }
  .contact-form .form-row { flex-direction: column; align-items: stretch; gap: 14px; }
  .contact-submit { justify-content: center; }
  .contact-form .form-fineprint { text-align: center; }
}
