/* ============================================================
   contact.css — Page Contact
   ============================================================ */

/* ── Layout principal ────────────────────────────────────── */
#contact.section {
  padding: 72px 0;
}

.contact__layout {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 100px;
  align-items: start;
}

/* ── Colonne gauche (infos) ──────────────────────────────── */
.contact__intro h2 {
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  margin-bottom: 8px;
}

.contact__intro p {
  font-size: 0.88rem;
  line-height: 1;
  color: var(--gris-2);
  margin-top: 12px;
  margin-bottom: 12px;
}

.contact__infos {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}
.contact__info {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--blanc-chaud);
  border: 1.5px solid var(--gris-5);
  border-radius: var(--radius-sm);
  transition: border-color var(--trans);
}
.contact__info:hover { border-color: var(--gris-4); }
.contact__info-icon {
  width: 32px; height: 32px;
  background: var(--blanc);
  border: 1.5px solid var(--gris-5);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  flex-shrink: 0;
}
.contact__info-label {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gris-3);
  margin-bottom: 1px;
}
.contact__info-val {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--encre);
}

/* Disponibilité */
.contact__dispo {
  background: var(--encre);
  color: var(--blanc);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.contact__dispo-icon { font-size: 1.1rem; flex-shrink: 0; }
.contact__dispo strong {
  display: block;
  font-size: 0.82rem;
  font-weight: 700;
  margin-bottom: 2px;
}
.contact__dispo p {
  font-size: 0.73rem;
  color: var(--gris-3);
  line-height: 1.4;
}

/* ── Formulaire ──────────────────────────────────────────── */
.contact-form {
  background: var(--blanc-chaud);
  border: 1.5px solid var(--gris-5);
  border-radius: var(--radius-lg);
  padding: 48px 44px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 4px;
}
.form-group--full { grid-column: 1 / -1; }

.form-group label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gris-2);
}
.form-group label sup { color: var(--rouge); }

.form-group input,
.form-group textarea,
.form-group select {
  background: var(--blanc);
  border: 1.5px solid var(--gris-4);
  border-radius: var(--radius-sm);
  color: var(--encre);
  padding: 13px 17px;
  font-size: 0.88rem;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color var(--trans), box-shadow var(--trans);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--encre);
  box-shadow: 0 0 0 3px rgba(17,17,16,0.06);
}
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--gris-3);
}
.form-group textarea {
  height: 150px;
  resize: vertical;
  min-height: 110px;
  max-height: 300px;
}

/* Indicateur de longueur */
.form-group__hint {
  font-size: 0.65rem;
  color: var(--gris-3);
  text-align: right;
  margin-top: 4px;
}

.form__submit {
  margin-top: 8px;
  width: 100%;
  justify-content: center;
  padding: 16px;
  font-size: 0.9rem;
}
.form__submit .btn-loading { display: none; }
.form__submit.loading .btn-text    { display: none; }
.form__submit.loading .btn-loading { display: inline; }

/* Feedback */
.form__feedback {
  margin-top: 16px;
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  font-weight: 500;
  display: none;
  line-height: 1.5;
}
.form__feedback.show  { display: block; }
.form__feedback--ok   { background: rgba(34,197,94,0.1);  color: #166534; border: 1.5px solid rgba(34,197,94,0.25); }
.form__feedback--err  { background: rgba(224,48,48,0.08); color: var(--rouge); border: 1.5px solid rgba(224,48,48,0.2); }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .contact__layout { grid-template-columns: 1fr; gap: 60px; }
}
@media (max-width: 640px) {
  .contact-form { padding: 32px 24px; }
  .form-row { grid-template-columns: 1fr; }
}
