/* ================================================================
   EDIFY — Feuille de styles unifiée — Thème clair
   Inspiré de m2iformation.fr : professionnel, lisible, structuré
   Couleurs marque : Rouge #C1272D · Or #E8950A · Noir #1a1a1a · Blanc #fff
   ================================================================ */

/* ── RESET & BASE ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Inter', sans-serif;
  background: #f4f5f7;
  color: #1a1a1a;
  line-height: 1.65;
  overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
  font-family: 'Raleway', sans-serif;
  font-weight: 600;
  line-height: 1.15;
  color: #1a1a1a;
}
a { color: inherit; text-decoration: none; transition: all .22s ease; }
img { max-width: 100%; height: auto; }

/* ── VARIABLES ────────────────────────────────────────────────── */
:root {
  --rouge:     #C1272D;
  --rouge-2:   #9B1B20;
  --rouge-3:   #D93035;
  --rouge-pale:#FFF1F1;
  --or:        #E8950A;
  --or-2:      #F4A300;
  --vert:      #22A35F;
  --blanc:     #ffffff;
  --gris-0:    #f4f5f7;
  --gris-1:    #e8eaed;
  --gris-2:    #d1d5db;
  --gris-3:    #9ca3af;
  --gris-4:    #6b7280;
  --noir:      #1a1a1a;
  --noir-2:    #374151;
  --border:    #e5e7eb;
  --font-h:    'Raleway', sans-serif;
  --font-b:    'Inter', sans-serif;
  --r:         8px;
  --rlg:       12px;
  --sh:        0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --sh-md:     0 4px 16px rgba(0,0,0,.1);
  --sh-lg:     0 10px 40px rgba(0,0,0,.12);
  --tr:        all .22s ease;
  --nav-h:     68px;
}

/* ── LAYOUT ───────────────────────────────────────────────────── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.page-wrap { padding-top: var(--nav-h); }
section { padding: 72px 0; }

/* ── NAVBAR ───────────────────────────────────────────────────── */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: #fff;
  border-bottom: 1px solid var(--border);
  box-shadow: var(--sh);
  transition: var(--tr);
}
#navbar.scrolled { box-shadow: var(--sh-md); }
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--nav-h); max-width: 1240px; margin: 0 auto; padding: 0 28px; gap: 16px;
}
.nav-logo { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo img { height: 36px; }
.nav-logo-txt {
  font-family: var(--font-h); font-size: 1.5rem; font-weight: 700;
  letter-spacing: .05em; display: none;
}
.nav-logo-txt .r { color: var(--rouge); }
.nav-logo-txt .o { color: var(--or); }

.nav-links {
  display: flex; align-items: center; gap: 2px;
  list-style: none; flex: 1; justify-content: center;
}
.nav-links > li > a {
  padding: 7px 13px; font-size: .875rem; font-weight: 500;
  color: var(--noir-2); border-radius: 6px; white-space: nowrap;
}
.nav-links > li > a:hover { color: var(--rouge); background: var(--rouge-pale); }
.nav-links > li > a.active { color: var(--rouge); font-weight: 600; }

/* Dropdown */
.nav-dd { position: relative; }
.nav-dd > a::after {
  content: ''; display: inline-block; width: 0; height: 0;
  border: 4px solid transparent; border-top-color: currentColor;
  margin-left: 5px; margin-top: 2px; opacity: .5; transition: transform .2s;
}
.nav-dd:hover > a::after { transform: rotate(180deg); }
.dd-menu {
  position: absolute; top: calc(100% + 4px); left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); min-width: 240px; padding: 6px;
  opacity: 0; visibility: hidden;
  transition: opacity .18s, transform .18s, visibility .18s .1s;
  box-shadow: var(--sh-lg); pointer-events: none;
}
.dd-menu::before {
  content: ''; position: absolute; top: -12px; left: 0; right: 0; height: 12px;
}
.nav-dd:hover .dd-menu {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
  transition: opacity .18s, transform .18s, visibility 0s;
}
.dd-menu a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px; font-size: .84rem; color: var(--noir-2); border-radius: 8px;
}
.dd-menu a:hover { color: var(--rouge); background: var(--rouge-pale); }
.dd-menu a i { width: 17px; text-align: center; color: var(--rouge); font-size: .85rem; flex-shrink: 0; }
.dd-divider { height: 1px; background: var(--border); margin: 5px 10px; }
.dd-label {
  padding: 8px 14px 4px; font-size: .65rem; color: var(--gris-3);
  letter-spacing: .1em; text-transform: uppercase;
  font-family: var(--font-h); font-weight: 600;
}

/* CTA bouton nav */
.nav-cta {
  background: var(--rouge) !important; color: #fff !important;
  font-weight: 600 !important; padding: 8px 20px !important;
  border-radius: 6px !important;
}
.nav-cta:hover {
  background: var(--rouge-2) !important;
  box-shadow: 0 4px 16px rgba(193,39,45,.3) !important;
}

/* Mobile nav */
.nav-toggle {
  display: none; background: none; border: none; cursor: pointer;
  padding: 8px; flex-direction: column; gap: 5px; flex-shrink: 0;
}
.nav-toggle span {
  display: block; width: 22px; height: 2px;
  background: var(--noir); border-radius: 2px; transition: var(--tr);
}
.mob-nav {
  display: none; position: fixed; top: var(--nav-h); left: 0; right: 0; bottom: 0;
  background: #fff; z-index: 999; overflow-y: auto;
  padding: 12px 16px 32px; flex-direction: column; gap: 2px;
  border-top: 2px solid var(--rouge);
}
.mob-nav.open { display: flex; }
.mob-section {
  font-size: .65rem; color: var(--gris-3); letter-spacing: .12em;
  text-transform: uppercase; padding: 14px 8px 6px;
  font-family: var(--font-h); font-weight: 600;
}
.mob-nav > a {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; font-size: .92rem; font-weight: 500;
  color: var(--noir-2); border-radius: var(--r);
}
.mob-nav > a i { width: 18px; text-align: center; color: var(--rouge); font-size: .85rem; }
.mob-nav > a:hover { background: var(--rouge-pale); color: var(--rouge); }
.mob-cta {
  background: var(--rouge) !important; color: #fff !important;
  font-weight: 600 !important; margin-top: 12px;
  justify-content: center !important; border-radius: var(--r);
}
.mob-cta:hover { background: var(--rouge-2) !important; }

@media (max-width: 1040px) {
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
}

/* ── BUTTONS ──────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 26px; font-family: var(--font-h); font-size: .9rem;
  font-weight: 600; letter-spacing: .04em; border-radius: var(--r);
  border: 2px solid transparent; cursor: pointer; transition: var(--tr);
  text-transform: uppercase; white-space: nowrap;
}
.btn-rouge {
  background: var(--rouge); color: #fff; border-color: var(--rouge);
}
.btn-rouge:hover {
  background: var(--rouge-2); border-color: var(--rouge-2);
  box-shadow: 0 6px 20px rgba(193,39,45,.3);
  transform: translateY(-1px);
}
.btn-or {
  background: var(--or); color: #fff; border-color: var(--or);
}
.btn-or:hover {
  background: var(--or-2); border-color: var(--or-2);
  box-shadow: 0 6px 20px rgba(232,149,10,.3);
  transform: translateY(-1px);
}
.btn-outline {
  background: transparent; color: var(--rouge); border-color: var(--rouge);
}
.btn-outline:hover { background: var(--rouge); color: #fff; }
.btn-outline-dark {
  background: transparent; color: var(--noir); border-color: var(--gris-2);
}
.btn-outline-dark:hover { border-color: var(--rouge); color: var(--rouge); }
.btn-sm  { padding: 7px 16px; font-size: .8rem; }
.btn-lg  { padding: 14px 34px; font-size: 1rem; }

/* ── BADGES ───────────────────────────────────────────────────── */
.badge {
  display: inline-block; padding: 3px 10px; font-size: .71rem;
  font-weight: 600; font-family: var(--font-h); border-radius: 100px;
  letter-spacing: .04em; text-transform: uppercase;
}
.badge-or    { background: #FFF7E6; color: #b8740a; border: 1px solid #fcd34d; }
.badge-rouge { background: var(--rouge-pale); color: var(--rouge); border: 1px solid #fca5a5; }
.badge-vert  { background: #f0fdf4; color: #166534; border: 1px solid #86efac; }
.badge-gris  { background: #f9fafb; color: var(--gris-4); border: 1px solid var(--border); }
.badge-bleu  { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }

/* ── SECTION TYPOGRAPHY ───────────────────────────────────────── */
.sec-label {
  font-family: var(--font-h); font-size: .72rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase; color: var(--rouge);
  margin-bottom: 10px; display: block;
}
.sec-title {
  font-family: var(--font-h);
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight: 700; margin-bottom: 14px; line-height: 1.1;
}
.sec-sub {
  font-size: .96rem; color: var(--gris-4); max-width: 560px; line-height: 1.72;
}

/* ── CARDS ────────────────────────────────────────────────────── */
.card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); box-shadow: var(--sh);
  transition: var(--tr); overflow: hidden;
}
.card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }

/* ── FORMS ────────────────────────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-label {
  display: block; font-size: .85rem; font-weight: 600;
  color: var(--noir-2); margin-bottom: 6px;
}
.form-ctrl {
  width: 100%; padding: 10px 14px;
  background: #fff; border: 1.5px solid var(--gris-2);
  border-radius: var(--r); color: var(--noir);
  font-family: var(--font-b); font-size: .91rem; outline: none; transition: var(--tr);
}
.form-ctrl:focus {
  border-color: var(--rouge); background: #fff;
  box-shadow: 0 0 0 3px rgba(193,39,45,.08);
}
.form-ctrl::placeholder { color: var(--gris-3); }
select.form-ctrl option { background: #fff; color: var(--noir); }
textarea.form-ctrl { min-height: 100px; resize: vertical; }

/* ── ALERTS ───────────────────────────────────────────────────── */
.alert-wrap {
  position: fixed; top: 80px; right: 18px; z-index: 9000;
  display: flex; flex-direction: column; gap: 8px; max-width: 360px;
}
.alert {
  padding: 12px 16px; border-radius: var(--r); font-size: .86rem;
  display: flex; align-items: center; gap: 9px;
  animation: slideIn .3s ease; box-shadow: var(--sh-md);
}
.alert-success { background: #f0fdf4; border: 1px solid #86efac; color: #166534; }
.alert-error   { background: var(--rouge-pale); border: 1px solid #fca5a5; color: var(--rouge-2); }
.alert-info    { background: #eff6ff; border: 1px solid #bfdbfe; color: #1d4ed8; }
@keyframes slideIn { from { transform: translateX(110%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* ── SPINNER ──────────────────────────────────────────────────── */
.spinner {
  width: 36px; height: 36px;
  border: 3px solid rgba(193,39,45,.15);
  border-top-color: var(--rouge);
  border-radius: 50%; animation: spin .8s linear infinite; margin: 0 auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── REVEAL ANIMATION ─────────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── HERO SECTIONS ────────────────────────────────────────────── */
.hero-section {
  background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
  color: #fff; padding: 100px 0 72px;
}
.hero-rouge {
  background: linear-gradient(135deg, var(--rouge-2) 0%, var(--rouge) 100%);
  color: #fff; padding: 80px 0 60px;
}
.hero-light {
  background: linear-gradient(135deg, #f8f9fa 0%, #fff 100%);
  border-bottom: 1px solid var(--border); padding: 80px 0 60px;
}

/* ── SECTION BACKGROUNDS ──────────────────────────────────────── */
.bg-white   { background: #fff; }
.bg-light   { background: var(--gris-0); }
.bg-rouge   { background: var(--rouge); color: #fff; }
.bg-noir    { background: var(--noir); color: #fff; }

/* ── DIVIDER ──────────────────────────────────────────────────── */
.divider-rouge { height: 3px; background: var(--rouge); width: 48px; border-radius: 2px; margin: 12px 0 20px; }

/* ── STAT CARDS ───────────────────────────────────────────────── */
.stat-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 24px; text-align: center;
  box-shadow: var(--sh);
}
.stat-num {
  font-family: var(--font-h); font-size: 2.4rem; font-weight: 700;
  color: var(--rouge); display: block; line-height: 1;
}
.stat-lbl {
  font-size: .82rem; color: var(--gris-4);
  text-transform: uppercase; letter-spacing: .06em;
  margin-top: 6px; display: block;
}

/* ── COURSE CARDS ─────────────────────────────────────────────── */
.course-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; transition: var(--tr);
  box-shadow: var(--sh);
}
.course-card:hover { box-shadow: var(--sh-md); transform: translateY(-3px); }
.course-card-img {
  width: 100%; height: 180px; object-fit: cover;
  background: linear-gradient(135deg, var(--gris-1), var(--gris-0));
}
.course-card-body { padding: 20px; }
.course-card-title {
  font-family: var(--font-h); font-size: 1.05rem; font-weight: 600;
  color: var(--noir); margin: 8px 0; line-height: 1.25;
}
.course-card-meta { font-size: .82rem; color: var(--gris-4); display: flex; gap: 12px; flex-wrap: wrap; }
.course-card-price {
  font-family: var(--font-h); font-size: 1.2rem; font-weight: 700;
  color: var(--rouge); margin-top: 12px;
}

/* ── DOMAIN ICON CHIP ─────────────────────────────────────────── */
.domain-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 100px; font-size: .78rem; font-weight: 600;
  font-family: var(--font-h); text-transform: uppercase; letter-spacing: .04em;
}
.chip-reseau  { background: #fff7ed; color: #c2410c; border: 1px solid #fed7aa; }
.chip-cyber   { background: #fef2f2; color: var(--rouge-2); border: 1px solid #fecaca; }
.chip-dev     { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.chip-data    { background: #f0fdf4; color: #166534; border: 1px solid #86efac; }

/* ── TABLE ────────────────────────────────────────────────────── */
.table-wrap {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; box-shadow: var(--sh);
}
.edify-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.edify-table th {
  background: #f8f9fa; font-family: var(--font-h); font-size: .72rem;
  letter-spacing: .08em; text-transform: uppercase; color: var(--gris-4);
  padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border);
}
.edify-table td {
  padding: 12px 16px; border-bottom: 1px solid #f3f4f6;
  color: var(--noir-2); vertical-align: middle;
}
.edify-table tr:last-child td { border-bottom: none; }
.edify-table tr:hover td { background: #fafafa; }

/* ── FOOTER ───────────────────────────────────────────────────── */
#footer {
  background: var(--noir); color: #d1d5db;
  border-top: 4px solid var(--rouge); padding: 60px 0 0;
}
.ft-grid {
  display: grid; grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 40px; padding-bottom: 44px; border-bottom: 1px solid rgba(255,255,255,.08);
}
.ft-brand p { font-size: .86rem; color: #9ca3af; margin: 14px 0 20px; line-height: 1.7; }
.ft-socials { display: flex; gap: 8px; }
.soc-btn {
  width: 36px; height: 36px; background: rgba(255,255,255,.07);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  color: #9ca3af; font-size: .85rem; transition: var(--tr);
}
.soc-btn:hover { background: var(--rouge); color: #fff; transform: translateY(-2px); }
.soc-btn.wa:hover { background: #25D366; }
.soc-btn.li:hover { background: #0077B5; }
.soc-btn.yt:hover { background: #FF0000; }
.ft-col h5 {
  font-family: var(--font-h); font-size: .8rem; font-weight: 600;
  color: #fff; margin-bottom: 18px; letter-spacing: .08em; text-transform: uppercase;
}
.ft-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.ft-col ul li a {
  font-size: .84rem; color: #9ca3af; transition: var(--tr);
  display: flex; align-items: center; gap: 7px;
}
.ft-col ul li a:hover { color: var(--or); padding-left: 3px; }
.ft-col ul li a i { color: var(--rouge); font-size: .74rem; width: 13px; flex-shrink: 0; }
.ft-ci { display: flex; align-items: flex-start; gap: 10px; font-size: .84rem; color: #9ca3af; margin-bottom: 10px; }
.ft-ci i { color: var(--rouge); margin-top: 2px; font-size: .78rem; flex-shrink: 0; width: 14px; }
.ft-ci a { color: var(--or); }
.ft-ci a:hover { color: var(--or-2); }
.ft-bottom {
  padding: 18px 0; display: flex; align-items: center;
  justify-content: space-between; font-size: .78rem; color: #6b7280;
}

@media (max-width: 900px) { .ft-grid { grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 580px) {
  .ft-grid { grid-template-columns: 1fr; gap: 22px; }
  .ft-bottom { flex-direction: column; gap: 8px; text-align: center; }
}

/* ── PAGINATION ───────────────────────────────────────────────── */
.pagination { display: flex; align-items: center; gap: 6px; justify-content: center; margin-top: 32px; }
.pagination a, .pagination span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 10px;
  border-radius: 6px; font-size: .85rem; font-weight: 500;
  border: 1px solid var(--border); background: #fff; color: var(--noir-2);
  transition: var(--tr);
}
.pagination a:hover { border-color: var(--rouge); color: var(--rouge); }
.pagination .current { background: var(--rouge); color: #fff; border-color: var(--rouge); }

/* ── BREADCRUMB ───────────────────────────────────────────────── */
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: .82rem; color: var(--gris-3); }
.breadcrumb a { color: var(--rouge); }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb span::before { content: '/'; margin-right: 6px; }

/* ── QUIZ / ORIENTATION ───────────────────────────────────────── */
.quiz-wrapper { max-width: 760px; margin: 48px auto; padding: 0 24px; }
.quiz-progress { margin-bottom: 32px; }
.progress-bar-outer {
  height: 6px; background: var(--gris-1);
  border-radius: 100px; overflow: hidden; margin-top: 8px;
}
.progress-bar-inner {
  height: 100%; background: var(--rouge);
  border-radius: 100px; transition: width .5s ease;
}
.progress-label {
  display: flex; justify-content: space-between;
  font-size: .82rem; color: var(--gris-4); margin-bottom: 8px;
}
.question-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 36px;
  display: none; animation: fadeSlide .4s ease; box-shadow: var(--sh);
}
.question-card.active { display: block; }
@keyframes fadeSlide {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
.question-num {
  font-size: .8rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--rouge); margin-bottom: 10px;
}
.question-text {
  font-family: var(--font-h); font-size: 1.3rem; font-weight: 700;
  margin-bottom: 24px; line-height: 1.3; color: var(--noir);
}
.options-grid { display: flex; flex-direction: column; gap: 10px; }
.option-btn {
  display: flex; align-items: center; gap: 14px; padding: 14px 18px;
  background: #fff; border: 1.5px solid var(--border);
  border-radius: var(--r); cursor: pointer; transition: var(--tr);
  text-align: left; width: 100%; font-family: var(--font-b);
  font-size: .95rem; color: var(--noir-2);
}
.option-btn:hover { border-color: var(--rouge); background: var(--rouge-pale); color: var(--rouge); }
.option-btn.selected {
  background: var(--rouge-pale); border-color: var(--rouge);
  color: var(--rouge); font-weight: 600;
}
.option-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--gris-0); display: flex; align-items: center;
  justify-content: center; font-size: 1.1rem; flex-shrink: 0;
}
.option-btn.selected .option-icon { background: rgba(193,39,45,.1); }
.quiz-nav { display: flex; justify-content: space-between; margin-top: 28px; gap: 12px; }
.quiz-section-title {
  font-family: var(--font-h); font-size: .75rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--gris-3);
  padding: 16px 0 8px; border-top: 1px solid var(--border); margin-top: 8px;
}
.input-question input, .input-question select {
  width: 100%; background: #fff; border: 1.5px solid var(--gris-2);
  border-radius: var(--r); padding: 13px 16px; color: var(--noir);
  font-family: var(--font-b); font-size: 1rem; outline: none; margin-top: 4px;
}
.input-question input:focus, .input-question select:focus { border-color: var(--rouge); }

/* ── SCORE BARS (RÉSULTATS ORIENTATION) ───────────────────────── */
.score-bar-wrap { margin-bottom: 20px; }
.score-label {
  display: flex; justify-content: space-between;
  font-size: .85rem; margin-bottom: 6px; font-weight: 500; color: var(--noir-2);
}
.score-bar {
  height: 12px; background: var(--gris-1);
  border-radius: 100px; overflow: hidden;
}
.score-fill { height: 100%; border-radius: 100px; transition: width 1s ease; }

/* ══════════════════════════════════════════════════════════════
   17. COMMUNAUTÉ / ALUMNI
   ══════════════════════════════════════════════════════════════ */

.alumni-hero { background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%); padding: 100px 0 80px; position: relative; overflow: hidden; text-align: center; color: #fff; }
.alumni-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px; }
.alumni-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 28px; text-align: center; transition: var(--tr); box-shadow: var(--sh); }
.alumni-card:hover { border-color: rgba(193,39,45,.2); transform: translateY(-4px); box-shadow: var(--sh-md); }
.alumni-avatar { width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 16px; display: flex; align-items: center; justify-content: center; font-family: var(--font-h); font-weight: 700; font-size: 1.4rem; }
.alumni-name { font-family: var(--font-h); font-weight: 700; font-size: 1.05rem; margin-bottom: 4px; color: var(--noir); }
.alumni-role { font-size: .85rem; color: var(--rouge); margin-bottom: 4px; }
.alumni-company { font-size: .82rem; color: var(--gris-3); }
.alumni-quote { font-size: .88rem; color: var(--gris-4); margin-top: 14px; font-style: italic; line-height: 1.6; }
.join-card { background: #fff; border-radius: var(--rlg); border: 1px solid rgba(193,39,45,.15); padding: 40px; text-align: center; box-shadow: var(--sh-md); }

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


/* ══════════════════════════════════════════════════════════════
   18. CONTACT
   ══════════════════════════════════════════════════════════════ */

.contact-layout { display: grid; grid-template-columns: 1fr 1.5fr; gap: 40px; max-width: 1100px; margin: 60px auto; padding: 0 24px; }
.contact-info-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 36px; box-shadow: var(--sh); }
.contact-form-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 36px; box-shadow: var(--sh); }
.info-item { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 24px; }
.info-icon { width: 44px; height: 44px; background: var(--rouge-pale); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--rouge); flex-shrink: 0; }
.info-label { font-size: .78rem; color: var(--gris-3); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; display: block; }
.info-value { font-size: .95rem; font-weight: 500; color: var(--noir); }

@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; gap: 24px; } }


/* ══════════════════════════════════════════════════════════════
   19. MISSION / À PROPOS
   ══════════════════════════════════════════════════════════════ */

.mission-hero { padding: 100px 0 80px; position: relative; overflow: hidden; background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%); color: #fff; }
.mission-hero h1 { color: #fff; }
.values-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.value-card { text-align: center; padding: 36px 24px; background: #fff; border-radius: var(--rlg); border: 1px solid var(--border); transition: var(--tr); box-shadow: var(--sh); }
.value-card:hover { border-color: rgba(193,39,45,.2); transform: translateY(-4px); box-shadow: var(--sh-md); }
.value-icon { font-size: 2.5rem; margin-bottom: 16px; display: block; }
.value-title { font-family: var(--font-h); font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.value-text { font-size: .88rem; color: var(--gris-4); line-height: 1.65; }
.team-stat { text-align: center; }
.team-stat .num { font-family: var(--font-h); font-size: 2.6rem; font-weight: 800; color: var(--rouge); line-height: 1; display: block; }
.team-stat .lbl { font-size: .85rem; color: var(--gris-4); margin-top: 6px; display: block; }

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


/* ══════════════════════════════════════════════════════════════
   20. SOLUTIONS
   ══════════════════════════════════════════════════════════════ */

.sol-hero { padding: 110px 0 64px; position: relative; overflow: hidden; background: var(--gris-0); border-bottom: 1px solid var(--border); }
.sol-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 60% at 70% 50%, rgba(193,39,45,.07) 0%, transparent 70%); pointer-events: none; }
.sol-hero-inner { max-width: 700px; }
.sol-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: var(--rouge-pale); border: 1px solid rgba(193,39,45,.2); border-radius: 50px; padding: 5px 14px; font-size: .78rem; font-weight: 600; color: var(--rouge); letter-spacing: .06em; text-transform: uppercase; margin-bottom: 20px; }
.sol-hero h1 { font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 700; color: var(--noir); line-height: 1.1; margin-bottom: 18px; }
.sol-hero h1 em { color: var(--rouge); font-style: normal; }
.sol-hero p { font-size: 1.05rem; color: var(--gris-4); line-height: 1.7; max-width: 580px; margin-bottom: 30px; }
.sol-pillars { display: flex; flex-wrap: wrap; gap: 10px; }
.sol-pillar { display: flex; align-items: center; gap: 7px; padding: 7px 14px; background: #fff; border: 1px solid var(--border); border-radius: 50px; font-size: .82rem; color: var(--gris-4); }
.sol-pillar i { color: var(--or); }
.sol-section { padding: 72px 0; }
.sol-section:nth-child(even) { background: var(--gris-0); }

/* Plans hébergement */
.plans-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; }
.plan-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; position: relative; transition: var(--tr); box-shadow: var(--sh); }
.plan-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.plan-card.featured { border-color: rgba(193,39,45,.3); box-shadow: 0 0 0 1px rgba(193,39,45,.1), var(--sh-md); }
.plan-badge { position: absolute; top: 16px; right: 16px; background: var(--rouge); color: #fff; font-size: .7rem; font-weight: 700; padding: 3px 10px; border-radius: 50px; letter-spacing: .05em; text-transform: uppercase; }
.plan-top { padding: 28px 24px 20px; border-bottom: 1px solid var(--border); }
.plan-name { font-family: var(--font-h); font-size: 1.15rem; font-weight: 600; color: var(--noir); margin-bottom: 6px; }
.plan-desc { font-size: .82rem; color: var(--gris-4); line-height: 1.5; }
.plan-price { font-family: var(--font-h); font-size: 1.6rem; font-weight: 700; color: var(--rouge); margin-top: 14px; }
.plan-price small { font-size: .8rem; color: var(--gris-3); font-weight: 400; }
.plan-feats { padding: 20px 24px; display: flex; flex-direction: column; gap: 9px; }
.plan-feat { display: flex; align-items: flex-start; gap: 9px; font-size: .84rem; color: var(--gris-4); }
.plan-feat i { color: var(--vert); margin-top: 2px; flex-shrink: 0; }
.plan-feat.muted i { color: var(--gris-2); }
.plan-feat.muted span { color: var(--gris-3); text-decoration: line-through; }
.plan-cta { margin: 0 24px 24px; display: block; text-align: center; padding: 11px 20px; border-radius: 8px; font-weight: 600; font-size: .88rem; transition: var(--tr); }
.plan-cta-primary { background: var(--rouge); color: #fff; }
.plan-cta-primary:hover { background: var(--rouge-3); }
.plan-cta-outline { background: transparent; border: 1px solid var(--border); color: var(--gris-4); }
.plan-cta-outline:hover { border-color: var(--rouge); color: var(--rouge); }

/* EDEN ERP */
.eden-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; margin-top: 44px; }
.eden-args { display: flex; flex-direction: column; gap: 16px; }
.eden-arg { display: flex; gap: 14px; align-items: flex-start; }
.eden-arg-ico { width: 44px; height: 44px; border-radius: 10px; flex-shrink: 0; background: #fff7ed; border: 1px solid rgba(232,149,10,.2); display: flex; align-items: center; justify-content: center; color: var(--or); font-size: 1.1rem; }
.eden-arg-body h4 { font-size: .95rem; font-weight: 600; color: var(--noir); margin-bottom: 4px; }
.eden-arg-body p { font-size: .83rem; color: var(--gris-4); line-height: 1.55; }
.eden-modules { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.eden-module { display: flex; align-items: center; gap: 10px; padding: 12px 14px; background: var(--gris-0); border: 1px solid var(--border); border-radius: 9px; transition: var(--tr); }
.eden-module:hover { border-color: rgba(232,149,10,.3); background: #fff7ed; }
.eden-module i { color: var(--or); width: 18px; text-align: center; }
.eden-module span { font-size: .83rem; color: var(--gris-4); }
.eden-cta-block { margin-top: 20px; }
.eden-note { font-size: .78rem; color: var(--gris-3); margin-top: 8px; }

/* Dev web cards */
.dev-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; }
.dev-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 28px 24px; transition: var(--tr); box-shadow: var(--sh); }
.dev-card:hover { border-color: rgba(193,39,45,.2); transform: translateY(-3px); box-shadow: var(--sh-md); }
.dev-icon { font-size: 2rem; margin-bottom: 14px; }
.dev-name { font-family: var(--font-h); font-size: 1.1rem; font-weight: 600; color: var(--noir); margin-bottom: 8px; }
.dev-desc { font-size: .83rem; color: var(--gris-4); line-height: 1.6; margin-bottom: 14px; }
.dev-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.dev-tag { font-size: .72rem; padding: 3px 9px; background: var(--gris-0); border: 1px solid var(--border); border-radius: 4px; color: var(--gris-4); }

/* CTA Sol */
.sol-cta { padding: 72px 0; text-align: center; background: var(--gris-0); border-top: 1px solid var(--border); }
.sol-cta h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; color: var(--noir); margin-bottom: 12px; }
.sol-cta p { color: var(--gris-4); font-size: 1rem; margin-bottom: 30px; }
.contacts-strip { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 20px; }
.contact-item { display: flex; align-items: center; gap: 7px; font-size: .85rem; color: var(--gris-4); }
.contact-item i { color: var(--rouge); }

@media (max-width: 900px) { .plans-grid { grid-template-columns: 1fr; } .eden-layout { grid-template-columns: 1fr; } .dev-grid { grid-template-columns: 1fr; } }


/* ══════════════════════════════════════════════════════════════
   21. ENTREPRISES B2B
   ══════════════════════════════════════════════════════════════ */

.b2b-hero { background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%); padding: 100px 0 80px; position: relative; overflow: hidden; color: #fff; }
.b2b-hero h1 { color: #fff; }
.b2b-hero::before { content: "B2B"; position: absolute; right: -40px; bottom: -40px; font-family: var(--font-h); font-size: 15rem; font-weight: 800; color: rgba(232,149,10,.04); }
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.service-card { background: #fff; border-radius: var(--rlg); padding: 32px; border: 1px solid var(--border); transition: var(--tr); box-shadow: var(--sh); }
.service-card:hover { border-color: rgba(193,39,45,.2); transform: translateY(-4px); box-shadow: var(--sh-md); }
.certifs-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 32px; }
.certif-badge { background: #fff; border: 1px solid var(--border); border-radius: var(--r); padding: 20px; text-align: center; box-shadow: var(--sh); }
.certif-badge .name { font-family: var(--font-h); font-weight: 700; margin-top: 10px; font-size: .95rem; color: var(--noir); }
.certif-badge .vendor { font-size: .78rem; color: var(--gris-3); margin-top: 4px; }

@media (max-width: 900px) { .services-grid { grid-template-columns: 1fr 1fr; } .certifs-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .services-grid { grid-template-columns: 1fr; } }


/* ══════════════════════════════════════════════════════════════
   22. RÉALISATIONS / PORTFOLIO
   ══════════════════════════════════════════════════════════════ */

.real-hero { padding: 100px 0 52px; background: var(--gris-0); border-bottom: 1px solid var(--border); position: relative; overflow: hidden; }
.real-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 50% 70% at 80% 50%, rgba(232,149,10,.06) 0%, transparent 65%); pointer-events: none; }
.real-hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: #fff7ed; border: 1px solid rgba(232,149,10,.2); border-radius: 50px; padding: 5px 14px; font-size: .78rem; font-weight: 600; color: var(--or); letter-spacing: .06em; text-transform: uppercase; margin-bottom: 18px; }
.real-hero h1 { font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; color: var(--noir); line-height: 1.1; margin-bottom: 14px; }
.real-hero h1 em { color: var(--or); font-style: normal; }
.real-hero p { font-size: 1rem; color: var(--gris-4); max-width: 560px; line-height: 1.7; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 28px; margin-top: 28px; }
.hero-stat { display: flex; align-items: baseline; gap: 8px; }
.hero-stat-num { font-family: var(--font-h); font-size: 1.8rem; font-weight: 700; color: var(--or); }
.hero-stat-label { font-size: .82rem; color: var(--gris-4); }

.filter-bar { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; padding: 24px 0 28px; border-bottom: 1px solid var(--border); margin-bottom: 36px; }
.filter-label { font-size: .78rem; font-weight: 600; color: var(--gris-3); text-transform: uppercase; letter-spacing: .08em; margin-right: 6px; }
.filter-btn { padding: 6px 16px; border-radius: 50px; font-size: .82rem; font-weight: 500; border: 1px solid var(--border); color: var(--gris-4); cursor: pointer; background: transparent; transition: var(--tr); text-decoration: none; display: inline-block; }
.filter-btn:hover { border-color: rgba(232,149,10,.4); color: var(--noir); }
.filter-btn.active { background: var(--or); border-color: var(--or); color: #111; font-weight: 600; }

.portfolio-section { padding: 20px 0 80px; }
.portfolio-count { font-size: .84rem; color: var(--gris-3); margin-bottom: 24px; }
.portfolio-count strong { color: var(--noir-2); }
.portfolio-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

.p-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; display: flex; flex-direction: column; transition: var(--tr); box-shadow: var(--sh); }
.p-card:hover { transform: translateY(-5px); box-shadow: var(--sh-md); border-color: rgba(232,149,10,.2); }
.p-img { width: 100%; height: 180px; object-fit: cover; display: block; background: var(--gris-0); }
.p-img-ph { width: 100%; height: 180px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; background: var(--gris-0); }
.p-img-ph i { font-size: 2.2rem; color: var(--gris-2); }
.p-img-ph span { font-size: .72rem; color: var(--gris-3); }
.p-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.p-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; flex-wrap: wrap; gap: 6px; }
.p-cat { font-size: .7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 3px 9px; border-radius: 4px; background: #fff7ed; color: var(--or); border: 1px solid rgba(232,149,10,.2); }
.p-pays { font-size: .74rem; color: var(--gris-3); display: flex; align-items: center; gap: 4px; }
.p-title { font-family: var(--font-h); font-size: 1.05rem; font-weight: 600; color: var(--noir); margin-bottom: 8px; }
.p-desc { font-size: .83rem; color: var(--gris-4); line-height: 1.6; flex: 1; }
.p-techs { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 12px; }
.p-tech { font-size: .7rem; padding: 2px 8px; background: var(--gris-0); border: 1px solid var(--border); border-radius: 4px; color: var(--gris-4); }
.p-footer { padding: 14px 20px; border-top: 1px solid var(--border); display: flex; gap: 8px; align-items: center; }
.p-link { display: flex; align-items: center; gap: 5px; font-size: .76rem; font-weight: 500; padding: 6px 12px; border-radius: 6px; background: var(--gris-0); color: var(--gris-4); transition: var(--tr); }
.p-link:hover { background: var(--gris-1); color: var(--noir); }
.p-date { font-size: .74rem; color: var(--gris-3); margin-left: auto; }

/* Real cards dans solutions */
.real-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; }
.real-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; transition: var(--tr); box-shadow: var(--sh); }
.real-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: rgba(193,39,45,.2); }
.real-img { width: 100%; height: 140px; object-fit: cover; }
.real-img-ph { width: 100%; height: 140px; background: var(--gris-0); display: flex; align-items: center; justify-content: center; }
.real-img-ph i { font-size: 2rem; color: var(--gris-2); }
.real-body { padding: 18px; }
.real-cat-tag { display: inline-block; font-size: .7rem; font-weight: 700; padding: 2px 8px; border-radius: 4px; margin-bottom: 8px; background: var(--rouge-pale); color: var(--rouge); border: 1px solid rgba(193,39,45,.2); }
.real-title { font-family: var(--font-h); font-size: 1rem; font-weight: 600; color: var(--noir); margin-bottom: 6px; }
.real-desc { font-size: .8rem; color: var(--gris-4); line-height: 1.55; }
.real-links { display: flex; gap: 8px; margin-top: 12px; }
.real-link { display: flex; align-items: center; gap: 5px; font-size: .76rem; color: var(--gris-4); padding: 5px 10px; background: var(--gris-0); border-radius: 6px; transition: var(--tr); }
.real-link:hover { color: var(--noir); background: var(--gris-1); }
.real-link i { font-size: .75rem; }
.no-real { text-align: center; padding: 40px 20px; color: var(--gris-3); }

@media (max-width: 960px) { .portfolio-grid { grid-template-columns: repeat(2,1fr); } .real-grid { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .portfolio-grid { grid-template-columns: 1fr; } }


/* ══════════════════════════════════════════════════════════════
   23. BLOG — liste + détail
   ══════════════════════════════════════════════════════════════ */

.blog-hero { background: var(--gris-0); padding: 56px 0 40px; border-bottom: 1px solid var(--border); }
.blog-hero{
    background: url('../images/back blog.avif') center/cover no-repeat;
 }
.blog-layout { display: grid; grid-template-columns: 1fr 280px; gap: 32px; max-width: 1200px; margin: 0 auto; padding: 40px 24px 60px; align-items: start; }
.article-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; transition: var(--tr); display: flex; flex-direction: column; margin-bottom: 24px; box-shadow: var(--sh); }
.article-card:hover { border-color: rgba(193,39,45,.2); box-shadow: var(--sh-md); transform: translateY(-3px); }
.art-img { width: 100%; height: 200px; object-fit: cover; display: block; }
.art-ph { width: 100%; height: 200px; background: var(--gris-0); display: flex; align-items: center; justify-content: center; font-size: 3rem; color: var(--gris-3); opacity: .4; }
.art-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.art-meta { display: flex; align-items: center; gap: 10px; font-size: .77rem; color: var(--gris-3); margin-bottom: 10px; flex-wrap: wrap; }
.art-cat { padding: 3px 10px; border-radius: 100px; font-size: .72rem; font-weight: 600; font-family: var(--font-h); background: var(--rouge-pale); color: var(--rouge); }
.art-title { font-family: var(--font-h); font-size: 1.1rem; font-weight: 700; color: var(--noir); margin-bottom: 8px; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.art-title a { color: inherit; text-decoration: none; }
.art-title a:hover { color: var(--rouge); }
.art-extrait { font-size: .88rem; color: var(--gris-4); line-height: 1.65; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 14px; }
.art-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--border); font-size: .78rem; color: var(--gris-3); }
.art-author { display: flex; align-items: center; gap: 7px; }
.auth-av { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; background: var(--rouge-pale); display: flex; align-items: center; justify-content: center; font-size: .7rem; color: var(--rouge); font-weight: 700; font-family: var(--font-h); }
.read-more { color: var(--rouge); font-weight: 600; font-family: var(--font-h); font-size: .8rem; text-decoration: none; }
.read-more:hover { color: var(--or); }


/* Article vedette */
.art-featured { grid-column: 1/-1; display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-radius: var(--rlg); overflow: hidden; border: 1px solid rgba(193,39,45,.15); margin-bottom: 32px; box-shadow: var(--sh-md); }
.art-featured .art-img, .art-featured .art-ph { height: 280px; border-radius: 0; }
.art-featured .art-body { padding: 28px; }
.art-featured .art-title { font-size: 1.3rem; -webkit-line-clamp: 3; }

/* Sidebar blog */
.side-box { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 18px; margin-bottom: 18px; box-shadow: var(--sh); }
.side-box.sticky-box { position: sticky; top: 84px; }
.side-box h4 { font-family: var(--font-h); font-size: .75rem; font-weight: 600; color: var(--gris-3); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 14px; }
.cat-link { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: .87rem; color: var(--noir-2); text-decoration: none; transition: var(--tr); }
.cat-link:last-child { border-bottom: none; }
.cat-link:hover { color: var(--rouge); }
.cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-right: 8px; }
.tag-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
.tag-a { padding: 4px 10px; background: var(--gris-0); border: 1px solid var(--border); border-radius: 100px; font-size: .77rem; color: var(--noir-2); text-decoration: none; transition: var(--tr); }
.tag-a:hover { border-color: var(--rouge); color: var(--rouge); }
.mini-art { display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.mini-art:last-child { border-bottom: none; }
.mini-art-img { width: 56px; height: 44px; object-fit: cover; border-radius: 6px; flex-shrink: 0; background: var(--gris-0); }
.mini-art-title { font-family: var(--font-h); font-size: .84rem; font-weight: 600; color: var(--noir); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.3; }
.mini-art-title a { color: inherit; text-decoration: none; }
.mini-art-title a:hover { color: var(--rouge); }
.mini-art-date { font-size: .72rem; color: var(--gris-3); margin-top: 3px; }

/* Blog detail */
.article-layout { display: grid; grid-template-columns: 1fr 280px; gap: 32px; max-width: 1200px; margin: 0 auto; padding: 40px 24px 60px; align-items: start; }
.art-cover { width: 100%; max-height: 400px; object-fit: cover; border-radius: var(--rlg); margin-bottom: 24px; }
.art-body-text { font-size: .97rem; color: var(--gris-4); line-height: 1.9; }
.art-body-text h2 { font-family: var(--font-h); color: var(--noir); font-size: 1.3rem; margin: 28px 0 12px; padding-bottom: 8px; border-bottom: 2px solid var(--rouge); }
.art-body-text h3 { font-family: var(--font-h); color: var(--noir); font-size: 1.1rem; margin: 22px 0 10px; }
.art-body-text p { margin-bottom: 14px; }
.art-body-text ul, .art-body-text ol { padding-left: 22px; margin-bottom: 14px; }
.art-body-text li { margin-bottom: 7px; }
.art-body-text strong { color: var(--noir); }
.art-body-text a { color: var(--rouge); text-decoration: underline; }
.art-body-text blockquote { border-left: 3px solid var(--rouge); padding: 12px 16px; background: var(--rouge-pale); border-radius: 0 var(--r) var(--r) 0; margin: 16px 0; font-style: italic; color: var(--noir); }
.art-body-text code { background: var(--gris-0); padding: 2px 6px; border-radius: 4px; font-family: monospace; font-size: .88em; color: var(--rouge); }
.art-body-text pre { background: var(--noir); border: 1px solid var(--border); border-radius: var(--r); padding: 16px; overflow-x: auto; margin-bottom: 14px; }
.art-body-text pre code { background: none; padding: 0; color: #d1d5db; }

.author-box { background: var(--gris-0); border: 1px solid var(--border); border-radius: var(--rlg); padding: 20px; margin: 32px 0; display: flex; gap: 16px; align-items: center; }
.auth-av-lg { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; background: var(--rouge-pale); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-h); font-size: 1.3rem; font-weight: 700; color: var(--rouge); }

/* Commentaires */
.comments-section { margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--border); }
.comment-item { background: #fff; border: 1px solid var(--border); border-radius: var(--r); padding: 16px; margin-bottom: 12px; box-shadow: var(--sh); }
.comment-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.comment-nom { font-family: var(--font-h); font-weight: 600; font-size: .9rem; color: var(--noir); }
.comment-date { font-size: .76rem; color: var(--gris-3); }
.comment-text { font-size: .88rem; color: var(--gris-4); line-height: 1.7; }
.comment-form { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 20px; margin-top: 20px; box-shadow: var(--sh); }
.comment-form h4 { font-family: var(--font-h); margin-bottom: 16px; color: var(--noir); }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.cf-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.cf-group label { font-size: .78rem; font-weight: 600; color: var(--noir-2); font-family: var(--font-h); letter-spacing: .04em; text-transform: uppercase; }
.cf-group input, .cf-group textarea { background: var(--gris-0); border: 1.5px solid var(--gris-2); border-radius: var(--r); padding: 10px 14px; color: var(--noir); font-family: var(--font-b); font-size: .88rem; outline: none; transition: var(--tr); width: 100%; box-sizing: border-box; }
.cf-group input:focus, .cf-group textarea:focus { border-color: var(--rouge); box-shadow: 0 0 0 3px rgba(193,39,45,.06); }
.cf-submit { background: var(--rouge); color: #fff; border: none; border-radius: var(--r); padding: 11px 24px; font-family: var(--font-h); font-weight: 700; font-size: .88rem; cursor: pointer; transition: var(--tr); text-transform: uppercase; letter-spacing: .04em; }
.cf-submit:hover { background: var(--rouge-3); }

@media (max-width: 900px) { .blog-layout, .article-layout { grid-template-columns: 1fr; } .art-featured { grid-template-columns: 1fr; } .side-box { position: static !important; } .cf-row { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .art-featured .art-img, .art-featured .art-ph { height: 160px; } }


/* ══════════════════════════════════════════════════════════════
   24. ACCOMPAGNEMENT
   ══════════════════════════════════════════════════════════════ */

.acc-wrap { max-width: 680px; margin: 60px auto; padding: 0 24px 80px; }
.acc-hero { text-align: center; padding: 40px 0 30px; }
.acc-hero .step-icon { width: 72px; height: 72px; background: var(--rouge-pale); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-size: 1.8rem; color: var(--rouge); border: 2px solid rgba(193,39,45,.2); }
.acc-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; margin-bottom: 20px; box-shadow: var(--sh); }
.acc-card-head { padding: 16px 20px; background: var(--gris-0); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
.acc-card-head .ico { font-size: 1.2rem; }
.acc-card-head h3 { font-family: var(--font-h); font-size: 1rem; font-weight: 600; margin: 0; color: var(--noir); }
.acc-card-body { padding: 20px; }
.momo-step { display: flex; gap: 14px; margin-bottom: 16px; align-items: flex-start; }
.momo-step:last-child { margin-bottom: 0; }
.step-num { width: 28px; height: 28px; border-radius: 50%; background: var(--rouge-pale); color: var(--rouge); font-family: var(--font-h); font-size: .82rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.step-text strong { display: block; font-family: var(--font-h); font-size: .88rem; color: var(--noir); margin-bottom: 2px; }
.step-text p { font-size: .83rem; color: var(--gris-4); line-height: 1.5; }
.step-text .code-block { background: var(--gris-0); border: 1px solid var(--border); padding: 8px 12px; border-radius: 6px; font-family: monospace; font-size: .9rem; color: var(--or); display: inline-block; margin-top: 5px; }
.tel-big { font-family: var(--font-h); font-size: 1.6rem; font-weight: 700; color: var(--or); display: block; margin: 8px 0 4px; }
.summary-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); font-size: .88rem; }
.summary-row:last-child { border-bottom: none; font-weight: 600; font-family: var(--font-h); font-size: .95rem; color: var(--noir); }
.summary-row .lbl { color: var(--gris-4); }
.acc-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 24px; }


/* ══════════════════════════════════════════════════════════════
   25. LISTE D'ATTENTE
   ══════════════════════════════════════════════════════════════ */

.wait-wrap { max-width: 560px; margin: 60px auto; padding: 0 20px 80px; }
.wait-card { background: #fff; border: 1px solid rgba(232,149,10,.2); border-radius: var(--rlg); overflow: hidden; box-shadow: var(--sh-md); }
.wait-head { background: var(--gris-0); padding: 28px 28px 20px; text-align: center; border-bottom: 1px solid var(--border); }
.wait-head i { font-size: 2.5rem; color: var(--or); margin-bottom: 10px; display: block; }
.wait-head h2 { font-size: 1.3rem; margin-bottom: 6px; color: var(--noir); }
.wait-head p { color: var(--gris-4); font-size: .9rem; }
.wait-body { padding: 28px; }
.wait-btn { width: 100%; padding: 13px; background: var(--or); color: #111; font-family: var(--font-h); font-weight: 700; font-size: .95rem; border: none; border-radius: var(--r); cursor: pointer; transition: var(--tr); text-transform: uppercase; letter-spacing: .04em; }
.wait-btn:hover { background: #d4850a; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,149,10,.3); }


/* ══════════════════════════════════════════════════════════════
   26. ANIMATIONS & UTILITIES
   ══════════════════════════════════════════════════════════════ */

@keyframes pulse    { 0%,100%{box-shadow:0 0 0 0 rgba(193,39,45,.45)} 60%{box-shadow:0 0 0 10px rgba(193,39,45,0)} }
@keyframes flt      { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes fadeSlide{ from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideIn  { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }
@keyframes spin     { to{transform:rotate(360deg)} }

/* — Utilities — */
.text-rouge   { color: var(--rouge); }
.text-or      { color: var(--or); }
.text-gris    { color: var(--gris-4); }
.text-center  { text-align: center; }
.text-right   { text-align: right; }
.mt-4  { margin-top: 16px; }
.mt-8  { margin-top: 32px; }
.mt-12 { margin-top: 48px; }
.mb-4  { margin-bottom: 16px; }
.mb-8  { margin-bottom: 32px; }
.gap-4 { gap: 16px; }
.gap-6 { gap: 24px; }
.flex  { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.grid  { display: grid; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.flex-wrap { flex-wrap: wrap; }
.font-h { font-family: var(--font-h); }
.uppercase { text-transform: uppercase; }
.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
.border-t { border-top: 1px solid var(--border); }
.border-rouge-t { border-top: 3px solid var(--rouge); }
.rounded { border-radius: var(--r); }
.rounded-lg { border-radius: var(--rlg); }
.shadow { box-shadow: var(--sh); }
.shadow-md { box-shadow: var(--sh-md); }
.w-full { width: 100%; }
.hidden { display: none; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* — Responsive global — */
@media (max-width: 640px) {
  .container { padding: 0 16px; }
  section { padding: 52px 0; }
  .hide-mobile { display: none !important; }
}
@media (min-width: 641px) {
  .show-mobile-only { display: none !important; }
}

/* ══════════════════════════════════════════════════════════════
   ── VARIABLES DE COMPATIBILITÉ (alias thème clair)
   Permettent aux templates d'utiliser les anciens noms sans
   modifier le HTML — tout est mappé vers le thème clair.
   ══════════════════════════════════════════════════════════════ */
:root {
  /* Anciens noms dark → valeurs claires */
  --blanc:         #ffffff;
  --blanc-2:       var(--gris-4);      /* texte secondaire → gris moyen */
  --font-body:     var(--font-b);
  --font-display:  var(--font-h);      /* Oswald */
  --gris:          var(--gris-3);
  --gris-light:    var(--gris-4);      /* texte léger */
  --gris-t:        var(--gris-3);
  --gris-text:     var(--gris-3);
  --nuit:          var(--gris-0);      /* fond "nuit" → fond gris clair */
  --nuit-2:        var(--gris-0);
  --nuit-3:        #ffffff;
  --or-dark:       #c07800;
  --radius:        var(--r);
  --radius-lg:     var(--rlg);
  --shadow-lg:     var(--sh-lg);
  --shlg:          var(--sh-lg);
  --transition:    var(--tr);
  --vert-light:    var(--vert);
  /* border : ancienne version dark était rgba(fff,.07) — on fixe */
}

/* ══════════════════════════════════════════════════════════════
   ── GRILLES ET MISES EN PAGE RÉUTILISABLES
   ══════════════════════════════════════════════════════════════ */
.grid-2col      { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.grid-2col-sm   { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
.grid-2col-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.grid-3col      { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.grid-4col      { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
@media (max-width: 900px) {
  .grid-2col, .grid-2col-sm { grid-template-columns: 1fr; gap: 28px; }
  .grid-3col { grid-template-columns: 1fr 1fr; gap: 20px; }
  .grid-4col { grid-template-columns: 1fr 1fr; gap: 14px; }
}
@media (max-width: 600px) {
  .grid-2col-form { grid-template-columns: 1fr; }
  .grid-3col, .grid-4col { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   ── TYPOGRAPHIE DE SECTIONS
   ══════════════════════════════════════════════════════════════ */
.heading-xl  { font-family: var(--font-h); font-size: clamp(2.2rem,4.5vw,3.5rem); font-weight: 800; margin-bottom: 12px; line-height: 1.08; }
.heading-lg  { font-family: var(--font-h); font-size: clamp(1.8rem,3.5vw,2.6rem); font-weight: 800; margin-bottom: 16px; line-height: 1.1; }
.heading-md  { font-family: var(--font-h); font-size: 1.8rem; font-weight: 800; margin-bottom: 16px; }
.heading-sm  { font-family: var(--font-h); font-size: 1.3rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.text-lead   { font-size: 1.05rem; color: var(--gris-4); max-width: 540px; line-height: 1.72; margin-bottom: 24px; }
.text-body   { font-size: .92rem; color: var(--gris-4); line-height: 1.7; }
.text-sm-muted { font-size: .88rem; color: var(--gris-3); }
.eyebrow-label {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--rouge-pale); border: 1px solid rgba(193,39,45,.2);
  border-radius: 50px; padding: 5px 14px;
  font-size: .78rem; font-weight: 600; color: var(--rouge);
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 20px;
}

/* ══════════════════════════════════════════════════════════════
   ── SECTIONS / FONDS ALTERNATIFS
   ══════════════════════════════════════════════════════════════ */
.section-white   { padding: 80px 0; background: #fff; }
.section-light   { padding: 80px 0; background: var(--gris-0); }
.section-center  { padding: 80px 0; text-align: center; }
.section-alt     { padding: 80px 0; background: var(--gris-0); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.section-dark-band {
  padding: 72px 0;
  background: var(--noir); color: #fff;
  border-top: 1px solid #2a2a2a;
}
.section-dark-band .sec-title { color: #fff; }
.section-dark-band .sec-sub   { color: #9ca3af; }

/* ══════════════════════════════════════════════════════════════
   ── LISTES DE FONCTIONNALITÉS (se_former, mission…)
   ══════════════════════════════════════════════════════════════ */
.feat-list { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.feat-item { display: flex; gap: 10px; font-size: .9rem; color: var(--gris-4); line-height: 1.55; }
.feat-item i { margin-top: 3px; flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════
   ── CARTES ACCENTUÉES (couleur bord + fond léger)
   ══════════════════════════════════════════════════════════════ */
.accent-card {
  border-radius: var(--rlg); padding: 32px;
  background: #fff; border: 1px solid var(--border); box-shadow: var(--sh);
}
.accent-card-red   { background: rgba(231,76,60,.05);  border: 1px solid rgba(231,76,60,.18);  border-radius: var(--rlg); padding: 32px; }
.accent-card-blue  { background: rgba(91,164,232,.05);  border: 1px solid rgba(91,164,232,.18);  border-radius: var(--rlg); padding: 32px; }
.accent-card-green { background: rgba(34,163,95,.05);  border: 1px solid rgba(34,163,95,.18);  border-radius: var(--rlg); padding: 32px; }
.accent-card-or    { background: rgba(232,149,10,.05);  border: 1px solid rgba(232,149,10,.18);  border-radius: var(--rlg); padding: 32px; }

/* ══════════════════════════════════════════════════════════════
   ── BOÎTES D'INFORMATION / ALERTES INLINE
   ══════════════════════════════════════════════════════════════ */
.info-box         { border-radius: var(--r); padding: 12px 16px; font-size: .85rem; }
.info-box-rouge   { background: var(--rouge-pale); border: 1px solid #fca5a5; color: var(--rouge-2); }
.info-box-vert    { background: #f0fdf4; border: 1px solid #86efac; border-radius: var(--rlg); padding: 24px; margin-top: 24px; }
.info-box-or      { background: #fff7ed; border: 1px solid rgba(232,149,10,.25); border-radius: 10px; padding: 14px 16px; margin-top: 18px; }
.info-box-blue    { background: rgba(193,39,45,.06); border: 1px solid rgba(193,39,45,.1); border-radius: var(--r); padding: 10px 16px; margin-bottom: 20px; font-size: .85rem; }

/* ══════════════════════════════════════════════════════════════
   ── BADGES DE DISPONIBILITÉ (sessions)
   ══════════════════════════════════════════════════════════════ */
.badge-available   { background: rgba(34,163,95,.12); color: #22A35F; border-radius: 100px; padding: 4px 10px; font-size: .75rem; font-weight: 600; }
.badge-unavailable { background: rgba(193,39,45,.10); color: var(--rouge-3); border-radius: 100px; padding: 4px 10px; font-size: .75rem; font-weight: 600; }
.badge-available-sm { background: rgba(34,163,95,.12); color: #22A35F; border-radius: 100px; padding: 2px 8px; font-size: .72rem; }

/* ══════════════════════════════════════════════════════════════
   ── BARRE BREADCRUMB
   ══════════════════════════════════════════════════════════════ */
.breadcrumb-bar { background: var(--gris-0); border-bottom: 1px solid var(--border); }
.breadcrumb-bar > .container { padding-top: 12px; padding-bottom: 12px; }

/* ══════════════════════════════════════════════════════════════
   ── PARTAGE SOCIAL (blog détail)
   ══════════════════════════════════════════════════════════════ */
.share-bar { display: flex; align-items: center; gap: 10px; margin: 20px 0; }
.share-lbl { font-family: var(--font-h); font-size: .78rem; color: var(--gris-3); text-transform: uppercase; letter-spacing: .06em; }
.share-btn {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; transition: var(--tr);
}
.share-li  { background: rgba(10,102,194,.08);  border: 1px solid rgba(10,102,194,.2);  color: #0A66C2; }
.share-wa  { background: rgba(37,211,102,.08);  border: 1px solid rgba(37,211,102,.2);  color: #25D366; }
.share-tw  { background: rgba(29,161,242,.08);  border: 1px solid rgba(29,161,242,.2);  color: #1DA1F2; }
.share-btn:hover { transform: translateY(-2px); filter: brightness(1.1); }

/* ══════════════════════════════════════════════════════════════
   ── PAGE MERCI / CONFIRMATION
   ══════════════════════════════════════════════════════════════ */
.merci-wrap {
  min-height: 60vh; display: flex; align-items: center;
  justify-content: center; text-align: center; padding: 60px 24px;
}
.merci-icon { font-size: 4rem; margin-bottom: 24px; display: block; }

/* ══════════════════════════════════════════════════════════════
   ── CHARGEMENT / SKELETON (catalogue)
   ══════════════════════════════════════════════════════════════ */
.loading-block {
  grid-column: 1/-1; display: flex; flex-direction: column;
  align-items: center; gap: 16px; padding: 60px 0;
}
.loading-spinner {
  width: 36px; height: 36px; border: 3px solid var(--border);
  border-top-color: var(--rouge); border-radius: 50%;
  animation: spin .7s linear infinite;
}

/* ══════════════════════════════════════════════════════════════
   ── UTILITAIRES COMPLÉMENTAIRES
   ══════════════════════════════════════════════════════════════ */
/* Couleurs d'icônes */
.icon-rouge   { color: var(--rouge); }
.icon-or      { color: var(--or); }
.icon-vert    { color: var(--vert); }
.icon-bleu    { color: #5BA4E8; }
.icon-cyber   { color: #E74C3C; }
/* Marges droites pour icônes inline */
.mr-xs { margin-right: 4px; }
.mr-sm { margin-right: 6px; }
/* Ligne séparatrice */
.hr-line { height: 1px; background: var(--border); margin: 20px 0; }
/* Opacité */
.opacity-30 { opacity: .3; }
.opacity-70 { opacity: .7; }
/* Grille no-results (full col) */
.col-full { grid-column: 1/-1; }
/* CTA centré */
.cta-center { text-align: center; margin-top: 32px; }

/* Score fills (orientation) */
.score-fill-or    { background: var(--or); }
.score-fill-rouge { background: #E74C3C; }
.score-fill-bleu  { background: #2563eb; }
.score-fill-vert  { background: var(--vert); }

/* Affichage flex centré */
.flex-center     { display: flex; align-items: center; justify-content: center; }
.flex-start      { display: flex; align-items: flex-start; gap: 10px; }
.flex-gap-sm     { display: flex; gap: 10px; flex-wrap: wrap; }
.flex-gap-md     { display: flex; gap: 14px; flex-wrap: wrap; }
.flex-gap-lg     { display: flex; gap: 20px; flex-wrap: wrap; }
.flex-between    { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 16px; }

/* Blocs d'image placeholder */
.img-placeholder {
  background: var(--gris-0); border-radius: var(--r);
  display: flex; align-items: center; justify-content: center;
  color: var(--gris-3);
}

/* Lien "voir tout" / "voir plus" */
.link-voir-plus { color: var(--rouge); font-weight: 600; font-size: .87rem; display: flex; align-items: center; gap: 6px; }
.link-voir-plus:hover { color: var(--rouge-2); }

/* Bloc vide (no-results) */
.empty-state { text-align: center; padding: 60px 20px; color: var(--gris-3); }
.empty-state i { font-size: 2.5rem; opacity: .25; display: block; margin-bottom: 12px; }


/* ── FOOTER COMPLÉMENTS ───────────────────────────────────────── */
.ft-logo     { height: 36px; }
.ft-logo-txt {
  font-family: var(--font-h); font-size: 1.5rem;
  font-weight: 700; color: #fff;
}
.ft-tagline  { color: #d1d5db; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : ACCUEIL ─────────────────────────────────────────
   ══════════════════════════════════════════════════════════════ */

/* HERO */
.hero {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%);
  border-bottom: 1px solid var(--border);
  padding: 80px 0 72px;
}
.hero-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.hero-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(var(--border) 1px, transparent 1px),
                    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 40px 40px; opacity: .4;
}
.hero-orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px); opacity: .18;
}
.hero-orb-1 { width: 400px; height: 400px; background: var(--rouge); top: -100px; right: -80px; }
.hero-orb-2 { width: 300px; height: 300px; background: var(--or); bottom: -60px; left: 10%; }
.hero-orb-3 { width: 200px; height: 200px; background: #5BA4E8; top: 40%; left: -60px; }
.hero-inner {
  position: relative; z-index: 1;
  max-width: 1200px; margin: 0 auto; padding: 0 28px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--rouge-pale); border: 1px solid rgba(193,39,45,.2);
  border-radius: 50px; padding: 5px 16px;
  font-size: .78rem; font-weight: 600; color: var(--rouge);
  letter-spacing: .05em; text-transform: uppercase; margin-bottom: 20px;
}
.eyebrow-dot {
  width: 7px; height: 7px; background: var(--rouge);
  border-radius: 50%; animation: pulse 2s infinite;
}
.eyebrow-txt { font-family: var(--font-h); }
.hero-title {
  font-family: var(--font-h); font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800; line-height: 1.1; color: var(--noir);
  margin-bottom: 20px;
}
.hero-title .accent { color: var(--rouge); display: block; !important }
.hero-sub {
  font-size: 1rem; color: var(--gris-4); line-height: 1.75; max-width: 500px;
  margin-bottom: 28px;
}
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; }
.hero-stats {
  display: flex; gap: 28px; flex-wrap: wrap;
  padding-top: 24px; border-top: 1px solid var(--border);
}
.hstat-n {
  font-family: var(--font-h); font-size: 1.6rem; font-weight: 800;
  color: var(--rouge); line-height: 1;
}
.hstat-l { font-size: .78rem; color: var(--gris-3); margin-top: 3px; }

/* Floating cards hero */
.hero-visual { position: relative; min-height: 340px; }
.fc {
  position: absolute; background: #fff;
  border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 18px; box-shadow: var(--sh-md);
  min-width: 200px; max-width: 220px;
  animation: flt 4s ease-in-out infinite;
}
.fc:nth-child(2) { animation-delay: 1.4s; }
.fc:nth-child(3) { animation-delay: 2.8s; }
.fc-icon {
  width: 38px; height: 38px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 10px; font-size: 1rem;
}
.fc-title { font-family: var(--font-h); font-size: .9rem; font-weight: 700; color: var(--noir); margin-bottom: 2px; }
.fc-sub { font-size: .77rem; color: var(--gris-3); margin-bottom: 8px; }
.fc-prog { height: 4px; background: var(--gris-1); border-radius: 100px; overflow: hidden; margin-top: 8px; }
.fc-prog-bar { height: 100%; border-radius: 100px; }

@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
}

/* STATS BAND */
.stats-band {
  background: var(--rouge); padding: 24px 0; color: #fff;
}
.stats-band-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 28px;
  display: flex; justify-content: space-around; flex-wrap: wrap; gap: 16px;
}
.sb-item { text-align: center; padding: 8px 16px; }
.sb-num {
  font-family: var(--font-h); font-size: 1.8rem;
  font-weight: 800; line-height: 1; color: #fff;
}
.sb-lbl { font-size: .78rem; opacity: .85; margin-top: 4px; }

/* VISION */
.vision-section { padding: 80px 0; background: #fff; }
.vision-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: start;
}
.vm-quote {
  font-family: var(--font-h); font-size: 1.4rem; font-weight: 600;
  color: var(--noir); line-height: 1.4; margin-bottom: 16px;
  border-left: 4px solid var(--rouge); padding-left: 18px;
}
.vm-quote em { color: var(--rouge); font-style: normal; }
.vm-desc { font-size: .96rem; color: var(--gris-4); line-height: 1.75; margin-bottom: 18px; }
.vision-pillars { display: flex; flex-direction: column; gap: 20px; }
.vp-item { display: flex; gap: 16px; align-items: flex-start; }
.vp-icon {
  width: 42px; height: 42px; border-radius: 10px; flex-shrink: 0;
  background: var(--rouge-pale); color: var(--rouge);
  display: flex; align-items: center; justify-content: center; font-size: 1rem;
}
.vp-title { font-family: var(--font-h); font-size: .95rem; font-weight: 700; color: var(--noir); margin-bottom: 4px; }
.vp-desc { font-size: .85rem; color: var(--gris-4); line-height: 1.6; }
@media (max-width: 860px) { .vision-grid { grid-template-columns: 1fr; gap: 36px; } }

/* DOMAINS */
.domains-section { padding: 80px 0; background: var(--gris-0); }
.domains-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-top: 48px;
}
.domain-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 24px 20px;
  transition: var(--tr); box-shadow: var(--sh);
  display: block; text-decoration: none;
  border-top: 3px solid var(--dc, var(--gris-2));
}
.domain-card:hover {
  transform: translateY(-4px); box-shadow: var(--sh-md);
  border-color: var(--dc, var(--rouge));
}
.dc-icon {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; margin-bottom: 14px;
}
.dc-title { font-family: var(--font-h); font-size: .98rem; font-weight: 700; color: var(--noir); margin-bottom: 6px; }
.dc-desc { font-size: .82rem; color: var(--gris-4); line-height: 1.55; margin-bottom: 12px; }
.dc-badge {
  font-size: .72rem; font-weight: 600; color: var(--gris-3);
  font-family: var(--font-h); letter-spacing: .03em;
}
@media (max-width: 900px) { .domains-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .domains-grid { grid-template-columns: 1fr; } }

/* FORMATS */
.formats-section { padding: 80px 0; background: #fff; }
.formats-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 48px;
}
.format-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 28px 24px;
  position: relative; transition: var(--tr); box-shadow: var(--sh);
  border-top: 4px solid transparent;
}
.format-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.format-top-bar {
  position: absolute; top: 0; left: 0; right: 0;
  height: 4px; border-radius: var(--rlg) var(--rlg) 0 0;
}
.format-pop {
  position: absolute; top: -10px; right: 18px;
  background: var(--or); color: #111; font-size: .7rem; font-weight: 700;
  padding: 3px 10px; border-radius: 50px; font-family: var(--font-h);
  letter-spacing: .04em; text-transform: uppercase;
}
.fc-tag {
  display: inline-block; padding: 3px 10px; border-radius: 100px;
  font-size: .72rem; font-weight: 600; font-family: var(--font-h);
  text-transform: uppercase; letter-spacing: .04em; margin-bottom: 10px;
}
.format-duration {
  font-family: var(--font-h); font-size: 1.5rem; font-weight: 800;
  color: var(--noir); margin-bottom: 12px;
}
.format-desc { font-size: .88rem; color: var(--gris-4); line-height: 1.65; margin-bottom: 18px; }
.format-features { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.format-features li {
  display: flex; align-items: center; gap: 8px;
  font-size: .86rem; color: var(--gris-4);
}
.format-features li i { font-size: .72rem; }
@media (max-width: 900px) { .formats-grid { grid-template-columns: 1fr; max-width: 500px; margin-left: auto; margin-right: auto; } }

/* COURSES FEATURED */
.courses-section { padding: 80px 0; background: var(--gris-0); }
.grid-cours {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.card-cours {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; transition: var(--tr);
  box-shadow: var(--sh); display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
}
.card-cours:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.card-cours-img {
  width: 100%; height: 160px; position: relative; overflow: hidden;
  background: var(--gris-0);
}
.card-cours-img img { width: 100%; height: 100%; object-fit: cover; }
.card-cours-img-ph {
  width: 100%; height: 160px; display: flex; align-items: center;
  justify-content: center; font-size: 2.5rem; color: var(--gris-3); opacity: .3;
}
.card-cours-body { padding: 18px; flex: 1; display: flex; flex-direction: column; }
.card-cours-meta { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.card-cours-title {
  font-family: var(--font-h); font-size: 1rem; font-weight: 700;
  color: var(--noir); margin-bottom: 6px; line-height: 1.3;
}
.card-cours-desc {
  font-size: .83rem; color: var(--gris-4); line-height: 1.55;
  flex: 1; margin-bottom: 12px;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.card-cours-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 10px; border-top: 1px solid var(--border);
  font-size: .8rem; color: var(--gris-3);
}
.voir { color: var(--rouge); font-weight: 600; font-family: var(--font-h); font-size: .8rem; }
@media (max-width: 900px) { .grid-cours { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .grid-cours { grid-template-columns: 1fr; } }

/* TÉMOIGNAGES */
.testi-section { padding: 80px 0; background: #fff; }
.testi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.testi-card {
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 28px; box-shadow: var(--sh);
  transition: var(--tr);
}
.testi-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.testi-stars { font-size: 1rem; color: var(--or); margin-bottom: 14px; letter-spacing: 2px; }
.testi-text { font-size: .9rem; color: var(--gris-4); line-height: 1.75; margin-bottom: 20px; font-style: italic; }
.testi-author { display: flex; align-items: center; gap: 12px; }
.testi-avatar {
  width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h); font-size: .9rem; font-weight: 700; color: #fff;
}
.testi-name { font-family: var(--font-h); font-size: .9rem; font-weight: 700; color: var(--noir); }
.testi-role { font-size: .78rem; color: var(--gris-3); }
@media (max-width: 900px) { .testi-grid { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; } }

/* CTA FINAL */
.cta-section { padding: 80px 0; background: var(--noir); }
.cta-inner { text-align: center; max-width: 680px; margin: 0 auto; }
.cta-inner .sec-label { color: rgba(255,255,255,.5); }
.cta-title {
  font-family: var(--font-h); font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 800; color: #fff; margin-bottom: 16px; line-height: 1.1;
}
.cta-sub { font-size: .98rem; color: #9ca3af; line-height: 1.7; margin-bottom: 32px; }
.cta-btns { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.cta-section .btn-outline { border-color: rgba(255,255,255,.25); color: #fff; }
.cta-section .btn-outline:hover { border-color: var(--rouge); background: var(--rouge); }

/* PARTENAIRES */
.partners-section { padding: 32px 0; background: var(--gris-0); border-top: 1px solid var(--border); }
.partners-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; text-align: center; }
.partner-label {
  display: block; font-family: var(--font-h); font-size: .7rem;
  font-weight: 600; color: var(--gris-3); letter-spacing: .12em;
  text-transform: uppercase; margin-bottom: 18px;
}
.partner-logos { display: flex; justify-content: center; gap: 28px; flex-wrap: wrap; align-items: center; }
.partner-item {
  font-family: var(--font-h); font-size: .85rem; font-weight: 600;
  color: var(--gris-3); letter-spacing: .04em; padding: 6px 14px;
  border: 1px solid var(--border); border-radius: 6px; background: #fff;
}

.partner-logos img{
    height:100px;
    border-radius:5%
}


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : SE FORMER ───────────────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.se-former-hero {
  padding: 110px 0 72px; background: var(--gris-0);
  border-bottom: 1px solid var(--border); position: relative; overflow: hidden;
}
.se-former-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 80% 50%, rgba(193,39,45,.06) 0%, transparent 70%);
  pointer-events: none;
}
.se-former-hero h1 { font-size: clamp(2.2rem, 4.5vw, 3.5rem); font-weight: 800; margin-bottom: 12px; }
.sf-sub { font-size: 1.05rem; color: var(--gris-4); max-width: 500px; line-height: 1.7; }

.sf-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 40px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; align-items: center; margin-bottom: 28px; box-shadow: var(--sh);
}
.sf-card:nth-child(even) { direction: rtl; }
.sf-card:nth-child(even) > * { direction: ltr; }
.sf-card-content h2 { font-family: var(--font-h); font-size: 1.8rem; font-weight: 800; margin-bottom: 16px; }
.sf-card-content p { color: var(--gris-4); line-height: 1.75; margin-bottom: 20px; }
.sf-card-visual {
  border-radius: var(--rlg); padding: 32px;
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px;
}
.sf-visual-icon { font-size: 3rem; margin-bottom: 8px; }
.sf-visual-title { font-family: var(--font-h); font-size: 1.1rem; font-weight: 700; color: var(--noir); }
.sf-visual-desc { font-size: .86rem; color: var(--gris-4); line-height: 1.6; }

/* Bootcamp banner */
.bootcamp-section { padding: 80px 0; background: var(--gris-0); }
.bootcamp-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 40px;
}
.bootcamp-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 28px; box-shadow: var(--sh);
  transition: var(--tr);
}
.bootcamp-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }

@media (max-width: 900px) {
  .sf-card { grid-template-columns: 1fr; }
  .sf-card:nth-child(even) { direction: ltr; }
  .bootcamp-grid { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : CATALOGUE ───────────────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.catalogue-hero {
  padding: 100px 0 56px; background: var(--gris-0);
  border-bottom: 1px solid var(--border); position: relative; overflow: hidden;
}
.catalogue-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 50% 60% at 80% 50%, rgba(193,39,45,.06) 0%, transparent 70%);
}
.catalogue-hero h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 800; position: relative; z-index: 1; }
.catalogue-filters {
  display: flex; flex-wrap: wrap; gap: 8px; padding: 20px 0 28px;
  border-bottom: 1px solid var(--border); margin-bottom: 32px;
}
.cat-filter-btn {
  padding: 6px 14px; border-radius: 50px; font-size: .82rem; font-weight: 500;
  border: 1px solid var(--border); background: #fff; color: var(--gris-4);
  cursor: pointer; transition: var(--tr); font-family: var(--font-b);
}
.cat-filter-btn:hover { border-color: var(--rouge); color: var(--rouge); }
.cat-filter-btn.active { background: var(--rouge); border-color: var(--rouge); color: #fff; font-weight: 600; }
.catalogue-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
@media (max-width: 900px) { .catalogue-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .catalogue-grid { grid-template-columns: 1fr; } }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : MISSION / À PROPOS ─────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.mission-intro-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  padding: 80px 0;
}
.mission-intro-text h2 { font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 800; margin-bottom: 20px; }
.mission-intro-text p  { color: var(--gris-4); line-height: 1.8; margin-bottom: 16px; }
.mission-intro-visual {
  background: var(--gris-0); border-radius: var(--rlg);
  height: 400px; display: flex; align-items: center;
  justify-content: center; border: 1px solid rgba(232,149,10,.1);
  font-size: 6rem; color: var(--gris-2);
}
.team-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 48px; }
.mission-cta-band {
  padding: 64px 0; text-align: center;
  background: var(--gris-0); border-top: 1px solid var(--border);
}
.mission-cta-band h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; margin-bottom: 20px; max-width: 700px; margin-left: auto; margin-right: auto; }
.mission-cta-band p { color: var(--gris-4); max-width: 500px; margin: 0 auto 32px; line-height: 1.7; }
@media (max-width: 900px) { .mission-intro-grid { grid-template-columns: 1fr; } .team-stats { grid-template-columns: 1fr 1fr; } }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : CONTACT ─────────────────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.contact-hero {
  padding: 100px 0 60px; background: var(--gris-0);
  border-bottom: 1px solid var(--border);
}
.contact-hero h1 { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; margin-bottom: 12px; }
.contact-hero p { color: var(--gris-4); max-width: 500px; line-height: 1.7; margin-top: 12px; }
.contact-socials { display: flex; gap: 10px; margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); }
.contact-social-label {
  font-family: var(--font-h); font-size: .78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; color: var(--gris-3);
  margin-bottom: 14px;
}
.contact-form-title { font-family: var(--font-h); font-size: 1.2rem; font-weight: 700; margin-bottom: 8px; }
.contact-form-sub { color: var(--gris-4); font-size: .88rem; margin-bottom: 28px; }
.contact-submit-wrap { width: 100%; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : COMMUNAUTÉ / ALUMNI ────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.communaute-hero {
  padding: 100px 0 80px; background: var(--noir);
  position: relative; overflow: hidden; text-align: center; color: #fff;
}
.communaute-hero h1 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; margin-bottom: 16px; }
.communaute-hero p { color: #9ca3af; max-width: 540px; margin: 0 auto; font-size: 1.05rem; line-height: 1.7; }
.stats-bar {
  display: flex; justify-content: center; gap: 48px; flex-wrap: wrap;
  margin-top: 48px; padding-top: 36px; border-top: 1px solid rgba(255,255,255,.08);
}
.stat-bar-item { text-align: center; }
.stat-bar-num {
  font-family: var(--font-h); font-size: 2rem; font-weight: 800; line-height: 1;
  background: linear-gradient(135deg, var(--or), var(--or-2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.stat-bar-lbl { font-size: .82rem; color: rgba(255,255,255,.5); margin-top: 4px; }
.comm-join-section { padding: 80px 0; background: var(--gris-0); }
.comm-join-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.comm-join-text h2 { font-size: 2rem; font-weight: 800; margin-bottom: 16px; }
.comm-join-text p { color: var(--gris-4); line-height: 1.75; margin-bottom: 24px; }
.comm-perks { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.comm-perk { display: flex; gap: 12px; align-items: flex-start; }
.comm-perk-ico { font-size: 1.5rem; }
.comm-perk-text h4 { font-family: var(--font-h); font-size: .95rem; font-weight: 700; margin-bottom: 2px; }
.comm-perk-text p { font-size: .84rem; color: var(--gris-4); line-height: 1.6; }
.comm-cta { padding: 80px 0; text-align: center; background: #fff; }
.comm-cta h2 { font-size: 2rem; font-weight: 800; margin-bottom: 12px; }
.comm-cta p { color: var(--gris-4); margin-bottom: 32px; }
@media (max-width: 860px) { .comm-join-grid { grid-template-columns: 1fr; } }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : ENTREPRISES / B2B ─────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.entreprises-hero {
  padding: 110px 0 80px; background: var(--gris-0);
  border-bottom: 1px solid var(--border); position: relative; overflow: hidden;
}
.entreprises-hero::before {
  content: "B2B"; position: absolute; right: -40px; bottom: -20px;
  font-family: var(--font-h); font-size: 14rem; font-weight: 800;
  color: rgba(193,39,45,.04); line-height: 1; pointer-events: none;
}
.entreprises-hero h1 { font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 800; margin-bottom: 16px; max-width: 600px; position: relative; z-index: 1; }
.entreprises-hero p { color: var(--gris-4); font-size: 1.05rem; max-width: 520px; line-height: 1.7; margin-bottom: 32px; position: relative; z-index: 1; }
.ent-service-icon { font-size: 2rem; margin-bottom: 14px; }
.ent-service-title { font-family: var(--font-h); font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.ent-service-desc  { font-size: .88rem; color: var(--gris-4); line-height: 1.65; }
.ent-section { padding: 72px 0; background: var(--gris-0); }
.ent-section:nth-child(odd) { background: #fff; }
.ent-cta-band { padding: 80px 0; text-align: center; background: #fff; }
.ent-cta-band h2 { font-size: 2rem; font-weight: 800; margin-bottom: 12px; }
.ent-cta-band p { color: var(--gris-4); max-width: 500px; margin: 0 auto 32px; line-height: 1.7; }
.ent-cta-links { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : MERCI / CONFIRMATION ───────────────────────────
   ══════════════════════════════════════════════════════════════ */

.merci-emoji { font-size: 4rem; margin-bottom: 24px; display: block; }
.merci-title { font-size: 2.5rem; font-weight: 800; margin-bottom: 12px; }
.merci-sub  { color: var(--gris-4); max-width: 480px; margin: 0 auto 32px; line-height: 1.7; }
.merci-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : ORIENTER RÉSULTAT ──────────────────────────────
   ══════════════════════════════════════════════════════════════ */

.resultat-hero {
  padding: 80px 0 64px;
  background: linear-gradient(135deg, var(--rouge-2), var(--rouge));
  color: #fff; text-align: center;
}
.resultat-hero h1 { color: #fff; font-size: clamp(1.8rem, 4vw, 2.8rem); margin-bottom: 10px; }
.resultat-hero p  { color: rgba(255,255,255,.85); font-size: 1.05rem; }
.resultat-layout {
  display: grid; grid-template-columns: 1.5fr 1fr;
  gap: 32px; max-width: 1100px; margin: 48px auto; padding: 0 24px;
}
.resultat-primary { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 32px; box-shadow: var(--sh); }
.resultat-sidebar { display: flex; flex-direction: column; gap: 20px; }
.rec-section-title { font-family: var(--font-h); font-size: 1.5rem; font-weight: 700; margin-bottom: 20px; color: var(--noir); }
.rec-header { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.rec-reco-title { font-size: 1.3rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.rec-desc { color: var(--gris-4); font-size: .92rem; margin-bottom: 18px; line-height: 1.6; }
.rec-cta { margin-bottom: 12px; display: inline-block; }
.rec-suggest-title { font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.rec-none-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 32px; text-align: center; box-shadow: var(--sh); }
.rec-none-icon { font-size: 2rem; color: var(--gris-3); margin-bottom: 12px; display: block; }
.rec-none-txt  { color: var(--gris-4); margin-bottom: 16px; }
.rec-next { background: #f0fdf4; border: 1px solid #86efac; border-radius: var(--rlg); padding: 24px; margin-top: 24px; }
.rec-next-header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.rec-next-ico { color: var(--vert); font-size: 1.3rem; }
.rec-next-title { font-family: var(--font-h); font-size: 1.05rem; font-weight: 700; color: #166534; }
.rec-next-desc  { color: #166534; font-size: .9rem; line-height: 1.6; }
.share-cta { text-align: center; margin-top: 48px; padding-top: 40px; border-top: 1px solid var(--border); }
.share-cta p { color: var(--gris-4); margin-bottom: 8px; }
@media (max-width: 900px) { .resultat-layout { grid-template-columns: 1fr; } }

.vp-icon-or   { background: rgba(232,149,10,.1);  color: var(--or); }
.vp-icon-vert { background: rgba(34,163,95,.1);   color: var(--vert); }
.vp-icon-bleu { background: rgba(91,164,232,.1);  color: #5BA4E8; }
.mb-0  { margin-bottom: 0; }
.mx-auto { margin-left: auto; margin-right: auto; }
.mb-12 { margin-bottom: 48px; }
.mt-6  { margin-top: 24px; }
.fc-tag-rouge { background: rgba(193,39,45,.1);  color: var(--rouge-3); }
.fc-tag-or    { background: rgba(232,149,10,.1); color: var(--or); }
.fc-tag-vert  { background: rgba(34,163,95,.1);  color: var(--vert); }
.fc-tag-bleu  { background: rgba(91,164,232,.1); color: #5BA4E8; }

/* ── UTILITAIRES SUPPLÉMENTAIRES ─────────────────────────────── */
.empty-state-icon { font-size: 2.5rem; opacity: .2; display: block; margin-bottom: 12px; }
.subscribe-msg    { font-size: .82rem; text-align: center; }
.wa-link          { display: flex; align-items: center; gap: 8px; color: #25D366; font-size: .83rem; text-decoration: none; font-weight: 600; }
.wa-link:hover    { opacity: .8; }
.mb-0             { margin-bottom: 0 !important; }

/* ── DÉTAIL FORMATION (classes inline manquantes) ─────────────── */
.formation-header { background: var(--gris-0); border-bottom: 1px solid var(--border); padding: 32px 0; }
.session-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 16px; margin-bottom: 12px;
}
.session-card.available { border-color: rgba(232,149,10,.25); }
.session-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 8px; }
.session-name   { font-family: var(--font-h); font-size: 1rem; font-weight: 600; margin-bottom: 4px; }
.session-meta   { font-size: .83rem; color: var(--gris-3); }
.session-footer { font-size: .83rem; color: var(--gris-3); margin-top: 10px; border-top: 1px solid var(--border); padding-top: 8px; }
.section-label-bar {
  font-size: .72rem; color: var(--gris-3); text-transform: uppercase;
  letter-spacing: .08em; margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
}
.section-label-bar::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.session-no-result { text-align: center; padding: 40px; color: var(--gris-3); }
.session-no-result-ico { font-size: 2.2rem; margin-bottom: 12px; display: block; opacity: .3; }
.related-title { font-family: var(--font-h); font-size: .9rem; font-weight: 600; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.related-meta  { display: flex; justify-content: space-between; font-size: .78rem; color: var(--gris-3); }
.btn-inline-sm { display: inline-block; padding: 8px 16px; font-size: .82rem; }

/* ── BLOG TAGS (couleur dynamique) ───────────────────────────── */
.art-tag-dyn {
  border-radius: 100px; padding: 4px 12px;
  font-size: .76rem; font-weight: 600;
  font-family: var(--font-h);
}

/* ── CATALOGUE DYNAMIQUE ─────────────────────────────────────── */
.cat-domain-color { color: var(--rouge); /* overridden per domain via JS */ }

/* ── ORIENTER RÉSULTAT (score bars) ──────────────────────────── */
.score-section-title { font-family: var(--font-h); font-size: 1.3rem; margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.fc-icon-rouge { background: rgba(193,39,45,.1);  color: var(--rouge); }
.fc-icon-or    { background: rgba(232,149,10,.1); color: var(--or); }
.fc-icon-vert  { background: rgba(34,163,95,.1);  color: var(--vert); }
.fc-icon-bleu  { background: rgba(91,164,232,.1); color: #5BA4E8; }
.testi-av-rouge { background: linear-gradient(135deg, var(--rouge), #700); }
.testi-av-vert  { background: linear-gradient(135deg, var(--vert),  #084); }
.testi-av-bleu  { background: linear-gradient(135deg, #5BA4E8, #025); }
.feat-icon      { margin-top: 3px; flex-shrink: 0; }
.pos-rel        { position: relative; z-index: 1; }
.fw-700         { font-weight: 700; }
.art-featured-link  { text-decoration: none; color: inherit; display: grid; }
.art-title-featured { font-size: 1.4rem; -webkit-line-clamp: 3 !important; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : CATALOGUE (complet) ────────────────────────────
   ══════════════════════════════════════════════════════════════ */

/* Hero */
.cat-hero {
  background: var(--gris-0);
  padding: 56px 0 44px;
  border-bottom: 1px solid var(--border);
  position: relative; overflow: hidden;
}

.cat-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('../images/back catalogue.jpg') center/cover no-repeat;
    transform: scaleX(-1);   /* miroir horizontal */
    z-index: 0;
}

.cat-hero::after {
  content: ''; position: absolute; top: 0; right: 0;
  width: 40%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(193,39,45,.04));
  pointer-events: none;
}
.cat-hero h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 700; }
.cat-hero .text-lead { margin-top: 6px; }

/* Search bar */
.search-wrap {
  display: flex; gap: 0;
  background: #fff; border: 1.5px solid var(--gris-2);
  border-radius: var(--r); max-width: 600px;
  margin-top: 24px; transition: var(--tr); overflow: hidden;
}
.search-wrap:focus-within {
  border-color: var(--rouge);
  box-shadow: 0 0 0 3px rgba(193,39,45,.08);
}
.search-wrap i {
  padding: 0 14px; color: var(--gris-3);
  align-self: center; flex-shrink: 0;
}
.search-wrap input {
  flex: 1; background: transparent; border: none; outline: none;
  padding: 13px 8px; color: var(--noir);
  font-family: var(--font-b); font-size: .95rem;
}
.search-wrap input::placeholder { color: var(--gris-3); }
.search-wrap button {
  background: var(--rouge); color: #fff; border: none;
  padding: 0 24px; font-family: var(--font-h); font-weight: 600;
  font-size: .88rem; letter-spacing: .04em;
  cursor: pointer; transition: var(--tr); flex-shrink: 0;
}
.search-wrap button:hover { background: var(--rouge-2); }

/* Layout */
.cat-layout {
  display: grid; grid-template-columns: 230px 1fr;
  gap: 28px; width: 100%; max-width: 1280px;
  margin: 0 auto; padding: 36px 24px; box-sizing: border-box;
}

/* Sidebar */
.cat-sidebar { position: sticky; top: 86px; align-self: start; min-width: 0; }
.filter-box {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 20px; margin-bottom: 12px;
  box-shadow: var(--sh);
}
.filter-box h4 {
  font-family: var(--font-h); font-size: .75rem; font-weight: 600;
  color: var(--gris-3); letter-spacing: .1em; text-transform: uppercase;
  margin-bottom: 14px;
}
.filter-list { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.fi {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 12px; border-radius: 7px; cursor: pointer;
  font-size: .86rem; color: var(--gris-4); transition: var(--tr);
}
.fi:hover { background: var(--rouge-pale); color: var(--rouge); }
.fi.active { background: var(--rouge-pale); color: var(--rouge); font-weight: 600; }
.fi-count {
  font-size: .72rem; background: var(--gris-1);
  padding: 2px 8px; border-radius: 100px; flex-shrink: 0; color: var(--gris-3);
}
.fi.active .fi-count { background: rgba(193,39,45,.1); color: var(--rouge); }

/* Profiles scroll */
.profiles-scroll {
  display: flex; gap: 8px; overflow-x: auto; padding-bottom: 6px;
  scrollbar-width: thin; scrollbar-color: var(--gris-2) transparent;
  margin-bottom: 20px;
}
.profiles-scroll::-webkit-scrollbar { height: 3px; }
.profiles-scroll::-webkit-scrollbar-track { background: transparent; }
.profiles-scroll::-webkit-scrollbar-thumb { background: var(--gris-2); border-radius: 3px; }
.ptab {
  padding: 7px 14px; background: #fff;
  border: 1px solid var(--border); border-radius: 100px;
  font-size: .8rem; font-weight: 500; color: var(--gris-4);
  cursor: pointer; transition: var(--tr); white-space: nowrap; flex-shrink: 0;
}
.ptab:hover { border-color: rgba(193,39,45,.3); color: var(--rouge); }
.ptab.active {
  background: var(--rouge-pale); border-color: rgba(193,39,45,.35);
  color: var(--rouge); font-weight: 600;
}

/* Toolbar */
.cat-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
}
.res-count { font-size: .88rem; color: var(--gris-3); }
.res-count strong { color: var(--noir); font-family: var(--font-h); }
.toolbar-right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.sort-sel, .psize-sel {
  background: #fff; border: 1.5px solid var(--gris-2); border-radius: var(--r);
  padding: 8px 12px; color: var(--noir);
  font-family: var(--font-b); font-size: .84rem;
  outline: none; cursor: pointer; transition: var(--tr);
}
.sort-sel:focus, .psize-sel:focus { border-color: var(--rouge); }

/* Main zone */
.cat-main { min-width: 0; width: 100%; }

/* Courses grid */
.courses-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; width: 100%;
}
@media (max-width: 1100px) { .courses-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .courses-grid { grid-template-columns: 1fr; } }

/* Course card */
.course-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; transition: var(--tr);
  cursor: pointer; display: flex; flex-direction: column;
  text-decoration: none; color: inherit; min-width: 0; box-shadow: var(--sh);
}
.course-card:hover {
  transform: translateY(-4px); border-color: rgba(193,39,45,.25);
  box-shadow: var(--sh-md);
}
.cc-img { width: 100%; height: 175px; object-fit: cover; display: block; }
.cc-ph {
  width: 100%; height: 175px;
  display: flex; align-items: center; justify-content: center;
  font-size: 2.8rem; background: var(--gris-0);
}
.cc-body { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.cc-meta { display: flex; gap: 6px; flex-wrap: wrap; }
.cc-title {
  font-family: var(--font-h); font-size: 1rem; font-weight: 600;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
  color: var(--noir); line-height: 1.35;
}
.cc-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 12px; border-top: 1px solid var(--border);
  font-size: .78rem; color: var(--gris-3); margin-top: auto;
}
.cc-footer-stats { display: flex; gap: 12px; }
.cc-stat { display: flex; align-items: center; gap: 4px; }
.cc-stat i { color: var(--or); font-size: .75rem; }
.cc-arrow { color: var(--rouge); font-size: .8rem; transition: var(--tr); }
.course-card:hover .cc-arrow { transform: translateX(4px); }

/* Loading / empty */
.loading-state {
  grid-column: 1/-1; display: flex; flex-direction: column;
  align-items: center; gap: 16px; padding: 60px 0;
}
.loading-state p { color: var(--gris-3); font-size: .9rem; }
/* override empty-state for grid context */
.courses-grid .empty-state { grid-column: 1/-1; }

/* Pagination */
.pg-btn {
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  background: #fff; border: 1px solid var(--border); border-radius: 8px;
  color: var(--gris-4); font-size: .88rem; cursor: pointer; transition: var(--tr);
  font-family: var(--font-h); font-weight: 500;
}
.pg-btn:hover { border-color: var(--rouge); color: var(--rouge); background: var(--rouge-pale); }
.pg-btn.active { background: var(--rouge); border-color: var(--rouge); color: #fff; font-weight: 700; }
.pg-btn:disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }
.pg-btn.arrow { font-size: .75rem; }
.pg-ellipsis { padding: 0 4px; color: var(--gris-3); line-height: 38px; }

/* Responsive */
@media (max-width: 900px) {
  .cat-layout { grid-template-columns: 1fr; padding: 20px 16px; }
  .cat-sidebar { position: static; }
  .filter-box { display: none; }
  .filter-box.show { display: block; }
  .profiles-scroll { margin-top: 0; }
}
@media (max-width: 600px) {
  .cat-hero { padding: 36px 0 28px; }
  .cat-toolbar { flex-direction: column; align-items: flex-start; }
}
.cat-hero-title { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 700; margin-bottom: 6px; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : DÉTAIL FORMATION ───────────────────────────────
   ══════════════════════════════════════════════════════════════ */

/* Breadcrumb bar */
.breadcrumb-bar { background: var(--gris-0); border-bottom: 1px solid var(--border); }
.breadcrumb {
  display: flex; align-items: center; gap: 7px;
  font-size: .82rem; color: var(--gris-3);
  padding: 12px 0; flex-wrap: wrap;
}
.breadcrumb a { color: var(--rouge); }
.breadcrumb a:hover { color: var(--or); }
.breadcrumb .cur { color: var(--noir); }

/* Layout 2 colonnes */
.detail-layout {
  display: grid; grid-template-columns: 1fr 360px;
  gap: 28px; max-width: 1200px; margin: 0 auto;
  padding: 28px 24px 60px; align-items: start;
}

/* Entête cours */
.detail-header { margin-bottom: 20px; }
.detail-badges { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 12px; }
.detail-title {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700; margin-bottom: 10px; line-height: 1.2; color: var(--noir);
}
.detail-desc { font-size: .97rem; color: var(--gris-4); line-height: 1.7; }

/* Stats bar */
.stats-bar {
  display: flex; background: #fff;
  border: 1px solid var(--border); border-radius: var(--rlg);
  margin-bottom: 28px; overflow: hidden; flex-wrap: wrap;
  box-shadow: var(--sh);
}
.stat-item {
  flex: 1; padding: 14px 12px;
  border-right: 1px solid var(--border);
  text-align: center; min-width: 80px;
}
.stat-item:last-child { border-right: none; }
.stat-val {
  font-family: var(--font-h); font-size: 1.05rem;
  font-weight: 600; color: var(--noir); display: block;
}
.stat-val-sm { font-size: .82rem; }
.stat-lbl {
  font-size: .7rem; color: var(--gris-3);
  text-transform: uppercase; letter-spacing: .06em;
  margin-top: 2px; display: block;
}
.stat-ico { color: var(--or); margin-right: 4px; font-size: .82rem; }
.stat-dispo-ok  { color: #22A35F; }
.stat-dispo-wait { color: var(--or); }
.stat-dispo-off  { color: var(--gris-3); }

/* Onglets */
.tab-nav {
  display: flex; border-bottom: 2px solid var(--border); margin-bottom: 24px;
}
.tnb {
  padding: 11px 16px; font-family: var(--font-h); font-size: .88rem;
  font-weight: 600; color: var(--gris-3); background: none;
  border: none; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
  transition: var(--tr); white-space: nowrap;
}
.tnb.active { color: var(--rouge); border-bottom-color: var(--rouge); }
.tnb:hover  { color: var(--noir); }
.tab-count {
  background: var(--rouge); color: #fff;
  border-radius: 100px; padding: 1px 6px;
  font-size: .68rem; margin-left: 4px;
}
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* Description richtext */
.course-desc { font-size: .93rem; color: var(--gris-4); line-height: 1.8; }
.course-desc p { margin-bottom: 12px; }
.course-desc h3,
.course-desc h4 { font-family: var(--font-h); color: var(--noir); margin: 20px 0 10px; }
.course-desc ul,
.course-desc ol { padding-left: 20px; margin-bottom: 12px; }
.course-desc li { margin-bottom: 5px; }
.course-desc strong { color: var(--noir); }

/* Curriculum */
.module-item {
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: var(--r); margin-bottom: 8px;
  overflow: hidden; transition: var(--tr);
}
.module-item:hover { border-color: rgba(193,39,45,.2); }
.module-hd {
  display: flex; align-items: center;
  padding: 13px 14px; cursor: pointer; gap: 10px;
}
.mod-num {
  width: 26px; height: 26px; border-radius: 6px;
  background: var(--rouge-pale); color: var(--rouge);
  font-family: var(--font-h); font-weight: 700; font-size: .78rem;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.mod-title { font-family: var(--font-h); font-size: .88rem; font-weight: 600; flex: 1; color: var(--noir); white-space: normal; word-break: break-word; line-height: 1.35; }
.mod-arr { color: var(--gris-3); font-size: .72rem; transition: var(--tr); flex-shrink: 0; }
.module-item.open .mod-arr { transform: rotate(180deg); color: var(--rouge); }
.module-bd {
  display: none; border-top: 1px solid var(--border);
  padding: 8px 14px 10px; background: #fff;
}
.module-item.open .module-bd { display: block; }
.lp-link {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 0; border-bottom: 1px solid var(--border);
  font-size: .83rem; color: var(--gris-4);
}
.lp-link:last-child { border-bottom: none; }
.lp-link i { color: var(--rouge); font-size: .75rem; flex-shrink: 0; }
.lp-ext-ico { font-size: .68rem; opacity: .6; }

/* Section label bar (curriculum catégories) */
.cat-sep {
  font-size: .72rem; color: var(--gris-3);
  text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
}
.cat-sep::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.curriculum-cat { margin-bottom: 16px; }

/* Prérequis */
.req-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.req-list li { display: flex; gap: 10px; font-size: .9rem; color: var(--gris-4); align-items: flex-start; }
.req-list li i { color: var(--rouge); margin-top: 2px; flex-shrink: 0; }
.req-section-title { margin-bottom: 16px; font-size: 1.05rem; font-family: var(--font-h); color: var(--noir); }
.req-section-gap   { margin: 28px 0 16px; font-size: 1.05rem; font-family: var(--font-h); color: var(--noir); }

/* Bootcamp sessions tab */
.bootcamp-intro { color: var(--gris-4); font-size: .9rem; margin-bottom: 20px; }
.session-detail-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 16px; margin-bottom: 12px; box-shadow: var(--sh);
}
.session-detail-card.available { border-color: rgba(232,149,10,.25); }
.session-info-date {
  font-size: .83rem; color: var(--gris-3); margin-top: 4px;
}
.session-info-date .icon-or { margin-right: 4px; }
.session-desc-txt {
  font-size: .83rem; color: var(--gris-3);
  margin-top: 10px; border-top: 1px solid var(--border); padding-top: 8px;
}
.session-enroll-btn { margin-top: 12px; padding: 10px; font-size: .85rem; }

/* Related courses */
.related-section {
  margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border);
}
.related-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 16px; }
.rc-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r); padding: 13px;
  transition: var(--tr); display: block;
  color: inherit; text-decoration: none; box-shadow: var(--sh);
}
.rc-card:hover { border-color: rgba(193,39,45,.3); transform: translateY(-2px); box-shadow: var(--sh-md); }
.rc-title {
  font-family: var(--font-h); font-size: .9rem; font-weight: 600;
  margin-bottom: 6px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden; color: var(--noir);
}
.rc-meta {
  display: flex; justify-content: space-between;
  font-size: .78rem; color: var(--gris-3);
}
.rc-voir { color: var(--rouge); }

/* ── PAYMENT CARD ─────────────────────────────── */
.pay-card {
  background: #fff; border: 1px solid rgba(193,39,45,.15);
  border-radius: var(--rlg); overflow: hidden;
  position: sticky; top: 84px;
  box-shadow: var(--sh-md);
}
.pay-card-img { height: 155px; overflow: hidden; background: var(--gris-0); }
.pay-card-img img { width: 100%; height: 100%; object-fit: cover; }
.pay-card-ph {
  width: 100%; height: 100%; display: flex;
  align-items: center; justify-content: center;
  font-size: 3rem; color: var(--rouge); opacity: .25;
}
.pay-body { padding: 18px; }

/* Mode tabs (Autonome / Bootcamp) */
.mode-tabs {
  display: flex; background: var(--gris-0);
  border: 1px solid var(--border); border-radius: var(--r);
  overflow: hidden; margin-bottom: 14px;
}
.mode-tab {
  flex: 1; padding: 9px 4px; text-align: center;
  font-family: var(--font-h); font-size: .8rem; font-weight: 600;
  color: var(--gris-3); cursor: pointer; transition: var(--tr);
  border: none; background: transparent; letter-spacing: .02em;
}
.mode-tab.act-auto { background: var(--rouge-pale); color: var(--rouge); }
.mode-tab.act-boot { background: #fff7ed; color: var(--or); }
.mode-tab:hover:not(.act-auto):not(.act-boot) { color: var(--noir); background: #fff; }

/* Price grid */
.price-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.price-box {
  background: var(--gris-0); border: 1.5px solid var(--border);
  border-radius: var(--r); padding: 12px; text-align: center;
  cursor: pointer; transition: var(--tr); position: relative;
}
.price-box:hover { border-color: rgba(193,39,45,.3); }
.price-box.sel-a { border-color: var(--rouge); background: var(--rouge-pale); }
.price-box.sel-b { border-color: var(--or); background: #fff7ed; }
.pb-label {
  font-size: .68rem; color: var(--gris-3);
  text-transform: uppercase; letter-spacing: .07em; margin-bottom: 5px; display: block;
}
.pb-price { font-family: var(--font-h); font-size: 1.15rem; font-weight: 700; color: var(--noir); }
.pb-sub   { font-size: .68rem; color: var(--gris-3); margin-top: 3px; display: block; }
.price-box.sel-a .pb-price { color: var(--rouge); }
.price-box.sel-b .pb-price { color: var(--or); }
.pbadge {
  position: absolute; top: -8px; right: 8px;
  background: var(--or); color: #111;
  font-size: .6rem; font-weight: 700; font-family: var(--font-h);
  padding: 2px 7px; border-radius: 100px;
}

/* Sessions box */
.sessions-box { margin-bottom: 14px; display: none; }
.sessions-box.vis { display: block; }
.sess-lbl {
  font-size: .72rem; color: var(--gris-3); text-transform: uppercase;
  letter-spacing: .08em; margin-bottom: 8px; display: block;
  font-family: var(--font-h); font-weight: 600;
}
.sess-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; background: #fff;
  border: 1.5px solid var(--border); border-radius: var(--r);
  margin-bottom: 6px; cursor: pointer; transition: var(--tr); font-size: .82rem;
}
.sess-item:hover { border-color: rgba(232,149,10,.3); }
.sess-item.sel   { border-color: var(--or); background: #fff7ed; }
.sess-item input[type=radio] { accent-color: var(--or); flex-shrink: 0; }
.sess-flex { flex: 1; }
.si-date { font-weight: 600; color: var(--noir); font-family: var(--font-h); font-size: .84rem; }
.si-meta { font-size: .72rem; color: var(--gris-3); margin-top: 1px; }
.si-pl   { font-size: .71rem; padding: 2px 8px; border-radius: 100px; flex-shrink: 0; }
.si-pl.ok  { background: rgba(34,163,95,.12); color: #22A35F; }
.si-pl.low { background: rgba(232,149,10,.12); color: var(--or); }

/* Waitbox */
.waitbox {
  background: #fff7ed; border: 1px solid rgba(232,149,10,.2);
  border-radius: var(--r); padding: 14px; margin-bottom: 14px; text-align: center;
}
.waitbox i   { font-size: 1.4rem; color: var(--or); margin-bottom: 6px; display: block; }
.waitbox h4  { font-family: var(--font-h); font-size: .9rem; color: var(--noir); margin-bottom: 4px; }
.waitbox p   { font-size: .78rem; color: var(--gris-3); margin-bottom: 10px; }

/* CTA buttons */
.pay-btn {
  display: block; width: 100%; padding: 13px;
  background: var(--rouge); color: #fff !important;
  font-family: var(--font-h); font-weight: 700; font-size: .93rem;
  letter-spacing: .05em; border: none; border-radius: var(--r);
  cursor: pointer; transition: var(--tr); text-align: center;
  text-decoration: none; margin-bottom: 8px; text-transform: uppercase;
}
.pay-btn:hover {
  background: var(--rouge-2); transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(193,39,45,.3);
}
.pay-btn-b { background: linear-gradient(135deg, #b8740a, var(--or)); color: #111 !important; }
.pay-btn-b:hover { box-shadow: 0 8px 24px rgba(232,149,10,.35); transform: translateY(-2px); }
.pay-btn-waiting { background: var(--gris-1) !important; color: var(--gris-3) !important; }
.pay-btn-o {
  display: block; width: 100%; padding: 9px;
  background: transparent; color: var(--gris-4);
  font-family: var(--font-h); font-weight: 600; font-size: .83rem;
  border: 1px solid var(--border); border-radius: var(--r);
  cursor: pointer; transition: var(--tr);
  text-align: center; text-decoration: none; margin-bottom: 7px;
}
.pay-btn-o:hover { border-color: var(--or); color: var(--or); }
.pay-btn-g {
  display: block; width: 100%; padding: 9px;
  background: transparent; color: #22A35F;
  font-family: var(--font-h); font-weight: 600; font-size: .83rem;
  border: 1px solid rgba(34,163,95,.25); border-radius: var(--r);
  cursor: pointer; transition: var(--tr);
  text-align: center; text-decoration: none;
}
.pay-btn-g:hover { background: rgba(34,163,95,.06); border-color: rgba(34,163,95,.5); }

/* Inclus / Badges paiement */
.pay-inc {
  list-style: none; padding-top: 14px; border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px; margin-top: 4px;
}
.pay-inc li { display: flex; align-items: center; gap: 7px; font-size: .8rem; color: var(--gris-4); }
.pay-inc li i { color: #22A35F; font-size: .76rem; }
.pay-badges {
  display: flex; gap: 5px; justify-content: center;
  margin-top: 12px; flex-wrap: wrap;
}
.pay-badge {
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: 4px; padding: 4px 8px;
  font-size: .7rem; font-weight: 600; color: var(--gris-3); font-family: var(--font-h);
}
.divider { height: 1px; background: var(--border); margin: 14px 0; }

/* Responsive */
@media (max-width: 960px) {
  .detail-layout    { grid-template-columns: 1fr; }
  .pay-card         { position: static; }
  .related-grid     { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : INSCRIPTION COURS ──────────────────────────────
   ══════════════════════════════════════════════════════════════ */

/* Layout */
.insc-layout {
  display: grid; grid-template-columns: 1fr 340px;
  gap: 28px; max-width: 1100px; margin: 0 auto;
  padding: 36px 24px 60px; align-items: start;
}

/* Carte formulaire */
.insc-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; box-shadow: var(--sh);
}
.insc-head {
  background: var(--gris-0); border-bottom: 1px solid var(--border); padding: 20px 24px;
}
.insc-head h2 { font-size: 1.15rem; margin: 0; color: var(--noir); }
.insc-body { padding: 24px; }

/* Section label dans formulaire */
.form-section-label {
  font-family: var(--font-h); font-size: .75rem; font-weight: 600;
  color: var(--gris-3); letter-spacing: .1em; text-transform: uppercase;
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.form-section-label i { color: var(--rouge); }

/* Grille formulaire */
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.form-group label {
  font-size: .8rem; font-weight: 600; color: var(--gris-4);
  font-family: var(--font-h); letter-spacing: .04em; text-transform: uppercase;
}
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--gris-0); border: 1.5px solid var(--gris-2);
  border-radius: var(--r); padding: 11px 14px;
  color: var(--noir); font-family: var(--font-b); font-size: .9rem;
  outline: none; transition: var(--tr); width: 100%; box-sizing: border-box;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--rouge); box-shadow: 0 0 0 3px rgba(193,39,45,.08);
}
.form-group input::placeholder { color: var(--gris-3); }
.form-group .hint { font-size: .75rem; color: var(--gris-3); margin-top: 2px; }

/* Paiement — options */
.pm-section   { margin-bottom: 14px; }
.pm-title {
  font-size: .78rem; font-weight: 600; color: var(--gris-3);
  text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: 10px; display: block; font-family: var(--font-h);
}
.pm-option { position: relative; margin-bottom: 8px; }
.pm-option input[type=radio] { position: absolute; opacity: 0; width: 0; height: 0; }
.pm-lbl {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px; background: var(--gris-0);
  border: 1.5px solid var(--gris-2); border-radius: var(--r);
  cursor: pointer; transition: var(--tr);
}
.pm-lbl:hover { border-color: rgba(193,39,45,.3); background: #fff; }
.pm-option input:checked + .pm-lbl { border-color: var(--or); background: #fff7ed; }
.pm-ico   { font-size: 1.5rem; flex-shrink: 0; width: 36px; text-align: center; }
.pm-info strong { display: block; font-family: var(--font-h); font-size: .9rem; font-weight: 600; color: var(--noir); }
.pm-info small  { font-size: .76rem; color: var(--gris-3); }
.pm-radio-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--gris-2); margin-left: auto;
  flex-shrink: 0; transition: var(--tr); position: relative;
}
.pm-option input:checked + .pm-lbl .pm-radio-dot {
  border-color: var(--or); background: rgba(232,149,10,.2);
}
.pm-option input:checked + .pm-lbl .pm-radio-dot::after {
  content: ''; position: absolute; inset: 3px; border-radius: 50%; background: var(--or);
}

/* Zone Stripe */
#stripe-zone {
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: var(--r); padding: 14px; margin-top: 8px; display: none;
}
#card-element { color: var(--noir); }
#card-errors  { color: var(--rouge); font-size: .82rem; margin-top: 8px; }

/* Stripe info texte */
.stripe-info {
  font-size: .78rem; color: var(--gris-3); margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.stripe-info i { color: #22A35F; }

/* Bouton submit */
.submit-btn {
  width: 100%; padding: 15px; background: var(--rouge); color: #fff;
  font-family: var(--font-h); font-weight: 700; font-size: 1rem;
  letter-spacing: .06em; border: none; border-radius: var(--r);
  cursor: pointer; transition: var(--tr); text-transform: uppercase; margin-top: 6px;
}
.submit-btn:hover { background: var(--rouge-2); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(193,39,45,.3); }
.submit-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }

/* Mention sécurité */
.secure-note {
  font-size: .75rem; color: var(--gris-3); text-align: center; margin-top: 12px;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.secure-note i { color: #22A35F; }

/* Alert box */
.alert-box {
  background: rgba(193,39,45,.06); border: 1px solid rgba(193,39,45,.2);
  border-radius: var(--r); padding: 12px 16px;
  margin-bottom: 14px; font-size: .85rem; color: var(--rouge); display: none;
}

/* Résumé sidebar */
.summary-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 20px;
  position: sticky; top: 84px; box-shadow: var(--sh);
}
.sum-img    { width: 100%; height: 130px; border-radius: var(--r); object-fit: cover; margin-bottom: 14px; }
.sum-img-ph {
  width: 100%; height: 130px; background: var(--gris-0);
  border-radius: var(--r); display: flex; align-items: center; justify-content: center;
  font-size: 2.5rem; color: var(--rouge); opacity: .25; margin-bottom: 14px;
}
.sum-title { font-family: var(--font-h); font-size: 1rem; font-weight: 600; margin-bottom: 10px; line-height: 1.3; color: var(--noir); }
.sum-mode {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 100px; font-size: .78rem;
  font-weight: 600; font-family: var(--font-h); margin-bottom: 14px;
}
.sum-mode.auto { background: var(--rouge-pale); color: var(--rouge); border: 1px solid rgba(193,39,45,.2); }
.sum-mode.boot { background: #fff7ed; color: var(--or); border: 1px solid rgba(232,149,10,.2); }
.sum-line {
  display: flex; justify-content: space-between;
  font-size: .85rem; color: var(--gris-4);
  padding: 7px 0; border-bottom: 1px solid var(--border);
}
.sum-line:last-child { border-bottom: none; }
.sum-line strong { color: var(--noir); }
.sum-total {
  display: flex; justify-content: space-between;
  padding: 14px 0 0; border-top: 2px solid var(--border); margin-top: 8px;
}
.sum-total span    { font-family: var(--font-h); font-size: .85rem; color: var(--gris-3); }
.sum-total strong  { font-family: var(--font-h); font-size: 1.2rem; font-weight: 700; color: var(--rouge); }

/* Badges sécurité sidebar */
.secure-badges { display: flex; gap: 6px; margin-top: 14px; flex-wrap: wrap; }
.sec-badge { display: flex; align-items: center; gap: 5px; font-size: .72rem; color: var(--gris-3); }
.sec-badge i { color: #22A35F; }

/* Infos session bootcamp dans summary */
.sess-info {
  background: #fff7ed; border: 1px solid rgba(232,149,10,.2);
  border-radius: var(--r); padding: 10px 12px; margin-bottom: 14px; font-size: .82rem;
}
.sess-info i     { color: var(--or); margin-right: 5px; }
.sess-info strong { color: var(--or); }
.sess-info-sub   { margin-top: 4px; color: var(--gris-3); }

/* WhatsApp link */
.wa-link {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; color: #22A35F; text-decoration: none;
  padding: 8px 0; font-weight: 600;
}
.wa-link:hover { color: #1a9050; }

/* Séparateur summary */
.sum-wa-sep { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border); }

/* Responsive */
@media (max-width: 880px) {
  .insc-layout   { grid-template-columns: 1fr; }
  .summary-card  { position: static; }
  .form-row      { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : ORIENTER — RÉSULTATS ───────────────────────────
   ══════════════════════════════════════════════════════════════ */

.result-hero {
  background: linear-gradient(135deg, var(--noir) 0%, #2d2d2d 100%);
  color: #fff; padding: 70px 0 50px; text-align: center;
}
.result-hero h1   { color: #fff; font-size: clamp(1.8rem, 4vw, 2.8rem); margin-bottom: 10px; }
.result-hero-sub  { opacity: .8; font-size: 1.05rem; }

.result-wrapper { max-width: 860px; margin: 48px auto; padding: 0 24px; }

/* Score card */
.score-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 32px;
  margin-bottom: 28px; box-shadow: var(--sh);
}

/* Domaine dominant */
.dominant-box { margin-top: 20px; }

/* Score label */
.score-label strong { color: var(--rouge); }

/* Titre formations recommandées */
.rec-list-title {
  font-family: var(--font-h); font-size: 1.5rem; font-weight: 700;
  margin-bottom: 20px; display: flex; align-items: center; gap: 10px;
}

/* Recommandation principale */
.top-rec {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 32px; margin-bottom: 16px;
  box-shadow: var(--sh-md); border-left: 4px solid var(--rouge);
}
.top-rec-title { font-size: 1.3rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }
.top-rec-desc  { color: var(--gris-4); font-size: .92rem; margin-bottom: 18px; line-height: 1.6; }

/* Recommandation secondaire */
.secondary-rec {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 24px; margin-bottom: 12px; box-shadow: var(--sh);
}
.secondary-rec-badge  { margin-bottom: 12px; display: inline-block; }
.secondary-rec-title  { font-size: 1.1rem; font-weight: 700; margin-bottom: 10px; color: var(--noir); }

/* Aucune recommandation */
.rec-none-icon-lg { font-size: 2rem; color: var(--gris-3); margin-bottom: 12px; display: block; }
.rec-none-desc    { color: var(--gris-4); margin-bottom: 16px; }

/* Entretien demandé */
.entretien-box {
  background: #f0fdf4; border: 1px solid #86efac;
  border-radius: var(--rlg); padding: 24px; margin-top: 24px;
}
.entretien-header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.entretien-ico    { color: var(--vert); font-size: 1.3rem; }
.entretien-title  { font-family: var(--font-h); font-size: 1.05rem; font-weight: 700; color: #166534; }
.entretien-desc   { color: #166534; font-size: .9rem; line-height: 1.6; }

/* CTA bas */
.result-cta { text-align: center; margin-top: 48px; padding-top: 40px; border-top: 1px solid var(--border); }
.result-cta-email { color: var(--gris-4); margin-bottom: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.result-cta-email i { color: var(--rouge); }
.result-cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 12px; }


/* ══════════════════════════════════════════════════════════════
   ──── PAGE : CURSUS ──────────────────────────────────────────
   ══════════════════════════════════════════════════════════════ */

/* Hero */
.cursus-hero {
  padding: 80px 0 60px; background: var(--gris-0);
  border-bottom: 1px solid var(--border); position: relative; overflow: hidden;
}
.cursus-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 55% 60% at 85% 50%, rgba(193,39,45,.06) 0%, transparent 70%);
  pointer-events: none;
}
.cursus-hero h1 { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; margin-bottom: 14px; position: relative; z-index: 1; }
.cursus-hero p  { color: var(--gris-4); font-size: 1.05rem; max-width: 540px; line-height: 1.7; position: relative; z-index: 1; }

/* Compteur total */
.cursus-count-band {
  background: #fff; border-bottom: 1px solid var(--border);
  padding: 14px 0;
}
.cursus-count-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
}
.cursus-count-txt { font-size: .88rem; color: var(--gris-3); }
.cursus-count-txt strong { color: var(--noir); font-family: var(--font-h); }

/* Grid cursus */
.cursus-section { padding: 56px 0 80px; }
.cursus-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 0;
}
@media (max-width: 960px) { .cursus-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .cursus-grid { grid-template-columns: 1fr; } }

/* Carte cursus */
.cursus-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; transition: var(--tr);
  display: flex; flex-direction: column; box-shadow: var(--sh);
  text-decoration: none; color: inherit;
}
.cursus-card:hover {
  transform: translateY(-5px); box-shadow: var(--sh-md);
  border-color: rgba(193,39,45,.2);
}
.cursus-card-img {
  width: 100%; height: 170px; object-fit: cover; display: block;
}
.cursus-card-ph {
  width: 100%; height: 170px; background: var(--gris-0);
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; color: var(--gris-2);
  border-bottom: 1px solid var(--border);
}
.cursus-card-body {
  padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 10px;
}
.cursus-card-name {
  font-family: var(--font-h); font-size: 1.08rem; font-weight: 700;
  color: var(--noir); line-height: 1.3;
}
.cursus-card-desc {
  font-size: .84rem; color: var(--gris-4); line-height: 1.6; flex: 1;
}
.cursus-card-stats {
  display: flex; gap: 14px; font-size: .78rem; color: var(--gris-3);
  padding-top: 10px; border-top: 1px solid var(--border); margin-top: auto;
}
.cursus-stat { display: flex; align-items: center; gap: 5px; }
.cursus-stat i { color: var(--or); }
.cursus-card-cta {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px; background: var(--gris-0); border-top: 1px solid var(--border);
  font-size: .82rem; font-weight: 600; color: var(--rouge); font-family: var(--font-h);
  transition: var(--tr);
}
.cursus-card:hover .cursus-card-cta { background: var(--rouge-pale); }
.cursus-card-cta i { transition: var(--tr); }
.cursus-card:hover .cursus-card-cta i { transform: translateX(4px); }

/* ── DÉTAIL CURSUS ─────────────────────────────────────────── */

/* Header détail */
.cursus-detail-hero {
  padding: 56px 0 44px; background: var(--gris-0);
  border-bottom: 1px solid var(--border);
}
.cursus-detail-hero h1 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 800; margin-bottom: 12px;
}
.cursus-detail-meta {
  display: flex; gap: 20px; flex-wrap: wrap; margin-top: 16px;
}
.cdm-item { display: flex; align-items: center; gap: 7px; font-size: .88rem; color: var(--gris-4); }
.cdm-item i { color: var(--rouge); }

/* Layout 2 colonnes */
.cursus-detail-layout {
  display: grid; grid-template-columns: 1fr 360px;
  gap: 32px; max-width: 1200px; margin: 40px auto; padding: 0 24px 80px;
  align-items: start;
}
@media (max-width: 960px) {
  .cursus-detail-layout { grid-template-columns: 1fr; }
}

/* Bloc cours par catégorie */
.cat-block { margin-bottom: 32px; }
.cat-block-title {
  font-family: var(--font-h); font-size: .78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--gris-3);
  margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
}
.cat-block-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.cat-block-title i { color: var(--rouge); }

/* Carte cours dans cursus */
.curs-course-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r); padding: 14px 16px; margin-bottom: 8px;
  display: flex; align-items: center; gap: 14px; transition: var(--tr);
  text-decoration: none; color: inherit;
}
.curs-course-card:hover { border-color: rgba(193,39,45,.2); box-shadow: var(--sh); }
.curs-course-thumb {
  width: 52px; height: 42px; border-radius: 6px; object-fit: cover;
  flex-shrink: 0; background: var(--gris-0);
}
.curs-course-ph {
  width: 52px; height: 42px; border-radius: 6px; flex-shrink: 0;
  background: var(--gris-0); display: flex; align-items: center;
  justify-content: center; font-size: 1.2rem; color: var(--gris-3);
}
.curs-course-info { flex: 1; min-width: 0; }
.curs-course-title {
  font-family: var(--font-h); font-size: .9rem; font-weight: 600;
  color: var(--noir); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.curs-course-meta { font-size: .75rem; color: var(--gris-3); margin-top: 2px; display: flex; gap: 10px; flex-wrap: wrap; }
.curs-course-arrow { color: var(--rouge); font-size: .8rem; flex-shrink: 0; transition: var(--tr); }
.curs-course-card:hover .curs-course-arrow { transform: translateX(4px); }

/* Sidebar candidature */
.apply-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden;
  position: sticky; top: 84px; box-shadow: var(--sh-md);
}
.apply-card-head {
  background: var(--rouge); color: #fff; padding: 20px 22px;
}
.apply-card-head h3 { font-size: 1.05rem; margin: 0; color: #fff; }
.apply-card-head p  { font-size: .82rem; opacity: .85; margin-top: 4px; }
.apply-card-body { padding: 20px 22px; }
.apply-info-list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.apply-info-list li { display: flex; align-items: center; gap: 9px; font-size: .85rem; color: var(--gris-4); }
.apply-info-list li i { color: var(--vert); font-size: .8rem; flex-shrink: 0; }
.apply-divider { height: 1px; background: var(--border); margin: 16px 0; }

/* Formulaire candidature (main) */
.apply-form-section {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden; box-shadow: var(--sh); margin-top: 32px;
}
.apply-form-head {
  background: var(--gris-0); border-bottom: 1px solid var(--border); padding: 20px 28px;
}
.apply-form-head h2 { font-size: 1.2rem; margin: 0; }
.apply-form-head p  { color: var(--gris-4); font-size: .88rem; margin-top: 6px; }
.apply-form-body { padding: 28px; }

/* Textarea motivation */
.motivation-textarea {
  min-height: 140px; resize: vertical;
}
.career-goals-textarea {
  min-height: 100px; resize: vertical;
}

/* Motivation type select */
.motivation-select { width: 100%; }

/* reCAPTCHA */
.recaptcha-wrap { margin: 16px 0; }

/* Submit btn plein */
.apply-submit-btn {
  width: 100%; padding: 14px; background: var(--rouge); color: #fff;
  font-family: var(--font-h); font-weight: 700; font-size: .95rem;
  letter-spacing: .06em; border: none; border-radius: var(--r);
  cursor: pointer; transition: var(--tr); text-transform: uppercase;
}
.apply-submit-btn:hover { background: var(--rouge-2); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(193,39,45,.3); }

/* CV upload zone */
.cv-upload-hint { font-size: .75rem; color: var(--gris-3); margin-top: 4px; }

/* ── PAGE SUCCÈS CANDIDATURE ───────────────────────────────── */
.app-success-wrap {
  min-height: 65vh; display: flex; align-items: center;
  justify-content: center; padding: 60px 24px; text-align: center;
}
.app-success-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 48px 40px; max-width: 540px;
  box-shadow: var(--sh-md);
}
.app-success-icon { font-size: 3.5rem; margin-bottom: 20px; display: block; }
.app-success-title { font-size: 1.8rem; font-weight: 800; margin-bottom: 12px; color: var(--noir); }
.app-success-sub   { color: var(--gris-4); line-height: 1.7; margin-bottom: 28px; }
.app-success-detail {
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: var(--r); padding: 16px; margin-bottom: 28px; text-align: left;
}
.app-success-detail-row { display: flex; justify-content: space-between; font-size: .85rem; padding: 5px 0; border-bottom: 1px solid var(--border); }
.app-success-detail-row:last-child { border-bottom: none; }
.app-success-detail-row .lbl { color: var(--gris-3); }
.app-success-detail-row .val { font-weight: 600; color: var(--noir); }
.app-success-btns { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ── CURSUS — compléments inline manquants ───────────────────── */

/* Image hero du cursus */
.cursus-detail-img {
  width: 100%; height: 280px; object-fit: cover;
  border-radius: var(--rlg); margin-bottom: 32px;
  border: 1px solid var(--border);
}

/* Erreurs de champ (hint rouge) */
.hint-error { color: var(--rouge); font-size: .75rem; margin-top: 2px; }

/* Alert dans formulaire (non flottante) */
.alert-wrap-inline { position: static; max-width: 100%; margin-bottom: 16px; }

/* Bouton plein-largeur bloc */
.btn-block { display: block; text-align: center; padding: 13px; }
.btn-block-sm { display: block; text-align: center; }

/* Astuce sidebar (texte centré petit) */
.sidebar-tip { font-size: .78rem; color: var(--gris-3); text-align: center; margin-bottom: 10px; }

/* WhatsApp centré */
.wa-link-center { justify-content: center; }

/* Texte confirmation email (app success) */
.app-success-email-note {
  font-size: .84rem; color: #166534; margin: 0;
  display: flex; align-items: flex-start; gap: 8px;
}

/* Section dark band — bouton outline */
.section-dark-band .btn-outline {
  border-color: rgba(255,255,255,.25); color: #fff;
}
.section-dark-band .btn-outline:hover {
  border-color: var(--rouge); background: var(--rouge);
}
/* Section dark band — sec-label */
.section-dark-band .sec-label { color: rgba(255,255,255,.5); }

/* Info box vert compacte (texte aligné à gauche) */
.info-box-vert-left { text-align: left; }




/* ══════════════════════════════════════════════════════════════
   ──── PAGE : RÉALISATIONS / PORTFOLIO (v2 — thème rouge)
   ══════════════════════════════════════════════════════════════ */

/* ── HERO ─────────────────────────────────────────────────────── */
.real-hero-v2 {
  position: relative; overflow: hidden;
  padding: 100px 0 72px;
  background: linear-gradient(135deg, #fff 0%, var(--gris-0) 100%);
  border-bottom: 1px solid var(--border);
}
.real-hero-v2-bg {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden;
}
.rhv2-orb {
  position: absolute; border-radius: 50%; filter: blur(72px);
}
.rhv2-orb-1 {
  width: 480px; height: 480px;
  background: rgba(193,39,45,.07);
  top: -160px; right: -100px;
}
.rhv2-orb-2 {
  width: 300px; height: 300px;
  background: rgba(232,149,10,.06);
  bottom: -80px; left: 5%;
}
.rhv2-watermark {
  position: absolute; right: -30px; bottom: -20px;
  font-family: var(--font-h); font-size: 11rem; font-weight: 800;
  color: rgba(193,39,45,.04); line-height: 1; user-select: none;
}

.real-hero-v2-inner {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 48px;
  align-items: center;
}

.real-hero-v2-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--rouge-pale); border: 1px solid rgba(193,39,45,.2);
  border-radius: 50px; padding: 5px 16px;
  font-size: .78rem; font-weight: 600; color: var(--rouge);
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 20px;
}
.real-hero-v2-eyebrow i { font-size: .65rem; }

.real-hero-v2-title {
  font-family: var(--font-h);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800; line-height: 1.1;
  color: var(--noir); margin-bottom: 16px;
}
.real-hero-v2-title em {
  color: var(--rouge); font-style: normal;
}

.real-hero-v2-sub {
  font-size: 1rem; color: var(--gris-4);
  line-height: 1.75; max-width: 520px; margin-bottom: 32px;
}

.real-hero-v2-stats {
  display: flex; align-items: center;
  gap: 24px; flex-wrap: wrap;
  padding-top: 24px; border-top: 1px solid var(--border);
}
.rhv2-stat { text-align: left; }
.rhv2-stat-num {
  font-family: var(--font-h); font-size: 1.8rem;
  font-weight: 800; color: var(--rouge); display: block; line-height: 1;
}
.rhv2-stat-lbl {
  font-size: .78rem; color: var(--gris-3); margin-top: 3px; display: block;
}
.rhv2-sep {
  width: 1px; height: 36px;
  background: var(--border); flex-shrink: 0;
}

/* Cartes déco flottantes hero */
.rhv2-deco-wrap {
  display: flex; flex-direction: column; gap: 12px;
}
.rhv2-deco-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); padding: 14px 18px;
  display: flex; align-items: center; gap: 14px;
  box-shadow: var(--sh-md);
  animation: flt 4s ease-in-out infinite;
}
.rhv2-deco-card-1 { animation-delay: 0s; }
.rhv2-deco-card-2 { animation-delay: 1.3s; }
.rhv2-deco-card-3 { animation-delay: 2.6s; }
.rhv2-deco-icon {
  width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
}
.rhv2-deco-title {
  font-family: var(--font-h); font-size: .9rem;
  font-weight: 700; color: var(--noir); line-height: 1.2;
}
.rhv2-deco-sub {
  font-size: .75rem; color: var(--gris-3); margin-top: 2px;
}

@media (max-width: 960px) {
  .real-hero-v2-inner { grid-template-columns: 1fr; }
  .rhv2-deco-wrap { display: none; }
}

/* ── FILTRE & COMPTEUR ────────────────────────────────────────── */
.real-portfolio-wrap { padding: 36px 0 80px; }

.real-filter-bar {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 10px; padding-bottom: 24px;
  border-bottom: 1px solid var(--border); margin-bottom: 20px;
}
.real-filter-label {
  font-size: .75rem; font-weight: 700; color: var(--gris-3);
  text-transform: uppercase; letter-spacing: .1em;
  font-family: var(--font-h); flex-shrink: 0; margin-right: 4px;
}
.real-filter-pills {
  display: flex; flex-wrap: wrap; gap: 7px;
}
.real-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 16px; border-radius: 50px; font-size: .82rem;
  font-weight: 500; color: var(--gris-4);
  border: 1px solid var(--border); background: #fff;
  transition: var(--tr); text-decoration: none;
}
.real-pill i { font-size: .72rem; }
.real-pill:hover {
  border-color: rgba(193,39,45,.35);
  color: var(--rouge); background: var(--rouge-pale);
}
.real-pill-active {
  background: var(--rouge) !important;
  border-color: var(--rouge) !important;
  color: #fff !important; font-weight: 700;
}

.real-count-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 28px; flex-wrap: wrap; gap: 8px;
}
.real-count-txt {
  font-size: .88rem; color: var(--gris-3);
}
.real-count-txt strong {
  font-family: var(--font-h); font-size: 1rem;
  font-weight: 700; color: var(--noir);
}
.real-count-reset {
  font-size: .8rem; color: var(--rouge); display: flex;
  align-items: center; gap: 5px; font-weight: 600;
  text-decoration: none; transition: var(--tr);
}
.real-count-reset:hover { color: var(--rouge-2); }

/* ── GRILLE PORTFOLIO ─────────────────────────────────────────── */
.real-portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 960px) { .real-portfolio-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) { .real-portfolio-grid { grid-template-columns: 1fr; } }

/* ── CARD PROJET ──────────────────────────────────────────────── */
.real-pcard {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--rlg); overflow: hidden;
  display: flex; flex-direction: column;
  transition: var(--tr); box-shadow: var(--sh);
}
.real-pcard:hover {
  transform: translateY(-6px);
  box-shadow: var(--sh-lg);
  border-color: rgba(193,39,45,.2);
}

/* Image */
.real-pcard-img-wrap {
  position: relative; overflow: hidden;
}
.real-pcard-img {
  width: 100%; height: 190px;
  object-fit: cover; display: block;
  transition: transform .4s ease;
}
.real-pcard:hover .real-pcard-img { transform: scale(1.04); }
.real-pcard-ph {
  width: 100%; height: 190px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
  background: linear-gradient(135deg, var(--gris-0), #fff);
  border-bottom: 1px solid var(--border);
}
.real-pcard-ph i { font-size: 2.5rem; color: var(--gris-2); }
.real-pcard-ph span { font-size: .75rem; color: var(--gris-3); font-family: var(--font-h); letter-spacing: .06em; text-transform: uppercase; }

/* Badge catégorie sur image */
.real-pcard-cat-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--rouge); color: #fff;
  font-size: .68rem; font-weight: 700; font-family: var(--font-h);
  padding: 3px 10px; border-radius: 100px;
  letter-spacing: .05em; text-transform: uppercase;
  box-shadow: 0 2px 8px rgba(193,39,45,.3);
}

/* Corps */
.real-pcard-body {
  padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 8px;
}

.real-pcard-meta {
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 4px;
}
.real-pcard-pays {
  font-size: .75rem; color: var(--gris-3);
  display: flex; align-items: center; gap: 4px;
}
.real-pcard-pays i { color: var(--rouge); font-size: .68rem; }
.real-pcard-date {
  font-size: .72rem; color: var(--gris-3);
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: 4px; padding: 2px 8px;
  font-family: var(--font-h); font-weight: 600;
}

.real-pcard-title {
  font-family: var(--font-h); font-size: 1.05rem; font-weight: 700;
  color: var(--noir); line-height: 1.3; margin: 0;
}

.real-pcard-desc {
  font-size: .84rem; color: var(--gris-4); line-height: 1.65;
  flex: 1; margin: 0;
}

/* Tech tags */
.real-pcard-techs {
  display: flex; flex-wrap: wrap; gap: 5px; margin-top: 4px;
}
.real-pcard-tech {
  font-size: .69rem; padding: 2px 9px;
  background: var(--gris-0); border: 1px solid var(--border);
  border-radius: 4px; color: var(--gris-4);
  font-family: var(--font-h); font-weight: 600;
}
.real-pcard-tech-more {
  background: var(--rouge-pale); border-color: rgba(193,39,45,.2);
  color: var(--rouge);
}

/* Footer */
.real-pcard-footer {
  padding: 12px 20px; border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: #fafafa;
}
.real-pcard-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .77rem; font-weight: 600; padding: 6px 13px;
  border-radius: 6px; transition: var(--tr); text-decoration: none;
  font-family: var(--font-h); letter-spacing: .03em;
}
.real-pcard-link-live {
  background: var(--rouge); color: #fff;
  box-shadow: 0 2px 8px rgba(193,39,45,.2);
}
.real-pcard-link-live:hover {
  background: var(--rouge-2);
  box-shadow: 0 4px 14px rgba(193,39,45,.35);
  transform: translateY(-1px);
}
.real-pcard-link-gh {
  background: var(--gris-0); color: var(--noir);
  border: 1px solid var(--border);
}
.real-pcard-link-gh:hover {
  background: #1a1a2e; color: #fff; border-color: #1a1a2e;
}
.real-pcard-confidential {
  font-size: .76rem; color: var(--gris-3);
  display: flex; align-items: center; gap: 5px;
  font-style: italic;
}
.real-pcard-confidential i { font-size: .68rem; }

/* ── ÉTAT VIDE ────────────────────────────────────────────────── */
.real-empty-state {
  grid-column: 1/-1; text-align: center;
  padding: 72px 24px; color: var(--gris-3);
}
.real-empty-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--rouge-pale); border: 1px solid rgba(193,39,45,.15);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
}
.real-empty-icon i { font-size: 1.8rem; color: var(--rouge); opacity: .5; }
.real-empty-state h3 {
  font-family: var(--font-h); font-size: 1.3rem;
  font-weight: 700; color: var(--noir-2); margin-bottom: 8px;
}
.real-empty-state p { font-size: .9rem; max-width: 360px; margin: 0 auto; }

/* ── CTA FINAL ────────────────────────────────────────────────── */
.real-cta-section {
  background: var(--noir);
  border-top: 4px solid var(--rouge);
  padding: 64px 0;
}
.real-cta-inner {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 32px; flex-wrap: wrap;
}
.real-cta-title {
  font-family: var(--font-h);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800; color: #fff; margin-bottom: 8px;
}
.real-cta-sub {
  color: #9ca3af; font-size: .95rem; line-height: 1.65;
}
.real-cta-actions {
  display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0;
}

@media (max-width: 768px) {
  .real-cta-inner { flex-direction: column; text-align: center; }
  .real-cta-actions { justify-content: center; }
}

/* ================================================================
   EDIFY — AJOUTS edify.css
   À coller à la fin de ton fichier edify.css existant
   Contient : section-label, section-header, nl-card amélioré
   ================================================================ */

/* ── PAGE COMMUNAUTÉ — classes manquantes ─────────────────────── */

/* Label de section (petit tag rouge au-dessus des titres)        */
.section-label {
  display: inline-block;
  font-family: var(--font-h);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--rouge);
  background: var(--rouge-pale);
  border: 1px solid rgba(193,39,45,.15);
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 14px;
}

/* En-tête de section (conteneur label + titre) */
.section-header {
  text-align: center;
  margin-bottom: 40px;
}
.section-header .section-title {
  font-family: var(--font-h);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 800;
  color: var(--noir);
  margin-top: 8px;
  line-height: 1.15;
}

/* Icône décorative dans la join-card communauté */
.join-card .sf-visual-icon { font-size: 3rem; margin-bottom: 12px; }

/* Drapeaux pays dans join-card */
.join-card-flags {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 20px;
  font-size: 1.5rem;
}

/* ── NEWSLETTER SIDEBAR (blog_detail) — REDESIGN ──────────────── */

.nl-card {
  background: var(--noir);
  border-radius: var(--rlg);
  padding: 24px;
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
}

/* Dégradé décoratif en fond */
.nl-card::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 140px; height: 140px;
  background: radial-gradient(circle, rgba(193,39,45,.25) 0%, transparent 70%);
  pointer-events: none;
}
.nl-card::after {
  content: '';
  position: absolute;
  bottom: -30px; left: -30px;
  width: 100px; height: 100px;
  background: radial-gradient(circle, rgba(232,149,10,.15) 0%, transparent 70%);
  pointer-events: none;
}

/* Icône d'en-tête */
.nl-card-icon {
  width: 42px; height: 42px;
  background: rgba(193,39,45,.2);
  border: 1px solid rgba(193,39,45,.3);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: var(--rouge-3);
  margin-bottom: 14px;
}

/* Titre */
.nl-card h4 {
  font-family: var(--font-h);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .04em;
  color: #fff;
  margin-bottom: 6px;
}

/* Sous-titres */
.nl-card-pitch {
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  line-height: 1.6;
  margin-bottom: 16px;
}

/* Champ de saisie */
.nl-field {
  position: relative;
  margin-bottom: 10px;
}
.nl-field i {
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  color: rgba(255,255,255,.3);
  font-size: .8rem;
  pointer-events: none;
}
.nl-input {
  width: 100%;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  padding: 10px 12px 10px 34px;
  color: #fff;
  font-family: var(--font-b);
  font-size: .86rem;
  outline: none;
  transition: border-color .2s, background .2s;
  box-sizing: border-box;
}
.nl-input::placeholder { color: rgba(255,255,255,.3); }
.nl-input:focus {
  border-color: rgba(193,39,45,.5);
  background: rgba(255,255,255,.1);
  box-shadow: 0 0 0 3px rgba(193,39,45,.12);
}

/* Bouton */
.nl-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 16px;
  background: var(--rouge);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-family: var(--font-h);
  font-weight: 700;
  font-size: .84rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, transform .15s, box-shadow .2s;
  margin-top: 4px;
}
.nl-btn:hover {
  background: var(--rouge-3);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(193,39,45,.4);
}

/* Message de confirmation/erreur */
.nl-msg {
  margin-top: 10px;
  font-size: .8rem;
  text-align: center;
  padding: 8px 12px;
  border-radius: 6px;
  display: none;
}
.nl-msg.ok  { background: rgba(34,163,95,.15); color: #4ade80; display: block; }
.nl-msg.err { background: rgba(193,39,45,.15); color: #f87171; display: block; }

/* Texte anti-spam sous le formulaire */
.nl-antispam {
  display: flex; align-items: center; gap: 6px;
  margin-top: 10px;
  font-size: .73rem;
  color: rgba(255,255,255,.3);
  justify-content: center;
}

/* ════════════════════════════════════════════════════════════════════
   FORMATION ENFANTS — Hub des Talents Africains
   À ajouter dans edify.css
   ════════════════════════════════════════════════════════════════════ */

/* ── Utilitaires spacing (si pas déjà dans edify.css) ─────────────── */
.mb-xs  { margin-bottom: 4px; }
.mb-sm  { margin-bottom: 8px; }
.mb-md  { margin-bottom: 16px; }
.mb-lg  { margin-bottom: 24px; }
.mb-xl  { margin-bottom: 40px; }
.mb-xxl { margin-bottom: 48px; }
.section-pad { padding: 72px 0; }
.grid-gap-md { gap: 20px; }

/* ── Hero ─────────────────────────────────────────────────────────── */
.hub-hero {
  background: linear-gradient(135deg, #0d1f0f 0%, #1a3a22 50%, #0f2d1a 100%);
  padding: 80px 0 60px;
  position: relative;
  overflow: hidden;
}
.hub-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(34,163,95,.08) 0%, transparent 70%);
  pointer-events: none;
}
.hub-hero-container  { position: relative; z-index: 1; }
.hub-hero-grid       { align-items: center; }
.hub-hero-title {
  color: #fff;
  font-family: var(--font-h);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  margin-bottom: 16px;
  line-height: 1.1;
}
.hub-hero-em    { color: #6ee7b7; font-style: normal; }
.hub-hero-sub   { font-size: 1rem; color: rgba(255,255,255,.75); line-height: 1.75; max-width: 500px; margin-bottom: 28px; }
.hub-hero-strong { color: #fff; }

.btn-vert { background: var(--vert); border-color: var(--vert); color: #fff; }
.btn-vert:hover { background: #16a34a; border-color: #16a34a; }
.hub-btn-outline { border-color: rgba(255,255,255,.3); color: #fff; }

/* ── Hero — cartes visuelles droite ──────────────────────────────── */
.hub-hero-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}
.hub-info-card {
  border-radius: var(--rlg);
  padding: 20px 24px;
  max-width: 280px;
  width: 100%;
}
.hub-info-card--vert  { background: rgba(34,163,95,.12);  border: 1px solid rgba(34,163,95,.25); }
.hub-info-card--or    { background: rgba(232,149,10,.10); border: 1px solid rgba(232,149,10,.25); }
.hub-info-card--rouge { background: rgba(193,39,45,.10);  border: 1px solid rgba(193,39,45,.25); }

.hub-info-card-label {
  font-size: .72rem;
  font-family: var(--font-h);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.hub-info-card-label--vert  { color: #6ee7b7; }
.hub-info-card-label--or    { color: var(--or); }
.hub-info-card-label--rouge { color: #fca5a5; }

.hub-info-card-num  { font-family: var(--font-h); font-size: 2rem; font-weight: 800; color: #fff; }
.hub-info-card-sub  { font-size: .82rem; color: rgba(255,255,255,.5); margin-top: 4px; }
.hub-info-card-text { font-size: .88rem; color: rgba(255,255,255,.7); line-height: 1.6; }

/* ── Accent cards inner layout ───────────────────────────────────── */
.hub-accent-inner { display: flex; gap: 12px; align-items: flex-start; }
.hub-accent-icon  { font-size: 1.5rem; flex-shrink: 0; }

/* ── Galerie ─────────────────────────────────────────────────────── */
.gallery-grid--mb     { margin-bottom: 12px; }
.gallery-item--large  { min-height: 320px; }
.gallery-item--sm     { min-height: 155px; }
.gallery-item--md     { min-height: 160px; }
.gallery-ph--large    { min-height: 320px; }
.gallery-ph--sm       { min-height: 155px; }
.gallery-ph--md       { min-height: 160px; }
.gallery-ph--col      { flex-direction: column; }
.gallery-ph-title     { color: var(--vert); font-family: var(--font-h); }
.gallery-ph-sub       { color: var(--gris-4); }
.gallery-ph-note      { font-size: .7rem; margin-top: 8px; color: var(--gris-3); }
.hub-gallery-note     { margin-top: 20px; display: flex; align-items: center; gap: 12px; }
.hub-gallery-note-icon { font-size: 1.2rem; flex-shrink: 0; }

/* ── Ateliers cards ──────────────────────────────────────────────── */
.atelier-tags { margin-top: 14px; }

.atelier-top--vert   { background: linear-gradient(135deg, rgba(34,163,95,.12),  rgba(34,163,95,.06)); }
.atelier-top--bleu   { background: linear-gradient(135deg, rgba(37,99,235,.10),  rgba(37,99,235,.05)); }
.atelier-top--or     { background: linear-gradient(135deg, rgba(232,149,10,.12), rgba(232,149,10,.06)); }
.atelier-top--rouge  { background: linear-gradient(135deg, rgba(193,39,45,.10),  rgba(193,39,45,.05)); }
.atelier-top--violet { background: linear-gradient(135deg, rgba(168,85,247,.10), rgba(168,85,247,.05)); }
.atelier-top--cyan   { background: linear-gradient(135deg, rgba(14,165,233,.10), rgba(14,165,233,.05)); }

.atelier-tag--vert   { background: rgba(34,163,95,.1);  color: var(--vert); }
.atelier-tag--bleu   { background: rgba(37,99,235,.1);  color: #1d4ed8; }
.atelier-tag--or     { background: rgba(232,149,10,.1); color: var(--or); }
.atelier-tag--rouge  { background: rgba(193,39,45,.1);  color: var(--rouge); }
.atelier-tag--violet { background: rgba(168,85,247,.1); color: #7c3aed; }
.atelier-tag--cyan   { background: rgba(14,165,233,.1); color: #0369a1; }

/* ── Fonctionnement — colonne cartes ─────────────────────────────── */
.hub-cards-col { display: flex; flex-direction: column; gap: 20px; }
.card-pad      { padding: 28px; }
.hub-card-title { margin-bottom: 16px; color: var(--noir); }
.hub-checklist {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: .84rem;
  color: var(--gris-4);
}
.hub-badges-wrap { display: flex; flex-wrap: wrap; gap: 8px; }

/* ── Timeline couleurs ───────────────────────────────────────────── */
.hub-timeline-wrap { max-width: 700px; margin: 0 auto; }
.timeline-dot--vert   { background: var(--vert);  color: #fff; }
.timeline-dot--or     { background: var(--or);    color: #111; }
.timeline-dot--rouge  { background: var(--rouge); color: #fff; }
.timeline-dot--violet { background: #7c3aed;      color: #fff; }
.timeline-dot--gris   { background: var(--noir);  color: #fff; opacity: .5; }
.timeline-year--vert   { color: var(--vert); }
.timeline-year--or     { color: var(--or); }
.timeline-year--rouge  { color: var(--rouge); }
.timeline-year--violet { color: #7c3aed; }
.timeline-year--gris   { color: var(--gris-3); }
.timeline-item--future { opacity: .7; }

/* ── Témoignages — avatar vert ───────────────────────────────────── */
.testi-avatar--vert { background: linear-gradient(135deg, var(--vert), #065f46); }

/* ── Prochaine session / CTA ─────────────────────────────────────── */
.hub-cta-wrap   { max-width: 860px; margin: 0 auto; }
.hub-cta-card   { padding: 40px; border: 2px solid rgba(34,163,95,.2); }
.hub-cta-grid   { align-items: center; }
.hub-cta-title  { margin-top: 8px; }
.hub-cta-infos  { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.hub-cta-info-item { color: var(--gris-4); }
.hub-eyebrow-vert { background: rgba(34,163,95,.08); border-color: rgba(34,163,95,.2); color: var(--vert); }
.hub-live-dot--vert { background: var(--vert); }
.hub-cta-visual       { text-align: center; }
.hub-cta-emoji        { font-size: 5rem; margin-bottom: 16px; }
.hub-cta-visual-title { font-size: 1.1rem; color: var(--vert); margin-bottom: 8px; font-family: var(--font-h); font-weight: 700; }
.cta-sec-label { color: rgba(255,255,255,.5); }

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .hub-hero        { padding: 56px 0 40px; }
  .hub-hero-cards  { align-items: stretch; }
  .hub-info-card   { max-width: 100%; }
  .hub-cta-card    { padding: 24px; }
  .hub-cta-visual  { display: none; }
}

/* ════════════════════════════════════════════════════════════════════
   FORMATION ENFANTS — Classes de base manquantes
   Ajouter dans edify.css (à la suite du bloc précédent)
   ════════════════════════════════════════════════════════════════════ */

/* ── Hero stat row ───────────────────────────────────────────────── */
.hub-stat-row {
  display: flex;
  gap: 24px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.hub-stat-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hub-stat-num {
  font-family: var(--font-h);
  font-size: 1.6rem;
  font-weight: 800;
  color: #6ee7b7;
  line-height: 1;
}
.hub-stat-lbl {
  font-size: .72rem;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-family: var(--font-h);
}

/* ── Hub badge (eyebrow hero) ────────────────────────────────────── */
.hub-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(34,163,95,.15);
  border: 1px solid rgba(34,163,95,.3);
  border-radius: 100px;
  padding: 5px 14px;
  font-size: .78rem;
  font-family: var(--font-h);
  font-weight: 600;
  color: #6ee7b7;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 18px;
}
.hub-live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #6ee7b7;
  display: inline-block;
  animation: pulse-dot 1.8s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .5; transform: scale(.7); }
}

/* ── Gallery grid ────────────────────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 12px;
}
.gallery-item {
  position: relative;
  border-radius: var(--r, 10px);
  overflow: hidden;
}
.gallery-item--large { grid-row: span 1; }

.gallery-ph {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--gris-2, #e5e7eb);
  border-radius: var(--r, 10px);
  font-size: .82rem;
  color: var(--gris-4, #6b7280);
  text-align: center;
  padding: 16px;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.gallery-ph.green-tint { background: rgba(34,163,95,.08); }
.gallery-icon { font-size: 1.6rem; flex-shrink: 0; }
.gallery-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: .72rem;
  padding: 6px 10px;
}

@media (max-width: 640px) {
  .gallery-grid { grid-template-columns: 1fr; }
}

/* ── Process steps ───────────────────────────────────────────────── */
.process-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.process-step {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding-bottom: 28px;
  position: relative;
}
/* Ligne verticale entre les étapes */
.process-step:not(:last-child)::before {
  content: "";
  position: absolute;
  left: 19px;
  top: 40px;
  bottom: 0;
  width: 2px;
  background: var(--border, rgba(0,0,0,.1));
}
.ps-num {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 50%;
  background: var(--rouge, #c1272d);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-h);
  font-weight: 800;
  font-size: 1rem;
  flex-shrink: 0;
}
.ps-text { padding-top: 8px; }
.ps-text h4 {
  font-family: var(--font-h);
  font-size: .95rem;
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--noir, #111);
}
.ps-text p {
  font-size: .85rem;
  color: var(--gris-4, #6b7280);
  line-height: 1.6;
  margin: 0;
}

/* ── Timeline ────────────────────────────────────────────────────── */
.timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}
/* Ligne verticale centrale */
.timeline::before {
  content: "";
  position: absolute;
  left: 19px;
  top: 20px;
  bottom: 20px;
  width: 2px;
  background: var(--border, rgba(0,0,0,.08));
}
.timeline-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding-bottom: 32px;
  position: relative;
}
.timeline-dot {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-h);
  font-size: .78rem;
  font-weight: 800;
  flex-shrink: 0;
  z-index: 1;
  position: relative;
}
.timeline-content { padding-top: 8px; flex: 1; }
.timeline-year {
  font-size: .78rem;
  font-family: var(--font-h);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}
.timeline-title {
  font-weight: 700;
  font-size: .95rem;
  color: var(--noir, #111);
  margin-bottom: 6px;
}
.timeline-desc {
  font-size: .84rem;
  color: var(--gris-4, #6b7280);
  line-height: 1.65;
  margin: 0;
}

/* ── Atelier card (si pas dans edify.css) ────────────────────────── */
.atelier-card {
  background: var(--blanc, #fff);
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: var(--rlg, 12px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.atelier-top {
  padding: 24px;
  font-size: 2rem;
  text-align: center;
}
.atelier-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.atelier-title {
  font-family: var(--font-h);
  font-weight: 700;
  font-size: .95rem;
  color: var(--noir, #111);
  margin-bottom: 8px;
}
.atelier-desc {
  font-size: .84rem;
  color: var(--gris-4, #6b7280);
  line-height: 1.6;
  flex: 1;
  margin: 0;
}
.atelier-tag {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: .74rem;
  font-weight: 600;
  font-family: var(--font-h);
}

/* ── Responsive général ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .hub-stat-row  { gap: 16px; }
  .hub-stat-num  { font-size: 1.3rem; }
  .hub-hero-cards { display: none; } /* masquer les cartes visuelles sur mobile */
}

.pay-result-wrap {
    display: flex; flex-direction: column; align-items: center;
    justify-content: center; min-height: 60vh; gap: 1.2rem;
    text-align: center; padding: 2rem;
  }
  .pay-icon { font-size: 4rem; }
  .pay-title { font-size: 1.6rem; font-weight: 700; color: #111827; margin: 0; }
  .pay-sub { color: #6b7280; max-width: 440px; line-height: 1.7; }
  .btns { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }
  .btn-retry { padding: .7rem 1.8rem; background: #dc2626; color: #fff; border: none; border-radius: 8px; font-size: 1rem; font-weight: 600; cursor: pointer; text-decoration: none; }
  .btn-home  { padding: .7rem 1.8rem; background: #f3f4f6; color: #374151; border: none; border-radius: 8px; font-size: 1rem; font-weight: 600; cursor: pointer; text-decoration: none; }

/* ================================================================
   EDIFY — Extension : Identité africaine + nouvelles pages
   Motifs kente/bogolan · Silhouettes continent · SEKOO · Écoles
   ================================================================ */

/* ── MOTIFS AFRICAINS — Variables & utilitaires ──────────────────── */
:root {
  --kente-1: #C1272D;
  --kente-2: #1a1a1a;
  --kente-3: #E8950A;
  --africa-accent: rgba(193,39,45,.07);
}

/* Motif kente géométrique en SVG inline via background */
.afri-kente-bg {
  position: relative;
  overflow: hidden;
}
.afri-kente-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(
      90deg,
      transparent 0px, transparent 18px,
      rgba(193,39,45,.06) 18px, rgba(193,39,45,.06) 20px
    ),
    repeating-linear-gradient(
      0deg,
      transparent 0px, transparent 18px,
      rgba(193,39,45,.06) 18px, rgba(193,39,45,.06) 20px
    ),
    repeating-linear-gradient(
      45deg,
      transparent 0px, transparent 8px,
      rgba(232,149,10,.04) 8px, rgba(232,149,10,.04) 10px
    );
  z-index: 0;
}
.afri-kente-bg > * { position: relative; z-index: 1; }

/* Bordure kente décorative (bande colorée en haut de section) */
.afri-kente-border {
  border-top: 4px solid transparent;
  border-image: repeating-linear-gradient(
    90deg,
    var(--rouge) 0px 20px,
    var(--noir) 20px 40px,
    var(--or) 40px 60px,
    var(--noir) 60px 80px
  ) 4;
}

/* Diagonale bogolan — fond de section */
.afri-bogolan-bg {
  position: relative;
  overflow: hidden;
}
.afri-bogolan-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 30 L30 0 L60 30 L30 60 Z' fill='none' stroke='rgba(193,39,45,0.04)' stroke-width='1'/%3E%3Crect x='25' y='25' width='10' height='10' fill='rgba(232,149,10,0.05)' transform='rotate(45 30 30)'/%3E%3C/svg%3E");
  background-size: 60px 60px;
  z-index: 0;
}
.afri-bogolan-bg > * { position: relative; z-index: 1; }

/* Silhouette continent africain — décoration SVG */
.afri-continent-deco {
  position: absolute;
  right: -40px;
  bottom: -20px;
  width: 320px;
  height: 380px;
  opacity: .04;
  pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M60 5 C40 5 20 15 15 35 C10 55 20 70 15 90 C10 110 5 125 8 145 C11 165 5 180 10 200 C15 218 30 230 50 235 C70 240 90 230 100 215 C110 200 108 185 115 170 C122 155 140 148 148 132 C156 116 150 95 155 78 C160 61 175 50 175 33 C175 16 160 5 145 8 C130 11 120 25 105 22 C90 19 80 5 60 5 Z' fill='%23C1272D'/%3E%3C/svg%3E") no-repeat center/contain;
}

/* Badge SEKOO */
.sekoo-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--noir);
  color: var(--or);
  font-family: var(--font-h);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 3px 10px 3px 8px;
  border-radius: 4px;
  border: 1px solid var(--or);
}
.sekoo-badge::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--or);
}

/* ── NOUVELLES PAGES — styles partagés ───────────────────────────── */

/* Hero pages internes — version africaine */
.afri-hero {
  padding: 120px 0 72px;
  background: var(--noir);
  position: relative;
  overflow: hidden;
}
.afri-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 55% at 80% 40%, rgba(193,39,45,.18) 0%, transparent 65%),
    radial-gradient(ellipse 35% 45% at 10% 80%, rgba(232,149,10,.1) 0%, transparent 60%);
  pointer-events: none;
}
.afri-hero-kente {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: repeating-linear-gradient(
    90deg,
    var(--rouge) 0 20px,
    var(--noir) 20px 40px,
    var(--or) 40px 60px,
    var(--noir) 60px 80px
  );
}
.afri-hero .container { position: relative; z-index: 1; }
.afri-hero h1 {
  color: #fff;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 18px;
}
.afri-hero h1 em { color: var(--rouge); font-style: normal; }
.afri-hero h1 strong { color: var(--or); font-weight: 800; }
.afri-hero p { color: rgba(255,255,255,.75); font-size: 1.05rem; line-height: 1.7; max-width: 580px; margin-bottom: 28px; }

/* Eyebrow africain */
.afri-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(193,39,45,.12);
  border: 1px solid rgba(193,39,45,.3);
  border-radius: 50px;
  padding: 5px 14px;
  font-size: .75rem;
  font-weight: 700;
  color: #ff8080;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 20px;
}

/* Pillar cards — niveau scolaire */
.school-pillar {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  overflow: hidden;
  transition: var(--tr);
}
.school-pillar:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-lg);
  border-color: rgba(193,39,45,.2);
}
.school-pillar-top {
  padding: 28px 24px 20px;
  background: var(--noir);
  position: relative;
  overflow: hidden;
}
.school-pillar-top::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    45deg,
    transparent 0, transparent 12px,
    rgba(255,255,255,.03) 12px, rgba(255,255,255,.03) 14px
  );
}
.school-pillar-badge {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 12px;
  position: relative; z-index: 1;
}
.school-pillar-badge.primaire { background: rgba(34,163,95,.2); color: #4ade80; border: 1px solid rgba(34,163,95,.3); }
.school-pillar-badge.lycee    { background: rgba(232,149,10,.2); color: #fbbf24; border: 1px solid rgba(232,149,10,.3); }
.school-pillar-badge.superieur{ background: rgba(193,39,45,.2);  color: #f87171; border: 1px solid rgba(193,39,45,.3); }
.school-pillar-icon {
  font-size: 2.4rem;
  margin-bottom: 10px;
  display: block;
  position: relative; z-index: 1;
}
.school-pillar-title {
  font-family: var(--font-h);
  font-size: 1.15rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 6px;
  position: relative; z-index: 1;
}
.school-pillar-sub {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  line-height: 1.5;
  position: relative; z-index: 1;
}
.school-pillar-body {
  padding: 24px;
}
.school-pillar-feats {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.school-pillar-feats li {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  font-size: .85rem;
  color: var(--noir-2);
  line-height: 1.5;
}
.school-pillar-feats li i { color: var(--rouge); margin-top: 2px; flex-shrink: 0; }

/* Grid 3 colonnes écoles */
.school-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
@media (max-width: 900px) { .school-grid { grid-template-columns: 1fr; } }

/* Process band */
.process-band {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: var(--noir);
  border-radius: var(--rlg);
  overflow: hidden;
  margin-top: 48px;
}
.process-band-step {
  flex: 1;
  padding: 28px 24px;
  border-right: 1px solid rgba(255,255,255,.08);
  position: relative;
}
.process-band-step:last-child { border-right: none; }
.process-band-step::after {
  content: '→';
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--rouge);
  font-size: 1.2rem;
  z-index: 2;
}
.process-band-step:last-child::after { display: none; }
.pb-num {
  font-family: var(--font-h);
  font-size: 2rem;
  font-weight: 800;
  color: var(--rouge);
  opacity: .4;
  line-height: 1;
  margin-bottom: 8px;
}
.pb-title { font-family: var(--font-h); font-size: .9rem; font-weight: 700; color: #fff; margin-bottom: 6px; }
.pb-desc  { font-size: .78rem; color: rgba(255,255,255,.5); line-height: 1.55; }
@media (max-width: 768px) {
  .process-band { flex-direction: column; }
  .process-band-step { border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }
  .process-band-step::after { content: '↓'; right: auto; left: 50%; top: auto; bottom: -16px; transform: translateX(-50%); }
}

/* Reconversion — cards parcours */
.parcours-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 700px) { .parcours-grid { grid-template-columns: 1fr; } }
.parcours-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  padding: 24px;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
}
.parcours-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--rouge);
}
.parcours-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md);
  border-color: rgba(193,39,45,.2);
}
.parcours-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.parcours-ico {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: var(--rouge-pale);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.parcours-title { font-family: var(--font-h); font-size: 1rem; font-weight: 700; color: var(--noir); }
.parcours-duration { font-size: .75rem; color: var(--gris-4); margin-top: 2px; }
.parcours-desc { font-size: .83rem; color: var(--gris-4); line-height: 1.6; margin-bottom: 14px; }
.parcours-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.parcours-tag {
  font-size: .72rem;
  padding: 3px 9px;
  border-radius: 4px;
  background: var(--gris-0);
  border: 1px solid var(--border);
  color: var(--gris-4);
}

/* Entreprises — refonte */
.ent-impact-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
@media (max-width: 900px) { .ent-impact-grid { grid-template-columns: repeat(2,1fr); } }
.ent-impact-card {
  background: var(--noir);
  border-radius: var(--r);
  padding: 24px 20px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ent-impact-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--rouge);
}
.ent-impact-num {
  font-family: var(--font-h);
  font-size: 2rem;
  font-weight: 800;
  color: var(--or);
  display: block;
  margin-bottom: 4px;
}
.ent-impact-lbl { font-size: .8rem; color: rgba(255,255,255,.6); }

/* Offre certification inline box */
.cert-box {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: var(--gris-0);
  border: 1px solid var(--border);
  border-radius: var(--r);
  transition: var(--tr);
}
.cert-box:hover { border-color: var(--rouge); background: var(--rouge-pale); }
.cert-box-logo { width: 44px; height: 44px; object-fit: contain; flex-shrink: 0; }
.cert-box-name { font-family: var(--font-h); font-size: .88rem; font-weight: 700; color: var(--noir); }
.cert-box-label { font-size: .76rem; color: var(--gris-4); }
.cert-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; margin-top: 24px; }
@media (max-width: 600px) { .cert-grid { grid-template-columns: 1fr; } }

/* Quote africaine */
.afri-quote {
  background: var(--noir);
  border-radius: var(--rlg);
  padding: 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.afri-quote::before {
  content: '"';
  position: absolute;
  top: -20px; left: 24px;
  font-size: 14rem;
  font-family: Georgia, serif;
  color: var(--rouge);
  opacity: .08;
  line-height: 1;
  pointer-events: none;
}
.afri-quote-text {
  font-family: var(--font-h);
  font-size: clamp(1.2rem, 2.5vw, 1.7rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
  max-width: 700px;
  margin: 0 auto 16px;
  position: relative; z-index: 1;
}
.afri-quote-text em { color: var(--or); font-style: normal; }
.afri-quote-sig {
  font-size: .85rem;
  color: rgba(255,255,255,.5);
  font-style: italic;
  position: relative; z-index: 1;
}

/* Signature SEKOO dans footer */
.ft-sekoo-block {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(232,149,10,.08);
  border: 1px solid rgba(232,149,10,.15);
  border-radius: var(--r);
  margin-top: 14px;
  text-decoration: none;
  transition: var(--tr);
}
.ft-sekoo-block:hover {
  background: rgba(232,149,10,.14);
  border-color: rgba(232,149,10,.3);
}
.ft-sekoo-name {
  font-family: var(--font-h);
  font-size: .95rem;
  font-weight: 800;
  color: var(--or);
  letter-spacing: .04em;
}
.ft-sekoo-sub { font-size: .72rem; color: rgba(255,255,255,.5); margin-top: 1px; }

/* Kente divider */
.kente-divider {
  height: 6px;
  background: repeating-linear-gradient(
    90deg,
    var(--rouge) 0 16px,
    var(--noir) 16px 32px,
    var(--or) 32px 48px,
    var(--noir) 48px 64px,
    #fff 64px 80px,
    var(--noir) 80px 96px
  );
  margin: 0;
  border: none;
  width: 100%;
}

/* Vision panafricaine — band stat */
.pan-africa-band {
  background: var(--noir);
  padding: 48px 0;
  position: relative;
  overflow: hidden;
}
.pan-africa-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    transparent 0, transparent 59px,
    rgba(193,39,45,.07) 59px, rgba(193,39,45,.07) 60px
  ),
  repeating-linear-gradient(
    0deg,
    transparent 0, transparent 59px,
    rgba(193,39,45,.07) 59px, rgba(193,39,45,.07) 60px
  );
  pointer-events: none;
}
.pan-africa-band .container { position: relative; z-index: 1; }
.pab-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  text-align: center;
}
@media (max-width: 768px) { .pab-grid { grid-template-columns: repeat(2,1fr); } }
.pab-item { padding: 12px 0; }
.pab-num {
  font-family: var(--font-h);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--or);
  display: block;
  line-height: 1;
  margin-bottom: 6px;
}
.pab-lbl { font-size: .8rem; color: rgba(255,255,255,.55); }
.pab-sep { width: 1px; background: rgba(255,255,255,.1); }

/* CTA africain rouge fort */
.afri-cta {
  background: var(--rouge);
  padding: 72px 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.afri-cta::before {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    45deg,
    transparent, transparent 30px,
    rgba(0,0,0,.04) 30px, rgba(0,0,0,.04) 31px
  );
  pointer-events: none;
}
.afri-cta .container { position: relative; z-index: 1; }
.afri-cta h2 { color: #fff; font-size: clamp(1.6rem,3vw,2.4rem); font-weight: 800; margin-bottom: 12px; }
.afri-cta p { color: rgba(255,255,255,.8); font-size: 1rem; max-width: 520px; margin: 0 auto 28px; line-height: 1.7; }
.btn-blanc {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  background: #fff;
  color: var(--rouge);
  font-family: var(--font-h);
  font-weight: 700;
  font-size: .9rem;
  border-radius: var(--r);
  transition: var(--tr);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.btn-blanc:hover { background: #f0f0f0; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.2); }
.btn-blanc-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255,255,255,.5);
  font-family: var(--font-h);
  font-weight: 600;
  font-size: .9rem;
  border-radius: var(--r);
  transition: var(--tr);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.btn-blanc-outline:hover { border-color: #fff; background: rgba(255,255,255,.1); }

/* Alumni flags row */
.alumni-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
}
.alumni-flag-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--gris-4);
  padding: 4px 10px;
  background: var(--gris-0);
  border: 1px solid var(--border);
  border-radius: 50px;
}

/* Responsive helpers */
@media (max-width: 768px) {
  .afri-hero { padding: 96px 0 56px; }
  .afri-quote { padding: 32px 24px; }
  .school-grid { grid-template-columns: 1fr; }
  .cert-grid { grid-template-columns: 1fr; }
}


/* ================================================================
   EDIFY — Extension Hub Africain · Motifs · Nouvelles pages
   Ajout : motifs kente/bogolan + silhouettes + SEKOO + pages écoles
   ================================================================ */

/* ── MOTIFS AFRICAINS ─────────────────────────────────────────── */

/* Pattern kente géométrique en background SVG inline */
.afrik-kente-bg {
  position: relative;
  overflow: hidden;
}
.afrik-kente-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .045;
  background-image:
    repeating-linear-gradient(
      45deg,
      var(--rouge) 0px, var(--rouge) 2px,
      transparent 2px, transparent 14px
    ),
    repeating-linear-gradient(
      -45deg,
      var(--noir) 0px, var(--noir) 2px,
      transparent 2px, transparent 14px
    );
  background-size: 28px 28px;
}

/* Bande bogolan horizontale (trait de séparation décoratif) */
.afrik-band {
  height: 6px;
  background: repeating-linear-gradient(
    90deg,
    var(--rouge) 0px, var(--rouge) 12px,
    var(--noir)  12px, var(--noir)  18px,
    var(--or)    18px, var(--or)    24px,
    var(--noir)  24px, var(--noir)  30px
  );
  width: 100%;
}

/* Coin décoratif kente (pseudo-element sur cartes) */
.afrik-corner {
  position: relative;
}
.afrik-corner::after {
  content: '';
  position: absolute;
  bottom: 0; right: 0;
  width: 48px; height: 48px;
  background:
    linear-gradient(135deg, transparent 50%, rgba(193,39,45,.12) 50%);
  border-radius: 0 0 var(--rlg) 0;
  pointer-events: none;
}

/* Silhouette continent africain (clip-path décoratif) */
.afrik-silhouette-wrap {
  position: relative;
}
.afrik-silhouette-wrap .afrik-svg-bg {
  position: absolute;
  right: -40px; top: 50%;
  transform: translateY(-50%);
  opacity: .04;
  pointer-events: none;
  width: 320px;
  height: auto;
}

/* Losange décoratif bogolan */
.afrik-diamond {
  display: inline-block;
  width: 10px; height: 10px;
  background: var(--rouge);
  transform: rotate(45deg);
  margin: 0 6px;
  flex-shrink: 0;
}
.afrik-diamond.or { background: var(--or); }
.afrik-diamond.sm { width: 7px; height: 7px; }

/* Trait bogolan sous titre de section */
.afrik-underline {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 10px;
  margin-bottom: 20px;
  width: 80px;
}
.afrik-underline span:nth-child(1) { flex: 3; height: 3px; background: var(--rouge); }
.afrik-underline span:nth-child(2) { width: 8px; height: 8px; background: var(--or); transform: rotate(45deg); margin: 0 4px; flex-shrink: 0; }
.afrik-underline span:nth-child(3) { flex: 1; height: 3px; background: var(--noir); }

/* Encadré citation style kente */
.afrik-quote {
  border-left: 4px solid var(--rouge);
  background: linear-gradient(90deg, rgba(193,39,45,.04) 0%, transparent 100%);
  padding: 20px 24px;
  border-radius: 0 var(--r) var(--r) 0;
  position: relative;
}
.afrik-quote::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: repeating-linear-gradient(
    180deg,
    var(--rouge) 0px, var(--rouge) 8px,
    var(--or) 8px, var(--or) 12px,
    var(--rouge) 12px, var(--rouge) 20px
  );
}

/* ── HERO AFRICAIN (refonte hero accueil) ─────────────────────── */
.hero-afrik {
  position: relative;
  background: var(--noir);
  padding: 110px 0 80px;
  overflow: hidden;
  min-height: 92vh;
  display: flex;
  align-items: center;
}
.hero-afrik::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 80% 50%, rgba(193,39,45,.18) 0%, transparent 65%),
    radial-gradient(ellipse 40% 40% at 10% 80%, rgba(232,149,10,.10) 0%, transparent 60%);
  pointer-events: none;
}
/* Motif kente en overlay discret */
.hero-afrik::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .03;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 16px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 16px);
  background-size: 32px 32px;
}

.hero-afrik .hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}

.hero-afrik .hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(232,149,10,.12);
  border: 1px solid rgba(232,149,10,.3);
  border-radius: 50px;
  padding: 6px 16px;
  margin-bottom: 22px;
}
.hero-afrik .eyebrow-txt {
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--or);
}
.hero-afrik .eyebrow-dot {
  width: 7px; height: 7px;
  background: var(--or);
  border-radius: 50%;
  animation: pulse-or 2s infinite;
}
@keyframes pulse-or {
  0%,100% { box-shadow: 0 0 0 0 rgba(232,149,10,.5); }
  50% { box-shadow: 0 0 0 6px rgba(232,149,10,0); }
}

.hero-afrik .hero-title {
  font-family: var(--font-h);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.08;
  margin-bottom: 20px;
}
.hero-afrik .hero-title .accent {
  color: var(--rouge);
  position: relative;
}
.hero-afrik .hero-title .accent-or { color: var(--or); }

.hero-afrik .hero-sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.72);
  line-height: 1.75;
  max-width: 500px;
  margin-bottom: 32px;
}
.hero-afrik .hero-btns { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 36px; }
.hero-afrik .hero-stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.hero-afrik .hstat-n {
  font-family: var(--font-h);
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--or);
  line-height: 1;
}
.hero-afrik .hstat-l {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  margin-top: 3px;
}

/* Bande kente verticale côté visuel hero */
.hero-afrik-kente-bar {
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 6px;
  background: repeating-linear-gradient(
    180deg,
    var(--rouge) 0px, var(--rouge) 20px,
    var(--or)    20px, var(--or)    28px,
    var(--noir)  28px, var(--noir)  34px,
    var(--or)    34px, var(--or)    42px
  );
  z-index: 10;
}

/* ── BADGES THÈME AFRIK ───────────────────────────────────────── */
.badge-afrik {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(193,39,45,.08);
  border: 1px solid rgba(193,39,45,.18);
  color: var(--rouge);
  padding: 4px 12px;
  border-radius: 50px;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.badge-afrik.or {
  background: rgba(232,149,10,.1);
  border-color: rgba(232,149,10,.25);
  color: #9a6200;
}
.badge-afrik.noir {
  background: rgba(26,26,26,.07);
  border-color: rgba(26,26,26,.18);
  color: var(--noir);
}

/* ── SECTION SEKOO ────────────────────────────────────────────── */
.sekoo-band {
  background: var(--noir);
  padding: 20px 0;
  position: relative;
  overflow: hidden;
}
.sekoo-band::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: .04;
  background-image:
    repeating-linear-gradient(90deg, #fff 0, #fff 1px, transparent 1px, transparent 24px);
}
.sekoo-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.sekoo-logo-txt {
  font-family: var(--font-h);
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: .08em;
  color: #fff;
}
.sekoo-logo-txt .s { color: var(--rouge); }
.sekoo-logo-txt .k { color: var(--or); }
.sekoo-sub {
  font-size: .8rem;
  color: rgba(255,255,255,.5);
  margin-left: 10px;
  font-family: var(--font-b);
}
.sekoo-cta {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--rouge);
  color: #fff;
  padding: 8px 20px;
  border-radius: var(--r);
  font-size: .82rem;
  font-weight: 600;
  transition: var(--tr);
}
.sekoo-cta:hover { background: var(--rouge-2); transform: translateY(-1px); }

/* ── PAGE ÉCOLES ──────────────────────────────────────────────── */
.ecoles-hero {
  background: var(--noir);
  padding: 110px 0 80px;
  position: relative;
  overflow: hidden;
}
.ecoles-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 70% at 80% 50%, rgba(193,39,45,.16) 0%, transparent 65%),
    radial-gradient(ellipse 30% 40% at 0% 100%, rgba(232,149,10,.1) 0%, transparent 60%);
  pointer-events: none;
}
.ecoles-hero::after {
  content: '';
  position: absolute; inset: 0;
  opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px);
  background-size: 40px 40px;
  pointer-events: none;
}

.ecoles-hero-inner { max-width: 680px; position: relative; z-index: 2; }
.ecoles-hero h1 {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 18px;
}
.ecoles-hero h1 em { color: var(--rouge); font-style: normal; }
.ecoles-hero h1 .or { color: var(--or); }
.ecoles-hero p { font-size: 1.05rem; color: rgba(255,255,255,.7); line-height: 1.75; max-width: 560px; margin-bottom: 28px; }

/* Grille des 3 offres scolaires */
.ecoles-offers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
@media (max-width: 960px) { .ecoles-offers-grid { grid-template-columns: 1fr; } }

.ecole-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  overflow: hidden;
  transition: var(--tr);
  display: flex;
  flex-direction: column;
  position: relative;
}
.ecole-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh-lg);
  border-color: rgba(193,39,45,.25);
}
.ecole-card-top {
  padding: 28px 24px 20px;
  position: relative;
}
.ecole-card-top::after {
  content: '';
  position: absolute;
  bottom: 0; left: 24px; right: 24px;
  height: 1px;
  background: repeating-linear-gradient(
    90deg,
    var(--rouge) 0px, var(--rouge) 6px,
    transparent 6px, transparent 10px
  );
}
.ecole-level-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .72rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 14px;
}
.ecole-level-tag.primaire { background: rgba(34,163,95,.1); color: #166534; border: 1px solid rgba(34,163,95,.25); }
.ecole-level-tag.secondaire { background: rgba(37,99,235,.08); color: #1d4ed8; border: 1px solid rgba(37,99,235,.2); }
.ecole-level-tag.superieur { background: rgba(193,39,45,.08); color: var(--rouge); border: 1px solid rgba(193,39,45,.2); }

.ecole-card-icon {
  font-size: 2.6rem;
  margin-bottom: 12px;
}
.ecole-card h3 {
  font-family: var(--font-h);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--noir);
  margin-bottom: 8px;
}
.ecole-card-sub {
  font-size: .85rem;
  color: var(--gris-4);
  line-height: 1.6;
}
.ecole-card-body {
  padding: 20px 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.ecole-feat-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 20px;
  flex: 1;
}
.ecole-feat-list li {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  font-size: .84rem;
  color: var(--noir-2);
  line-height: 1.5;
}
.ecole-feat-list li i { color: var(--rouge); margin-top: 2px; flex-shrink: 0; font-size: .8rem; }

.ecole-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  background: var(--rouge);
  color: #fff;
  border-radius: var(--r);
  font-weight: 600;
  font-size: .88rem;
  transition: var(--tr);
  margin-top: auto;
}
.ecole-cta:hover { background: var(--rouge-2); transform: translateY(-1px); }
.ecole-cta.outline {
  background: transparent;
  border: 1.5px solid var(--rouge);
  color: var(--rouge);
}
.ecole-cta.outline:hover { background: var(--rouge); color: #fff; }

/* Bloc "pourquoi intégrer le numérique" */
.ecoles-why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 960px) { .ecoles-why-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ecoles-why-grid { grid-template-columns: 1fr; } }

.ecoles-why-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  padding: 24px 20px;
  text-align: center;
  transition: var(--tr);
}
.ecoles-why-card:hover { border-color: rgba(193,39,45,.2); box-shadow: var(--sh-md); }
.ecoles-why-icon {
  font-size: 2rem;
  margin-bottom: 12px;
}
.ecoles-why-title {
  font-family: var(--font-h);
  font-size: .95rem;
  font-weight: 700;
  color: var(--noir);
  margin-bottom: 8px;
}
.ecoles-why-desc {
  font-size: .82rem;
  color: var(--gris-4);
  line-height: 1.6;
}

/* Processus de partenariat */
.ecoles-process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 44px;
  position: relative;
}
.ecoles-process::before {
  content: '';
  position: absolute;
  top: 28px; left: 12.5%; right: 12.5%;
  height: 2px;
  background: repeating-linear-gradient(
    90deg,
    var(--rouge) 0px, var(--rouge) 12px,
    rgba(193,39,45,.15) 12px, rgba(193,39,45,.15) 20px
  );
  z-index: 0;
}
@media (max-width: 760px) {
  .ecoles-process { grid-template-columns: 1fr 1fr; }
  .ecoles-process::before { display: none; }
}
.ecole-step {
  text-align: center;
  padding: 0 12px;
  position: relative;
  z-index: 1;
}
.ecole-step-num {
  width: 56px; height: 56px;
  background: var(--rouge);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-h);
  font-size: 1.2rem;
  font-weight: 800;
  margin: 0 auto 16px;
  border: 3px solid #fff;
  box-shadow: var(--sh-md);
}
.ecole-step-title {
  font-family: var(--font-h);
  font-size: .9rem;
  font-weight: 700;
  color: var(--noir);
  margin-bottom: 6px;
}
.ecole-step-desc {
  font-size: .8rem;
  color: var(--gris-4);
  line-height: 1.5;
}

/* Formats d'intervention (tableau comparatif) */
.ecoles-formats-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 32px;
  border-radius: var(--rlg);
  overflow: hidden;
  box-shadow: var(--sh);
}
.ecoles-formats-table th {
  background: var(--noir);
  color: #fff;
  padding: 14px 18px;
  text-align: left;
  font-family: var(--font-h);
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: .04em;
}
.ecoles-formats-table th:first-child { border-radius: var(--rlg) 0 0 0; }
.ecoles-formats-table th:last-child  { border-radius: 0 var(--rlg) 0 0; }
.ecoles-formats-table td {
  padding: 12px 18px;
  font-size: .85rem;
  color: var(--noir-2);
  border-bottom: 1px solid var(--border);
  background: #fff;
  vertical-align: middle;
}
.ecoles-formats-table tr:last-child td { border-bottom: none; }
.ecoles-formats-table tr:nth-child(even) td { background: var(--gris-0); }
.ecoles-formats-table .check { color: var(--vert); font-size: .9rem; }
.ecoles-formats-table .cross { color: var(--gris-3); font-size: .9rem; }

/* ── PAGE RECONVERSION ────────────────────────────────────────── */
.reconv-hero {
  background: linear-gradient(135deg, var(--noir) 0%, #2a1a1a 100%);
  padding: 110px 0 80px;
  position: relative;
  overflow: hidden;
}
.reconv-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 55% 65% at 75% 45%, rgba(232,149,10,.15) 0%, transparent 65%);
  pointer-events: none;
}
.reconv-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px);
  background-size: 36px 36px;
  pointer-events: none;
}

.reconv-hero-inner { max-width: 660px; position: relative; z-index: 2; }
.reconv-hero h1 {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 18px;
}
.reconv-hero h1 em { color: var(--or); font-style: normal; }

/* Timeline parcours reconversion */
.reconv-timeline {
  position: relative;
  padding-left: 40px;
  margin-top: 36px;
}
.reconv-timeline::before {
  content: '';
  position: absolute;
  left: 14px; top: 8px; bottom: 8px;
  width: 2px;
  background: repeating-linear-gradient(
    180deg,
    var(--or) 0px, var(--or) 10px,
    rgba(232,149,10,.2) 10px, rgba(232,149,10,.2) 16px
  );
}
.reconv-step {
  position: relative;
  margin-bottom: 28px;
}
.reconv-step::before {
  content: attr(data-num);
  position: absolute;
  left: -40px; top: 0;
  width: 28px; height: 28px;
  background: var(--or);
  color: var(--noir);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-h);
  font-weight: 800;
  font-size: .82rem;
  border: 2px solid #fff;
  box-shadow: var(--sh);
}
.reconv-step-title {
  font-family: var(--font-h);
  font-weight: 700; font-size: .95rem;
  color: var(--noir); margin-bottom: 4px;
}
.reconv-step-desc {
  font-size: .84rem; color: var(--gris-4); line-height: 1.6;
}

/* Grille domaines reconversion */
.reconv-domains {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 32px;
}
@media (max-width: 640px) { .reconv-domains { grid-template-columns: 1fr; } }

.reconv-domain-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  padding: 20px;
  display: flex; gap: 14px; align-items: flex-start;
  transition: var(--tr);
  text-decoration: none;
  color: inherit;
}
.reconv-domain-card:hover {
  border-color: rgba(193,39,45,.25);
  box-shadow: var(--sh-md);
  transform: translateY(-2px);
}
.reconv-domain-ico {
  width: 44px; height: 44px;
  border-radius: var(--r);
  background: rgba(193,39,45,.07);
  border: 1px solid rgba(193,39,45,.15);
  display: flex; align-items: center; justify-content: center;
  color: var(--rouge); font-size: 1.1rem; flex-shrink: 0;
}
.reconv-domain-name {
  font-family: var(--font-h); font-weight: 700; font-size: .95rem;
  color: var(--noir); margin-bottom: 4px;
}
.reconv-domain-desc { font-size: .82rem; color: var(--gris-4); line-height: 1.5; }

/* Profils types reconversion */
.reconv-profiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 760px) { .reconv-profiles { grid-template-columns: 1fr; } }

.reconv-profile {
  border: 1.5px solid var(--border);
  border-radius: var(--rlg);
  padding: 24px;
  background: var(--gris-0);
  transition: var(--tr);
}
.reconv-profile:hover { border-color: var(--or); background: #fff; }
.reconv-profile-avatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h); font-weight: 800; font-size: 1rem;
  color: #fff;
  margin-bottom: 12px;
}
.reconv-profile-name { font-family: var(--font-h); font-weight: 700; font-size: .95rem; margin-bottom: 2px; }
.reconv-profile-before { font-size: .8rem; color: var(--gris-4); margin-bottom: 10px; }
.reconv-profile-arrow {
  display: flex; align-items: center; gap: 8px;
  font-size: .8rem; color: var(--gris-4); margin-bottom: 4px;
}
.reconv-profile-after { font-size: .88rem; font-weight: 600; color: var(--vert); }

/* ── FORMATION ENTREPRISES (refonte discours) ─────────────────── */
.entreprises-hero {
  background: var(--noir);
  padding: 110px 0 80px;
  position: relative;
  overflow: hidden;
}
.entreprises-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 70% at 80% 50%, rgba(193,39,45,.16) 0%, transparent 65%);
  pointer-events: none;
}
.entreprises-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px);
  background-size: 36px 36px;
  pointer-events: none;
}

/* ── SOLUTIONS HERO (refonte) ─────────────────────────────────── */
.sol-hero {
  background: var(--noir);
  padding: 110px 0 72px;
  position: relative; overflow: hidden;
}
.sol-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 75% 50%, rgba(193,39,45,.15) 0%, transparent 65%),
    radial-gradient(ellipse 35% 45% at 5% 90%, rgba(232,149,10,.1) 0%, transparent 55%);
  pointer-events: none;
}
.sol-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .03;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px);
  background-size: 40px 40px;
  pointer-events: none;
}
.sol-hero-inner { max-width: 700px; position: relative; z-index: 2; }
.sol-hero h1 { font-size: clamp(2rem,4.5vw,3.2rem); font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 18px; }
.sol-hero h1 em { color: var(--rouge); font-style: normal; }
.sol-hero p { font-size: 1.05rem; color: rgba(255,255,255,.7); line-height: 1.75; max-width: 580px; margin-bottom: 30px; }
.sol-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(193,39,45,.12); border: 1px solid rgba(193,39,45,.25);
  border-radius: 50px; padding: 5px 14px;
  font-size: .78rem; font-weight: 700; color: var(--rouge);
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 20px;
}
.sol-pillars { display: flex; flex-wrap: wrap; gap: 10px; }
.sol-pillar {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 14px; background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 50px; font-size: .82rem; color: rgba(255,255,255,.75);
}
.sol-pillar i { color: var(--or); }

/* Section headings Solutions */
.sol-section { padding: 72px 0; }
.sol-section:nth-child(even) { background: var(--gris-0); }
.sec-label { font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--rouge); margin-bottom: 10px; }
.sec-title { font-size: clamp(1.6rem,3vw,2.4rem); font-weight: 700; color: var(--noir); margin-bottom: 14px; }
.sec-sub { font-size: 1rem; color: var(--gris-4); max-width: 560px; line-height: 1.7; }

/* ── SECTION CTA AFRIK ────────────────────────────────────────── */
.cta-afrik {
  background: var(--noir);
  padding: 80px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-afrik::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 80% at 50% 50%, rgba(193,39,45,.12) 0%, transparent 70%);
  pointer-events: none;
}
.cta-afrik::after {
  content: '';
  position: absolute; inset: 0; opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 24px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 24px);
  background-size: 48px 48px;
  pointer-events: none;
}
.cta-afrik h2 { font-size: clamp(1.7rem,3.5vw,2.5rem); font-weight: 800; color: #fff; margin-bottom: 14px; position: relative; z-index: 1; }
.cta-afrik h2 em { color: var(--or); font-style: normal; }
.cta-afrik p { color: rgba(255,255,255,.65); font-size: 1rem; max-width: 540px; margin: 0 auto 32px; line-height: 1.7; position: relative; z-index: 1; }
.cta-afrik .cta-btns { position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

/* ── SE FORMER HERO (refonte) ─────────────────────────────────── */
.se-former-hero {
  background: var(--noir);
  padding: 110px 0 80px;
  position: relative; overflow: hidden;
}
.se-former-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 75% at 80% 50%, rgba(193,39,45,.16) 0%, transparent 65%),
    radial-gradient(ellipse 30% 40% at 5% 85%, rgba(232,149,10,.1) 0%, transparent 55%);
  pointer-events: none;
}
.se-former-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 18px);
  background-size: 36px 36px;
  pointer-events: none;
}

/* ── MISSION HERO (refonte) ───────────────────────────────────── */
.mission-hero {
  background: var(--noir);
  padding: 110px 0 80px;
  position: relative; overflow: hidden;
}
.mission-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 55% 65% at 75% 40%, rgba(193,39,45,.14) 0%, transparent 60%),
    radial-gradient(ellipse 35% 45% at 0% 90%, rgba(232,149,10,.09) 0%, transparent 55%);
  pointer-events: none;
}
.mission-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .025;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px);
  background-size: 40px 40px;
  pointer-events: none;
}
.mission-hero .container { position: relative; z-index: 2; }
.mission-hero h1 { font-size: clamp(2rem,4.5vw,3.2rem); font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 16px; margin-top: 10px; }
.mission-hero h1 .text-or { color: var(--or); }
.mission-hero .section-label { color: var(--or); }
.mission-hero .text-lead { color: rgba(255,255,255,.72); max-width: 600px; }

/* ── COMMUNAUTÉ HERO (refonte) ────────────────────────────────── */
.alumni-hero {
  background: var(--noir);
  padding: 110px 0 80px;
  position: relative; overflow: hidden;
  background-blend-mode: luminosity;
  background-size: cover;
  background-position: center;
}
.alumni-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(26,26,26,.92) 0%, rgba(26,26,26,.75) 100%),
    radial-gradient(ellipse 50% 60% at 80% 50%, rgba(193,39,45,.2) 0%, transparent 65%);
  pointer-events: none;
}
.alumni-hero::after {
  content: '';
  position: absolute; inset: 0; opacity: .03;
  background-image:
    repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px),
    repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 1px, transparent 20px);
  background-size: 40px 40px;
  pointer-events: none;
}
.alumni-hero .container { position: relative; z-index: 2; }
.alumni-hero .section-label { color: var(--or); }
.alumni-hero .heading-lg { color: #fff; font-size: clamp(2rem,4.5vw,3.2rem); font-weight: 800; margin-bottom: 14px; }
.alumni-hero .text-lead { color: rgba(255,255,255,.72); max-width: 580px; }

/* ── FOOTER SEKOO LINK ────────────────────────────────────────── */
.ft-sekoo-link {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(193,39,45,.08);
  border: 1px solid rgba(193,39,45,.18);
  border-radius: var(--r);
  padding: 8px 14px;
  font-size: .82rem;
  color: var(--rouge);
  font-weight: 600;
  transition: var(--tr);
  margin-top: 12px;
}
.ft-sekoo-link:hover { background: var(--rouge); color: #fff; border-color: var(--rouge); }
.ft-sekoo-brand {
  font-family: var(--font-h);
  font-weight: 800;
  letter-spacing: .06em;
}
.ft-sekoo-brand .s { color: var(--rouge); }
.ft-sekoo-brand .k { color: var(--or); }

/* ── RESPONSIVE GÉNÉRAL NOUVELLES PAGES ──────────────────────── */
@media (max-width: 768px) {
  .hero-afrik .hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .hero-afrik .hero-visual { display: none; }
  .se-former-hero .container > div { max-width: 100%; }
  .ecoles-hero-inner, .reconv-hero-inner { max-width: 100%; }
  .ecoles-why-grid { grid-template-columns: 1fr 1fr; }
  .reconv-profiles { grid-template-columns: 1fr; }
}



/* ================================================================
   SEKOO — Refonte palette rouge/noir/blanc · Identité africaine v2
   Surcharge totale de l'or/vert → rouge/noir bichromie stricte
   ================================================================ */

/* ── 1. PALETTE : NEUTRALISATION OR / VERT ─────────────────────── */
:root {
  --or:        #C1272D;   /* redirect or → rouge */
  --or-2:      #9B1B20;
  --or-dark:   #9B1B20;
  --vert:      #2d2d2d;   /* redirect vert → gris foncé */
  --vert-light:#2d2d2d;
  --gris-dark: #2d2d2d;
  --blanc-off: #f8f5f2;   /* blanc légèrement chaud */
}

/* Toutes les classes de couleur or/vert redirigées */
.btn-or           { background:var(--rouge);    color:#fff; border-color:var(--rouge); }
.btn-or:hover     { background:var(--rouge-2);  border-color:var(--rouge-2); box-shadow:0 6px 20px rgba(193,39,45,.3); transform:translateY(-1px); }
.badge-or         { background:rgba(193,39,45,.08); color:var(--rouge); border:1px solid rgba(193,39,45,.18); }
.badge-vert       { background:#f0f0f0; color:#2d2d2d; border:1px solid #d1d5db; }
.icon-or          { color:var(--rouge); }
.icon-vert        { color:#2d2d2d; }
.text-or          { color:var(--rouge); }
.text-or-2        { color:var(--rouge-2); }
.text-vert        { color:#2d2d2d; }
.score-fill-or    { background:var(--rouge); }
.score-fill-vert  { background:#2d2d2d; }
.vp-icon-or       { background:rgba(193,39,45,.08); color:var(--rouge); }
.vp-icon-vert     { background:#f0f0f0; color:#2d2d2d; }
.fc-icon-or       { background:rgba(193,39,45,.08); color:var(--rouge); }
.fc-icon-vert     { background:#2d2d2d; color:#fff; }
.fc-tag-or        { background:rgba(193,39,45,.08); color:var(--rouge); }
.fc-tag-vert      { background:#f0f0f0; color:#2d2d2d; }
.testi-av-or      { background:var(--rouge); }
.testi-av-vert    { background:#2d2d2d; }
.testi-stars      { color:#1a1a1a; }
.accent-card-or   { background:rgba(193,39,45,.04); border:1px solid rgba(193,39,45,.14); border-radius:var(--rlg); padding:32px; }
.eden-arg-ico     { background:rgba(193,39,45,.06); border:1px solid rgba(193,39,45,.15); color:var(--rouge); }
.eden-module i    { color:var(--rouge); }
.btn-eden         { background:var(--rouge); color:#fff; }
.btn-eden:hover   { background:var(--rouge-2); transform:translateY(-2px); }

/* Footer links */
.ft-col ul li a:hover { color:var(--rouge); }
.ft-ci a              { color:var(--rouge); }
.ft-ci a:hover        { color:var(--rouge-2); }
.ft-sekoo-name        { color:var(--rouge); }
.ft-sekoo-block       { background:rgba(193,39,45,.08); border-color:rgba(193,39,45,.15); }
.ft-sekoo-block:hover { background:rgba(193,39,45,.14); border-color:rgba(193,39,45,.3); }

/* Stats band hero */
.stats-band  { background:var(--noir); }
.sb-num      { color:#fff; }
.sb-lbl      { color:rgba(255,255,255,.5); }
.sb-item + .sb-item { border-left-color:rgba(255,255,255,.08); }

/* hero orb — supprimer orbe or */
.hero-orb-2 { background:rgba(193,39,45,.25); }
.hero-orb-3 { background:rgba(193,39,45,.1); }
.hero-stat-num { color:var(--rouge); }

/* Breadcrumb hover */
.breadcrumb a:hover { color:var(--rouge); }

/* Filter buttons réalisations */
.filter-btn.active { background:var(--rouge); border-color:var(--rouge); color:#fff; }

/* Tags blog/catalogue */
.p-cat { background:rgba(193,39,45,.07); color:var(--rouge); border:1px solid rgba(193,39,45,.15); }
.real-hero-eyebrow { background:rgba(193,39,45,.08); border-color:rgba(193,39,45,.18); color:var(--rouge); }
.real-hero h1 em { color:var(--rouge); }

/* Waitlist */
.wait-head i { color:var(--rouge); }
.wait-btn    { background:var(--rouge); color:#fff; }
.wait-btn:hover { background:var(--rouge-2); }
.tel-big     { color:var(--rouge); }

/* Acc card score */
.rec-next-ico { color:var(--rouge); }

/* Code highlight */
.step-text .code-block { color:var(--rouge); }

/* ── 2. NAVBAR SEKOO ────────────────────────────────────────────── */
.sekoo-logo-wrap {
  display:flex; flex-direction:column; line-height:1;
  text-decoration:none;
}
.sekoo-logo-name {
  font-family:var(--font-h);
  font-size:1.5rem;
  font-weight:800;
  letter-spacing:.04em;
  color:var(--noir);
  line-height:1;
}
.sekoo-logo-name span { color:var(--rouge); }
.sekoo-logo-by {
  font-size:.62rem;
  font-weight:500;
  color:var(--gris-3);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-top:1px;
}

/* ── 3. MOTIFS AFRICAINS v2 — SVG géométriques ──────────────────── */

/* Watermark continent — version grande */
.afri-watermark {
  position:absolute;
  right:-60px; top:50%;
  transform:translateY(-50%);
  width:460px; height:520px;
  opacity:.06;
  pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M60 5 C40 5 20 15 15 35 C10 55 20 70 15 90 C10 110 5 125 8 145 C11 165 5 180 10 200 C15 218 30 230 50 235 C70 240 90 230 100 215 C110 200 108 185 115 170 C122 155 140 148 148 132 C156 116 150 95 155 78 C160 61 175 50 175 33 C175 16 160 5 145 8 C130 11 120 25 105 22 C90 19 80 5 60 5 Z' fill='%23C1272D'/%3E%3C/svg%3E") no-repeat center/contain;
}

/* Motif géométrique kente — triangles + losanges */
.afri-geo-deco {
  position:absolute;
  pointer-events:none;
  overflow:hidden;
}
/* Décoration titre section — losanges rouges */
.sec-geo-accent {
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:8px;
}
.sec-geo-accent::before,
.sec-geo-accent::after {
  content:'';
  display:inline-block;
  width:8px; height:8px;
  background:var(--rouge);
  transform:rotate(45deg);
  opacity:.7;
}
.sec-geo-accent-sm::before,
.sec-geo-accent-sm::after { width:5px; height:5px; }

/* Ligne décorative géométrique sous les h2 */
.sec-title-geo {
  position:relative;
  padding-bottom:16px;
  margin-bottom:20px;
}
.sec-title-geo::after {
  content:'';
  position:absolute;
  bottom:0; left:0;
  width:60px; height:3px;
  background:repeating-linear-gradient(
    90deg,
    var(--rouge) 0 10px,
    transparent 10px 14px,
    #2d2d2d 14px 24px,
    transparent 24px 28px
  );
}
.text-center .sec-title-geo::after { left:50%; transform:translateX(-50%); }

/* Kente divider élégant — version fine */
.kente-divider {
  height:4px;
  background:repeating-linear-gradient(
    90deg,
    var(--rouge) 0 24px,
    #1a1a1a 24px 48px,
    #f8f5f2 48px 72px,
    #1a1a1a 72px 96px
  );
  border:none;
  margin:0;
  width:100%;
}

/* Losange décoratif SVG inline dans sections hero */
.afri-diamond-deco {
  position:absolute;
  pointer-events:none;
  opacity:.06;
}

/* ── 4. HERO — Supprimer cadre interrompu, design épuré ─────────── */
.afri-hero {
  background:var(--noir);
  padding:110px 0 64px;
  position:relative;
  overflow:hidden;
}
.afri-hero::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse 50% 60% at 75% 40%, rgba(193,39,45,.2) 0%, transparent 65%),
             radial-gradient(ellipse 30% 40% at 5% 85%, rgba(193,39,45,.07) 0%, transparent 60%);
  pointer-events:none;
}
/* Remplace le kente interrompu par une barre rouge pleine sobre */
.afri-hero-kente {
  position:absolute;
  bottom:0; left:0; right:0;
  height:3px;
  background:var(--rouge);
}
/* Retirer le bg bogolan répété du hero — trop chargé */
.afri-hero.afri-bogolan-bg::after { display:none; }
.afri-hero.afri-kente-bg::before  { display:none; }

/* Hero se-former spécifique */
.se-former-hero {
  background:var(--noir);
  position:relative;
  overflow:hidden;
}
.se-former-hero::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse 55% 70% at 70% 35%, rgba(193,39,45,.18) 0%, transparent 65%);
  pointer-events:none;
}

/* ── 5. STATS BAR DETAIL FORMATION — fix alignement ────────────── */
.stats-bar {
  display:flex;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--rlg);
  margin-bottom:28px;
  overflow:hidden;
  box-shadow:var(--sh);
}
.stat-item {
  flex:1;
  padding:14px 10px;
  border-right:1px solid var(--border);
  text-align:center;
  min-width:0;         /* prevent overflow */
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}
.stat-item:last-child { border-right:none; }
.stat-val {
  font-family:var(--font-h);
  font-size:.95rem;
  font-weight:700;
  color:var(--noir);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  white-space:nowrap;
}
.stat-val-sm { font-size:.8rem; }
.stat-lbl {
  font-size:.62rem;
  color:var(--gris-3);
  text-transform:uppercase;
  letter-spacing:.07em;
  display:block;
  white-space:nowrap;
}
.stat-ico    { color:var(--rouge); font-size:.8rem; }
.stat-dispo-ok   { color:var(--rouge); font-weight:700; }
.stat-dispo-wait { color:#2d2d2d; }
.stat-dispo-off  { color:var(--gris-3); }

/* ── 6. PAY CARD — sticky desktop + barre mobile fixe ──────────── */
.pay-card {
  background:#fff;
  border:1px solid rgba(193,39,45,.15);
  border-radius:var(--rlg);
  overflow:hidden;
  position:sticky;
  top:84px;
  box-shadow:var(--sh-md);
  max-height:calc(100vh - 100px);
  overflow-y:auto;
}

/* Mode tab bootcamp : remplace jaune par gris foncé */
.mode-tab.act-boot { background:rgba(45,45,45,.08); color:#2d2d2d; }
.mode-tab.act-boot:hover { background:rgba(45,45,45,.12); }

/* Price box bootcamp selected : remplace jaune par noir */
.price-box.sel-b  { border-color:#2d2d2d; background:rgba(45,45,45,.05); }
.price-box.sel-b .pb-price { color:#2d2d2d; }
.pbadge           { background:var(--rouge); color:#fff; }

/* Sessions : remplace or par rouge/gris */
.sess-item:hover  { border-color:rgba(193,39,45,.3); }
.sess-item.sel    { border-color:var(--rouge); background:var(--rouge-pale); }
.sess-item input[type=radio] { accent-color:var(--rouge); }
.si-pl.ok         { background:rgba(45,45,45,.1); color:#2d2d2d; }
.si-pl.low        { background:rgba(193,39,45,.1); color:var(--rouge); }

/* Waitbox : remplace jaune par gris clair */
.waitbox   { background:#f8f5f2; border-color:rgba(0,0,0,.08); }
.waitbox i { color:var(--rouge); }

/* Bootcamp CTA button */
.pay-btn-b {
  background:linear-gradient(135deg,#2d2d2d,#1a1a1a);
  color:#fff !important;
}
.pay-btn-b:hover { box-shadow:0 8px 24px rgba(0,0,0,.3); transform:translateY(-2px); }

/* Outline buttons */
.pay-btn-o:hover { border-color:var(--rouge); color:var(--rouge); }
.pay-btn-g {
  color:#2d2d2d;
  border-color:rgba(45,45,45,.2);
}
.pay-btn-g:hover { background:rgba(45,45,45,.05); border-color:rgba(45,45,45,.4); }

/* Inclus checkmarks */
.pay-inc li i { color:var(--rouge); }

/* pb-price-or → remplace or par gris foncé */
.pb-price-or { color:#2d2d2d !important; }

/* Session detail card highlight */
.session-detail-card.available { border-color:rgba(193,39,45,.2); }

/* ── 7. STICKY MOBILE — barre fixe en bas ───────────────────────── */
.mobile-cta-bar {
  display:none;
  position:fixed;
  bottom:0; left:0; right:0;
  background:#fff;
  border-top:2px solid var(--rouge);
  padding:12px 20px;
  z-index:500;
  box-shadow:0 -4px 20px rgba(0,0,0,.12);
  align-items:center;
  gap:12px;
}
.mobile-cta-bar .mcb-price {
  flex:1;
}
.mobile-cta-bar .mcb-label {
  font-size:.7rem;
  color:var(--gris-4);
  text-transform:uppercase;
  letter-spacing:.06em;
  display:block;
}
.mobile-cta-bar .mcb-amount {
  font-family:var(--font-h);
  font-size:1.1rem;
  font-weight:800;
  color:var(--noir);
}
.mobile-cta-bar .mcb-btn {
  background:var(--rouge);
  color:#fff;
  font-family:var(--font-h);
  font-weight:700;
  font-size:.88rem;
  padding:12px 20px;
  border-radius:var(--r);
  text-decoration:none;
  white-space:nowrap;
  display:flex;
  align-items:center;
  gap:7px;
  letter-spacing:.04em;
  text-transform:uppercase;
}

@media (max-width:960px) {
  .detail-layout { grid-template-columns:1fr; }
  .detail-layout > aside { display:none; } /* caché, remplacé par barre mobile */
  .mobile-cta-bar { display:flex; }
  .related-grid   { grid-template-columns:1fr; }
  /* Espace pour barre fixe */
  .detail-layout { padding-bottom:80px; }
}

@media (max-width:640px) {
  .stats-bar { flex-wrap:nowrap; overflow-x:auto; }
  .stat-item { min-width:72px; flex-shrink:0; }
}

/* ── 8. SUPPRESSION DES FONDS BOGOLAN RÉPÉTÉS DANS SECTIONS ─────── */
.afri-bogolan-bg::after { display:none; }
.afri-kente-bg::before  { display:none; }

/* Remplacement : fond géométrique sobre avec losanges SVG */
.afri-geo-section {
  position:relative;
  overflow:hidden;
}
.afri-geo-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='40,8 72,40 40,72 8,40' fill='none' stroke='rgba(193,39,45,0.04)' stroke-width='1'/%3E%3Ccircle cx='40' cy='40' r='3' fill='rgba(193,39,45,0.04)'/%3E%3C/svg%3E");
  background-size:80px 80px;
}
.afri-geo-section > * { z-index:1; }

/* ── 9. PAN AFRICA BAND — rouge/noir seulement ───────────────────── */
.pan-africa-band { background:var(--noir); }
.pan-africa-band::before { display:none; } /* retire la grille */
.pab-num  { color:var(--rouge); }
.pab-lbl  { color:rgba(255,255,255,.5); }

/* ── 10. AFRI-CTA rouge — déjà rouge, juste nettoyer le motif ────── */
.afri-cta::before { display:none; }
/* Ajout d'un watermark continent discret */
.afri-cta {
  background:var(--rouge);
  position:relative;
  overflow:hidden;
}
.afri-cta::after {
  content:'';
  position:absolute;
  right:-80px; bottom:-60px;
  width:400px; height:450px;
  opacity:.07;
  pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M60 5 C40 5 20 15 15 35 C10 55 20 70 15 90 C10 110 5 125 8 145 C11 165 5 180 10 200 C15 218 30 230 50 235 C70 240 90 230 100 215 C110 200 108 185 115 170 C122 155 140 148 148 132 C156 116 150 95 155 78 C160 61 175 50 175 33 C175 16 160 5 145 8 C130 11 120 25 105 22 C90 19 80 5 60 5 Z' fill='%23fff'/%3E%3C/svg%3E") no-repeat center/contain;
}

/* ── 11. SEKOO-BADGE — rouge/noir ────────────────────────────────── */
.sekoo-badge {
  background:var(--noir);
  color:var(--rouge);
  border-color:rgba(193,39,45,.3);
}
.sekoo-badge::before { background:var(--rouge); }

/* ── 12. SCHOOL PILLAR BADGES — garder les 3 niveaux distincts ───── */
/* primaire → vert conservé car niveau différent — remplacé par rouge pâle */
.school-pillar-badge.primaire  { background:rgba(193,39,45,.12); color:var(--rouge); border-color:rgba(193,39,45,.25); }
.school-pillar-badge.lycee     { background:rgba(45,45,45,.15); color:#e0e0e0; border-color:rgba(45,45,45,.3); }
.school-pillar-badge.superieur { background:rgba(193,39,45,.2); color:#fff; border-color:rgba(193,39,45,.35); }

/* ── 13. PROCESS BAND — rouge/noir ───────────────────────────────── */
.process-band { background:var(--noir); }
.pb-num       { color:rgba(193,39,45,.5); }
.pb-title     { color:#fff; }
.pb-desc      { color:rgba(255,255,255,.5); }
.process-band-step::after { color:var(--rouge); }

/* ── 14. AFRI-QUOTE — noir/rouge ─────────────────────────────────── */
.afri-quote::before { color:var(--rouge); }
.afri-quote-text em { color:var(--rouge); }

/* ── 15. CERT BOX ────────────────────────────────────────────────── */
.cert-box:hover { border-color:var(--rouge); background:var(--rouge-pale); }

/* ── 16. ALUMNI FLAGS ────────────────────────────────────────────── */
.alumni-flag-item { border-color:var(--border); color:var(--gris-4); }

/* ── 17. PARCOURS CARD ───────────────────────────────────────────── */
.parcours-card::before { background:var(--rouge); }
.parcours-ico          { background:var(--rouge-pale); color:var(--rouge); }

/* ── 18. ENT IMPACT CARD ─────────────────────────────────────────── */
.ent-impact-card::before { background:var(--rouge); }
.ent-impact-num { color:var(--rouge); }

/* ── 19. BADGE BLEU → gris foncé ─────────────────────────────────── */
.badge-bleu { background:#f0f0f0; color:#2d2d2d; border:1px solid #d1d5db; }
.icon-bleu  { color:#2d2d2d; }
.accent-card-blue { background:rgba(45,45,45,.04); border:1px solid rgba(45,45,45,.1); border-radius:var(--rlg); padding:32px; }
.accent-card-green { background:rgba(45,45,45,.04); border:1px solid rgba(45,45,45,.1); border-radius:var(--rlg); padding:32px; }

/* ── 20. HERO VISUEL CARDS — rouge/gris foncé ────────────────────── */
.fc-icon-rouge { background:rgba(193,39,45,.1); color:var(--rouge); }
.score-fill-rouge { background:var(--rouge); }
.testi-av-rouge { background:linear-gradient(135deg,var(--rouge),var(--rouge-2)); }
.testi-av-bleu  { background:linear-gradient(135deg,#2d2d2d,#1a1a1a); }

/* ── 21. FEAT-ITEM icons ─────────────────────────────────────────── */
.feat-item .icon-or   { color:var(--rouge); }
.feat-item .icon-vert { color:#2d2d2d; }
.feat-item .icon-bleu { color:#2d2d2d; }

/* ── 22. RESPONSIVE DETAIL FORMATION ────────────────────────────── */
@media (max-width:768px) {
  .detail-title { font-size:1.3rem; }
  .stats-bar    { border-radius:var(--r); }
  .stat-item    { padding:10px 6px; }
  .stat-val     { font-size:.85rem; }
  .stat-lbl     { font-size:.58rem; }
  .tab-nav      { overflow-x:auto; }
  .tnb          { white-space:nowrap; font-size:.82rem; padding:10px 12px; }
  .related-grid { grid-template-columns:1fr; }
}



/* ================================================================
   SEKOO v3 — Classes manquantes : piliers, hero nettoyé, sec-geo
   ================================================================ */

/* ── Hero accent-or neutralisé ──────────────────────────────────── */
.hero-afrik .hero-title .accent-or { color:#fff; }
.hero-afrik-kente-bar {
  position:absolute;
  bottom:0; left:0; right:0;
  height:3px;
  background:var(--rouge);
}

/* ── PILIERS GRID — page accueil ─────────────────────────────────── */
.piliers-section { padding:72px 0; }
.piliers-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:0;
}
@media(max-width:1200px){ .piliers-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:768px) { .piliers-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .piliers-grid { grid-template-columns:1fr; } }

.pilier-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--rlg);
  padding:24px;
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
  transition:var(--tr);
  position:relative;
  overflow:hidden;
}
.pilier-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:transparent;
  transition:var(--tr);
}
.pilier-card:hover {
  transform:translateY(-4px);
  box-shadow:var(--sh-md);
  border-color:rgba(193,39,45,.2);
}
.pilier-card:hover::before { background:var(--rouge); }

.pilier-icon {
  width:48px; height:48px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem;
  margin-bottom:14px;
  flex-shrink:0;
}
.pilier-title {
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--noir);
  margin-bottom:8px;
}
.pilier-desc {
  font-size:.84rem;
  color:var(--gris-4);
  line-height:1.6;
  flex:1;
}

/* ── SEKOO BAND section ──────────────────────────────────────────── */
.sekoo-band {
  background:var(--noir);
  padding:56px 0;
  position:relative;
  overflow:hidden;
}
.sekoo-band::before {
  content:'';
  position:absolute; inset:0;
  background:repeating-linear-gradient(
    90deg,
    transparent 0, transparent 79px,
    rgba(193,39,45,.06) 79px, rgba(193,39,45,.06) 80px
  ),
  repeating-linear-gradient(
    0deg,
    transparent 0, transparent 79px,
    rgba(193,39,45,.06) 79px, rgba(193,39,45,.06) 80px
  );
  pointer-events:none;
}
.sekoo-band .container { position:relative; z-index:1; }

/* ── Section géo accent ──────────────────────────────────────────── */
.sec-geo-wrap {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
  justify-content:center;
}
.sec-geo-wrap .sec-label { margin:0; }
.sec-geo-lozenge {
  display:inline-block;
  width:8px; height:8px;
  background:var(--rouge);
  transform:rotate(45deg);
  opacity:.6;
  flex-shrink:0;
}

/* ── Vision section — piliers icons override ─────────────────────── */
.vp-icon-or   { background:rgba(193,39,45,.08)!important; color:var(--rouge)!important; }
.vp-icon-vert { background:rgba(45,45,45,.08)!important;  color:#2d2d2d!important; }

/* ── HSTAT couleurs ──────────────────────────────────────────────── */
.hstat-n { color:var(--rouge) !important; }

/* ── Testi stars noir/rouge ──────────────────────────────────────── */
.testi-stars { color:var(--rouge); font-size:1rem; letter-spacing:2px; margin-bottom:14px; }

/* ── Partner label ───────────────────────────────────────────────── */
.partner-label { color:var(--gris-4); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; }

/* ── Eyebrow SEKOO dans hero ─────────────────────────────────────── */
.hero .hero-eyebrow .eyebrow-dot { background:var(--rouge); }

/* ── Stats band dark ─────────────────────────────────────────────── */
.stats-band {
  background:var(--noir) !important;
  border-top:none; border-bottom:none;
}
.stats-band .sb-num { color:#fff !important; }
.stats-band .sb-lbl { color:rgba(255,255,255,.45) !important; }
.stats-band-inner { border-color:rgba(255,255,255,.08) !important; }
.sb-item + .sb-item { border-left:1px solid rgba(255,255,255,.08); }

/* ── Corrige les inline --or dans les templates ──────────────────── */
/* rc-meta clock icon */
.rc-meta i { color:var(--rouge) !important; }

/* Session detail available border */
.session-detail-card.available { border-color:rgba(193,39,45,.2); }

/* ── Acc cards override pour rouge/gris ─────────────────────────── */
.accent-card-red   { background:rgba(193,39,45,.04);  border:1px solid rgba(193,39,45,.12);  border-radius:var(--rlg); padding:32px; }
.accent-card-blue  { background:rgba(45,45,45,.04);   border:1px solid rgba(45,45,45,.1);    border-radius:var(--rlg); padding:32px; }
.accent-card-green { background:rgba(45,45,45,.04);   border:1px solid rgba(45,45,45,.1);    border-radius:var(--rlg); padding:32px; }
.accent-card-or    { background:rgba(193,39,45,.04);  border:1px solid rgba(193,39,45,.12);  border-radius:var(--rlg); padding:32px; }

/* ── Nav SEKOO logo ──────────────────────────────────────────────── */
.sekoo-logo-wrap:hover .sekoo-logo-name { color:var(--rouge); }
.sekoo-logo-wrap:hover .sekoo-logo-name span { color:var(--noir); }

/* ── Mobile responsive hero text ────────────────────────────────── */
@media (max-width:768px) {
  .piliers-grid { gap:14px; }
  .pilier-card  { padding:18px; }
  .sekoo-logo-name { font-size:1.3rem; }
}

/* ── Fix: supprimer les références or dans les inline styles ────── */
/* Ces règles ont priorité sur les inline styles via !important ciblé */
[style*="color:var(--or)"],
[style*="color: var(--or)"] {
  color:var(--rouge) !important;
}
[style*="background:var(--or)"],
[style*="background: var(--or)"] {
  background:var(--rouge) !important;
}


/* ================================================================
   SEKOO — Patch v3 : dropdown auto-width · footer · mobile drawer
   ================================================================ */

/* ── 1. DROPDOWN navbar — largeur auto ──────────────────────────── */
.dd-menu {
  min-width: max-content;
  width: max-content;
  max-width: 360px;
  left: 0;
  transform: translateX(0) translateY(-6px);
  white-space: nowrap;
}
.nav-dd:hover .dd-menu {
  transform: translateX(0) translateY(0);
}
/* S'assurer que le dropdown ne déborde pas à droite */
.nav-dd:last-of-type .dd-menu,
.nav-dd:nth-last-of-type(-n+3) .dd-menu {
  left: auto;
  right: 0;
  transform: translateX(0) translateY(-6px);
}
.nav-dd:nth-last-of-type(-n+3):hover .dd-menu {
  transform: translateX(0) translateY(0);
}
.dd-menu a {
  white-space: nowrap;
  padding: 9px 18px 9px 14px;
}

/* ── 2. FOOTER — refonte fidèle capture ─────────────────────────── */
#footer {
  background: #111;
  padding: 0;
  border-top: 3px solid var(--rouge);
}
.ft-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 48px;
  padding: 56px 0 40px;
  align-items: start;
}
.ft-brand { }
.ft-brand-logo-text {
  font-family: var(--font-h);
  font-size: 2.2rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .04em;
  line-height: 1;
  margin-bottom: 2px;
}
.ft-brand-logo-text span { color: var(--rouge); }
.ft-brand-by {
  font-size: .62rem;
  color: rgba(255,255,255,.35);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 16px;
  display: block;
}
.ft-brand p {
  font-size: .85rem;
  color: rgba(255,255,255,.55);
  line-height: 1.7;
  margin-bottom: 18px;
  max-width: 280px;
}
.ft-tagline { color: rgba(255,255,255,.85); font-weight: 600; }
.ft-socials {
  display: flex;
  gap: 8px;
  margin-top: 20px;
}
.soc-btn {
  width: 34px; height: 34px;
  border-radius: 6px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6);
  font-size: .8rem;
  transition: var(--tr);
}
.soc-btn:hover      { background: var(--rouge); border-color: var(--rouge); color: #fff; }
.soc-btn.li:hover   { background: #0077b5; border-color: #0077b5; }
.soc-btn.yt:hover   { background: #ff0000; border-color: #ff0000; }
.soc-btn.wa:hover   { background: #25D366; border-color: #25D366; }

.ft-col h5 {
  font-family: var(--font-h);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ft-col ul { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.ft-col ul li a {
  display: flex; align-items: center; gap: 8px;
  font-size: .84rem; color: rgba(255,255,255,.5);
  padding: 5px 0;
  transition: var(--tr);
  text-decoration: none;
}
.ft-col ul li a:hover { color: #fff; padding-left: 4px; }
.ft-col ul li a i {
  width: 14px; text-align: center;
  color: var(--rouge); font-size: .75rem; flex-shrink: 0;
}
.ft-ci {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .84rem; color: rgba(255,255,255,.5);
  margin-bottom: 10px;
}
.ft-ci i { color: var(--rouge); width: 14px; text-align: center; margin-top: 2px; flex-shrink: 0; }
.ft-ci a { color: var(--rouge); text-decoration: none; }
.ft-ci a:hover { color: #fff; }
.ft-bottom {
  border-top: 1px solid rgba(255,255,255,.07);
  padding: 18px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: .78rem;
  color: rgba(255,255,255,.3);
}
.ft-bottom a { color: rgba(255,255,255,.4); text-decoration: none; }
.ft-bottom a:hover { color: #fff; }
/* bouton nous écrire dans footer */
.ft-cta-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 20px;
  background: var(--rouge);
  color: #fff;
  font-family: var(--font-h);
  font-weight: 600;
  font-size: .82rem;
  border-radius: var(--r);
  text-decoration: none;
  margin-top: 12px;
  transition: var(--tr);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.ft-cta-btn:hover { background: var(--rouge-2); transform: translateY(-1px); }
/* Remove old sekoo block in footer */
.ft-sekoo-block { display: none; }

@media (max-width: 960px) {
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 32px; padding: 40px 0 32px; }
  .ft-brand { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .ft-grid { grid-template-columns: 1fr; }
  .ft-brand { grid-column: auto; }
}

/* ── 3. MOBILE DRAWER — détail formation ────────────────────────── */
.drawer-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 800;
  backdrop-filter: blur(2px);
}
.drawer-overlay.open { display: block; }

.inscription-drawer {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #fff;
  border-radius: 20px 20px 0 0;
  z-index: 801;
  max-height: 92vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.32,1,.64,1);
  box-shadow: 0 -8px 40px rgba(0,0,0,.18);
}
.inscription-drawer.open {
  transform: translateY(0);
}
.drawer-handle {
  width: 40px; height: 4px;
  background: var(--gris-2);
  border-radius: 2px;
  margin: 12px auto 4px;
}
.drawer-header {
  padding: 8px 20px 16px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.drawer-title {
  font-family: var(--font-h);
  font-size: 1rem; font-weight: 700; color: var(--noir);
}
.drawer-close {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--gris-0);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: .85rem; color: var(--gris-4);
  flex-shrink: 0;
}
.drawer-body { padding: 20px; }

/* Mode tabs dans le drawer */
.drawer-mode-tabs {
  display: flex; gap: 8px;
  margin-bottom: 20px;
}
.drawer-tab {
  flex: 1;
  padding: 11px 8px;
  border-radius: var(--r);
  border: 2px solid var(--border);
  background: #fff;
  font-family: var(--font-h);
  font-size: .82rem; font-weight: 600;
  color: var(--gris-4);
  cursor: pointer;
  text-align: center;
  transition: var(--tr);
}
.drawer-tab.active-auto {
  border-color: var(--rouge);
  background: var(--rouge-pale);
  color: var(--rouge);
}
.drawer-tab.active-boot {
  border-color: #2d2d2d;
  background: rgba(45,45,45,.06);
  color: #2d2d2d;
}

/* Prix dans le drawer */
.drawer-price-block {
  background: var(--gris-0);
  border-radius: var(--r);
  padding: 16px;
  margin-bottom: 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.drawer-price-lbl { font-size: .72rem; color: var(--gris-4); text-transform: uppercase; letter-spacing: .06em; }
.drawer-price-val { font-family: var(--font-h); font-size: 1.4rem; font-weight: 800; color: var(--rouge); }
.drawer-price-sub { font-size: .74rem; color: var(--gris-4); margin-top: 2px; }

/* Sessions dans le drawer */
.drawer-sessions-wrap { margin-bottom: 16px; }
.drawer-sess-title {
  font-size: .72rem; color: var(--gris-4);
  text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: 8px; font-weight: 600;
}

/* Inclus dans le drawer */
.drawer-inclus {
  list-style: none;
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.drawer-inclus li {
  display: flex; align-items: center; gap: 7px;
  font-size: .8rem; color: var(--gris-4);
}
.drawer-inclus li i { color: var(--rouge); font-size: .76rem; }

/* CTA drawer */
.drawer-cta {
  display: block; width: 100%; padding: 14px;
  background: var(--rouge); color: #fff;
  font-family: var(--font-h); font-weight: 700; font-size: .95rem;
  letter-spacing: .05em; border: none; border-radius: var(--r);
  cursor: pointer; text-align: center; text-decoration: none;
  margin-bottom: 8px; text-transform: uppercase;
  transition: var(--tr);
}
.drawer-cta:hover { background: var(--rouge-2); }
.drawer-cta-secondary {
  display: block; width: 100%; padding: 10px;
  background: transparent; color: var(--gris-4);
  border: 1px solid var(--border); border-radius: var(--r);
  font-family: var(--font-h); font-weight: 600; font-size: .83rem;
  text-align: center; text-decoration: none; margin-bottom: 6px;
  transition: var(--tr);
}
.drawer-cta-secondary:hover { border-color: var(--rouge); color: var(--rouge); }

/* Sticky pay-card fix */
.pay-card {
  position: sticky;
  top: 84px;
  align-self: start;
  max-height: calc(100vh - 96px);
  overflow-y: auto;
}
/* Sur mobile : assurer que aside ne s'affiche pas */
@media (max-width: 960px) {
  .detail-layout > aside { display: none !important; }
  .inscription-drawer, .drawer-overlay { display: none; }
  .inscription-drawer.open, .drawer-overlay.open { display: block; }
}

/* ── 4. PAY CARD STICKY — fix desktop ───────────────────────────── */
.detail-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 28px 24px 60px;
  align-items: start;
}
/* Force le sticky sur l'aside */
.detail-layout > aside {
  position: sticky;
  top: 84px;
  align-self: start;
}



/* ================================================================
   SEKOO — Patch responsive v4 · detail_formation mobile
   ================================================================ */

/* ── BREADCRUMB — fix double séparateur ─────────────────────────── */
/* Le HTML contient déjà › — on supprime le / CSS */
.breadcrumb span::before { content: '' !important; margin-right: 0 !important; }
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px 6px;
  font-size: .82rem;
  color: var(--gris-3);
}
.breadcrumb a         { color: var(--rouge); text-decoration: none; white-space: nowrap; }
.breadcrumb a:hover   { text-decoration: underline; }
.breadcrumb .cur      { color: var(--noir-2); }

/* ── STATS BAR — fix mobile complet ────────────────────────────── */
/* Desktop : tous les items en ligne, même hauteur */
.stats-bar {
  display: flex;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  margin-bottom: 24px;
  overflow: hidden;
  box-shadow: var(--sh);
  flex-wrap: nowrap;   /* jamais de wrap — scroll horizontal sur mobile */
}
.stat-item {
  flex: 1 1 0;
  min-width: 0;
  padding: 14px 8px;
  border-right: 1px solid var(--border);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
}
.stat-item:last-child { border-right: none; }
.stat-val {
  font-family: var(--font-h);
  font-size: .9rem;
  font-weight: 700;
  color: var(--noir);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  white-space: nowrap;
  line-height: 1.2;
}
.stat-val-sm { font-size: .78rem; }
.stat-lbl {
  font-size: .6rem;
  color: var(--gris-3);
  text-transform: uppercase;
  letter-spacing: .06em;
  display: block;
  white-space: nowrap;
  line-height: 1.2;
}
.stat-ico { color: var(--rouge); font-size: .75rem; flex-shrink: 0; }
.stat-dispo-ok   { color: var(--rouge); font-weight: 700; font-size: .78rem; }
.stat-dispo-wait { color: #2d2d2d; font-size: .78rem; }
.stat-dispo-off  { color: var(--gris-3); }

/* Mobile : scroll horizontal discret si trop d'items */
@media (max-width: 640px) {
  .stats-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; /* Firefox */
  }
  .stats-bar::-webkit-scrollbar { display: none; }
  .stat-item {
    flex: 0 0 auto;
    min-width: 68px;
    padding: 12px 6px;
  }
  .stat-val   { font-size: .82rem; }
  .stat-lbl   { font-size: .58rem; }
}

/* ── MOBILE CTA BAR — ne jamais chevaucher le footer ────────────── */
.mobile-cta-bar {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #fff;
  border-top: 2px solid var(--rouge);
  padding: 10px 16px;
  z-index: 200;  /* sous le drawer (801) et overlay (800) */
  box-shadow: 0 -4px 20px rgba(0,0,0,.12);
  align-items: center;
  gap: 12px;
  /* safe-area pour iPhone X+ */
  padding-bottom: calc(10px + env(safe-area-inset-bottom));
}
.mobile-cta-bar .mcb-price { flex: 1; min-width: 0; }
.mobile-cta-bar .mcb-label {
  font-size: .66rem;
  color: var(--gris-4);
  text-transform: uppercase;
  letter-spacing: .06em;
  display: block;
  line-height: 1.2;
}
.mobile-cta-bar .mcb-amount {
  font-family: var(--font-h);
  font-size: 1rem;
  font-weight: 800;
  color: var(--noir);
  white-space: nowrap;
}
.mobile-cta-bar .mcb-btn {
  background: var(--rouge);
  color: #fff !important;
  font-family: var(--font-h);
  font-weight: 700;
  font-size: .85rem;
  padding: 11px 18px;
  border-radius: var(--r);
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 7px;
  letter-spacing: .04em;
  text-transform: uppercase;
  flex-shrink: 0;
  transition: var(--tr);
}
.mobile-cta-bar .mcb-btn:hover { background: var(--rouge-2); }

@media (max-width: 960px) {
  .detail-layout                 { grid-template-columns: 1fr !important; padding-bottom: 90px; }
  .detail-layout > aside         { display: none !important; }
  .mobile-cta-bar                { display: flex; }
  .related-grid                  { grid-template-columns: 1fr; }
}

/* ── PAGE-WRAP padding-bottom pour barre fixe ───────────────────── */
/* Évite que le footer soit caché derrière la barre sticky */
@media (max-width: 960px) {
  .detail-formation-page .page-wrap,
  body:has(.mobile-cta-bar) #footer {
    /* Le footer n'est pas caché — la barre est au-dessus du contenu scrollable */
  }
}

/* ── FOOTER MOBILE — colonnes empilées ──────────────────────────── */
@media (max-width: 960px) {
  .ft-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
    padding: 36px 0 28px !important;
  }
  .ft-brand { grid-column: 1 / -1 !important; }
  .ft-brand p { max-width: 100%; font-size: .84rem; }
}
@media (max-width: 580px) {
  .ft-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .ft-brand { grid-column: auto !important; }
  .ft-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    font-size: .74rem;
  }
}

/* ── DETAIL LAYOUT MOBILE — espacements ────────────────────────── */
@media (max-width: 768px) {
  .detail-layout {
    padding: 16px 16px 90px !important;
    gap: 20px !important;
  }
  .detail-title { font-size: 1.25rem !important; line-height: 1.3; }
  .detail-badges { gap: 5px; }
  .tab-nav { overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .tab-nav::-webkit-scrollbar { display: none; }
  .tnb { padding: 10px 12px !important; font-size: .82rem !important; white-space: nowrap; }
  .related-section { margin-top: 32px; padding-top: 24px; }
  .related-grid { grid-template-columns: 1fr; }
}

/* ── BREADCRUMB BAR MOBILE ──────────────────────────────────────── */
@media (max-width: 640px) {
  .breadcrumb-bar > .container { padding-top: 10px; padding-bottom: 10px; }
  .breadcrumb { font-size: .76rem; gap: 3px 5px; }
  .breadcrumb .cur {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
    vertical-align: bottom;
  }
}


/* Breadcrumb separator span */
.bc-sep {
  color: var(--gris-3);
  font-size: .75rem;
  flex-shrink: 0;
  line-height: 1;
}


/* ================================================================
   SEKOO — Patch responsive v5 · stats bar + footer overflow + barre 2 prix
   ================================================================ */

/* ── OVERFLOW GLOBAL — empêche le débordement horizontal ─────────── */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}
/* Tous les containers respectent la largeur du viewport */
.page-wrap, #footer, .breadcrumb-bar,
.detail-layout, .stats-band, .hero-inner,
.hero, .hero-bg {
  overflow-x: hidden;
}

/* ── STATS BAR — desktop ligne, mobile grille 2×2 ───────────────── */
.stats-bar {
  display: flex !important;
  flex-wrap: nowrap !important;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  margin-bottom: 24px;
  box-shadow: var(--sh);
  overflow: hidden;
}
.stat-item {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  padding: 14px 10px !important;
  border-right: 1px solid var(--border);
  text-align: center;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
}
.stat-item:last-child { border-right: none !important; }
.stat-val {
  font-family: var(--font-h);
  font-size: .88rem !important;
  font-weight: 700;
  color: var(--noir);
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  white-space: nowrap !important;
  line-height: 1.2;
}
.stat-lbl {
  font-size: .6rem !important;
  color: var(--gris-3);
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block !important;
  white-space: nowrap !important;
  line-height: 1.2;
}
.stat-ico { color: var(--rouge) !important; font-size: .72rem; flex-shrink: 0; }

/* Mobile : grille 2 colonnes × 2 rangées */
@media (max-width: 640px) {
  .stats-bar {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    flex-wrap: unset !important;
    overflow: visible;
  }
  .stat-item {
    flex: unset !important;
    border-right: none !important;
    border-bottom: 1px solid var(--border);
    padding: 12px 8px !important;
  }
  /* Ligne séparatrice verticale entre les deux colonnes */
  .stat-item:nth-child(odd)  { border-right: 1px solid var(--border) !important; }
  /* Dernière rangée : pas de bordure basse */
  .stat-item:nth-last-child(-n+2) { border-bottom: none !important; }
  .stat-val { font-size: .84rem !important; }
  .stat-lbl { font-size: .58rem !important; }
}

/* ── FOOTER OVERFLOW FIX ──────────────────────────────────────────── */
#footer {
  overflow-x: hidden;
  width: 100%;
  box-sizing: border-box;
}
#footer .container {
  overflow-x: hidden;
  padding-left: 16px;
  padding-right: 16px;
}
.ft-grid {
  width: 100%;
  box-sizing: border-box;
}

/* ── BARRE MOBILE — DEUX PRIX + S'INSCRIRE ──────────────────────── */
.mobile-cta-bar {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #fff;
  border-top: 2px solid var(--rouge);
  z-index: 200;
  box-shadow: 0 -4px 20px rgba(0,0,0,.12);
  align-items: stretch;
  padding: 0;
  /* safe-area iPhone X+ */
  padding-bottom: env(safe-area-inset-bottom, 0px);
  box-sizing: border-box;
}

/* Zone prix — 2 prix côte à côte */
.mcb-prices {
  display: flex;
  flex: 1;
  align-items: stretch;
  min-width: 0;
}
.mcb-price-item {
  flex: 1;
  padding: 10px 10px 10px 14px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  border-right: 1px solid var(--border);
}
.mcb-price-item:last-child { border-right: none; }
.mcb-price-label {
  font-size: .58rem;
  color: var(--gris-4);
  text-transform: uppercase;
  letter-spacing: .07em;
  line-height: 1;
  margin-bottom: 2px;
  white-space: nowrap;
}
.mcb-price-val {
  font-family: var(--font-h);
  font-size: .88rem;
  font-weight: 800;
  color: var(--noir);
  white-space: nowrap;
  line-height: 1.2;
}
.mcb-price-val.unavailable {
  font-size: .78rem;
  color: var(--gris-3);
  font-weight: 500;
}

/* Bouton S'inscrire dans la barre */
.mcb-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--rouge);
  color: #fff !important;
  font-family: var(--font-h);
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0 18px;
  flex-shrink: 0;
  align-self: stretch;
  cursor: pointer;
  border: none;
  border-left: 1px solid rgba(255,255,255,.15);
  transition: background .18s;
  /* Largeur auto selon le texte */
  min-width: 0;
  white-space: nowrap;
}
.mcb-btn i { font-size: .8rem; flex-shrink: 0; }
.mcb-btn:hover, .mcb-btn:active { background: var(--rouge-2); }

@media (max-width: 960px) {
  .mobile-cta-bar { display: flex !important; }
  .detail-layout > aside { display: none !important; }
  .detail-layout { padding-bottom: 72px !important; }
}

/* Sur très petit écran — compacter encore */
@media (max-width: 360px) {
  .mcb-price-item { padding: 8px 6px 8px 10px; }
  .mcb-price-val  { font-size: .8rem; }
  .mcb-btn        { padding: 0 12px; font-size: .78rem; min-width: 90px; }
}

/* ── DETAIL LAYOUT — overflow fix ────────────────────────────────── */
.detail-layout {
  overflow-x: hidden;
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 768px) {
  .detail-layout {
    padding: 14px 14px 80px !important;
  }
  .course-desc { overflow-wrap: break-word; word-break: break-word; }
  .course-desc img, .course-desc table { max-width: 100%; overflow-x: auto; display: block; }
}
/* ── BLOC PRIX CARTES — partagé catalogue + accueil ────────────────
   Utilisé sur .course-card (catalogue) et .card-cours (accueil)
──────────────────────────────────────────────────────────────────── */
.cc-pricing {
  border-top: 1px solid var(--border);
  padding: 10px 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.cc-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.cc-price-mode {
  font-size: .7rem;
  font-family: var(--font-h);
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--gris-3);
  flex-shrink: 0;
}
.cc-price-val {
  font-family: var(--font-h);
  font-size: .95rem;
  font-weight: 800;
  white-space: nowrap;
}
.cc-price-val--auto { color: var(--rouge); }
.cc-price-val--boot { color: var(--noir); }
.cc-price-dots {
  flex: 1;
  border-bottom: 1px dotted var(--gris-2);
  margin: 0 4px;
  margin-bottom: 3px;
}
.cc-next-session {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  color: var(--gris-4);
  background: var(--gris-0);
  border-radius: 5px;
  padding: 4px 8px;
  margin-top: 2px;
  border-left: 2px solid var(--rouge);
}
.cc-next-session i { color: var(--rouge); font-size: .65rem; flex-shrink: 0; }
.cc-next-session strong { color: var(--noir); font-family: var(--font-h); }

/* Compatibilité .card-cours (grille accueil) avec le bloc prix */
.card-cours .cc-pricing { margin-top: auto; }