/* ================================================================
   page-contact.css — enbi
   Page /contact/ (template page-contact.hbs).
   Portée : .page-contact (classe body ajoutée par Ghost).
   Registre Accueil : rendre le premier pas facile et rassurant.
   Deux colonnes : on explique comment ça marche, puis on agit.
   Tokens uniquement. Filets et cadres, pas d'ombres.
================================================================ */

/* ────────────────────────────────────────────────────────────
   LAYOUT — aside (réassurance) + formulaire encadré
──────────────────────────────────────────────────────────── */
.page-contact .contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}

/* ────────────────────────────────────────────────────────────
   ASIDE — comment ça fonctionne
──────────────────────────────────────────────────────────── */
.page-contact .contact-aside__title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: -.01em;
  color: var(--cadre);
  margin: 0 0 1.5rem;
}
.page-contact .contact-steps {
  list-style: none;
  margin: 0 0 1.75rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
}
.page-contact .contact-step {
  display: grid;
  grid-template-columns: 1.875rem 1fr;
  gap: .875rem;
  align-items: start;
}
.page-contact .contact-step__n {
  width: 1.875rem;
  height: 1.875rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--methode-tint);
  color: var(--methode);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: .875rem;
  font-variant-numeric: tabular-nums;
}
.page-contact .contact-step p {
  margin: .25rem 0 0;
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  line-height: 1.5;
  color: var(--ink);
  text-wrap: pretty;
}
.page-contact .contact-note {
  background: var(--methode-tint);
  border-radius: var(--radius);
  padding: 1.125rem 1.25rem;
  margin-bottom: 1.5rem;
}
.page-contact .contact-note p {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink);
  text-wrap: pretty;
}
.page-contact .contact-alt {
  margin: 0;
  font-family: var(--font-sans);
  font-size: .9375rem;
  line-height: 1.5;
  color: var(--ink-2);
}
.page-contact .contact-alt a {
  color: var(--methode);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}
.page-contact .contact-alt a:hover { color: var(--methode-700); }
.page-contact .contact-alt .arr { transition: transform .25s var(--ease); display: inline-block; }
.page-contact .contact-alt a:hover .arr { transform: translateX(3px); }

/* ────────────────────────────────────────────────────────────
   FORM PANEL — surface chaleureuse encadrée (sans ombre)
──────────────────────────────────────────────────────────── */
.page-contact .contact-form-panel {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.25rem);
}
.page-contact .contact-submit {
  width: 100%;
  justify-content: center;
  margin-top: .25rem;
}

/* Confirmation (était sans style) */
.page-contact .form-confirm-title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--cadre);
  margin: 0 0 .625rem;
  padding-top: .25rem;
}
.page-contact .form-confirm-title::before {
  content: "";
  display: inline-block;
  width: 1.15rem;
  height: 1.15rem;
  margin-right: .55rem;
  vertical-align: -.15rem;
  background-color: var(--methode);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2032%2032'%3E%3Cpath%20d='M14,21.414,9,16.413,10.413,15,14,18.586,21.585,11,23,12.415Z'/%3E%3Cpath%20d='M16,2A14,14,0,1,0,30,16,14.016,14.016,0,0,0,16,2Zm0,26A12,12,0,1,1,28,16,12.014,12.014,0,0,1,16,28Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2032%2032'%3E%3Cpath%20d='M14,21.414,9,16.413,10.413,15,14,18.586,21.585,11,23,12.415Z'/%3E%3Cpath%20d='M16,2A14,14,0,1,0,30,16,14.016,14.016,0,0,0,16,2Zm0,26A12,12,0,1,1,28,16,12.014,12.014,0,0,1,16,28Z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.page-contact .form-confirm-body {
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--ink);
  margin: 0;
  max-width: 52ch;
}

/* ────────────────────────────────────────────────────────────
   LEGAL — bloc données personnelles, discret mais lisible
──────────────────────────────────────────────────────────── */
.page-contact .contact-legal {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  padding-top: 1.75rem;
  border-top: 1px solid var(--line);
  max-width: 760px;
}
.page-contact .contact-legal__title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: .8125rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
  color: var(--methode);
  margin: 0 0 .875rem;
}
.page-contact .contact-legal p {
  font-family: var(--font-sans);
  font-size: .875rem;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0 0 .625rem;
  max-width: 72ch;
}
.page-contact .contact-legal p:last-child { margin-bottom: 0; }

/* ────────────────────────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
  .page-contact .contact-layout { grid-template-columns: 1fr; gap: 2.25rem; }
}
