/* ============================================================
   RESET & BASE
============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; margin: 0; padding: 0; }
img { max-width: 100%; display: block; }

:root {
  --navy:      #0B1D51;
  --navy-2:    #132268;
  --navy-3:    #1a2d80;
  --red:       #C91B1B;
  --red-2:     #E02020;
  --red-3:     #E8503A;
  --red-glow:  rgba(201,27,27,.28);
  --gold:      #D4A843;
  --off-white: #F4F6FB;
  --white:     #FFFFFF;
  --ink:       #0D1525;
  --muted:     #6B7280;
  --border:    #E4E8F2;
  --shadow-sm: 0 2px 16px rgba(11,29,81,.07);
  --shadow-md: 0 12px 48px rgba(11,29,81,.11);
  --shadow-lg: 0 24px 72px rgba(11,29,81,.15);
  --shadow-red: 0 8px 32px rgba(201,27,27,.22);
  --radius:    8px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --font: 'Inter', system-ui, sans-serif;
  --trans: all .35s cubic-bezier(.22,.68,0,1.15);
  --trans-fast: all .2s cubic-bezier(.4,0,.2,1);
  --grad-red: linear-gradient(135deg, #C91B1B 0%, #E8503A 100%);
  --grad-navy: linear-gradient(135deg, #0B1D51 0%, #1a2d80 100%);
}

body { margin: 0; padding: 0; font-family: var(--font); font-weight: 400; color: var(--ink); background: var(--white); -webkit-font-smoothing: antialiased; overflow-x: hidden; }

/* ============================================================
   UTILITY
============================================================ */
.container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.section { padding: 112px 0; }
.section--dark  { background: rgba(11, 29, 81, 0.92); }
.section--gray  { background: rgba(247, 248, 252, 0.88); }
.section--white { background: rgba(255, 255, 255, 0.88); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 10px; font-weight: 800; letter-spacing: 3.5px;
  text-transform: uppercase; color: var(--red); margin-bottom: 18px;
}
.eyebrow::before { content: ''; display: block; width: 28px; height: 2px; background: var(--grad-red); border-radius: 2px; flex-shrink: 0; }
.eyebrow--light { color: rgba(255,150,150,.9); }
.eyebrow--light::before { background: rgba(255,150,150,.7); }

.h-section { font-size: 2rem; font-size: clamp(1.8rem, 2.8vw, 2.5rem); font-weight: 800; line-height: 1.16; letter-spacing: -.03em; color: var(--ink); }
.h-section--light { color: var(--white); }

.divider { width: 40px; height: 2px; background: var(--grad-red); border-radius: 2px; margin: 22px 0 30px; }
.divider--center { margin-left: auto; margin-right: auto; }

.lead { font-size: 1.05rem; font-weight: 300; line-height: 1.9; color: var(--muted); }
.lead--light { color: rgba(255,255,255,.58); }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font); font-size: 12px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 15px 32px; border-radius: 100px;
  text-decoration: none; transition: var(--trans);
  cursor: pointer; border: none; outline: none; white-space: nowrap;
}
.btn i { font-size: .8em; transition: transform .25s cubic-bezier(.22,.68,0,1.4); }
.btn:hover i { transform: translateX(4px); }
.btn-primary { background: var(--grad-red); color: var(--white); box-shadow: var(--shadow-red); }
.btn-primary:hover { color: var(--white); transform: translateY(-2px); box-shadow: 0 12px 40px rgba(201,27,27,.35); }
.btn-ghost { background: transparent; color: var(--white); border: 1.5px solid rgba(255,255,255,.25); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.btn-ghost:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.5); color: var(--white); }
.btn-outline { background: transparent; color: var(--navy); border: 1.5px solid var(--border); }
.btn-outline:hover { border-color: var(--navy); background: var(--navy); color: var(--white); }

/* Scroll reveal */
[data-reveal] { opacity: 0; transform: translateY(32px); transition: opacity .7s cubic-bezier(.22,.68,0,1.15), transform .7s cubic-bezier(.22,.68,0,1.15); }
[data-reveal].revealed { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: .1s; }
[data-reveal-delay="2"] { transition-delay: .2s; }
[data-reveal-delay="3"] { transition-delay: .3s; }
[data-reveal-delay="4"] { transition-delay: .4s; }

/* ============================================================
   NAVBAR
============================================================ */
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: rgba(11,29,81,0.88); -webkit-backdrop-filter: blur(24px) saturate(200%); backdrop-filter: blur(24px) saturate(200%); border-bottom: 1px solid rgba(255,255,255,.07); transition: background .4s ease, box-shadow .4s ease; }
.navbar.scrolled { background: rgba(11,29,81,0.97); box-shadow: 0 4px 40px rgba(0,0,0,.3); }
.navbar__inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.navbar__logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.navbar__logo img { height: 64px; width: auto; object-fit: contain; filter: brightness(0) invert(1); }
.navbar__logo-name { font-size: 16px; font-weight: 900; letter-spacing: 5px; text-transform: uppercase; color: var(--white); line-height: 1; }
.navbar__links { display: flex; align-items: center; gap: 0; list-style: none; flex-wrap: nowrap; }
.navbar__links a { display: block; padding: 8px 10px; font-size: 10.5px; font-weight: 700; letter-spacing: .9px; text-transform: uppercase; text-decoration: none; color: rgba(255,255,255,.6); border-radius: 100px; transition: var(--trans-fast); white-space: nowrap; }
.navbar__links a:hover, .navbar__links a.active { color: var(--white); background: rgba(255,255,255,.09); }
.navbar__links .nav-cta a { background: rgba(201,27,27,.9); color: var(--white); padding: 8px 16px; }
.navbar__links .nav-cta a:hover { background: var(--red-2); }
.navbar__links .nav-cta--formation a { background: #1a2d80; border: 1px solid rgba(255,255,255,.25); }
.navbar__links .nav-cta--formation a:hover { background: #223399; }
.nav-user { display: flex; align-items: center; gap: 6px; }
.nav-user__name { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #fff; white-space: nowrap; display: flex; align-items: center; gap: 5px; padding: 0 6px; }
.nav-user__logout { background: transparent; border: 1px solid rgba(255,255,255,.3); border-radius: 6px; color: #fff; cursor: pointer; padding: 5px 8px; font-size: .75rem; line-height: 1; transition: border-color .2s, color .2s; }
.nav-user__logout:hover { background: rgba(201,27,27,.25); color: #ffb3b3; border-color: rgba(201,27,27,.3); }
.navbar__toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; background: none; border: none; }
.navbar__toggle span { display: block; width: 24px; height: 2px; background: var(--white); border-radius: 2px; transition: var(--trans-fast); }
.navbar__toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.navbar__toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.navbar__toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.navbar__mobile { display: none; position: fixed; top: 72px; left: 0; right: 0; bottom: 0; background: var(--ink); z-index: 999; padding: 32px 24px; overflow-y: auto; }
.navbar__mobile.open { display: block; }
.navbar__mobile ul { list-style: none; }
.navbar__mobile ul li { border-bottom: 1px solid rgba(255,255,255,.06); }
.navbar__mobile ul li a { display: block; padding: 18px 0; font-size: 15px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.7); text-decoration: none; transition: var(--trans-fast); }
.navbar__mobile ul li a:hover { color: var(--white); padding-left: 10px; }
.navbar__mobile .mobile-cta { margin-top: 32px; display: flex; flex-direction: column; gap: 12px; }
.navbar__mobile .mobile-cta .btn { justify-content: center; }

/* ============================================================
   HERO
============================================================ */
.accueil {
  min-height: 100vh; background: url('asset/images/image_fond.webp') center center / cover no-repeat;
  position: relative; overflow: hidden; display: flex; align-items: center;
}
.accueil__bg {
  position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 20%, rgba(201,27,27,.13) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 0% 100%, rgba(26,45,128,.45) 0%, transparent 55%),
    radial-gradient(ellipse 100% 80% at 50% 50%, rgba(11,29,81,.6) 0%, transparent 70%),
    rgba(11, 29, 81, 0.72);
}
.accueil__grain {
  position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 1; pointer-events: none; opacity: .35;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}
/* Big decorative background word */
.accueil__wordmark {
  position: absolute; bottom: -40px; right: -40px; z-index: 0;
  font-family: 'DM Serif Display', serif;
  font-size: 180px; font-size: clamp(120px, 18vw, 260px);
  font-weight: 400; line-height: 1;
  color: rgba(255,255,255,.025);
  letter-spacing: -.05em;
  pointer-events: none; user-select: none;
  white-space: nowrap;
}
.accueil__content { position: relative; z-index: 2; padding: 158px 0 80px; width: 100%; } /* 38px announce bar + 72px navbar + 48px spacing */

.accueil__layout { display: flex; flex-direction: column; gap: 48px; }

/* Top bar */
.accueil__topbar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.accueil__pill { display: inline-flex; align-items: center; gap: 10px; background: rgba(201,27,27,.12); border: 1px solid rgba(201,27,27,.25); padding: 8px 18px; border-radius: 100px; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,160,160,.9); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.accueil__pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red-2); animation: pulse 2s infinite; flex-shrink: 0; }
@keyframes pulse { 0%,100% { opacity:1; transform:scale(1); box-shadow:0 0 0 0 rgba(224,32,32,.4); } 50% { opacity:.8; transform:scale(1.3); box-shadow:0 0 0 5px rgba(224,32,32,0); } }
.accueil__topbar-right { display: flex; align-items: center; gap: 12px; font-size: 11px; font-weight: 600; color: rgba(255,255,255,.35); letter-spacing: 1px; }
.accueil__sep { color: rgba(255,255,255,.15); }

/* Main grid */
.accueil__main { display: grid; grid-template-columns: 1fr 400px; gap: 64px; align-items: center; }

.accueil__title {
  font-family: 'Inter', sans-serif;
  font-weight: 900;
  font-size: 4rem; font-size: clamp(3rem, 5.5vw, 5.2rem);
  line-height: 1.04; letter-spacing: -.03em; color: var(--white);
  margin-bottom: 28px;
  text-transform: uppercase;
}
.accueil__title-em {
  font-style: normal;
  background: var(--grad-red);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.accueil__subtitle { font-size: 1.05rem; font-weight: 300; line-height: 1.85; color: rgba(255,255,255,.55); max-width: 480px; margin-bottom: 44px; }
.accueil__actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* Right stats panel */
.accueil__stats-panel {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-xl); padding: 28px;
  -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px);
  box-shadow: 0 24px 80px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.08);
  display: grid; grid-template-columns: 1fr 1fr; gap: 3px;
  overflow: hidden; margin-bottom: 12px;
}
.accueil__stat-item {
  background: rgba(255,255,255,.05); padding: 24px 20px; text-align: center;
}
.accueil__stat-item--accent { background: var(--grad-red); }
.accueil__stat-item--wide { grid-column: 1/-1; display: flex; align-items: center; justify-content: center; gap: 12px; background: rgba(255,255,255,.07) !important; }
.accueil__stat-item--wide i { color: var(--gold); font-size: 1rem; }
.accueil__stat-item--wide span { font-size: 11px; font-weight: 500; color: rgba(255,255,255,.65); }
.accueil__stat-num { font-size: 2.2rem; font-weight: 800; color: var(--white); line-height: 1; margin-bottom: 6px; letter-spacing: -.03em; }
.accueil__stat-lbl { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.55); }

.accueil__values-strip { display: flex; gap: 0; border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); overflow: hidden; }
.accueil__values-strip span { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 8px; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.4); border-right: 1px solid rgba(255,255,255,.08); transition: background .2s, color .2s; }
.accueil__values-strip span:last-child { border-right: none; }
.accueil__values-strip span:hover { background: rgba(255,255,255,.05); color: rgba(255,255,255,.8); }
.accueil__values-strip i { color: var(--red); font-size: 12px; }

.accueil__scroll { position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 8px; text-decoration: none; }
.accueil__scroll span { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.2); font-weight: 700; }
.accueil__scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, rgba(255,255,255,.3), transparent); animation: scrollLine 2.2s ease-in-out infinite; }
@keyframes scrollLine { 0% { transform:scaleY(0); transform-origin:top; opacity:1; } 60% { transform:scaleY(1); transform-origin:top; } 100% { transform:scaleY(1); transform-origin:bottom; opacity:0; } }

/* ============================================================
   PARTNERS GRID
============================================================ */
.partners {
  background: var(--white);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 56px 0;
}
.partners__header {
  text-align: center;
  margin-bottom: 40px;
}
.partners__label {
  font-size: 10px; font-weight: 800; letter-spacing: 3px;
  text-transform: uppercase; color: var(--muted); opacity: .55;
}

.partners__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

.p-logo {
  display: flex; flex-direction: column; align-items: center; justify-content: space-between; gap: 10px;
  padding: 18px 14px;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: var(--white);
  transition: var(--trans-fast); cursor: default; min-height: 100px;
}
.p-logo:hover { border-color: rgba(11,29,81,.18); box-shadow: var(--shadow-sm); transform: translateY(-3px); }
.p-logo__mark {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--c, var(--navy));
  color: white; display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 900; letter-spacing: -.5px; flex-shrink: 0;
}
.p-logo__img-wrap {
  width: 100%; height: 52px;
  display: flex; align-items: center; justify-content: center;
}
.p-logo__img-wrap img {
  max-width: 100%; max-height: 52px; width: auto; height: auto;
  object-fit: contain; display: block;
}
.p-logo > span { font-size: 10px; font-weight: 600; color: var(--muted); text-align: center; letter-spacing: .3px; white-space: nowrap; max-width: 90px; overflow: hidden; text-overflow: ellipsis; }

@media (max-width: 1100px) { .partners__grid { grid-template-columns: repeat(5, 1fr); } }
@media (max-width: 768px)  { .partners__grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 480px)  { .partners__grid { grid-template-columns: repeat(3, 1fr); } }

/* ============================================================
   ABOUT
============================================================ */
.about__layout {
  display: grid; grid-template-columns: 48px 1fr 1fr; gap: 56px; align-items: start;
}
.about__side-label {
  writing-mode: vertical-rl; text-orientation: mixed;
  font-size: 10px; font-weight: 800; letter-spacing: 4px;
  text-transform: uppercase; color: var(--border);
  transform: rotate(180deg); padding-top: 8px; user-select: none;
  align-self: start; margin-top: 12px;
}
.about__checklist { list-style: none; margin: 28px 0; display: flex; flex-direction: column; gap: 0; }
.about__checklist li { display: flex; align-items: center; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--border); font-size: 13px; font-weight: 600; letter-spacing: .5px; color: var(--navy); transition: padding-left .2s; }
.about__checklist li:last-child { border-bottom: none; }
.about__checklist li:hover { padding-left: 4px; }
.about__checklist li i { color: var(--red); font-size: 11px; flex-shrink: 0; }
.about__signature { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--off-white); width: fit-content; }
.about__signature-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--grad-navy); display: flex; align-items: center; justify-content: center; color: white; font-size: .9rem; flex-shrink: 0; }
.about__signature strong { display: block; font-size: 13px; font-weight: 700; color: var(--navy); letter-spacing: -.01em; }
.about__signature span { font-size: 11px; color: var(--muted); }

.about__right { display: flex; flex-direction: column; gap: 20px; }
.about__body .lead + .lead { margin-top: 16px; }
.about__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }

.about__photo-box {
  border-radius: 20px; overflow: hidden;
  box-shadow: 0 20px 60px rgba(11,29,81,.18);
}
.about__photo-box img {
  width: 100%; height: 420px; object-fit: cover; object-position: top; display: block;
}
.about__photo-name {
  margin-top: 14px; text-align: center;
}
.about__photo-name strong {
  display: block; font-size: 1.1rem; font-weight: 700; color: var(--navy);
}
.about__photo-name span {
  font-size: .8rem; color: var(--muted); letter-spacing: .08em; text-transform: uppercase;
}

.about__map-box {
  position: relative; background: var(--grad-navy);
  border-radius: var(--radius-xl); overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.about__map-box img.zone { width: 100%; height: 100%; object-fit: contain; }
.about__map-overlay {
  position: absolute; bottom: 16px; left: 16px;
  background: rgba(11,29,81,.85); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius); padding: 10px 16px;
}
.about__map-overlay span { display: block; font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.45); }
.about__map-overlay strong { font-size: 13px; font-weight: 800; color: white; }
.about__pull-quote { background: var(--off-white); border-radius: var(--radius-lg); padding: 24px 28px; border-left: 3px solid var(--red); }
.about__pull-quote i { color: var(--red); font-size: 1.2rem; margin-bottom: 12px; display: block; }
.about__pull-quote p { font-size: .9rem; font-style: italic; color: var(--muted); line-height: 1.75; }

/* ============================================================
   CLIENTS — STRIP
============================================================ */
.clients__header { margin-bottom: 48px; }
.clients__header .eyebrow { display: flex; }

.clients__strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: 1px solid var(--border); border-radius: var(--radius-xl); overflow: hidden; }
.client-tile {
  padding: 36px 28px; position: relative; overflow: hidden;
  border-right: 1px solid var(--border);
  transition: background .3s;
}
.client-tile:last-child { border-right: none; }
.client-tile:hover { background: var(--navy); }
.client-tile:hover .client-tile__num { color: rgba(255,255,255,.07); }
.client-tile:hover .client-tile__icon { color: var(--red); background: rgba(201,27,27,.15); }
.client-tile:hover h3 { color: var(--white); }
.client-tile:hover p { color: rgba(255,255,255,.55); }

.client-tile__num { position: absolute; top: 10px; right: 14px; font-family: 'DM Serif Display', serif; font-size: 5rem; font-weight: 400; line-height: 1; color: rgba(201,27,27,.15); pointer-events: none; transition: color .3s; }
.client-tile__icon { width: 48px; height: 48px; border-radius: 12px; background: rgba(11,29,81,.07); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: var(--navy); margin-bottom: 20px; transition: var(--trans-fast); }
.client-tile h3 { font-size: .9rem; font-weight: 700; color: var(--navy); margin-bottom: 10px; line-height: 1.3; letter-spacing: -.01em; transition: color .3s; }
.client-tile p { font-size: .82rem; line-height: 1.75; color: var(--muted); font-weight: 300; transition: color .3s; }

/* ============================================================
   SERVICES — BENTO
============================================================ */
.services__header { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; margin-bottom: 48px; }
.services__header-desc { max-width: 440px; }

.bento { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: auto auto; gap: 16px; }

.bento-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); padding: 36px 32px;
  position: relative; overflow: hidden; transition: var(--trans);
}
.bento-card::before {
  content: attr(data-num); /* not used */
  position: absolute; bottom: -10px; right: 12px;
  font-family: 'DM Serif Display', serif; font-size: 5.5rem;
  font-weight: 400; line-height: 1; color: rgba(11,29,81,.045);
  pointer-events: none; transition: color .4s;
}
.bento-card:hover { border-color: transparent; box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.bento-card:hover::before { color: rgba(11,29,81,.07); }

.bento-card--featured { grid-column: span 2; }
.bento-card--dark { background: var(--grad-navy); border-color: transparent; }
.bento-card--dark::before { color: rgba(255,255,255,.04); }
.bento-card--dark:hover { transform: translateY(-5px); }
.bento-card--accent { background: var(--off-white); }

.bento-card__num { font-family: 'DM Serif Display', serif; font-size: 1.6rem; font-weight: 400; color: #FF1A1A; line-height: 1; margin-bottom: 16px; }
.bento-card--dark .bento-card__num { color: #FF3333; }

.bento-card__icon { width: 52px; height: 52px; border-radius: 12px; background: rgba(11,29,81,.07); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: var(--navy); margin-bottom: 20px; transition: var(--trans-fast); }
.bento-card--dark .bento-card__icon { background: rgba(255,255,255,.1); color: white; }
.bento-card:hover .bento-card__icon { background: var(--grad-red); color: white; box-shadow: var(--shadow-red); }
.bento-card--dark:hover .bento-card__icon { background: rgba(255,255,255,.15); }

.bento-card h3 { font-size: 1rem; font-weight: 700; color: var(--navy); margin-bottom: 12px; line-height: 1.3; letter-spacing: -.01em; }
.bento-card--dark h3 { color: var(--white); }
.bento-card p { font-size: .875rem; line-height: 1.8; color: var(--muted); font-weight: 300; }
.bento-card--dark p { color: rgba(255,255,255,.6); }

.bento-card__list { list-style: none; margin-top: 20px; display: flex; flex-direction: column; gap: 0; }
.bento-card__list li { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.08); font-size: 12px; color: rgba(255,255,255,.65); }
.bento-card__list li::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--red-3); flex-shrink: 0; }
.bento-card__list li:last-child { border-bottom: none; }

.bento-cta {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 24px;
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--navy); text-decoration: none;
  border-bottom: 2px solid var(--red); padding-bottom: 4px;
  transition: var(--trans-fast);
}
.bento-cta i { transition: transform .25s cubic-bezier(.22,.68,0,1.4); }
.bento-cta:hover { color: var(--red); }
.bento-cta:hover i { transform: translateX(4px); }

/* ============================================================
   ENGAGEMENTS — ROW LAYOUT
============================================================ */
.engagements__header { margin-bottom: 56px; }

.eng-rows { display: flex; flex-direction: column; gap: 2px; border-radius: var(--radius-xl); overflow: hidden; }
.eng-row {
  display: grid; grid-template-columns: 100px 1px 1fr;
  gap: 48px; align-items: center;
  padding: 40px 44px; background: rgba(255,255,255,.03);
  transition: background .3s;
}
.eng-row:hover { background: rgba(255,255,255,.06); }
.eng-row__num { font-family: 'DM Serif Display', serif; font-size: 4.5rem; font-weight: 400; line-height: 1; letter-spacing: -.04em; background: linear-gradient(135deg, rgba(224,32,32,.85) 0%, rgba(232,80,58,.3) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.eng-row__divider { width: 1px; height: 80px; background: rgba(255,255,255,.1); align-self: center; }
.eng-row__tag { display: inline-flex; align-items: center; gap: 7px; background: rgba(201,27,27,.12); border: 1px solid rgba(201,27,27,.2); border-radius: 100px; padding: 5px 14px; font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,150,150,.85); margin-bottom: 14px; }
.eng-row__body p { font-size: .92rem; line-height: 1.9; color: rgba(255,255,255,.55); font-weight: 300; max-width: 640px; }

/* ============================================================
   PLATFORM — SPLIT FULL
============================================================ */
.platform-section {
  display: grid; grid-template-columns: 1fr 1fr; min-height: 700px;
}
.platform-section__left { background: var(--grad-navy); display: flex; align-items: center; }
.platform-section__left-inner { padding: 80px 64px; max-width: 560px; margin: 0 auto; }

.plat-features { margin-top: 36px; display: flex; flex-direction: column; gap: 0; border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); overflow: hidden; }
.plat-feat { display: flex; align-items: flex-start; gap: 20px; padding: 20px 24px; border-bottom: 1px solid rgba(255,255,255,.07); transition: background .2s; }
.plat-feat:last-child { border-bottom: none; }
.plat-feat:hover { background: rgba(255,255,255,.04); }
.plat-feat__num { font-size: 11px; font-weight: 800; color: var(--red); letter-spacing: 1px; flex-shrink: 0; width: 24px; margin-top: 2px; }
.plat-feat strong { display: block; font-size: 12px; font-weight: 700; letter-spacing: .5px; color: var(--white); margin-bottom: 4px; }
.plat-feat p { font-size: .82rem; color: rgba(255,255,255,.5); line-height: 1.65; }

.platform-section__right { background: var(--off-white); display: flex; align-items: center; justify-content: center; position: relative; padding: 60px 48px; }

/* Platform screen */
.platform__visual { position: relative; width: 100%; max-width: 440px; }
.platform__screen { background: var(--white); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg), 0 0 0 1px rgba(11,29,81,.08); overflow: hidden; transform: perspective(1200px) rotateY(-4deg) rotateX(2deg); transition: transform .6s cubic-bezier(.22,.68,0,1.15); }
.platform-section__right:hover .platform__screen { transform: none; }
.platform__screen-bar { background: var(--grad-navy); padding: 13px 18px; display: flex; align-items: center; gap: 7px; }
.platform__screen-bar span { width: 10px; height: 10px; border-radius: 50%; }
.platform__screen-bar span:nth-child(1) { background: #ff5f57; }
.platform__screen-bar span:nth-child(2) { background: #febc2e; }
.platform__screen-bar span:nth-child(3) { background: #28c840; }
.platform__screen-url { flex: 1; text-align: center; font-size: 10px; color: rgba(255,255,255,.25); letter-spacing: .5px; }
.platform__screen-body { padding: 24px; }
.ps-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.ps-title { font-size: 13px; font-weight: 800; color: var(--navy); letter-spacing: -.01em; }
.ps-date { font-size: 10px; color: var(--muted); }
.ps-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 20px; }
.ps-stat { background: var(--off-white); border-radius: 10px; padding: 14px; text-align: center; border: 1px solid var(--border); }
.ps-stat__num { font-size: 1.3rem; font-weight: 800; color: var(--navy); line-height: 1; letter-spacing: -.03em; }
.ps-stat__lbl { font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.ps-section-label { font-size: 9px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.ps-list { display: flex; flex-direction: column; gap: 4px; }
.ps-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px; background: var(--off-white); border-radius: 8px; font-size: 11px; color: var(--ink); font-weight: 500; border: 1px solid var(--border); }
.ps-item > span:nth-child(2) { flex: 1; }
.ps-item__dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.ps-item__dot--green  { background: #16a34a; box-shadow: 0 0 0 2px rgba(22,163,74,.2); }
.ps-item__dot--blue   { background: #2563eb; box-shadow: 0 0 0 2px rgba(37,99,235,.2); }
.ps-item__dot--orange { background: #d97706; box-shadow: 0 0 0 2px rgba(217,119,6,.2); }
.ps-item__badge { font-size: 9px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; padding: 3px 9px; border-radius: 100px; white-space: nowrap; background: rgba(22,163,74,.1); color: #16a34a; }
.ps-item__badge--pending { background: rgba(37,99,235,.1); color: #2563eb; }
.ps-item__badge--new    { background: rgba(217,119,6,.1);  color: #d97706; }
.platform__pill { position: absolute; display: flex; align-items: center; gap: 8px; background: var(--white); border-radius: 100px; padding: 9px 18px; box-shadow: var(--shadow-md); border: 1px solid var(--border); font-size: 11px; font-weight: 700; color: var(--navy); white-space: nowrap; }
.platform__pill i { color: var(--red); }
.platform__pill--1 { bottom: 40px; left: 12px; }
.platform__pill--2 { top: 44px; right: 12px; }

/* ============================================================
   FAQ
============================================================ */
.faq-layout { display: grid; grid-template-columns: 320px 1fr; gap: 80px; align-items: start; }
.faq-layout__intro { position: sticky; top: 100px; }
.faq__item { border-bottom: 1px solid var(--border); }
.faq__item:first-child { border-top: 1px solid var(--border); }
.faq__question { width: 100%; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; background: none; border: none; padding: 22px 0; cursor: pointer; text-align: left; font-family: var(--font); }
.faq__question span { font-size: .95rem; font-weight: 600; color: var(--navy); line-height: 1.45; letter-spacing: -.01em; }
.faq__question i { font-size: .75rem; color: var(--red); flex-shrink: 0; margin-top: 5px; transition: transform .35s cubic-bezier(.22,.68,0,1.4), color .2s; }
.faq__question[aria-expanded="true"] i { transform: rotate(45deg); }
.faq__question[aria-expanded="true"] span { color: var(--red); }
.faq__answer { overflow: hidden; max-height: 0; transition: max-height .45s cubic-bezier(.4,0,.2,1); }
.faq__answer p { padding: 0 40px 22px 0; font-size: .9rem; color: var(--muted); line-height: 1.9; font-weight: 300; }

/* ============================================================
   CONDITIONS
============================================================ */
.cond-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.cond-layout__left { position: sticky; top: 100px; }
.cond-list { margin-top: 8px; }
.cond-item { display: flex; gap: 20px; padding: 26px 0; border-bottom: 1px solid var(--border); transition: padding-left .25s; }
.cond-item:last-child { border-bottom: none; }
.cond-item:hover { padding-left: 4px; }
.cond-icon { width: 44px; height: 44px; min-width: 44px; background: var(--off-white); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--red); font-size: .95rem; transition: var(--trans-fast); border: 1px solid var(--border); }
.cond-item:hover .cond-icon { background: var(--grad-navy); color: var(--white); border-color: transparent; box-shadow: 0 6px 20px rgba(11,29,81,.2); }
.cond-item h5 { font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--navy); margin-bottom: 6px; }
.cond-item p { font-size: .875rem; color: var(--muted); line-height: 1.75; }

/* ============================================================
   CONTACT — SPLIT FULL
============================================================ */
.contact-section { display: grid; grid-template-columns: 1fr 1fr; min-height: 700px; }
.contact-section__left { background: var(--ink); display: flex; align-items: center; position: relative; overflow: hidden; }
.contact-section__left::before { content: ''; position: absolute; bottom: -120px; right: -120px; width: 400px; height: 400px; border-radius: 50%; background: radial-gradient(circle, rgba(201,27,27,.12) 0%, transparent 70%); pointer-events: none; }
.contact-section__left-inner { padding: 80px 64px; position: relative; z-index: 1; }

.contact-info-list { display: flex; flex-direction: column; gap: 16px; }
.contact-info-item {
  display: flex; align-items: center; gap: 16px;
  padding: 16px 20px; border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.04);
  text-decoration: none; transition: background .2s;
}
.contact-info-item:hover { background: rgba(255,255,255,.08); }
.contact-info-item__icon { width: 40px; height: 40px; min-width: 40px; border-radius: 10px; background: rgba(255,255,255,.08); display: flex; align-items: center; justify-content: center; color: var(--red); font-size: .9rem; }
.contact-info-item > div span { display: block; font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 3px; }
.contact-info-item > div strong { display: block; font-size: 13px; font-weight: 700; color: var(--white); }
.contact-social { display: flex; gap: 10px; margin-top: 36px; }
.contact-social a { width: 36px; height: 36px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.4); text-decoration: none; font-size: .8rem; transition: var(--trans-fast); }
.contact-social a:hover { background: var(--red); border-color: var(--red); color: white; transform: translateY(-2px); }

.contact-section__right { background: var(--off-white); display: flex; align-items: center; justify-content: center; padding: 80px 64px; }
.contact-form-box { background: var(--white); border-radius: var(--radius-xl); padding: 48px; box-shadow: var(--shadow-md); border: 1px solid var(--border); width: 100%; max-width: 480px; }
.contact-form-box__header { margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.contact-form-box__header h3 { font-size: 1.3rem; font-weight: 800; color: var(--navy); letter-spacing: -.02em; margin-bottom: 4px; }
.contact-form-box__header p { font-size: 12px; color: var(--muted); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--navy); margin-bottom: 8px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; border: 1.5px solid var(--border); border-radius: var(--radius); padding: 13px 16px; font-family: var(--font); font-size: .9rem; color: var(--ink); background: var(--off-white); transition: var(--trans-fast); outline: none; resize: vertical; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--navy); background: var(--white); box-shadow: 0 0 0 4px rgba(11,29,81,.06); }
.form-group textarea { min-height: 110px; }
.form-group select { cursor: pointer; }
.btn-submit { width: 100%; justify-content: center; font-size: 12px; padding: 16px; border-radius: 100px; }

/* ============================================================
   FOOTER
============================================================ */
.footer { background: var(--ink); border-top: 1px solid rgba(255,255,255,.05); position: relative; overflow: hidden; }
.footer::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 1px; background: linear-gradient(90deg, transparent, rgba(201,27,27,.4) 50%, transparent); }
.footer__top { padding: 64px 0 44px; display: grid; grid-template-columns: 260px 1fr 1fr 1fr; gap: 48px; }
.footer__brand-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.footer__brand-logo img { height: 56px; width: auto; object-fit: contain; filter: brightness(0) invert(1); opacity: .9; }
.footer__brand-logo span { font-size: 13px; font-weight: 900; letter-spacing: 4px; text-transform: uppercase; color: var(--white); }
.footer__brand p { font-size: .82rem; line-height: 1.85; color: rgba(255,255,255,.35); margin-bottom: 24px; }
.footer__social { display: flex; gap: 8px; }
.footer__social a { width: 34px; height: 34px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.07); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.4); text-decoration: none; font-size: .8rem; transition: var(--trans-fast); }
.footer__social a:hover { background: var(--red); border-color: var(--red); color: white; transform: translateY(-2px); }
.footer__col h4 { font-size: 9px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 20px; }
.footer__col ul { list-style: none; }
.footer__col ul li { margin-bottom: 10px; }
.footer__col ul li a { font-size: .82rem; color: rgba(255,255,255,.45); text-decoration: none; transition: color .2s; }
.footer__col ul li a:hover { color: rgba(255,255,255,.9); }
.footer__col .contact-line { display: flex; align-items: flex-start; gap: 10px; font-size: .82rem; color: rgba(255,255,255,.45); margin-bottom: 12px; }
.footer__col .contact-line i { color: var(--red); margin-top: 2px; font-size: .8rem; }
.footer__col .contact-line a { color: rgba(255,255,255,.45); text-decoration: none; transition: color .2s; }
.footer__col .contact-line a:hover { color: white; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.05); padding: 20px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer__bottom p { font-size: .75rem; color: rgba(255,255,255,.2); }
.footer__bottom-links { display: flex; gap: 20px; }
.footer__bottom-links a { font-size: .75rem; color: rgba(255,255,255,.2); text-decoration: none; transition: color .2s; }
.footer__bottom-links a:hover { color: rgba(255,255,255,.55); }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 1100px) {
  .accueil__main { grid-template-columns: 1fr; }
  .accueil__right { display: none; }
  .about__layout { grid-template-columns: 0 1fr 1fr; }
  .about__side-label { display: none; }
  .platform-section { grid-template-columns: 1fr; }
  .platform-section__left-inner { padding: 60px 40px; max-width: 100%; }
  .platform-section__right { padding: 60px 40px; }
  .contact-section { grid-template-columns: 1fr; }
  .contact-section__left-inner { padding: 60px 40px; }
  .contact-section__right { padding: 60px 40px; }
  .bento-card--featured { grid-column: span 1; }
  .bento { grid-template-columns: repeat(2, 1fr); }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 36px; }
}

@media (max-width: 900px) {
  .section { padding: 80px 0; }
  .navbar__links { display: none; }
  .navbar__toggle { display: flex; }
  .clients__strip { grid-template-columns: 1fr 1fr; }
  .client-tile { border-bottom: 1px solid var(--border); }
  .client-tile:nth-child(even) { border-right: none; }
  .bento { grid-template-columns: 1fr; }
  .bento-card--featured { grid-column: span 1; }
  .eng-row { grid-template-columns: 70px 1px 1fr; gap: 24px; padding: 32px 24px; }
  .faq-layout { grid-template-columns: 1fr; gap: 40px; }
  .faq-layout__intro { position: static; }
  .cond-layout { grid-template-columns: 1fr; }
  .cond-layout__left { position: static; }
  .footer__top { grid-template-columns: 1fr 1fr; }
  .about__layout { grid-template-columns: 1fr; }
  .about__right { display: none; }
  .services__header { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .section { padding: 60px 0; }
  .container { padding: 0 18px; }
  .accueil__title { font-size: 2.8rem; }
  .accueil__actions { flex-direction: column; }
  .accueil__actions .btn { justify-content: center; }
  .accueil__topbar-right { display: none; }
  .clients__strip { grid-template-columns: 1fr; border-radius: var(--radius-lg); }
  .client-tile { border-right: none; }
  .eng-row { grid-template-columns: 1fr; gap: 16px; padding: 28px 20px; }
  .eng-row__divider { display: none; }
  .eng-row__num { font-size: 3rem; }
  .form-row { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr; gap: 32px; }
  .footer__bottom { flex-direction: column; text-align: center; }
  .contact-section__left-inner { padding: 48px 24px; }
  .contact-section__right { padding: 48px 24px; }
  .contact-form-box { padding: 32px 24px; }
  .platform-section__left-inner { padding: 48px 24px; }
  .platform-section__right { padding: 48px 24px; }
}


/* ============================================================
   PAGE ACCUEIL (pages internes)
============================================================ */
.page-accueil {
  background: var(--grad-navy);
  padding: 140px 0 80px;
  position: relative;
  overflow: hidden;
}
.page-accueil__wordmark {
  position: absolute; top: 0; right: 0; bottom: 0; left: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'DM Serif Display', serif;
  font-size: 120px; font-size: clamp(72px, 16vw, 190px);
  font-weight: 700;
  color: rgba(255,255,255,.04);
  letter-spacing: .06em;
  pointer-events: none; user-select: none; white-space: nowrap;
}
.page-accueil__inner { position: relative; z-index: 1; }
.page-accueil__breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: .8rem; color: rgba(255,255,255,.5); margin-bottom: 28px;
}
.page-accueil__breadcrumb a { color: rgba(255,255,255,.5); text-decoration: none; }
.page-accueil__breadcrumb a:hover { color: #fff; }
.page-accueil__breadcrumb i { font-size: .65rem; }
.page-accueil__title {
  font-size: 2.8rem; font-size: clamp(2.1rem, 5vw, 3.7rem);
  font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 20px;
}
.page-accueil__title em {
  font-family: 'DM Serif Display', serif; font-weight: 400; font-style: italic;
  background: var(--grad-red);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.page-accueil__sub {
  color: rgba(255,255,255,.7); font-size: 1.05rem; max-width: 560px; line-height: 1.7;
}


/* ============================================================
   UTILITAIRES COMMUNS
============================================================ */
.text-gradient-red {
  font-family: 'DM Serif Display', serif; font-weight: 400; font-style: italic;
  background: var(--grad-red);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.text-gradient-ocean {
  font-family: 'DM Serif Display', serif; font-weight: 400; font-style: italic;
  background: linear-gradient(135deg,#075985,#0284c7);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.text-gradient-violet {
  font-family: 'DM Serif Display', serif; font-weight: 400; font-style: italic;
  background: linear-gradient(135deg,#4c1d95,#6d28d9);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.section-label {
  font-size: .85rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted);
  margin: 32px 0 14px; display: block;
}
.btn-group { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }

.quote-box {
  margin-top: 32px; padding: 24px;
  background: var(--off-white); border-radius: 14px; border: 1px solid var(--border);
}
.quote-box__icon { color: var(--red); font-size: 1.5rem; margin-bottom: 10px; display: block; }
.quote-box__text { font-size: .95rem; color: var(--ink); line-height: 1.7; font-style: italic; }
.quote-box__signature {
  margin-top: 16px; display: flex; align-items: center; gap: 12px;
}
.quote-box__avatar {
  width: 36px; height: 36px; background: var(--grad-navy); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .85rem; flex-shrink: 0;
}
.quote-box__name { font-size: .88rem; font-weight: 700; color: var(--ink); display: block; }
.quote-box__role { font-size: .78rem; color: var(--muted); }


/* ============================================================
   PAGES RÉGIONS
============================================================ */
.region-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start;
}
.cities-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 28px 0;
}
.city-tag {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; text-decoration: none;
  background: var(--off-white); border: 1px solid var(--border);
  border-radius: var(--radius); font-size: .85rem; font-weight: 500; color: var(--ink);
  transition: var(--trans-fast);
}
.city-tag:hover { border-color: var(--red); background: rgba(201,27,27,.04); }
.city-tag i { color: var(--red); font-size: .7rem; flex-shrink: 0; }

.services-mini {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 28px;
}
.service-mini-card {
  padding: 20px; background: var(--off-white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); transition: var(--trans-fast);
}
.service-mini-card:hover { border-color: var(--red); box-shadow: 0 4px 24px rgba(201,27,27,.1); }
.service-mini-card i { color: var(--red); font-size: 1.2rem; margin-bottom: 10px; display: block; }
.service-mini-card h4 { font-size: .9rem; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.service-mini-card p { font-size: .82rem; color: var(--muted); line-height: 1.5; }

.region-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 32px;
}
.region-stat {
  background: var(--off-white); border: 1px solid var(--border);
  border-radius: 14px; padding: 20px 14px; text-align: center;
}
.region-stat__num {
  font-family: 'DM Serif Display', serif; font-size: 1.9rem; font-weight: 700;
  background: var(--grad-red); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.region-stat__lbl { font-size: .75rem; color: var(--muted); margin-top: 4px; line-height: 1.4; }

.region-cta-box {
  background: var(--grad-navy);
  border-radius: var(--radius-lg); padding: 36px; margin-top: 40px; color: #fff;
}
.region-cta-box h3 { font-size: 1.3rem; font-weight: 700; margin-bottom: 10px; }
.region-cta-box p { color: rgba(255,255,255,.75); font-size: .9rem; line-height: 1.6; margin-bottom: 24px; }
.region-cta-box .btn-group { margin-top: 0; }

@media (max-width: 900px) {
  .region-layout { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 600px) {
  .cities-grid { grid-template-columns: repeat(2, 1fr); }
  .services-mini { grid-template-columns: 1fr; }
  .region-stats { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   PAGE ZONE D'INTERVENTION
============================================================ */
.zone-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start;
}
.zone-map-box {
  position: relative;
  background: linear-gradient(135deg, #0B1D51 0%, #1a2d80 60%, #0e3a6e 100%);
  border-radius: var(--radius-xl); overflow: hidden;
  padding: 40px 32px; border: none;
  box-shadow: 0 16px 48px rgba(11,29,81,.28);
}
.zone-map-box::before {
  content: '';
  position: absolute; top: 0; right: 0; bottom: 0; left: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(201,27,27,.18) 0%, transparent 65%);
  pointer-events: none;
}
.zone-map-box img.zone {
  width: 100%; height: auto; display: block;
  position: relative; z-index: 1;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,.3));
}
.zone-map-overlay {
  position: absolute; bottom: 24px; left: 24px;
  background: var(--grad-navy); color: #fff;
  padding: 12px 20px; border-radius: var(--radius);
  display: flex; flex-direction: column; gap: 2px;
}
.zone-map-overlay span { font-size: .72rem; opacity: .7; text-transform: uppercase; letter-spacing: .08em; }
.zone-map-overlay strong { font-size: 1rem; font-weight: 700; }

.zone-regions {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 28px 0;
}
.zone-region {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; background: var(--off-white);
  border-radius: var(--radius); border: 1px solid var(--border);
  font-size: .88rem; font-weight: 500; color: var(--ink);
  transition: var(--trans); text-decoration: none;
}
.zone-region:hover { border-color: var(--red); background: rgba(201,27,27,.04); }
.zone-region i { color: var(--red); font-size: .75rem; flex-shrink: 0; }

.zone-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 40px;
}
.zone-stat {
  background: var(--off-white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 20px 16px; text-align: center;
}
.zone-stat__num {
  font-family: 'DM Serif Display', serif; font-size: 2rem; font-weight: 700;
  background: var(--grad-red); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}
.zone-stat__lbl { font-size: .78rem; color: var(--muted); margin-top: 4px; line-height: 1.4; }

.zone-pull-quote {
  background: var(--grad-navy); color: #fff;
  border-radius: var(--radius-lg); padding: 28px 32px; margin-top: 24px;
}
.zone-pull-quote i { font-size: 1.8rem; color: var(--red); margin-bottom: 12px; display: block; }
.zone-pull-quote p { font-size: 1rem; line-height: 1.7; color: rgba(255,255,255,.85); }

@media (max-width: 900px) {
  .zone-layout { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 600px) {
  .zone-stats { grid-template-columns: repeat(2, 1fr); }
  .zone-regions { grid-template-columns: 1fr; }
}

/* Espace client footer */
.footer-espace-btn { font-size: 11px !important; padding: 10px 20px !important; }

/* ============================================================
   ANNOUNCE BAR
============================================================ */
.announce-bar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1002;
  background: var(--grad-red);
  padding: 0 24px; height: 38px;
  display: flex; align-items: center; justify-content: center;
}
.announce-bar__inner {
  display: flex; align-items: center; gap: 14px;
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: rgba(255,255,255,.92);
  white-space: nowrap; overflow: hidden;
}
.announce-bar__dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,.85); animation: pulse 2s infinite;
}
.announce-bar__sep { color: rgba(255,255,255,.3); flex-shrink: 0; }
.announce-bar__cities { color: rgba(255,255,255,.7); overflow: hidden; text-overflow: ellipsis; }
.announce-bar__cta {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3);
  color: var(--white); text-decoration: none; padding: 3px 12px;
  border-radius: 100px; font-size: 10px; font-weight: 800; letter-spacing: 1.5px;
  transition: var(--trans-fast); flex-shrink: 0;
}
.announce-bar__cta:hover { background: rgba(255,255,255,.28); }
.announce-bar__cta i { font-size: .7em; }

/* Navbar offset for announce bar */
.navbar--offset { top: 38px; }

/* ============================================================
   HERO — MISSIONS CARD & FLOAT BADGES
============================================================ */
.hero-missions-card {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-xl); overflow: hidden;
  -webkit-backdrop-filter: blur(28px); backdrop-filter: blur(28px);
  box-shadow: 0 32px 80px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.1);
  margin-bottom: 12px;
}
.hero-missions-card__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,.08);
}
.hero-missions-card__title {
  font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.7); display: flex; align-items: center; gap: 8px;
}
.hero-missions-card__title i { color: var(--gold); }
.hero-missions-card__live {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.4);
}
.hero-missions-card__live .dot { width: 5px; height: 5px; background: #16a34a; animation: pulse 2s infinite; }
.hero-missions-card__list { padding: 8px 0; }
.hero-missions-card__item {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 20px; border-bottom: 1px solid rgba(255,255,255,.05);
  transition: background .2s;
}
.hero-missions-card__item:last-child { border-bottom: none; }
.hero-missions-card__item:hover { background: rgba(255,255,255,.04); }
.hero-missions-card__dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.hero-missions-card__info { flex: 1; min-width: 0; }
.hero-missions-card__info strong {
  display: block; font-size: 12px; font-weight: 700; color: var(--white);
  margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.hero-missions-card__info span {
  font-size: 10px; color: rgba(255,255,255,.42); display: flex; align-items: center; gap: 4px;
}
.hero-missions-card__info span i { font-size: .75em; color: rgba(255,255,255,.25); }
.hero-missions-card__tag {
  font-size: 9px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase;
  padding: 3px 9px; border-radius: 100px; white-space: nowrap; flex-shrink: 0;
}
.hero-missions-card__tag--new  { background: rgba(217,119,6,.2);  color: #fbbf24; }
.hero-missions-card__tag--open { background: rgba(22,163,74,.15); color: #4ade80; }
.hero-missions-card__footer {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 20px; background: rgba(201,27,27,.15); border-top: 1px solid rgba(201,27,27,.2);
  font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: rgba(255,150,150,.9); text-decoration: none; transition: background .2s;
}
.hero-missions-card__footer:hover { background: rgba(201,27,27,.25); }
.hero-missions-card__footer i { font-size: .8em; transition: transform .25s cubic-bezier(.22,.68,0,1.4); }
.hero-missions-card__footer:hover i { transform: translateX(4px); }

/* Float badges */
.hero-float-badges {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px;
}
.hero-float-badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  border-radius: 100px; padding: 7px 14px;
  font-size: 11px; font-weight: 600; color: rgba(255,255,255,.7);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
}

/* Hero inline stats */
.hero-inline-stats {
  display: flex; align-items: center; gap: 0;
  margin-top: 36px; border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg); overflow: hidden;
}
.hero-inline-stat {
  flex: 1; text-align: center; padding: 14px 16px;
  border-right: 1px solid rgba(255,255,255,.1);
}
.hero-inline-stat:last-child { border-right: none; }
.hero-inline-stat__sep { display: none; }
.hero-inline-stat strong {
  display: block; font-size: 1.4rem; font-weight: 800; color: var(--white);
  line-height: 1; letter-spacing: -.03em; margin-bottom: 4px;
}
.hero-inline-stat span {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.4);
}

/* ============================================================
   SECTION INTRO (titres de section centrés ou alignés)
============================================================ */
.section-intro {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end;
  margin-bottom: 56px;
}
.section-intro__desc { max-width: 420px; }
.section-intro--center {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; margin-bottom: 60px;
}
.section-intro--center .eyebrow { align-self: center; }

/* ============================================================
   POSTES GRID — 4 cartes
============================================================ */
.postes-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.poste-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); overflow: hidden; transition: var(--trans);
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  position: relative;
}
.poste-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: var(--grad-red); transform: scaleX(0); transform-origin: left;
  transition: transform .35s cubic-bezier(.22,.68,0,1.15);
}
.poste-card:hover { border-color: transparent; box-shadow: var(--shadow-lg); transform: translateY(-6px); }
.poste-card:hover::after { transform: scaleX(1); }

/* Bandeau photo en haut de chaque carte */
.pcb {
  height: 160px; flex-shrink: 0;
  position: relative; overflow: hidden;
}
/* Couleur de fallback si l'image ne charge pas */
.pcb--navy   { background-color: #0b1d51; }
.pcb--ocean  { background-color: #0c4a6e; }
.pcb--blue   { background-color: #1e3a8a; }
.pcb--violet { background-color: #2e1065; }
/* Image couvre tout le bandeau */
.pcb__bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}

.pcb__num {
  position: absolute; top: 12px; left: 16px; z-index: 1;
  font-size: 11px; font-weight: 800; letter-spacing: 1.5px;
  color: rgba(255,255,255,.35);
  font-family: 'Inter', sans-serif;
}

/* Corps de carte (sous le bandeau) */
.poste-card__body {
  padding: 24px 24px 28px; display: flex; flex-direction: column; flex: 1;
}

.poste-card--featured {
  background: var(--grad-navy); border-color: transparent;
  grid-row: span 1;
}
.poste-card--featured::after { background: rgba(255,255,255,.2); }
.poste-card--featured .pcb {
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.poste-card__icon {
  width: 44px; height: 44px; border-radius: 10px;
  background: rgba(11,29,81,.07); display: flex; align-items: center;
  justify-content: center; font-size: 1.1rem; color: var(--navy);
  margin-bottom: 14px; transition: var(--trans-fast); flex-shrink: 0;
}
.poste-card--featured .poste-card__icon { background: rgba(255,255,255,.12); color: var(--white); }
.poste-card:hover .poste-card__icon { background: var(--grad-red); color: var(--white); box-shadow: var(--shadow-red); }
.poste-card h3 { font-size: .95rem; font-weight: 700; color: var(--navy); margin-bottom: 10px; line-height: 1.3; }
.poste-card--featured h3 { color: var(--white); }
.poste-card p { font-size: .84rem; color: var(--muted); line-height: 1.8; font-weight: 300; flex: 1; }
.poste-card--featured p { color: rgba(255,255,255,.6); }
.poste-card__tasks {
  list-style: none; margin: 14px 0; display: flex; flex-direction: column; gap: 0;
}
.poste-card__tasks li {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.08);
  font-size: 11.5px; color: rgba(255,255,255,.65);
}
.poste-card__tasks li::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--red-3); flex-shrink: 0; }
.poste-card__tasks li:last-child { border-bottom: none; }
.ptag {
  display: inline-flex; padding: 4px 10px; border-radius: 100px;
  font-size: 9.5px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase;
  color: var(--navy); background: rgba(11,29,81,.07); border: 1px solid rgba(11,29,81,.1);
  transition: var(--trans-fast);
}
.poste-card--featured .ptag { color: rgba(255,255,255,.7); background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.15); }
.poste-card:hover .ptag { color: var(--navy); }
.poste-card--featured:hover .ptag { color: rgba(255,255,255,.9); }
.poste-card__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.poste-card__link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 18px; font-size: .8rem; font-weight: 700;
  color: var(--navy); letter-spacing: .3px;
  transition: gap .2s;
}
.poste-card--featured .poste-card__link { color: rgba(255,255,255,.8); }
.poste-card:hover .poste-card__link { gap: 10px; }

/* Tâches pour cartes non-featured */
.poste-card:not(.poste-card--featured) .poste-card__tasks li {
  border-bottom-color: var(--border); color: var(--muted);
}
.poste-card:not(.poste-card--featured) .poste-card__tasks li::before { background: var(--navy); }
.postes-cta {
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: center;
  margin-top: 48px;
}

/* ============================================================
   PROCESSUS — stepper horizontal
============================================================ */
.proc-steps-h {
  display: flex; gap: 0; margin-top: 64px; position: relative;
}
.proc-steps-h::before {
  content: ''; position: absolute; top: 27px; left: 28px; right: 28px; height: 1px;
  background: var(--border); z-index: 0;
}
.proc-step-h {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 0 12px; position: relative;
}
.proc-step-h__circle {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--white); border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--navy); position: relative; z-index: 1;
  margin-bottom: 24px; transition: var(--trans);
  box-shadow: var(--shadow-sm);
}
.proc-step-h__num {
  position: absolute; top: -6px; right: -6px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--red); color: white;
  font-size: 9px; font-weight: 800; letter-spacing: .5px;
  display: flex; align-items: center; justify-content: center;
}
.proc-step-h:hover .proc-step-h__circle {
  background: var(--grad-navy); color: var(--white); border-color: transparent;
  box-shadow: 0 8px 24px rgba(11,29,81,.25); transform: translateY(-4px);
}
.proc-step-h__circle--accent { background: var(--grad-red); border-color: transparent; color: var(--white); box-shadow: var(--shadow-red); }
.proc-step-h__circle--final { background: var(--grad-navy); border-color: transparent; color: var(--white); box-shadow: 0 8px 24px rgba(11,29,81,.2); }
.proc-step-h h4 { font-size: .88rem; font-weight: 700; color: var(--navy); margin-bottom: 10px; line-height: 1.3; }
.proc-step-h p { font-size: .8rem; color: var(--muted); line-height: 1.75; }
.proc-step-h__line { display: none; }

/* ============================================================
   PROFIL RECHERCHÉ
============================================================ */
.profil-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start;
}
.profil-layout__left { position: sticky; top: 120px; }
.profil-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); overflow: hidden;
  box-shadow: var(--shadow-md);
}
.profil-card__header {
  display: flex; align-items: center; gap: 12px;
  padding: 20px 28px; background: var(--off-white);
  border-bottom: 1px solid var(--border);
  font-size: 12px; font-weight: 700; letter-spacing: .5px; color: var(--navy);
}
.profil-card__header i { color: var(--red); font-size: 1rem; }
.profil-list {
  list-style: none; padding: 8px 0; margin: 0;
}
.profil-list li {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 18px 28px; border-bottom: 1px solid var(--border);
  transition: background .2s;
}
.profil-list li:last-child { border-bottom: none; }
.profil-list li:hover { background: rgba(11,29,81,.02); }
.profil-list__icon {
  width: 36px; height: 36px; min-width: 36px; border-radius: 10px;
  background: rgba(201,27,27,.08); display: flex; align-items: center;
  justify-content: center; color: var(--red); font-size: .85rem;
}
.profil-list li strong { display: block; font-size: .88rem; font-weight: 700; color: var(--navy); margin-bottom: 4px; }
.profil-list li span { font-size: .82rem; color: var(--muted); line-height: 1.65; }
.profil-card__footer {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 28px; background: var(--grad-navy);
  font-size: 11px; font-weight: 700; color: rgba(255,255,255,.75); letter-spacing: .3px;
}
.profil-card__footer i { color: var(--gold); font-size: .9rem; flex-shrink: 0; }

/* ============================================================
   CONTRATS GRID
============================================================ */
.contrats-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 8px;
}
.contrat-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); padding: 36px 32px;
  transition: var(--trans); position: relative; overflow: hidden;
}
.contrat-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--border); transition: background .3s;
}
.contrat-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); border-color: transparent; }
.contrat-card:hover::before { background: var(--grad-red); }
.contrat-card--featured { background: var(--grad-navy); border-color: transparent; }
.contrat-card--featured::before { background: rgba(255,255,255,.12); }
.contrat-card--featured:hover::before { background: rgba(255,255,255,.25); }
.contrat-card__top {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 20px;
}
.contrat-card__icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: rgba(11,29,81,.07); display: flex; align-items: center;
  justify-content: center; font-size: 1.2rem; color: var(--navy);
  transition: var(--trans-fast);
}
.contrat-card--featured .contrat-card__icon { background: rgba(255,255,255,.12); color: var(--white); }
.contrat-card:hover .contrat-card__icon { background: var(--grad-red); color: var(--white); box-shadow: var(--shadow-red); }
.contrat-card--featured:hover .contrat-card__icon { background: rgba(255,255,255,.2); }
.contrat-card__badge {
  font-size: 9px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  background: var(--grad-red); color: var(--white); padding: 4px 10px; border-radius: 100px;
}
.contrat-card h3 { font-size: 1.1rem; font-weight: 800; color: var(--navy); margin-bottom: 6px; letter-spacing: -.01em; }
.contrat-card--featured h3 { color: var(--white); }
.contrat-card__type { font-size: 11px; font-weight: 600; color: var(--muted); letter-spacing: .5px; text-transform: uppercase; margin-bottom: 16px; }
.contrat-card--featured .contrat-card__type { color: rgba(255,255,255,.45); }
.contrat-card p { font-size: .875rem; color: var(--muted); line-height: 1.8; font-weight: 300; }
.contrat-card--featured p { color: rgba(255,255,255,.6); }
.contrat-card__legal {
  display: flex; align-items: center; gap: 8px; margin-top: 20px;
  padding: 10px 14px; background: rgba(255,255,255,.1); border-radius: var(--radius);
  font-size: 10px; font-weight: 700; color: rgba(255,255,255,.6); letter-spacing: .3px;
}
.contrat-card__legal i { color: var(--gold); flex-shrink: 0; }

/* ============================================================
   APP DOWNLOAD STRIP (platform section)
============================================================ */
.app-download-strip {
  margin-top: 32px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1);
}
.app-download-strip__label {
  display: block; font-size: 10px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 14px;
}
.app-download-strip__btns { display: flex; gap: 12px; flex-wrap: wrap; }
.app-btn {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius); padding: 10px 18px;
  color: var(--white); text-decoration: none; transition: var(--trans-fast);
}
.app-btn:hover { background: rgba(255,255,255,.13); border-color: rgba(255,255,255,.28); }
.app-btn i { font-size: 1.3rem; color: rgba(255,255,255,.6); flex-shrink: 0; }
.app-btn > span { display: flex; flex-direction: column; font-size: 12px; font-weight: 700; letter-spacing: .5px; line-height: 1; }
.app-btn > span small { display: block; font-size: 9px; color: rgba(255,255,255,.45); letter-spacing: 1px; line-height: 1; margin-bottom: 2px; }

/* ============================================================
   RESPONSIVE — INDEX RECRUTEMENT
============================================================ */
@media (max-width: 1100px) {
  .postes-grid { grid-template-columns: repeat(2, 1fr); }
  .poste-card--featured { grid-column: span 2; }
  .proc-steps-h { flex-wrap: wrap; gap: 24px; }
  .proc-steps-h::before { display: none; }
  .proc-step-h { flex: 0 0 calc(50% - 12px); align-items: flex-start; text-align: left; flex-direction: row; gap: 16px; }
  .proc-step-h__circle { margin-bottom: 0; flex-shrink: 0; }
  .section-intro { grid-template-columns: 1fr; gap: 20px; }
  .contrats-grid { grid-template-columns: 1fr; }
  .profil-layout { grid-template-columns: 1fr; gap: 40px; }
  .profil-layout__left { position: static; }
  .announce-bar__cities { display: none; }
}
@media (max-width: 900px) {
  .postes-grid { grid-template-columns: 1fr 1fr; }
  .poste-card--featured { grid-column: span 2; }
  .proc-step-h { flex: 0 0 100%; }
  .contrats-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .announce-bar { padding: 0 12px; }
  .announce-bar__inner { gap: 8px; }
  .postes-grid { grid-template-columns: 1fr; }
  .poste-card--featured { grid-column: span 1; }
  .hero-inline-stats { display: none; }
  .hero-float-badges { display: none; }
  .accueil__content { padding-top: 128px; }
  .navbar--offset { top: 38px; }
}

/* ============================================================
   PAGE RECRUTEMENT
============================================================ */

/* Hero recrutement */
.recru-hero__layout {
  display: grid; grid-template-columns: 1fr 360px; gap: 64px; align-items: center;
  margin-top: 32px;
}
.recru-hero__text .btn-group { margin-top: 36px; }
.recru-hero__stats {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-xl); padding: 24px;
  -webkit-backdrop-filter: blur(24px); backdrop-filter: blur(24px);
  display: grid; grid-template-columns: 1fr 1fr; gap: 3px; overflow: hidden;
}
.recru-hero__stat {
  background: rgba(255,255,255,.05); padding: 24px 18px; text-align: center;
}
.recru-hero__stat--accent { background: var(--grad-red); }
.recru-hero__stat--wide {
  grid-column: 1/-1; display: flex; align-items: center; justify-content: center;
  gap: 12px; background: rgba(255,255,255,.07) !important;
}
.recru-hero__stat--wide i { color: var(--gold); font-size: 1rem; }
.recru-hero__stat--wide span { font-size: 11px; font-weight: 500; color: rgba(255,255,255,.65); }
.recru-hero__stat-num { font-size: 2rem; font-weight: 800; color: var(--white); line-height: 1; margin-bottom: 6px; letter-spacing: -.03em; }
.recru-hero__stat-lbl { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.5); }

/* Postes strip (4 colonnes) */
.postes-strip { grid-template-columns: repeat(4, 1fr) !important; }

/* Poste tags */
.poste-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 16px; }
.poste-tag {
  display: inline-flex; padding: 4px 11px;
  border-radius: 100px; font-size: 10px; font-weight: 700; letter-spacing: .5px;
  text-transform: uppercase; color: var(--navy);
  background: rgba(11,29,81,.07); border: 1px solid rgba(11,29,81,.1);
  transition: var(--trans-fast);
}
.client-tile:hover .poste-tag { color: rgba(255,255,255,.6); background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.15); }

/* Processus de recrutement */
.proc-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start;
}
.proc-layout__left { position: sticky; top: 100px; }

.proc-steps { display: flex; flex-direction: column; }

.proc-step {
  display: grid; grid-template-columns: 64px 1fr; gap: 24px;
  padding: 8px 0 32px;
}
.proc-step__num-wrap { display: flex; flex-direction: column; align-items: center; }
.proc-step__num {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--grad-navy); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-family: 'DM Serif Display', serif; font-size: 1.2rem; font-weight: 400;
  flex-shrink: 0; box-shadow: 0 4px 16px rgba(11,29,81,.2); position: relative; z-index: 1;
  border: 2px solid rgba(255,255,255,.1);
}
.proc-step__line {
  width: 1px; flex: 1; background: var(--border); margin-top: 8px; min-height: 20px;
}
.proc-step__body { padding-top: 12px; padding-bottom: 8px; }
.proc-step__body h4 {
  font-size: .95rem; font-weight: 700; color: var(--navy);
  margin-bottom: 10px; display: flex; align-items: center; gap: 10px;
}
.proc-step__body h4 i { color: var(--red); font-size: .85rem; }
.proc-step__body p { font-size: .875rem; color: var(--muted); line-height: 1.8; }

/* Contrats bento */
.contrats-bento { grid-template-rows: auto; }

/* Responsive recrutement (page recrutement.html) */
@media (max-width: 1100px) {
  .recru-hero__layout { grid-template-columns: 1fr; }
  .recru-hero__stats { display: none; }
  .postes-strip { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 900px) {
  .proc-layout { grid-template-columns: 1fr; gap: 40px; }
  .proc-layout__left { position: static; }
}
@media (max-width: 600px) {
  .postes-strip { grid-template-columns: 1fr !important; }
  .proc-step { grid-template-columns: 48px 1fr; gap: 16px; }
  .proc-step__num { width: 40px; height: 40px; font-size: 1rem; }
}

/* ============================================================
   RESPONSIVE — CORRECTIFS COMPLÉMENTAIRES
============================================================ */

/* Supprimer la hauteur min fixe quand les sections s'empilent */
@media (max-width: 1100px) {
  .contact-section,
  .platform-section { min-height: auto; }
}

/* Tablette/mobile : afficher la photo About sous le texte */
@media (max-width: 900px) {
  .about__right { display: block; }
  .about__photo-box img { height: 280px; }
  .faq__answer p { padding-right: 12px; }
}

/* Mobile : ajuster les espacements et petits éléments */
@media (max-width: 600px) {
  .accueil__content { padding: 96px 0 56px; }
  .page-accueil { padding: 100px 0 56px; }

  .accueil__values-strip { flex-wrap: wrap; }
  .accueil__values-strip span { flex: 1 1 33%; border-bottom: 1px solid rgba(255,255,255,.08); }
  .accueil__values-strip span:nth-child(3) { border-right: none; }

  /* Masquer les pilules décoratives flottantes sur mobile */
  .platform__pill { display: none; }

  /* Bento cards : réduire le padding interne */
  .bento-card { padding: 24px 20px; }

  /* Contact form box : réduire */
  .contact-form-box { padding: 28px 18px; }

  /* Navbar logo : réduire l'image */
  .navbar__logo img { height: 48px; }

  /* Page hero interne : titre plus petit */
  .page-accueil__title { font-size: clamp(1.7rem, 7vw, 2.5rem); }
}

/* Très petits écrans (≤ 400 px) */
@media (max-width: 400px) {
  .navbar__logo-name { display: none; }
  .accueil__title { font-size: clamp(2rem, 8vw, 2.8rem); }
  .h-section { font-size: clamp(1.5rem, 6vw, 2rem); }
  .eng-row { padding: 22px 16px; }
  .section { padding: 48px 0; }
  .container { padding: 0 14px; }

  /* Zone d'intervention */
  .zone-stats { grid-template-columns: 1fr; }
  .zone-pull-quote { padding: 24px 18px; }
  .zone-pull-quote p { font-size: .9rem; }
  .zone-map-overlay { bottom: 14px; left: 14px; padding: 10px 14px; }
}

/* ============================================================
   PARCOURS DE RECRUTEMENT — PHASE LABELS
============================================================ */
.parcours-phases {
  display: flex; gap: 12px; margin-bottom: 48px; flex-wrap: wrap;
}
.parcours-phase {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 20px; border-radius: 100px;
  font-size: .8rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
}
.parcours-phase--blue  { background: rgba(59,130,246,.12); color: #3b82f6; border: 1px solid rgba(59,130,246,.2); }
.parcours-phase--red   { background: rgba(201,27,27,.1);   color: var(--red);  border: 1px solid rgba(201,27,27,.18); }
.parcours-phase--green { background: rgba(22,163,74,.1);   color: #16a34a;     border: 1px solid rgba(22,163,74,.2); }
.parcours-phase__dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: currentColor; flex-shrink: 0;
}

/* ============================================================
   JOURNEY — TIMELINE RECRUTEMENT
============================================================ */
.journey {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px 20px;
  position: relative;
}

/* Connector line between marker and card */
.journey__connector {
  width: 2px; flex: 0 0 20px; min-height: 20px;
  background: var(--border);
  margin: 0 auto;
}

/* Ligne de connexion horizontale entre colonnes */
.journey::before {
  content: '';
  position: absolute;
  top: 34px; left: calc(16.66% + 28px); right: calc(16.66% + 28px);
  height: 2px;
  background: linear-gradient(90deg, #3b82f6 0%, var(--red) 50%, #16a34a 100%);
  z-index: 0;
}

.journey__step {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; position: relative; z-index: 1;
}
.journey__step--featured { /* highlighted step (e-learning) */ }

/* Marqueur circulaire */
.journey__marker {
  width: 68px; height: 68px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  margin-bottom: 20px; flex-shrink: 0;
  box-shadow: 0 6px 24px rgba(0,0,0,.1);
  position: relative;
  border: 3px solid rgba(255,255,255,.6);
  transition: transform .3s, box-shadow .3s;
}
.journey__step:hover .journey__marker { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.15); }
.journey__marker--blue  { background: linear-gradient(135deg,#3b82f6,#2563eb); color: #fff; }
.journey__marker--red   { background: var(--grad-red); color: #fff; }
.journey__marker--green { background: linear-gradient(135deg,#22c55e,#16a34a); color: #fff; }

/* Badge numéro en haut à droite du marqueur */
.journey__num {
  position: absolute; top: -6px; right: -6px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--white); color: var(--navy);
  font-size: .65rem; font-weight: 800; letter-spacing: .02em;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
  border: 1.5px solid var(--border);
}

/* Carte de step */
.journey__card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 20px 18px;
  width: 100%;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .3s, transform .3s;
}
.journey__step:hover .journey__card {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.journey__card--featured {
  background: var(--grad-navy);
  border-color: transparent;
  box-shadow: 0 8px 32px rgba(11,29,81,.25);
}

/* Phase tag inside card */
.journey__phase-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  padding: 4px 10px; border-radius: 100px; margin-bottom: 10px;
}
.journey__phase-tag--blue  { background: rgba(59,130,246,.12); color: #3b82f6; }
.journey__phase-tag--red   { background: rgba(201,27,27,.12);  color: var(--red); }
.journey__phase-tag--green { background: rgba(22,163,74,.12);  color: #16a34a; }

.journey__card h4 {
  font-size: .95rem; font-weight: 700; color: var(--navy);
  margin: 0 0 8px; line-height: 1.3;
}
.journey__card--featured h4 { color: var(--white); }
.journey__card p {
  font-size: .82rem; color: var(--muted); line-height: 1.7; margin: 0;
}
.journey__card--featured p { color: rgba(255,255,255,.75); }

/* E-learning preview mini-badges inside featured card */
.journey__elearning-preview {
  display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0;
}
.journey__elearn-badge {
  font-size: .68rem; font-weight: 600; padding: 3px 10px; border-radius: 100px;
  background: rgba(255,255,255,.12); color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.18);
}
.journey__elearn-badge--more {
  background: rgba(255,255,255,.06); color: rgba(255,255,255,.5);
}

/* Meta row (duration / action link) */
.journey__meta {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 12px; gap: 8px;
}
.journey__meta span {
  font-size: .75rem; color: var(--muted); display: flex; align-items: center; gap: 5px;
}
.journey__card--featured .journey__meta span { color: rgba(255,255,255,.55); }
.journey__link {
  font-size: .75rem; font-weight: 700; color: var(--red);
  text-decoration: none; display: flex; align-items: center; gap: 4px;
  transition: gap .2s;
}
.journey__card--featured .journey__link { color: #fbbf24; }
.journey__link:hover { gap: 8px; }

/* ============================================================
   E-LEARNING — GRILLE DE MODULES
============================================================ */
.elearn-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}

/* Card wide spans 2 cols */
.elearn-card--wide {
  grid-column: span 2;
}

.elearn-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
  transition: transform .3s, box-shadow .3s;
}
.elearn-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
}

/* Colored header strip */
.elearn-card__header {
  padding: 20px 22px;
  display: flex; align-items: center; justify-content: space-between;
}
.elearn-card__header--navy  { background: var(--grad-navy); }
.elearn-card__header--red   { background: var(--grad-red); }
.elearn-card__header--blue  { background: linear-gradient(135deg,#3b82f6,#2563eb); }
.elearn-card__header--gold  { background: linear-gradient(135deg,#d97706,#b45309); }
.elearn-card__header--teal  { background: linear-gradient(135deg,#0891b2,#0e7490); }

.elearn-card__num {
  font-family: 'DM Serif Display', serif;
  font-size: 2rem; font-weight: 400;
  color: rgba(255,255,255,.25);
  line-height: 1;
}
.elearn-card__icon {
  width: 48px; height: 48px; border-radius: 14px;
  background: rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; color: var(--white);
  backdrop-filter: blur(4px);
}

/* Card body */
.elearn-card__body { padding: 20px 22px; flex: 1; display: flex; flex-direction: column; }

.elearn-card__duration {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .72rem; font-weight: 600; color: var(--muted);
  margin-bottom: 10px;
}
.elearn-card__duration i { color: var(--red); }

.elearn-card__body h4 {
  font-size: 1rem; font-weight: 700; color: var(--navy);
  margin: 0 0 8px; line-height: 1.3;
}
.elearn-card__body p {
  font-size: .83rem; color: var(--muted); line-height: 1.7; margin: 0 0 14px; flex: 1;
}

/* Topic tags */
.elearn-card__topics {
  display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px;
}
.elearn-card__topics span {
  font-size: .7rem; font-weight: 600; padding: 3px 10px;
  border-radius: 100px; background: rgba(11,29,81,.06);
  color: var(--navy); border: 1px solid rgba(11,29,81,.09);
}

/* Card footer with progress bar */
.elearn-card__footer {
  padding: 14px 22px 18px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px;
}
.elearn-progress {
  height: 5px; border-radius: 100px;
  background: rgba(11,29,81,.08); overflow: hidden;
}
.elearn-progress__bar {
  height: 100%; border-radius: 100px;
  background: var(--grad-red); width: 0%;
  transition: width 1s cubic-bezier(.4,0,.2,1);
}

/* Status badge */
.elearn-status {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  color: var(--muted);
}
.elearn-status--todo { color: var(--muted); }
.elearn-status::before {
  content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%;
  background: currentColor; opacity: .5;
}

/* ============================================================
   E-LEARNING — BANDEAU CERTIFICATION
============================================================ */
.elearn-certification {
  background: var(--grad-navy);
  border-radius: var(--radius-xl);
  padding: 36px 40px;
  display: flex; align-items: center; gap: 40px;
  box-shadow: 0 8px 40px rgba(11,29,81,.2);
}
.elearn-certification__left {
  display: flex; align-items: center; gap: 24px; flex: 1;
}
.elearn-cert-icon {
  width: 72px; height: 72px; border-radius: 20px;
  background: rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem; color: #fbbf24; flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.15);
}
.elearn-certification__left h3,
.elearn-certification__left h4 {
  font-size: 1.2rem; font-weight: 700; color: var(--white); margin: 0 0 6px;
}
.elearn-certification__left p {
  font-size: .85rem; color: rgba(255,255,255,.65); margin: 0; line-height: 1.6;
}
/* Cert badge — inside certification dark bar */
.elearn-cert-badge {
  flex-shrink: 0;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px; padding: 16px 24px; text-align: center;
}
.elearn-cert-badge i { font-size: 1.8rem; color: #fbbf24; margin-bottom: 6px; }
.elearn-cert-badge strong {
  font-size: .8rem; font-weight: 800; color: var(--white);
  text-transform: uppercase; letter-spacing: .06em;
}
.elearn-cert-badge span {
  font-size: .7rem; color: rgba(255,255,255,.5);
}
/* Cert badge — standalone light variant (section-intro) */
.section-intro .elearn-cert-badge {
  flex-direction: row; align-items: center; gap: 14px;
  background: rgba(11,29,81,.05); border: 1px solid rgba(11,29,81,.1);
  border-radius: 14px; padding: 14px 18px; text-align: left;
  align-self: flex-start;
}
.section-intro .elearn-cert-badge i { font-size: 1.5rem; color: var(--gold); margin-bottom: 0; }
.section-intro .elearn-cert-badge strong {
  color: var(--navy); font-size: .78rem;
  display: block; margin-bottom: 2px;
}
.section-intro .elearn-cert-badge span { color: var(--muted); }

/* ============================================================
   RESPONSIVE — PARCOURS + E-LEARNING
============================================================ */
@media (max-width: 1100px) {
  .journey { grid-template-columns: repeat(2, 1fr); }
  .journey::before { display: none; }
  .elearn-grid { grid-template-columns: repeat(2, 1fr); }
  .elearn-card--wide { grid-column: span 2; }
  .elearn-certification { gap: 24px; padding: 28px 28px; }
}

@media (max-width: 900px) {
  .elearn-certification { flex-direction: column; align-items: flex-start; gap: 20px; }
  .elearn-certification__left { flex-direction: column; align-items: flex-start; gap: 16px; }
  .elearn-cert-badge { align-self: stretch; flex-direction: row; justify-content: center; }
}

@media (max-width: 600px) {
  .parcours-phases { gap: 8px; }
  .parcours-phase { font-size: .7rem; padding: 6px 14px; }
  .journey { grid-template-columns: 1fr; gap: 16px; }
  .journey__marker { width: 56px; height: 56px; font-size: 1.1rem; margin-bottom: 14px; }
  .elearn-grid { grid-template-columns: 1fr; }
  .elearn-card--wide { grid-column: span 1; }
  .elearn-certification { padding: 22px 18px; }
}

/* ============================================================
   PAGE FORMATION — HERO
============================================================ */
.formation-hero {
  background: var(--grad-navy);
  padding: 158px 0 72px;
  position: relative;
  overflow: hidden;
}
.formation-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(201,27,27,.12), transparent);
  pointer-events: none;
}
.formation-hero__layout {
  display: grid; grid-template-columns: 1fr 420px; gap: 60px; align-items: center;
  position: relative; z-index: 1;
}

.formation-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: .78rem; color: rgba(255,255,255,.45); margin-bottom: 20px;
}
.formation-breadcrumb a { color: rgba(255,255,255,.55); text-decoration: none; transition: color .2s; }
.formation-breadcrumb a:hover { color: var(--white); }
.formation-breadcrumb i { font-size: .6rem; }

.formation-hero__title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 400; color: var(--white);
  line-height: 1.15; margin: 0 0 20px;
}
.formation-hero__title em { font-style: italic; color: rgba(255,255,255,.7); }
.formation-hero__desc {
  font-size: 1.05rem; color: rgba(255,255,255,.7); line-height: 1.75;
  max-width: 520px; margin: 0 0 28px;
}
.formation-hero__desc strong { color: var(--white); }

.formation-hero__badges {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.fh-badge {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 14px; border-radius: 100px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  font-size: .78rem; font-weight: 600; color: rgba(255,255,255,.92);
}
.fh-badge i { color: rgba(255,255,255,.65); }

/* Progress card */
.formation-progress-card {
  background: var(--white);
  border-radius: var(--radius-xl);
  padding: 28px 28px 22px;
  box-shadow: 0 24px 64px rgba(0,0,0,.25);
}
.fpc__top {
  display: flex; align-items: center; gap: 14px; margin-bottom: 18px;
}
.fpc__avatar {
  width: 48px; height: 48px; border-radius: 14px;
  background: var(--grad-navy);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; color: var(--white); flex-shrink: 0;
}
.fpc__user { flex: 1; }
.fpc__name { font-size: .9rem; font-weight: 700; color: var(--navy); }
.fpc__sub  { font-size: .72rem; color: var(--muted); }
.fpc__percent {
  font-size: 1.4rem; font-weight: 800; color: var(--navy);
  font-variant-numeric: tabular-nums;
}

.fpc__bar-wrap { margin-bottom: 20px; }
.fpc__bar {
  height: 8px; background: rgba(11,29,81,.08); border-radius: 100px; overflow: hidden;
}
.fpc__bar-fill {
  height: 100%; border-radius: 100px;
  background: var(--grad-red);
  transition: width .8s cubic-bezier(.4,0,.2,1);
}

.fpc__stats {
  display: flex; gap: 0; border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.fpc__stat {
  flex: 1; text-align: center; padding: 12px 8px;
  border-right: 1px solid var(--border);
}
.fpc__stat:last-child { border-right: none; }
.fpc__stat strong { display: block; font-size: 1rem; font-weight: 800; color: var(--navy); }
.fpc__stat span   { font-size: .7rem; color: var(--muted); }

.fpc__modules-track {
  display: flex; gap: 6px; margin-bottom: 16px;
}
.fpc__mod {
  flex: 1; height: 5px; border-radius: 100px;
  background: rgba(11,29,81,.1);
  transition: background .4s;
}
.fpc__mod--active { background: var(--red); }
.fpc__mod--exam   { background: rgba(11,29,81,.18); }

.fpc__next {
  display: flex; align-items: center; gap: 10px;
  background: rgba(11,29,81,.04); border-radius: 10px;
  padding: 10px 14px;
  font-size: .8rem; color: var(--navy); font-weight: 600;
}
.fpc__next i { color: var(--red); font-size: .9rem; }


/* ============================================================
   PAGE FORMATION — LAYOUT BODY
============================================================ */
.formation-body {
  background: var(--bg);
  padding: 48px 0 80px;
}
.formation-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 32px;
  align-items: start;
}

/* Sidebar */
.formation-sidebar {
  position: sticky; top: 130px; overflow: hidden;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 24px;
  display: flex; flex-direction: column; gap: 4px;
}
/* ── Vidéo règlement dans la sidebar ────────────────────── */
.fsb__video {
  margin: -24px -24px 20px;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  overflow: hidden;
  background: #000;
}
.fsb__video-player {
  width: 100%; display: block;
}
.fsb__video-title {
  margin: 0; padding: 8px 14px;
  background: var(--navy);
  color: rgba(255,255,255,.75);
  font-size: .73rem; font-weight: 600; letter-spacing: .02em;
}

.fsb__title {
  font-size: .7rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted);
  margin-bottom: 12px;
}
.fsb__nav { display: flex; flex-direction: column; gap: 2px; }
.fsb__item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: 12px;
  text-decoration: none; transition: background .2s;
  cursor: pointer;
}
.fsb__item:hover { background: rgba(11,29,81,.04); }
.fsb__item--active { background: rgba(11,29,81,.06); }
.fsb__item--locked { opacity: .6; cursor: not-allowed; pointer-events: none; }
.fsb__item--final { margin-top: 4px; }

.fsb__num {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem; font-weight: 800; color: var(--white); flex-shrink: 0;
}
.fsb__num--locked { background: rgba(11,29,81,.1) !important; color: var(--muted); }
.fsb__num--red    { background: rgba(201,27,27,.12) !important; color: var(--red); }
.fsb__num--red i  { font-size: .75rem; }

.fsb__info { flex: 1; min-width: 0; }
.fsb__label { display: block; font-size: .8rem; font-weight: 600; color: var(--navy); line-height: 1.3; }
.fsb__dur   { display: block; font-size: .68rem; color: var(--muted); }
.fsb__dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  background: rgba(11,29,81,.12);
}
.fsb__dot--active { background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.2); }
.fsb__lock { font-size: .65rem; color: var(--muted); flex-shrink: 0; }

.fsb__divider { height: 1px; background: var(--border); margin: 10px 0; }

.fsb__cert {
  display: flex; align-items: center; gap: 10px;
  background: rgba(198,145,43,.08); border: 1px solid rgba(198,145,43,.2);
  border-radius: 12px; padding: 12px; margin-top: 8px;
}
.fsb__cert-icon { font-size: 1.3rem; color: var(--gold); flex-shrink: 0; }
.fsb__cert strong { display: block; font-size: .78rem; font-weight: 700; color: var(--navy); }
.fsb__cert span   { font-size: .68rem; color: var(--muted); }

.fsb__cta {
  margin-top: 14px; width: 100%; justify-content: center;
  font-size: .82rem; padding: 12px 16px;
}


/* ============================================================
   FORMATION MODULES — ACCORDION
============================================================ */
.formation-main { display: flex; flex-direction: column; gap: 16px; }

.formation-module {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .3s;
}
.formation-module:hover { box-shadow: var(--shadow-md); }
.formation-module--active { border-color: rgba(11,29,81,.2); }
.formation-module--exam { border-color: rgba(201,27,27,.18); }

/* Header */
.fm__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; cursor: pointer; gap: 16px;
  transition: background .2s;
  user-select: none;
}
.fm__header:hover { background: rgba(11,29,81,.02); }
.fm__header-left { display: flex; align-items: center; gap: 16px; flex: 1; }
.fm__header-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }

.fm__num {
  width: 52px; height: 52px; border-radius: 14px; flex-shrink: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px;
  color: var(--white); font-size: .9rem;
  box-shadow: 0 4px 14px rgba(0,0,0,.15);
}
.fm__num-label { font-size: .6rem; font-weight: 800; letter-spacing: .05em; opacity: .75; }

.fm__title { font-size: 1rem; font-weight: 700; color: var(--navy); margin: 0 0 6px; }
.fm__meta {
  display: flex; flex-wrap: wrap; gap: 12px;
  font-size: .75rem; color: var(--muted);
}
.fm__meta span { display: flex; align-items: center; gap: 4px; }
.fm__meta-warn { color: #d97706; }
.fm__meta-warn i { color: #d97706; }

.fm__badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  padding: 4px 10px; border-radius: 100px; white-space: nowrap;
}
.fm__badge--active { background: rgba(34,197,94,.12); color: #166534; border: 1px solid rgba(34,197,94,.2); }
.fm__badge--locked { background: rgba(11,29,81,.06); color: var(--muted); border: 1px solid var(--border); }
.fm__badge--done   { background: rgba(59,130,246,.1); color: #1d4ed8; border: 1px solid rgba(59,130,246,.2); }

.fm__chevron {
  font-size: .8rem; color: var(--muted);
  transition: transform .3s;
}
.fm--open .fm__chevron { transform: rotate(180deg); }

/* Body collapse */
.fm__body {
  max-height: 0; overflow: hidden;
  transition: max-height .45s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.fm--open .fm__body { max-height: 4000px; }

/* ── Lessons ────────────────────────────────────────── */
.fm__lessons {
  padding: 0 24px 8px; border-bottom: 1px solid var(--border);
}
.fm__lessons-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 0 12px;
  font-size: .8rem; font-weight: 700; color: var(--navy);
}
.fm__lessons-prog { font-weight: 400; color: var(--muted); font-size: .75rem; }

.fm__lesson {
  display: flex; align-items: stretch; gap: 0;
  padding: 0; border-bottom: 1px solid rgba(11,29,81,.05);
  flex-direction: column; cursor: pointer;
}
.fm__lesson:last-of-type { border-bottom: none; }

.fm__lesson-icon {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(11,29,81,.06); color: var(--muted);
  font-size: .75rem; font-weight: 700;
}
.fm__lesson-icon--done    { background: rgba(34,197,94,.15); color: #166534; }
.fm__lesson-icon--current { background: rgba(201,27,27,.1); color: var(--red); }

.fm__lesson-body { flex: 1; min-width: 0; }
.fm__lesson-name { display: block; font-size: .85rem; font-weight: 600; color: var(--navy); }
.fm__lesson-type { display: block; font-size: .7rem; color: var(--muted); margin-top: 2px; }
.fm__lesson-type i { margin-right: 3px; }
.fm__lesson-dur  { font-size: .72rem; color: var(--muted); white-space: nowrap; flex-shrink: 0; }

.fm__lesson--done .fm__lesson-name    { color: var(--muted); text-decoration: line-through; }
.fm__lesson--current .fm__lesson-name { color: var(--navy); font-weight: 700; }

/* Lesson expandable content */
.fm__lesson-header {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; cursor: pointer;
}
.fm__lesson-chevron {
  font-size: .7rem; color: var(--muted); margin-left: auto; flex-shrink: 0;
  transition: transform .25s; padding-left: 8px;
}
.fm__lesson.fl--open .fm__lesson-chevron { transform: rotate(180deg); }
.fm__lesson-content {
  display: none;
  background: var(--gray-50, #f8fafc);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px 22px;
  margin-bottom: 8px;
}
.fm__lesson.fl--open .fm__lesson-content { display: block; }
.fl__section-title {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .8px; color: var(--muted); margin: 0 0 10px;
}
.fl__key-points {
  list-style: none; margin: 0 0 16px; display: flex; flex-direction: column; gap: 8px;
}
.fl__key-points li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: .84rem; color: var(--navy); line-height: 1.6;
}
.fl__key-points li::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--red); flex-shrink: 0; margin-top: 7px;
}
.fl__text {
  font-size: .84rem; color: #374151; line-height: 1.8;
  margin-bottom: 16px;
}
.fl__callout {
  background: rgba(11,29,81,.05); border-left: 3px solid var(--navy);
  border-radius: 0 8px 8px 0; padding: 12px 16px;
  font-size: .82rem; color: var(--navy); margin-bottom: 16px; line-height: 1.7;
}
.fl__callout strong { display: block; margin-bottom: 4px; }
.fl__callout-steps { margin: 8px 0 0 0; padding-left: 20px; display: flex; flex-direction: column; gap: 6px; }
.fl__callout-steps li { font-size: .83rem; line-height: 1.5; color: var(--ink); padding-left: 4px; }
.fl__mark-done {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 18px; border-radius: 8px; border: none; cursor: pointer;
  font-size: .8rem; font-weight: 700; letter-spacing: .3px;
  background: var(--grad-navy); color: white;
  transition: opacity .2s;
}
.fl__mark-done:hover { opacity: .85; }
.fl__mark-done--done {
  background: #dcfce7; color: #15803d; cursor: default;
}
/* ── Inline Video Player ─────────────────────────────────── */
.fl__vid { border-radius: 12px; overflow: hidden; background: #070f26; margin-bottom: 20px; box-shadow: 0 8px 32px rgba(11,29,81,.35); user-select: none; }
.fl__vid-screen { position: relative; height: 260px; overflow: hidden; }
.fl__vid-slide { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; padding: 28px 32px; text-align: center; opacity: 0; transform: scale(1.04); transition: opacity .55s ease, transform .55s ease; pointer-events: none; will-change: opacity, transform; }
.fl__vid-slide--active { opacity: 1; transform: scale(1); pointer-events: auto; }
.fl__vid-slide-inner { max-width: 460px; width: 100%; }
.fl__vid-logo { height: 32px; margin-bottom: 14px; filter: brightness(0) invert(1); opacity: .9; }
.fl__vid-title { font-family: 'Inter', sans-serif; font-size: 1.4rem; font-weight: 900; color: #fff; line-height: 1.15; margin-bottom: 10px; text-transform: uppercase; letter-spacing: -.025em; }
.fl__vid-sub { font-size: .75rem; color: rgba(255,255,255,.4); letter-spacing: .5px; }
.fl__vid-eyebrow { font-size: .68rem; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: rgba(255,255,255,.45); margin-bottom: 16px; }
.fl__vid-body { font-size: .9rem; color: rgba(255,255,255,.8); line-height: 1.75; }
.fl__vid-stat { margin-top: 18px; font-size: .72rem; font-weight: 700; color: rgba(255,255,255,.35); letter-spacing: .6px; }
.fl__vid-values { display: flex; gap: 28px; justify-content: center; margin-top: 6px; }
.fl__vid-value { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.fl__vid-value i { font-size: 1.8rem; color: rgba(255,255,255,.65); }
.fl__vid-value span { font-size: .7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.55); }
.fl__vid-timeline { display: flex; flex-direction: column; gap: 10px; text-align: left; }
.fl__vid-step { display: flex; align-items: center; gap: 12px; font-size: .82rem; color: rgba(255,255,255,.75); }
.fl__vid-step-dot { width: 26px; height: 26px; border-radius: 50%; background: rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: .62rem; font-weight: 800; color: rgba(255,255,255,.7); }
.fl__vid-dots { display: flex; gap: 6px; justify-content: center; padding: 8px 0 2px; }
.fl__vid-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.18); border: none; cursor: pointer; transition: background .25s, transform .25s; padding: 0; }
.fl__vid-dot--active { background: #fff; transform: scale(1.3); }
.fl__vid-controls { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: rgba(0,0,0,.35); }
.fl__vid-play-btn { width: 30px; height: 30px; border-radius: 50%; background: #fff; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: #0b1d51; font-size: .72rem; flex-shrink: 0; transition: transform .15s; }
.fl__vid-play-btn:hover { transform: scale(1.1); }
.fl__vid-progress-wrap { flex: 1; height: 4px; background: rgba(255,255,255,.15); border-radius: 2px; cursor: pointer; }
.fl__vid-progress-bar { height: 100%; background: #fff; border-radius: 2px; width: 0%; }
.fl__vid-time { font-size: .67rem; color: rgba(255,255,255,.45); font-variant-numeric: tabular-nums; white-space: nowrap; }

/* ── Presenter layout ───────────────────────────────────── */
.fl__vid--with-presenter .fl__vid-screen {
  display: grid; grid-template-columns: 170px 1fr;
}
.fl__vid-presenter-panel {
  background: rgba(255,255,255,.03); border-right: 1px solid rgba(255,255,255,.07);
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 18px 14px; gap: 10px;
}
.fl__vid-content-panel { position: relative; overflow: hidden; }
.fl__vid-content-panel .fl__vid-slide { position: absolute; inset: 0; }

/* ── Photo Presenter ─────────────────────────────────────── */
.fl__vid-photo-wrap {
  position: relative; width: 120px; height: 150px;
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,.55);
  animation: vid-breathe 4s ease-in-out infinite;
  flex-shrink: 0;
}
.fl__vid-photo {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 8%;
  display: block;
}
.fl__vid-photo-wrap--talking {
  animation: vid-talk-bob 0.38s ease-in-out infinite !important;
}
.fl__vid-photo-wrap--talking::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(37,99,235,.1) 0%, transparent 40%);
  animation: vid-light-pulse 0.38s ease-in-out infinite;
}
.fl__vid-presenter-name {
  font-size: .72rem; font-weight: 800; color: rgba(255,255,255,.85);
  letter-spacing: .5px; text-align: center; line-height: 1.3;
}
.fl__vid-presenter-role {
  font-size: .62rem; color: rgba(255,255,255,.4); letter-spacing: .5px;
}
.fl__vid-speaking {
  display: flex; gap: 4px; align-items: center; height: 14px;
}
.fl__vid-speaking span {
  width: 4px; height: 4px; background: rgba(255,255,255,.35);
  border-radius: 50%; opacity: 0;
}
.fl__vid-speaking--on span:nth-child(1) { animation: vid-dot .9s 0s infinite; }
.fl__vid-speaking--on span:nth-child(2) { animation: vid-dot .9s .2s infinite; }
.fl__vid-speaking--on span:nth-child(3) { animation: vid-dot .9s .4s infinite; }

/* ── Keyframes ───────────────────────────────────────────── */
@keyframes vid-breathe {
  0%,100% { transform: scale(1); }
  50%     { transform: scale(1.014); }
}
@keyframes vid-talk-bob {
  0%,100% { transform: scale(1) translateY(0); }
  50%     { transform: scale(1.009) translateY(-2px); }
}
@keyframes vid-light-pulse {
  0%,100% { opacity: 0.4; }
  50%     { opacity: 1; }
}
@keyframes vid-dot {
  0%,100% { opacity: 0; transform: scale(.6); }
  50%     { opacity: 1; transform: scale(1); }
}

.fm__lessons-progress {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 0 4px; font-size: .72rem; color: var(--muted);
}
.fm__lessons-bar {
  flex: 1; height: 4px; border-radius: 100px;
  background: rgba(11,29,81,.08); overflow: hidden;
}
.fm__lessons-bar-fill {
  height: 100%; border-radius: 100px;
  background: linear-gradient(90deg,#3b82f6,#16a34a);
  transition: width .8s;
}

/* ── Quiz ────────────────────────────────────────────── */
.fm__quiz {
  padding: 20px 24px 24px; position: relative;
}
.fm__quiz--preview { opacity: .7; pointer-events: none; }

.fm__quiz-hd {
  display: flex; align-items: center; gap: 14px;
  background: rgba(11,29,81,.03); border: 1px solid var(--border);
  border-radius: 14px; padding: 16px 20px; margin-bottom: 16px;
}
.fm__quiz-icon-wrap {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--grad-navy);
  display: flex; align-items: center; justify-content: center;
  color: var(--white); font-size: 1rem; flex-shrink: 0;
}
.fm__quiz-info { flex: 1; }
.fm__quiz-title { font-size: .95rem; font-weight: 700; color: var(--navy); margin: 0 0 3px; }
.fm__quiz-sub   { font-size: .75rem; color: var(--muted); margin: 0; }
.fm__quiz-req {
  font-size: .85rem; font-weight: 800; color: var(--red);
  background: rgba(201,27,27,.08); border: 1px solid rgba(201,27,27,.15);
  border-radius: 8px; padding: 6px 12px; white-space: nowrap; flex-shrink: 0;
}
.fm__quiz-badge--gold { color: var(--gold); background: rgba(198,145,43,.1); border-color: rgba(198,145,43,.2); }

/* ── Quiz locked state ────────────────────────────────── */
.fm__quiz--locked .fm__quiz-body {
  filter: blur(4px); pointer-events: none; opacity: 0.2; user-select: none;
}
.fm__quiz-lock-overlay {
  position: absolute; inset: 0; z-index: 5;
  display: flex; align-items: center; justify-content: center;
  border-radius: 14px; background: rgba(255,255,255,.6);
}
.fm__quiz-lock-box {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 14px; padding: 22px 36px; text-align: center;
  box-shadow: var(--shadow-lg);
}
.fm__quiz-lock-box i { font-size: 1.9rem; color: var(--muted); margin-bottom: 10px; display: block; }
.fm__quiz-lock-box p { margin: 0; font-size: .87rem; color: var(--navy); font-weight: 700; }
.fm__quiz-lock-remaining { font-size: .78rem; color: var(--red); font-weight: 700; margin-top: 5px; }

.fm__quiz-note {
  display: flex; align-items: flex-start; gap: 10px;
  background: rgba(59,130,246,.06); border: 1px solid rgba(59,130,246,.15);
  border-radius: 10px; padding: 12px 14px; margin-bottom: 20px;
  font-size: .78rem; color: #1e40af;
}
.fm__quiz-note i  { margin-top: 1px; flex-shrink: 0; }
.fm__quiz-note p  { margin: 0; }

/* ── Questions ──────────────────────────────────────── */
.fm__quiz-body { display: flex; flex-direction: column; gap: 24px; }

.fq__question {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 14px; padding: 18px 20px;
  transition: border-color .2s;
}
.fq__question:focus-within { border-color: rgba(11,29,81,.3); }

.fq__q-num {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted); margin-bottom: 8px;
}
.fq__q-text {
  font-size: .9rem; color: var(--navy); line-height: 1.6; margin: 0 0 14px;
}
.fq__q-text strong { color: var(--navy); }

.fq__options { display: flex; flex-direction: column; gap: 8px; }

.fq__option {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--white); cursor: pointer;
  transition: border-color .2s, background .2s;
  font-size: .85rem; color: var(--navy);
}
.fq__option:hover { border-color: rgba(11,29,81,.25); background: rgba(11,29,81,.02); }
.fq__option input[type=radio] {
  width: 16px; height: 16px; accent-color: var(--red); flex-shrink: 0; cursor: pointer;
}
.fq__option span { flex: 1; }

/* Feedback states */
.fq__option--correct {
  background: rgba(34,197,94,.1) !important;
  border-color: #22c55e !important;
  color: #14532d;
}
.fq__option--correct::after {
  content: '\f00c';
  font-family: 'Font Awesome 6 Free', sans-serif; font-weight: 900;
  font-size: .75rem; color: #166534; margin-left: auto; flex-shrink: 0;
}
.fq__option--wrong {
  background: rgba(201,27,27,.08) !important;
  border-color: var(--red) !important;
  color: #991b1b;
}
.fq__option--wrong::after {
  content: '\f00d';
  font-family: 'Font Awesome 6 Free', sans-serif; font-weight: 900;
  font-size: .75rem; color: var(--red); margin-left: auto; flex-shrink: 0;
}

/* Actions row */
.fq__actions {
  display: flex; align-items: center; flex-wrap: wrap; gap: 12px;
  padding-top: 8px;
}
.btn--sm { padding: 9px 18px; font-size: .82rem; }

.fq__warn {
  display: none; align-items: center; gap: 6px;
  font-size: .78rem; color: #d97706; font-weight: 600;
}
.fq__warn--visible { display: flex; }
.fq__warn i { color: #d97706; }

/* Result banner */
.fq__result { margin-top: 20px; border-radius: 14px; overflow: hidden; }

.fq__result-pass,
.fq__result-fail {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 20px 22px;
  border-radius: 14px;
}
.fq__result-pass {
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.25);
}
.fq__result-fail {
  background: rgba(201,27,27,.07); border: 1px solid rgba(201,27,27,.2);
}
.fq__result-ico { font-size: 1.6rem; flex-shrink: 0; }
.fq__result-pass .fq__result-ico { color: #16a34a; }
.fq__result-fail .fq__result-ico { color: var(--red); }
.fq__result-pass strong { color: #15803d; font-size: .95rem; }
.fq__result-fail strong { color: var(--red);  font-size: .95rem; }
.fq__result-pass p,
.fq__result-fail p { font-size: .82rem; color: var(--muted); margin: 6px 0 0; }

/* ── Lock overlay ───────────────────────────────────── */
.fm__lock-overlay {
  position: relative; z-index: 2;
  padding: 40px 24px;
  display: flex; align-items: center; justify-content: center;
}
.fm__lock-overlay--exam { padding: 48px 24px; }

.fm__body-blur {
  filter: blur(3px); pointer-events: none; user-select: none;
  opacity: .4; overflow: hidden; max-height: 320px;
}

/* Content blurred when module locked */
.formation-module--locked .fm__lessons,
.formation-module--locked .fm__quiz {
  filter: blur(4px);
  pointer-events: none;
  opacity: 0.35;
  user-select: none;
}

.fm__lock-box {
  max-width: 420px; text-align: center;
}
.fm__lock-ico {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(11,29,81,.08); color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; margin: 0 auto 16px;
}
.fm__lock-ico--gold {
  background: rgba(198,145,43,.12); color: var(--gold);
  font-size: 1.8rem;
}
.fm__lock-box h4 {
  font-size: 1.1rem; font-weight: 700; color: var(--navy); margin: 0 0 8px;
}
.fm__lock-box p {
  font-size: .88rem; color: var(--muted); line-height: 1.7; margin: 0 0 20px;
}
.fm__lock-box strong { color: var(--navy); }

.fm__lock-checklist {
  display: flex; flex-direction: column; gap: 8px;
  text-align: left; margin-top: 20px;
}
.fm__lock-check {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; color: var(--muted); padding: 6px 0;
}
.fm__lock-check i { font-size: .5rem; color: rgba(11,29,81,.3); flex-shrink: 0; }

/* ── Exam preview ───────────────────────────────────── */
.fm__exam-preview { padding: 20px 24px 24px; }
.fm__exam-topics {
  display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px;
}
.fm__exam-topic {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 10px;
  background: rgba(11,29,81,.05); border: 1px solid var(--border);
  font-size: .8rem; font-weight: 600; color: var(--navy);
}
.fm__exam-topic i { color: var(--muted); }

.fm__exam-rules { display: flex; flex-direction: column; gap: 8px; }
.fm__exam-rule {
  display: flex; align-items: center; gap: 10px;
  font-size: .83rem; color: var(--muted);
}
.fm__exam-rule i { color: #22c55e; font-size: .8rem; flex-shrink: 0; }


/* ============================================================
   CERTIFICATION PREVIEW CARD
============================================================ */
.formation-cert {
  display: grid; grid-template-columns: 1fr auto;
  gap: 40px; align-items: center;
  background: var(--grad-navy);
  border-radius: var(--radius-xl);
  padding: 40px 44px;
  margin-top: 8px;
  box-shadow: 0 12px 48px rgba(11,29,81,.25);
  position: relative; overflow: hidden;
}
.formation-cert::before {
  content: '';
  position: absolute; top: -40px; right: 240px; bottom: -40px;
  width: 1px; background: rgba(255,255,255,.07);
}

.formation-cert__left { display: flex; align-items: flex-start; gap: 20px; }
.formation-cert__icon-wrap {
  width: 64px; height: 64px; border-radius: 18px; flex-shrink: 0;
  background: rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; color: #fcd34d;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}
.formation-cert__body h3 {
  font-size: 1.15rem; font-weight: 700; color: var(--white); margin: 0 0 8px;
}
.formation-cert__body p {
  font-size: .84rem; color: rgba(255,255,255,.65); line-height: 1.7; margin: 0;
}
.formation-cert__pills {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px;
}
.formation-cert__pills span {
  display: flex; align-items: center; gap: 6px;
  font-size: .72rem; font-weight: 600; color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.09); border: 1px solid rgba(255,255,255,.15);
  padding: 4px 10px; border-radius: 100px;
}
.formation-cert__pills span i { color: #fcd34d; }

/* Certificate mockup */
.formation-cert__right { flex-shrink: 0; }
.cert-mockup {
  width: 220px;
  background: var(--white);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,.35);
  transform: rotate(2deg);
}
.cert-mockup__header {
  background: var(--grad-navy);
  padding: 12px 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.cert-mockup__logo { height: 20px; filter: brightness(10); }
.cert-mockup__header span { color: rgba(255,255,255,.7); font-size: .75rem; font-weight: 700; }
.cert-mockup__body { padding: 16px; }
.cert-mockup__label {
  font-size: .6rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted); margin-bottom: 8px;
}
.cert-mockup__name {
  font-family: 'DM Serif Display', serif; font-size: 1rem;
  color: var(--navy); margin-bottom: 8px;
}
.cert-mockup__text {
  font-size: .65rem; color: var(--muted); line-height: 1.6; margin-bottom: 12px;
}
.cert-mockup__meta {
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border); padding-top: 10px;
}
.cert-mockup__meta span { font-size: .6rem; color: var(--muted); }
.cert-mockup__seal {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(198,145,43,.12); border: 1.5px solid rgba(198,145,43,.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-size: .75rem;
}


/* ============================================================
   FORMATION CTA
============================================================ */
.formation-cta {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; flex-wrap: wrap;
}
.formation-cta__btns {
  display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0;
}


/* ============================================================
   RESPONSIVE — PAGE FORMATION
============================================================ */
@media (max-width: 1100px) {
  .formation-hero__layout { grid-template-columns: 1fr; gap: 40px; }
  .formation-hero { padding: 140px 0 56px; }
  .formation-layout { grid-template-columns: 240px 1fr; gap: 20px; }
}

@media (max-width: 900px) {
  .formation-layout { grid-template-columns: 1fr; }
  .formation-sidebar { position: static; }
  .fsb__nav { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
  .fsb__item--final { grid-column: span 2; }
  .formation-cert { grid-template-columns: 1fr; }
  .formation-cert__right { display: none; }
  .formation-cta { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   PAGES POSTE — STYLES COMMUNS
============================================================ */

/* Hero */
.poste-hero {
  background: var(--grad-navy);
  padding: 158px 0 80px;
  position: relative; overflow: hidden;
}
.poste-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 80% 50%, rgba(201,27,27,.1), transparent);
  pointer-events: none;
}
.poste-hero__layout {
  display: grid; grid-template-columns: 1fr 320px;
  gap: 64px; align-items: center;
  position: relative; z-index: 1;
}
.page-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: .75rem; color: rgba(255,255,255,.4); margin-bottom: 20px;
}
.page-breadcrumb a { color: rgba(255,255,255,.5); text-decoration: none; transition: color .2s; }
.page-breadcrumb a:hover { color: var(--white); }
.page-breadcrumb i { font-size: .55rem; }

.poste-hero__role-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px; border-radius: 100px;
  font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em;
  margin-bottom: 18px;
}
.poste-hero__title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2rem, 3.5vw, 2.9rem);
  font-weight: 400; color: var(--white);
  line-height: 1.15; margin: 0 0 16px;
}
.poste-hero__tagline {
  font-size: 1.05rem; font-style: italic;
  color: rgba(255,255,255,.6); margin: 0 0 16px;
  font-family: 'DM Serif Display', serif;
}
.poste-hero__desc {
  font-size: .95rem; color: rgba(255,255,255,.72);
  line-height: 1.8; max-width: 520px; margin: 0 0 28px;
}

.poste-hero__stats {
  display: flex; gap: 24px; flex-wrap: wrap; margin-bottom: 32px;
}
.poste-hero__stat {
  display: flex; flex-direction: column; gap: 2px;
}
.poste-hero__stat strong {
  font-size: 1.3rem; font-weight: 800; color: var(--white);
  font-family: 'DM Serif Display', serif;
}
.poste-hero__stat span { font-size: .7rem; color: rgba(255,255,255,.45); text-transform: uppercase; letter-spacing: .05em; }

.poste-hero__btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* Visual (right col) */
.poste-hero__visual {
  display: flex; flex-direction: column; align-items: center; gap: 20px;
}
.poste-hero__icon-circle {
  width: 160px; height: 160px; border-radius: 40px;
  display: flex; align-items: center; justify-content: center;
  font-size: 3.5rem; color: var(--white);
  box-shadow: 0 24px 64px rgba(0,0,0,.35);
  position: relative;
}
.poste-hero__icon-circle::after {
  content: '';
  position: absolute; inset: -2px;
  border-radius: 42px;
  background: linear-gradient(135deg, rgba(255,255,255,.2), rgba(255,255,255,0));
  pointer-events: none;
}
.poste-hero__photo {
  width: 100%; max-width: 420px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 20px;
  box-shadow: 0 24px 64px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.1);
  display: block;
}
.poste-hero__open-badge {
  background: rgba(34,197,94,.15); border: 1px solid rgba(34,197,94,.3);
  color: #4ade80; font-size: .72rem; font-weight: 700;
  padding: 5px 14px; border-radius: 100px;
  display: inline-flex; align-items: center; gap: 6px;
}
.poste-hero__open-badge::before {
  content: ''; width: 7px; height: 7px; border-radius: 50%;
  background: #4ade80;
  animation: pulse-dot 1.5s infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(.75); }
}
.poste-hero__qualities {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
}
.poste-hero__quality {
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.7); font-size: .72rem; font-weight: 600;
  padding: 5px 12px; border-radius: 100px;
}

/* Responsabilités */
.respons-grid {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 20px;
  margin-top: 48px;
}
.respons-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .3s, box-shadow .3s;
}
.respons-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.respons-card__header {
  padding: 18px 22px;
  display: flex; align-items: center; gap: 14px;
}
.respons-card__num {
  font-size: .65rem; font-weight: 800; opacity: .5;
  text-transform: uppercase; letter-spacing: .08em;
}
.respons-card__icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(255,255,255,.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--white); flex-shrink: 0;
}
.respons-card__title { font-size: 1rem; font-weight: 700; color: var(--white); margin: 0; }
.respons-card__body { padding: 18px 22px 22px; }
.respons-card__body p { font-size: .875rem; color: var(--muted); line-height: 1.75; margin: 0 0 14px; }
.respons-card__tips { display: flex; flex-direction: column; gap: 6px; }
.respons-card__tip {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: .78rem; color: var(--navy); line-height: 1.5;
}
.respons-card__tip i { color: var(--red); font-size: .6rem; margin-top: 4px; flex-shrink: 0; }

/* Profil */
.poste-profil-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start;
}
.profil-checklist { display: flex; flex-direction: column; gap: 10px; margin-top: 24px; }
.profil-checklist__item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 16px; border-radius: 12px;
  background: var(--bg); border: 1px solid var(--border);
}
.profil-checklist__item i {
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .65rem;
}
.profil-checklist__item--ok i    { background: rgba(34,197,94,.15); color: #166534; }
.profil-checklist__item--plus i  { background: rgba(59,130,246,.12); color: #1d4ed8; }
.profil-checklist__item--no i    { background: rgba(201,27,27,.1); color: var(--red); }
.profil-checklist__item strong { display: block; font-size: .85rem; font-weight: 700; color: var(--navy); }
.profil-checklist__item span   { display: block; font-size: .78rem; color: var(--muted); margin-top: 2px; }

.profil-who-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-xl); padding: 28px;
  box-shadow: var(--shadow-sm);
}
.profil-who-card h4 {
  font-size: .85rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted); margin: 0 0 18px;
}
.who-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid rgba(11,29,81,.05);
}
.who-item:last-child { border-bottom: none; }
.who-item__icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem;
}
.who-item strong { display: block; font-size: .85rem; font-weight: 700; color: var(--navy); }
.who-item span   { display: block; font-size: .75rem; color: var(--muted); }

/* Journée type */
.day-timeline { margin-top: 48px; position: relative; }
.day-timeline::before {
  content: '';
  position: absolute; left: 80px; top: 20px; bottom: 20px;
  width: 2px; background: var(--border);
}
.day-step {
  display: grid; grid-template-columns: 80px 16px 1fr;
  gap: 0 20px; margin-bottom: 32px; position: relative;
}
.day-step:last-child { margin-bottom: 0; }
.day-step__time {
  font-size: .8rem; font-weight: 800; color: var(--muted);
  text-align: right; padding-top: 12px; white-space: nowrap;
}
.day-step__dot {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--white); border: 3px solid var(--border);
  margin-top: 12px; flex-shrink: 0; position: relative; z-index: 1;
  transition: border-color .3s;
}
.day-step:hover .day-step__dot { border-color: var(--red); }
.day-step__card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 14px; padding: 14px 18px;
  box-shadow: var(--shadow-sm);
  transition: transform .2s, box-shadow .2s;
}
.day-step:hover .day-step__card { transform: translateX(4px); box-shadow: var(--shadow-md); }
.day-step__card h4 {
  font-size: .9rem; font-weight: 700; color: var(--navy); margin: 0 0 6px;
  display: flex; align-items: center; gap: 8px;
}
.day-step__card h4 i { color: var(--red); font-size: .8rem; }
.day-step__card p { font-size: .82rem; color: var(--muted); line-height: 1.7; margin: 0; }

/* CTA postuler */
.poste-apply {
  background: var(--grad-navy);
  padding: 80px 0;
  position: relative; overflow: hidden;
}
.poste-apply::before {
  content: '';
  position: absolute; top: -60px; right: -60px;
  width: 320px; height: 320px; border-radius: 50%;
  background: rgba(201,27,27,.1);
  pointer-events: none;
}
.poste-apply__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 40px; flex-wrap: wrap;
  position: relative; z-index: 1;
}
.poste-apply__text h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--white); font-weight: 400; margin: 0 0 10px;
}
.poste-apply__text p { font-size: .9rem; color: rgba(255,255,255,.6); margin: 0; }
.poste-apply__btns { display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0; }

/* Responsive — poste pages */
@media (max-width: 1100px) {
  .poste-hero__layout { grid-template-columns: 1fr; gap: 40px; }
  .poste-hero { padding: 140px 0 60px; }
  .poste-hero__visual { flex-direction: row; justify-content: flex-start; }
  .poste-hero__icon-circle { width: 100px; height: 100px; font-size: 2.2rem; border-radius: 26px; }
  .respons-grid { grid-template-columns: 1fr; }
  .poste-profil-layout { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 600px) {
  .poste-hero { padding: 126px 0 48px; }
  .poste-hero__title { font-size: clamp(1.7rem, 7vw, 2.4rem); }
  .poste-hero__stats { gap: 16px; }
  .day-timeline::before { left: 64px; }
  .day-step { grid-template-columns: 64px 14px 1fr; gap: 0 12px; }
  .day-step__time { font-size: .7rem; }
  .poste-apply__inner { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 600px) {
  .formation-hero { padding: 130px 0 48px; }
  .formation-hero__title { font-size: clamp(1.8rem, 7vw, 2.6rem); }
  .formation-hero__badges { gap: 7px; }
  .fh-badge { font-size: .72rem; padding: 5px 11px; }
  .fsb__nav { grid-template-columns: 1fr; }
  .fsb__item--final { grid-column: span 1; }
  .fm__header { padding: 14px 16px; gap: 10px; }
  .fm__header-left { gap: 10px; }
  .fm__num { width: 44px; height: 44px; border-radius: 12px; font-size: .8rem; }
  .fm__title { font-size: .9rem; }
  .fm__meta { gap: 8px; font-size: .7rem; }
  .fm__lessons { padding: 0 16px 8px; }
  .fm__quiz { padding: 16px; }
  .fm__quiz-hd { flex-wrap: wrap; }
  .fm__quiz-req { width: 100%; text-align: center; }
  .fq__question { padding: 14px 14px; }
  .fq__option { padding: 9px 12px; font-size: .82rem; }
  .formation-cert { padding: 28px 22px; }
  .formation-cert__left { flex-direction: column; }

  /* Lecteur vidéo présentateur : panneau horizontal compact */
  .fl__vid--with-presenter .fl__vid-screen { grid-template-columns: 1fr; height: auto; }
  .fl__vid-presenter-panel {
    flex-direction: row; align-items: center;
    padding: 10px 14px; gap: 12px;
    border-right: none; border-bottom: 1px solid rgba(255,255,255,.07);
  }
  .fl__vid-photo-wrap { width: 48px; height: 60px; animation: none; }
  .fl__vid-presenter-role { display: none; }
  .fl__vid-content-panel { height: 200px; }
  .fl__vid-content-panel .fl__vid-slide { padding: 16px 18px; }
  .fl__vid-title { font-size: 1.05rem; }
  .fl__vid-body { font-size: .83rem; }
  .fl__vid-values { gap: 14px; flex-wrap: wrap; }
  .fl__vid-value i { font-size: 1.4rem; }
  .fl__vid-timeline { gap: 7px; }
  .fl__vid-step { font-size: .78rem; gap: 9px; }

  /* Quiz lock overlay */
  .fm__quiz-lock-box { padding: 18px 22px; }
  .fm__quiz-lock-box i { font-size: 1.5rem; }
}

/* ============================================================
   RESPONSIVE — 480 px (tablette portrait étroite / grand mobile)
============================================================ */
@media (max-width: 480px) {

  /* ── Recrutement ── */
  .poste-card__body { padding: 18px 18px 22px; }
  .poste-card--featured { padding: 24px 16px; }
  .poste-card__title  { font-size: 1rem; }
  .contrat-card       { padding: 22px 18px; }
  .proc-step          { gap: 14px; }
  .recru-hero__text .btn-group { flex-direction: column; }
  .recru-hero__text .btn-group .btn { justify-content: center; }

  /* ── À-propos ── */
  .about__card        { padding: 22px 18px; }
  .about__stat-num    { font-size: 2rem; }
  .val-card           { padding: 22px 18px; }

  /* ── Zone d'intervention ── */
  .zone-region        { padding: 10px 12px; font-size: .8rem; }
  .zone-stat          { padding: 18px 14px; }
  .zone-stat__num     { font-size: 1.6rem; }

  /* ── Formation ── */
  .fm__lesson-header  { gap: 10px; }
  .fl__lesson-content { padding: 12px 14px 16px; }
  .fl__callout        { padding: 11px 13px; font-size: .8rem; }
  .fl__mark-done      { font-size: .8rem; padding: 8px 14px; }
  .fq__btn-group      { flex-direction: column; }
  .fq__submit         { width: 100%; justify-content: center; }
  .fm__lessons-bar    { height: 5px; }

  /* ── Global ── */
  .btn-group          { flex-wrap: wrap; }
  .btn-group .btn     { flex: 1 1 auto; min-width: 0; justify-content: center; }
  .bento-card         { padding: 22px 18px; }
  .footer__top        { gap: 24px; }
  .footer__col        { min-width: 0; }
}
