/* ============================================================
   Galaad — home.css
   Styles spécifiques à la home narrative (5 sections).
   ============================================================ */

/* ---------- Hero (Section 01) ---------- */

.hero__title {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 88px;
  line-height: 0.98;
  color: var(--galaad-ink);
  letter-spacing: -0.02em;
  max-width: 880px;
}

.hero__chapeau {
  font-family: var(--font-voice);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--galaad-ink-soft);
  line-height: 1.5;
  margin-top: var(--space-40);
  max-width: 660px;
}

.hero__signature {
  font-family: var(--font-voice);
  font-weight: 500;
  font-style: italic;
  font-size: 18px;
  color: var(--galaad-ink);
  max-width: 660px;
  margin-top: var(--space-24);
  padding-top: var(--space-24);
  border-top: 1px solid var(--galaad-rule-strong);
}

@media (max-width: 1024px) {
  .hero__title { font-size: 64px; }
  .hero__chapeau { font-size: 20px; }
}

@media (max-width: 720px) {
  .hero__title { font-size: 48px; }
  .hero__chapeau { font-size: 18px; }
  .hero__signature { font-size: 16px; }
}

/* ---------- Constat (Section 02) ---------- */

.constat__title {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 56px;
  line-height: 1.08;
  color: var(--galaad-ink);
  letter-spacing: -0.01em;
}

.constat__body {
  font-family: var(--font-voice);
  font-weight: 400;
  font-size: 24px;
  line-height: 1.45;
  color: var(--galaad-ink);
  max-width: 740px;
  margin-top: var(--space-40);
}

@media (max-width: 720px) {
  .constat__title { font-size: 36px; }
  .constat__body { font-size: 19px; }
}

/* ---------- Promesse (Section 03, fond encre) ---------- */

.promesse__opening {
  font-family: var(--font-voice);
  font-weight: 500;
  font-style: italic;
  font-size: 48px;
  line-height: 1.12;
  letter-spacing: -0.01em;
  max-width: 860px;
  color: var(--galaad-cream);
}

.promesse__body {
  font-family: var(--font-voice);
  font-weight: 400;
  font-size: 26px;
  line-height: 1.48;
  max-width: 780px;
  margin-top: var(--space-80);
  color: var(--galaad-cream);
  opacity: 0.92;
}

.promesse__body p {
  max-width: 780px;
  margin: 0 0 var(--space-24);
}

.promesse__body p:last-child {
  margin-bottom: 0;
}

.promesse__signature {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 48px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  max-width: 780px;
  margin-top: var(--space-80);
  padding-top: var(--space-24);
  border-top: 1px solid rgba(250, 247, 240, 0.22);
  color: var(--galaad-cream);
}

@media (max-width: 1024px) {
  .promesse__opening { font-size: 36px; }
  .promesse__body { font-size: 22px; }
  .promesse__signature { font-size: 36px; }
}

@media (max-width: 720px) {
  .promesse__opening { font-size: 28px; }
  .promesse__body { font-size: 19px; }
  .promesse__signature { font-size: 28px; }
}

/* ---------- 4 portes (Section 04) ---------- */

.portes__intro {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 52px;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--galaad-ink);
}

.portes__intro-sub {
  font-family: var(--font-voice);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--galaad-ink-soft);
  line-height: 1.5;
  margin-top: var(--space-24);
  max-width: 620px;
}

@media (max-width: 720px) {
  .portes__intro { font-size: 36px; }
  .portes__intro-sub { font-size: 18px; }
}

/* ---------- Appel (Section 05) ---------- */

.appel__intro {
  font-family: var(--font-voice);
  font-weight: 500;
  font-size: 56px;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--galaad-ink);
}

.appel__intro-sub {
  font-family: var(--font-voice);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--galaad-ink-soft);
  line-height: 1.5;
  margin-top: var(--space-24);
  max-width: 640px;
}

.appel__ctas {
  display: flex;
  align-items: center;
  gap: var(--space-40);
  margin-top: var(--space-80);
  flex-wrap: wrap;
}

@media (max-width: 720px) {
  .appel__intro { font-size: 36px; }
  .appel__intro-sub { font-size: 18px; }
  .appel__ctas {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-24);
  }
}
