/* ============================================================
   DOCTO — Styles globaux + variables CSS
   Charte graphique : drapeau tchadien (navy / rouge / or / teal)
   ============================================================ */

:root {
  --navy:   #1A2C6B;
  --red:    #D42B2B;
  --gold:   #F5C200;
  --teal:   #0A7EA4;
  --white:  #FFFFFF;
  --off:    #F4F7FB;
  --gray:   #6B7280;
  --dark:   #0D1B3E;

  --radius-card: 18px;
  --radius-btn: 11px;
  --shadow-soft: 0 8px 24px rgba(0,0,0,.08);
  --transition: all .25s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--white);
  color: var(--dark);
  overflow-x: hidden;
  line-height: 1.5;
}

h1, h2, h3, h4, h5 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  color: var(--navy);
}

a { color: inherit; }

img { max-width: 100%; display: block; }

button { font-family: inherit; cursor: pointer; }

/* ── UTILITAIRES ── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 5%; }
.text-center { text-align: center; }
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-32 { margin-bottom: 32px; }

.section-eyebrow {
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--teal);
  margin-bottom: 12px;
}
.section-title {
  font-size: clamp(26px, 3vw, 40px);
  margin-bottom: 16px;
  letter-spacing: -0.5px;
}
.section-sub {
  color: var(--gray);
  font-size: 16px;
  line-height: 1.6;
  max-width: 560px;
  margin-bottom: 48px;
}

/* ── BADGES DE STATUT ── */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
}
.badge-vert   { background: rgba(34,197,94,.15); color: #16A34A; }
.badge-rouge  { background: rgba(212,43,43,.12); color: var(--red); }
.badge-gold   { background: rgba(245,194,0,.18); color: #A16207; }
.badge-navy   { background: rgba(26,44,107,.1); color: var(--navy); }
.badge-gris   { background: rgba(107,114,128,.12); color: var(--gray); }

/* ── FORMULAIRES ── */
.form-group { margin-bottom: 18px; }
.form-group label {
  display: block;
  font-size: 13px; font-weight: 600;
  color: var(--dark);
  margin-bottom: 6px;
}
.form-control {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid rgba(26,44,107,0.15);
  border-radius: 10px;
  font-size: 14px;
  font-family: inherit;
  color: var(--dark);
  background: var(--white);
  transition: var(--transition);
}
.form-control:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(10,126,164,0.12);
}
textarea.form-control { resize: vertical; min-height: 90px; }
.form-hint { font-size: 12px; color: var(--gray); margin-top: 4px; }
.form-error { font-size: 12px; color: var(--red); margin-top: 4px; font-weight: 600; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }

/* ── ALERTES / FLASH MESSAGES ── */
.alert {
  padding: 14px 18px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 20px;
  display: flex; align-items: center; gap: 10px;
}
.alert-succes  { background: rgba(34,197,94,.1);  color: #15803D; border: 1px solid rgba(34,197,94,.25); }
.alert-erreur  { background: rgba(212,43,43,.08); color: var(--red); border: 1px solid rgba(212,43,43,.2); }
.alert-info    { background: rgba(10,126,164,.08); color: var(--teal); border: 1px solid rgba(10,126,164,.2); }
.alert-warning { background: rgba(245,194,0,.15); color: #92650A; border: 1px solid rgba(245,194,0,.35); }

/* ── SCROLL REVEAL (JS ajoute .reveal-visible) ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .5s ease, transform .5s ease; }
.reveal-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .form-row { grid-template-columns: 1fr; }
}
