/* Page "Notre engagement" : garanties d authenticite, certificat de la galerie
   et certificat d expert independant. Design coherent vintage galerie :
   beige + or, serif Libre Baskerville pour les titres, sans-serif Raleway
   pour les meta-tags uppercase. Pas de border-radius (convention design system). */

.engagement-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 2.5rem 2rem 4rem;
  font-family: var(--serif);
  color: var(--text);
  line-height: 1.7;
}

/* ---- Hero (eyebrow + h1 + lede) ---- */
.engagement-hero { text-align: center; padding: 1.5rem 0 2.5rem; }
.engagement-eyebrow {
  font-family: var(--sans);
  font-size: var(--t-eyebrow);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin: 0 0 1.2rem;
}
.engagement-title {
  font-family: var(--serif);
  font-size: var(--t-hero);
  font-weight: 700;
  color: var(--forest);
  line-height: 1.2;
  margin: 0 0 1.2rem;
  letter-spacing: 0.01em;
}
.engagement-title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold2);
}
.engagement-lede {
  font-family: var(--serif);
  font-size: var(--t-body);
  font-style: italic;
  color: var(--muted);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ---- Section (label en haut + carte) ---- */
.engagement-section { margin: 2rem 0 0; }
.engagement-section-label {
  font-family: var(--sans);
  font-size: var(--t-micro);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin: 0 0 1rem;
}

/* ---- Carte principale (encadre clair avec bordure or a gauche) ---- */
.engagement-card {
  background: #fff;
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  padding: 2rem 2rem 1.8rem;
}
.engagement-card-title {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 700;
  color: var(--forest);
  line-height: 1.3;
  margin: 0 0 0.8rem;
}
.engagement-card-tag {
  font-family: var(--sans);
  font-size: var(--t-micro);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin: 0 0 1.2rem;
}
.engagement-card-text {
  font-family: var(--serif);
  font-size: var(--t-body);
  color: var(--text);
  margin: 0 0 1.1rem;
  line-height: 1.7;
}
.engagement-card-text strong {
  color: var(--forest);
  font-weight: 700;
}

/* ---- Sous-encadre beige : "Chaque acquisition comprend" ---- */
.engagement-included {
  background: var(--beige);
  border: 1px solid var(--border);
  padding: 1.2rem 1.4rem;
  margin-top: 1.2rem;
}
.engagement-included-title {
  font-family: var(--sans);
  font-size: var(--t-micro);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin: 0 0 0.7rem;
}
.engagement-included-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.engagement-included-list li {
  font-family: var(--serif);
  font-size: var(--t-body);
  color: var(--text);
  padding: 0.25rem 0 0.25rem 1rem;
  position: relative;
}
.engagement-included-list li::before {
  content: "\2014"; /* tiret cadratin */
  color: var(--gold);
  position: absolute;
  left: 0;
}

/* ---- Bloc CTA sombre : "Demander un devis d expertise" ---- */
.engagement-cta {
  background: var(--forest);
  color: #f5ede0;
  padding: 1.4rem 1.6rem;
  margin-top: 1.4rem;
}
.engagement-cta-title {
  font-family: var(--serif);
  font-size: var(--t-body);
  font-weight: 700;
  color: #f5ede0;
  margin: 0 0 0.45rem;
}
.engagement-cta-text {
  font-family: var(--serif);
  font-size: var(--t-small);
  color: #d8d2c2;
  margin: 0 0 1.1rem;
  line-height: 1.65;
}
.engagement-cta-btn {
  display: inline-block;
  font-family: var(--sans);
  font-size: var(--t-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold3);
  background: transparent;
  border: 1px solid var(--gold3);
  padding: 10px 22px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.engagement-cta-btn:hover,
.engagement-cta-btn:focus-visible {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
  outline: none;
}

/* ---- Separateur losange or entre les 2 sections ---- */
.engagement-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 2.5rem 0;
  position: relative;
}
.engagement-divider::before,
.engagement-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border);
}
.engagement-divider-mark {
  color: var(--gold);
  font-size: var(--t-body);
  padding: 0 1rem;
}

/* ---- Note de bas de page : lien vers CGV ---- */
.engagement-footnote {
  font-family: var(--serif);
  font-size: var(--t-small);
  color: var(--muted);
  font-style: italic;
  text-align: center;
  margin: 2.5rem 0 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.engagement-footnote a {
  color: var(--gold);
  text-decoration: underline;
}
.engagement-footnote a:hover { color: var(--gold2); }

/* ---- Sprint 2.2 : Process en 4 etapes (Comment nous authentifions une piece) ---- */
.engagement-process {
  margin: 2.5rem 0;
}
.engagement-process-title {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 700;
  color: var(--forest);
  margin: 0.4rem 0 0.8rem;
}
.engagement-process-lede {
  font-family: var(--serif);
  font-size: var(--t-body);
  line-height: 1.7;
  color: var(--text);
  margin: 0 0 1.4rem;
}
.engagement-process-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 1rem;
}
.process-step {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: 1rem;
  padding: 1rem 1.2rem;
  background: var(--bg-soft, #f6f0e0);
  border-left: 3px solid var(--gold, #c49a3c);
  border-radius: 4px;
}
.process-step-num {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 700;
  color: #fff;
  background: var(--gold, #c49a3c);
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.process-step-body { display: flex; flex-direction: column; gap: 0.4rem; }
.process-step-title {
  font-family: var(--serif);
  font-size: var(--t-body);
  font-weight: 700;
  color: var(--forest);
  margin: 0;
}
.process-step-body p {
  margin: 0;
  font-size: var(--t-small);
  line-height: 1.65;
  color: var(--text);
}
.engagement-process-conclusion {
  margin: 1.4rem 0 0;
  font-size: var(--t-small);
  line-height: 1.65;
  color: var(--muted);
  font-style: italic;
}

/* ---- Sprint 2.1 : FAQ section ---- */
.engagement-faq { margin: 2.5rem 0; }
.engagement-faq-title {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 700;
  color: var(--forest);
  margin: 0.4rem 0 1.2rem;
}

/* ---- Responsive ---- */
@media (max-width: 640px) {
  .engagement-wrap { padding: 1.5rem 1rem 3rem; }
  .engagement-title { font-size: var(--t-h1); }
  .engagement-card { padding: 1.4rem 1.2rem; }
  /* Tous les h2 de section uniformes : card-title, process-title, faq-title */
  .engagement-card-title,
  .engagement-process-title,
  .engagement-faq-title { font-size: var(--t-h3); }
  .engagement-cta { padding: 1.2rem 1.2rem; }
  .process-step { grid-template-columns: 2.4rem 1fr; padding: 0.9rem 1rem; gap: 0.7rem; }
  .process-step-num { width: 2rem; height: 2rem; font-size: var(--t-h3); }
}
