/* ================================================================
   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; margin-top: 80px;
}
.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); }
.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; }