
/* =========================================================
   VARIABLES & RESET
   ========================================================= */
:root {
  --navy:        #0C1A2E;
  --navy-mid:    #112238;
  --navy-light:  #1C3252;
  --orange:      #F45D00;
  --orange-h:    #FF6B1A;
  --orange-10:   rgba(244,93,0,.10);
  --orange-20:   rgba(244,93,0,.20);
  --white:       #FFFFFF;
  --off-white:   #F6F8FB;
  --slate:       #E8EDF5;
  --text:        #0C1A2E;
  --text-mid:    #3D5272;
  --text-muted:  #7A90AB;
  --border:      rgba(12,26,46,.10);
  --border-l:    #E2E8F0;
  --shadow-sm:   0 2px 12px rgba(12,26,46,.07);
  --shadow-md:   0 8px 36px rgba(12,26,46,.12);
  --shadow-lg:   0 24px 72px rgba(12,26,46,.18);
  --r:           6px;
  --ease:        cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Outfit',sans-serif;
  font-weight:400;
  color:var(--text);
  background:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:'Outfit',sans-serif;cursor:pointer;border:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--off-white)}
::-webkit-scrollbar-thumb{background:var(--orange);border-radius:2px}

/* =========================================================
   UTILITIES
   ========================================================= */
.container{max-width:1200px;margin:0 auto;padding:0 48px}
.section-label{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--orange);margin-bottom:18px;
}
.section-label::before{content:'';width:28px;height:1.5px;background:var(--orange)}
h1,h2,h3,h4{line-height:1.1;letter-spacing:-.02em}
h2{font-size:clamp(34px,4vw,52px);font-weight:700;color:var(--text)}
h3{font-size:20px;font-weight:600;color:var(--text)}
p{line-height:1.75;color:var(--text-mid)}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;font-size:13px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  border-radius:var(--r);transition:all .28s var(--ease);
  white-space:nowrap;
}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-h);transform:translateY(-2px);box-shadow:0 10px 30px rgba(244,93,0,.35)}
.btn-outline-white{border:1.5px solid rgba(255,255,255,.35);color:#fff}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.btn-outline-navy{border:1.5px solid var(--navy);color:var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:#fff}
.btn svg{width:16px;height:16px;transition:transform .25s}
.btn:hover svg{transform:translateX(3px)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* =========================================================
   NAV
   ========================================================= */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:90px;
  display:flex;align-items:center;
  padding:0 48px;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),height .35s;
  background:transparent;
}
#navbar.scrolled{
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow-sm);
  height:88px;
}
#navbar.scrolled .nav-link{color:var(--text-mid)}
#navbar.scrolled .nav-link:hover{color:var(--orange)}
#navbar.scrolled .nav-logo-text{color:var(--navy)}
#navbar.hero-mode .nav-link{color:rgba(255,255,255,.75)}
#navbar.hero-mode .nav-link:hover{color:#fff}
#navbar.hero-mode .nav-logo-text{color:#fff}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav-logo{display:flex;align-items:center;gap:12px;cursor:pointer;}
.nav-logo-text{font-size:13px;font-weight:700;letter-spacing:.04em;line-height:1.3;transition:color .3s;}
.nav-logo-text img{border-radius:5px;}
.nav-logo-text span{display:block;font-weight:400;font-size:11px;opacity:.7;letter-spacing:.12em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-link{
  font-size:15px;font-weight:500;letter-spacing:.02em;
  position:relative;padding-bottom:2px;transition:color .25s;
}
.nav-link::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;
  background:var(--orange);transition:width .3s var(--ease);
}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-cta .btn{padding:11px 24px;font-size:12.5px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:currentColor;border-radius:1px;transition:all .3s}

/* =========================================================
   DROPDOWN MENU  ← NOUVEAU
   ========================================================= */
.nav-item {
  position: relative;
  list-style: none;
}
.nav-item .nav-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
}
.nav-item .nav-link-arrow svg {
  width: 12px;
  height: 12px;
  transition: transform .25s var(--ease);
  flex-shrink: 0;
}
.nav-item:hover .nav-link-arrow svg { transform: rotate(180deg); }

.dropdown {
  position: absolute;
  top: calc(100% + 5px);
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  min-width: 256px;
  border-radius: 5px;
  box-shadow: 0 16px 48px rgba(12,26,46,.18);
  padding: 8px 0;
  z-index: 110;
  border-top: 2px solid var(--orange);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(8px);
  transition: all .25s var(--ease);
  pointer-events: none;
}
.nav-item:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: all;
}
/* small arrow tip */
.dropdown::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid var(--orange);
}
.dropdown a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 20px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-mid);
  transition: all .2s;
  border-left: 3px solid transparent;
}
.dropdown a:hover {
  background: var(--orange-10);
  color: var(--orange);
  border-left-color: var(--orange);
  padding-left: 24px;
}
.dropdown a .dd-icon {
  font-size: 17px;
  flex-shrink: 0;
  line-height: 1;
}
.dropdown-divider {
  height: 1px;
  background: var(--border-l);
  margin: 6px 0;
}

/* =========================================================
   POPUP ANNONCES  ← NOUVEAU
   ========================================================= */
.popup-overlay {
  position: fixed;
  inset: 0;
  background: rgba(8,18,38,.72);
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(6px);
  animation: popupFadeIn .4s ease both;
}
.popup-overlay.hidden { display: none; }

@keyframes popupFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.popup-box {
  background: #fff;
  border-radius: 16px;
  width: min(680px, 95vw);
  max-height: 90vh;
  overflow: hidden;
  position: relative;
  box-shadow: 0 32px 80px rgba(12,26,46,.35);
  animation: popupSlideIn .45s .1s var(--ease) both;
}
@keyframes popupSlideIn {
  from { opacity: 0; transform: translateY(32px) scale(.97); }
  to   { opacity: 1; transform: none; }
}

.popup-header {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.popup-header::before {
  content: '';
  position: absolute;
  right: -40px; top: -40px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: rgba(244,93,0,.12);
}
.popup-header-left { position: relative; z-index: 1; }
.popup-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--orange);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 10px;
}
.popup-header h3 {
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}
.popup-close {
  background: rgba(255,255,255,.12);
  border: none;
  color: rgba(255,255,255,.7);
  width: 36px; height: 36px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  position: relative; z-index: 1;
  flex-shrink: 0;
}
.popup-close:hover { background: rgba(255,255,255,.25); color: #fff; }

.popup-body { padding: 28px; overflow-y: auto; max-height: 400px; }

.popup-ad-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 20px;
}
.popup-ad-card {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 16px 18px;
  border-radius: var(--r);
  border: 1.5px solid var(--border-l);
  transition: border-color .2s, box-shadow .2s;
  cursor: pointer;
}
.popup-ad-card:hover {
  border-color: var(--orange-20);
  box-shadow: var(--shadow-sm);
}
.popup-ad-card.featured {
  border-color: var(--orange);
  background: var(--orange-10);
}
.popup-ad-icon {
  width: 48px; height: 48px;
  border-radius: 10px;
  background: var(--navy);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.popup-ad-card.featured .popup-ad-icon { background: var(--orange); }
.popup-ad-content { flex: 1; min-width: 0; }
.popup-ad-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 4px;
}
.popup-ad-content h4 {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.3;
}
.popup-ad-content p {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.55;
}
.popup-ad-arrow {
  color: var(--orange);
  font-size: 18px;
  align-self: center;
  flex-shrink: 0;
}

.popup-footer {
  padding: 16px 28px;
  border-top: 1px solid var(--border-l);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.popup-footer label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--text-muted);
  cursor: pointer;
}
.popup-footer input[type="checkbox"] { accent-color: var(--orange); width: 15px; height: 15px; }

/* =========================================================
   HERO
   ========================================================= */
#hero{
  min-height:100vh;
  background:var(--navy);
  position:relative;overflow:hidden;
  display:flex;align-items:center;
  padding:120px 0 80px;
}
#hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:36px 36px;
  z-index:0;
}
#hero::after{
  content:'';position:absolute;
  top:-15%;right:-5%;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(244,93,0,.18) 0%,transparent 65%);
  z-index:0;pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--orange);margin-bottom:28px;
  animation:fadeSlideUp .7s var(--ease) both;
}
.hero-tag::before{content:'';width:32px;height:1.5px;background:var(--orange)}
.hero-h1{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(52px,6.5vw,82px);
  font-weight:500;
  line-height:1;
  letter-spacing:-.01em;
  color:#fff;
  margin-bottom:28px;
  animation:fadeSlideUp .7s .12s var(--ease) both;
}
.hero-h1 .accent{color:var(--orange)}
.hero-sub{
  font-size:16px;font-weight:400;line-height:1.8;
  color:rgba(255,255,255,.62);
  max-width:500px;
  margin-bottom:44px;
  animation:fadeSlideUp .7s .22s var(--ease) both;
}
.hero-actions{
  display:flex;gap:14px;flex-wrap:wrap;
  animation:fadeSlideUp .7s .32s var(--ease) both;
}
.hero-badges{
  display:flex;gap:48px;margin-top:52px;padding-top:40px;
  border-top:1px solid rgba(248,245,240,.08);
  position:relative;z-index:1;
  animation:fadeSlideUp .7s .4s var(--ease) both;
  /*flex-wrap:wrap;*/
}
.hero-badge{
  display:flex;align-items:center;gap:10px;
  font-size:12.5px;color:rgba(255,255,255,.55);letter-spacing:.03em;
}
.hero-badge svg{color:var(--orange);flex-shrink:0}
.hero-visual{position:relative;animation:fadeSlideLeft .9s .18s var(--ease) both}
.hero-card-main{
  background:var(--navy-mid);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:36px;
  position:relative;overflow:hidden;
}
.hero-card-main::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--orange),transparent);
}
.hero-card-kpi{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.kpi-val{font-size:42px;font-weight:800;color:#fff;line-height:1;margin-bottom:4px;display:flex;justify-content:center;align-items:baseline;gap:2px;}
.kpi-val span{font-size:24px;color:var(--orange)}
.kpi-lbl{font-size:11.5px;color:rgba(255,255,255,.45);font-weight:500;text-transform:uppercase;letter-spacing:.1em}
.hero-card-float{
  position:absolute;bottom:-78px;left:-28px;
  background:var(--orange);border-radius:10px;
  padding:18px 24px;
  box-shadow:0 12px 40px rgba(244,93,0,.35);
  animation:float 3.5s ease-in-out infinite;
}
.hero-card-float p{font-size:12px;font-weight:700;color:#fff;letter-spacing:.06em;text-transform:uppercase}
.hero-card-float strong{font-size:20px;font-weight:800;color:#fff;display:block;margin-top:2px}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes fadeSlideLeft{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:none}}
@keyframes rotateSlow{to{transform:translateY(-50%) rotate(360deg)}}

.gear-svg{
  position:absolute;right:-80px;top:50%;transform:translateY(-50%);
  opacity:.04;animation:rotateSlow 40s linear infinite;pointer-events:none;
  z-index:0;
}
.scroll-cue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;
  color:rgba(255,255,255,.35);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
}
.scroll-cue-line{width:1px;height:40px;background:rgba(255,255,255,.15);position:relative;overflow:hidden;}
.scroll-cue-line::after{
  content:'';position:absolute;top:-40px;width:1px;height:40px;
  background:var(--orange);animation:scrollDown 1.6s infinite;
}
@keyframes scrollDown{to{top:40px}}

/* =========================================================
   TRUST BAR
   ========================================================= */
.trust-bar{background:var(--orange);padding:0;overflow:hidden;height:48px;display:flex;align-items:center;}
.marquee-track{display:flex;gap:0;animation:marquee 22s linear infinite;width:max-content;}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  display:inline-flex;align-items:center;gap:14px;
  padding:0 36px;
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;
}
.marquee-dot{width:4px;height:4px;background:rgba(255,255,255,.5);border-radius:50%;flex-shrink:0}

/* =========================================================
   ABOUT
   ========================================================= */
#about{padding:110px 0;background:var(--white)}
.about-grid{display:grid;grid-template-columns:5fr 6fr;gap:80px;align-items:start}
.about-intro-text{font-size:17px;line-height:1.85;color:var(--text-mid);margin-bottom:40px;}
.about-intro-text strong{color:var(--text);font-weight:600}
.mvv-tabs{display:flex;gap:4px;margin-bottom:32px;background:var(--off-white);padding:4px;border-radius:var(--r)}
.mvv-tab{flex:1;padding:10px 16px;font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:none;border-radius:4px;color:var(--text-muted);transition:all .25s;cursor:pointer;}
.mvv-tab.active{background:#fff;color:var(--orange);box-shadow:var(--shadow-sm)}
.mvv-tab:hover:not(.active){color:var(--text)}
.mvv-panel{display:none;animation:fadeIn .35s var(--ease)}
.mvv-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.mvv-content{background:var(--off-white);border-radius:var(--r);padding:32px;border-left:3px solid var(--orange);}
.mvv-content p{font-size:15.5px;line-height:1.85;color:var(--text-mid)}
.values-stack{display:flex;flex-direction:column;gap:14px;}
.value-row{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--off-white);border-radius:var(--r);transition:all .25s;cursor:default;border:1.5px solid transparent;}
.value-row:hover{border-color:var(--orange-20);background:#fff;box-shadow:var(--shadow-sm)}
.val-num{width:32px;height:32px;border-radius:50%;background:var(--orange-10);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;font-weight:800;color:var(--orange);}
.val-text{font-size:14.5px;font-weight:500;color:var(--text)}
.val-desc{font-size:12.5px;color:var(--text-muted);margin-left:auto;text-align:right;max-width:180px}
.about-right{position:sticky;top:96px}
.about-img-main{
  width:100%;height:420px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);
  border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  position:relative;
}
.about-img-text{position:relative;z-index:1;text-align:center;padding:32px}
.about-img-quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:26px;color:rgba(255,255,255,.8);line-height:1.4;margin-bottom:16px;}
.about-img-author{font-size:12px;color:var(--orange);font-weight:600;letter-spacing:.15em;text-transform:uppercase}
.about-float-badge{
  position:absolute;bottom:-20px;right:-20px;
  background:#fff;border-radius:10px;padding:20px 24px;
  box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:14px;
}
.badge-icon{width:44px;height:44px;background:var(--orange-10);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.badge-icon svg{color:var(--orange)}
.badge-text p{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.badge-text strong{font-size:15px;font-weight:700;color:var(--text)}
.about-visual-wrap{position:relative}

/* =========================================================
   STATS
   ========================================================= */
#stats{padding:80px 0;background:var(--navy);position:relative;overflow:hidden;}
#stats::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border-radius:var(--r);overflow:hidden;position:relative;z-index:1;}
.stat-card{background:transparent;padding:48px 40px;text-align:center;transition:background .25s;}
.stat-card:hover{background:rgba(255,255,255,.03)}
.stat-num{font-size:52px;font-weight:800;color:#fff;line-height:1;margin-bottom:8px;display:flex;justify-content:center;align-items:baseline;gap:2px;}
.stat-num .plus{font-size:32px;color:var(--orange)}
.stat-lbl{font-size:12px;color:rgba(255,255,255,.45);font-weight:500;letter-spacing:.12em;text-transform:uppercase;line-height:1.4}
.stat-sep{width:32px;height:1.5px;background:var(--orange);margin:14px auto}

/* =========================================================
   SERVICES
   ========================================================= */
#services{padding:110px 0;background:var(--off-white)}
.services-header{text-align:center;max-width:640px;margin:0 auto 64px}
.services-header h2{margin-bottom:16px}
.services-header p{font-size:16px;color:var(--text-muted)}
.service-tabs-nav{display:flex;justify-content:center;gap:8px;margin-bottom:52px;flex-wrap:wrap;}
.stab{padding:12px 28px;border-radius:100px;font-size:13px;font-weight:600;border:1.5px solid var(--border-l);background:#fff;color:var(--text-mid);transition:all .25s var(--ease);cursor:pointer;display:flex;align-items:center;gap:8px;}
.stab:hover{border-color:var(--orange);color:var(--orange)}
.stab.active{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 6px 24px rgba(244,93,0,.28)}
.stab-icon{font-size:16px}
.service-panel{display:none;animation:fadeIn .4s var(--ease)}
.service-panel.active{display:block}
.service-layout{display:grid;grid-template-columns:5fr 4fr;gap:60px;align-items:start;background:#fff;border-radius:12px;padding:52px;box-shadow:var(--shadow-sm);border:1px solid var(--border-l);}
.service-tag-line{font-size:13px;font-style:italic;color:var(--text-muted);margin-bottom:20px;padding:12px 16px;background:var(--orange-10);border-radius:var(--r);border-left:3px solid var(--orange);}
.service-desc{font-size:15px;line-height:1.85;color:var(--text-mid);margin-bottom:36px}
.service-list{list-style:none;display:flex;flex-direction:column;gap:0}
.service-list li{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-l);font-size:14.5px;color:var(--text-mid);transition:color .2s;}
.service-list li:last-child{border-bottom:none}
.service-list li:hover{color:var(--orange)}
.li-check{width:20px;height:20px;background:var(--orange-10);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;}
.li-check svg{color:var(--orange);width:10px;height:10px}
.service-cta-wrap{margin-top:36px;display:flex;gap:12px;flex-wrap:wrap;}
.service-visual-card{background:var(--navy);border-radius:10px;padding:36px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;min-height:400px;}
.service-visual-card::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:22px 22px;}
.svc-icon{font-size:64px;position:relative;z-index:1;margin-bottom:20px;opacity:.85}
.svc-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:28px;color:#fff;line-height:1.2;position:relative;z-index:1;margin-bottom:12px;}
.svc-tagline{font-size:12.5px;color:rgba(255,255,255,.4);letter-spacing:.12em;text-transform:uppercase;font-weight:600;position:relative;z-index:1}
.svc-orange-bar{height:3px;background:linear-gradient(90deg,var(--orange),transparent);margin-top:24px;position:relative;z-index:1;border-radius:2px;}
.svc-number{position:absolute;bottom:20px;right:24px;font-size:96px;font-weight:800;color:rgba(255,255,255,.04);line-height:1;z-index:0;select:none}

/* =========================================================
   WHY GIC
   ========================================================= */
#pourquoi{padding:110px 0;background:var(--white)}
.why-header{margin-bottom:64px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{padding:32px;border-radius:var(--r);border:1.5px solid var(--border-l);transition:all .3s var(--ease);position:relative;overflow:hidden;background:#fff;}
.why-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--orange);transform:scaleX(0);transition:transform .3s var(--ease);transform-origin:left;}
.why-card:hover{box-shadow:var(--shadow-md);transform:translateY(-5px);border-color:var(--orange-20)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon{width:50px;height:50px;background:var(--orange-10);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.why-icon svg{color:var(--orange);width:24px;height:24px}
.why-card h3{font-size:17px;margin-bottom:10px}
.why-card p{font-size:13.5px;color:var(--text-muted);line-height:1.7}

/* =========================================================
   MARKETING
   ========================================================= */
#marketing{padding:110px 0;background:var(--navy);position:relative;overflow:hidden}
#marketing::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.035) 1px,transparent 1px);background-size:36px 36px;}
#marketing::after{content:'';position:absolute;left:-5%;bottom:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(244,93,0,.14) 0%,transparent 65%);pointer-events:none;z-index:0;}
.marketing-inner{position:relative;z-index:1}
.marketing-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.marketing-left .section-label{color:rgba(255,255,255,.5)}
.marketing-left .section-label::before{background:rgba(255,255,255,.5)}
.marketing-left h2{color:#fff;margin-bottom:20px}
.marketing-left p{color:rgba(255,255,255,.6);font-size:15.5px;line-height:1.85;margin-bottom:32px}
.longrich-badge-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.l-badge{padding:7px 18px;border:1px solid rgba(244,93,0,.4);border-radius:100px;font-size:12px;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:.08em;}
.l-badge.orange-fill{background:var(--orange);border-color:var(--orange);color:#fff}
.marketing-cta-row{display:flex;gap:12px;flex-wrap:wrap;}
.longrich-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:40px;backdrop-filter:blur(10px);}
.longrich-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.09)}
.longrich-logo{width:52px;height:52px;border-radius:10px;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-.02em;}
.longrich-header h3{color:#fff;font-size:22px;margin-bottom:4px}
.longrich-header p{font-size:12.5px;color:rgba(255,255,255,.4);font-weight:500}
.longrich-features{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}
.lf-row{display:flex;align-items:flex-start;gap:12px;padding:14px;background:rgba(255,255,255,.04);border-radius:var(--r);transition:background .2s;}
.lf-row:hover{background:rgba(255,255,255,.08)}
.lf-icon{color:var(--orange);font-size:18px;flex-shrink:0;margin-top:1px}
.lf-text strong{display:block;font-size:13.5px;color:#fff;font-weight:600;margin-bottom:2px}
.lf-text span{font-size:12px;color:rgba(255,255,255,.45)}

/* =========================================================
   LIVRES
   ========================================================= */
#livres{padding:110px 0;background:var(--off-white)}
.livres-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;flex-wrap:wrap;gap:16px}
.livres-header .left h2{margin-bottom:8px}
.livres-header .left p{color:var(--text-muted);font-size:15px}
.livres-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.livre-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-l);transition:all .3s var(--ease);display:flex;flex-direction:column;}
.livre-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.livre-cover{height:200px;display:flex;align-items:center;justify-content:center;position:relative;font-size:72px;}
.lc-1{background:linear-gradient(145deg,#0C1A2E,#1C3252)}
.lc-2{background:linear-gradient(145deg,#1A0800,#3D1400)}
.lc-3{background:linear-gradient(145deg,#001018,#00283C)}
.lc-4{background:linear-gradient(145deg,#120C1A,#261838)}
.livre-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4),transparent 50%);}
.livre-cover-emoji{position:relative;z-index:1}
.livre-spine{position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--orange)}
.livre-body{padding:20px;flex:1;display:flex;flex-direction:column}
.livre-cat{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:8px;}
.livre-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;margin-bottom:8px}
.livre-desc{font-size:12.5px;color:var(--text-muted);line-height:1.65;flex:1}
.livre-cta{margin-top:16px;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.08em;transition:gap .2s;}
.livre-card:hover .livre-cta{gap:10px}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
#temoignages{padding:110px 0;background:var(--white)}
.temo-header{text-align:center;max-width:560px;margin:0 auto 60px}
.temo-header h2{margin-bottom:12px}
.temo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.temo-card{padding:36px;border-radius:var(--r);background:var(--off-white);border:1.5px solid var(--border-l);position:relative;transition:all .3s;}
.temo-card:hover{border-color:var(--orange-20);box-shadow:var(--shadow-md)}
.temo-quote-icon{font-size:40px;color:var(--orange);opacity:.3;line-height:1;margin-bottom:16px;font-family:'Georgia',serif}
.temo-text{font-size:14.5px;line-height:1.8;color:var(--text-mid);font-style:italic;margin-bottom:24px}
.temo-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border-l)}
.temo-avatar{width:44px;height:44px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:700;color:#fff;}
.temo-name{font-size:13.5px;font-weight:700;color:var(--text);display:block}
.temo-role{font-size:12px;color:var(--text-muted);margin-top:2px;display:block}
.temo-stars{color:var(--orange);font-size:13px;letter-spacing:2px;margin-bottom:12px}

/* =========================================================
   CTA STRIP
   ========================================================= */
.cta-strip{background:var(--orange);padding:52px 0;position:relative;overflow:hidden;}
.cta-strip::before{content:'';position:absolute;right:-80px;top:50%;transform:translateY(-50%);width:400px;height:400px;border-radius:50%;border:80px solid rgba(255,255,255,.07);pointer-events:none;}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.cta-strip-left h2{font-size:clamp(24px,3vw,36px);color:#fff;font-weight:700;margin-bottom:6px}
.cta-strip-left p{color:rgba(255,255,255,.75);font-size:15px}
.cta-strip-right{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}

/* =========================================================
   CONTACT
   ========================================================= */
#contact{padding:0;background:var(--white)}
.contact-grid{display:grid;grid-template-columns:5fr 7fr}
.contact-left{background:var(--navy);padding:80px 56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
.contact-left::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:30px 30px;}
.contact-left-content{position:relative;z-index:1}
.contact-left .section-label{color:var(--orange)}
.contact-left h2{color:#fff;margin-bottom:20px}
.contact-left>div>p{color:rgba(255,255,255,.6);font-size:15px;line-height:1.8;margin-bottom:48px}
.contact-details-list{display:flex;flex-direction:column;gap:28px;position:relative;z-index:1}
.cdetail{display:flex;gap:16px;align-items:flex-start}
.cdetail-icon{width:44px;height:44px;background:rgba(244,93,0,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cdetail-icon svg{color:var(--orange);width:20px;height:20px}
.cdetail-label{font-size:10.5px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:3px}
.cdetail-val{font-size:14px;color:rgba(255,255,255,.85);line-height:1.6;font-weight:500}
.contact-socials{display:flex;gap:10px;margin-top:36px;position:relative;z-index:1}
.soc-btn{width:40px;height:40px;border-radius:8px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:13px;font-weight:700;transition:all .25s;text-decoration:none;}
.soc-btn:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.contact-right{padding:80px 56px}
.contact-right h3{font-size:24px;font-weight:700;color:var(--text);margin-bottom:6px}
.contact-right>p{font-size:14.5px;color:var(--text-muted);margin-bottom:36px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-field{display:flex;flex-direction:column;gap:7px}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.form-field input,.form-field textarea,.form-field select{padding:13px 16px;border:1.5px solid var(--border-l);border-radius:var(--r);font-size:14.5px;font-family:'Outfit',sans-serif;color:var(--text);background:#fff;outline:none;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;}
.form-field textarea{height:120px;resize:none}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(244,93,0,.1);}
.form-field select option{background:#fff;color:var(--text)}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted);opacity:.7}
.form-submit-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:8px}
.form-privacy{font-size:12px;color:var(--text-muted);line-height:1.5;max-width:320px}
.form-privacy svg{display:inline;vertical-align:middle;width:12px;height:12px;color:var(--orange);margin-right:4px}

/* =========================================================
   FOOTER
   ========================================================= */
footer{background:var(--navy);border-top:1px solid rgba(255,255,255,.06);padding:64px 0 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07);}
.footer-brand .logo-row{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-brand p{font-size:13.5px;color:rgba(255,255,255,.45);line-height:1.8;max-width:280px}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:20px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:13.5px;color:rgba(255,255,255,.5);transition:color .2s}
.footer-links a:hover{color:var(--orange)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-copy{font-size:12.5px;color:rgba(255,255,255,.3)}
.footer-badge{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.3);}
.footer-badge span{color:var(--orange)}
.footer-badge a{color:var(--orange)}

/* =========================================================
   MOBILE MENU
   ========================================================= */
.mobile-menu{display:none;position:fixed;inset:0;z-index:999;background:var(--navy);padding:100px 32px 48px;flex-direction:column;overflow-y:auto;}
.mobile-menu.open{display:flex}
.mobile-nav-links{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:40px}
.mobile-nav-links a{display:block;padding:14px 0;font-size:22px;font-weight:700;color:rgba(255,255,255,.75);border-bottom:1px solid rgba(255,255,255,.07);transition:color .2s;}
.mobile-nav-links a:hover{color:var(--orange)}
.mobile-close{position:absolute;top:24px;right:24px;background:none;border:none;cursor:pointer;font-size:24px;color:rgba(255,255,255,.6);font-family:'Outfit',sans-serif;}
/* Mobile sub-menu */
.mobile-sub{list-style:none;padding:4px 0 8px 16px;}
.mobile-sub li a{font-size:16px!important;padding:8px 0!important;color:rgba(255,255,255,.5)!important;border-bottom:none!important;}
.mobile-sub li a:hover{color:var(--orange)!important}

/* =========================================================
   PAGE HERO (sous-pages)  ← NOUVEAU
   ========================================================= */
.page-hero {
  background: var(--navy);
  padding: 130px 0 72px;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle,rgba(255,255,255,.055) 1px,transparent 1px);
  background-size: 36px 36px;
}
.page-hero::after {
  content: '';
  position: absolute;
  top: -20%;
  right: -5%;
  width: 600px; height: 600px;
  background: radial-gradient(circle,rgba(244,93,0,.15) 0%,transparent 65%);
  pointer-events: none;
}
.page-hero-inner {
  position: relative;
  z-index: 1;
}
.page-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 20px;
}
.page-hero-tag::before { content:''; width:32px; height:1.5px; background:var(--orange); }
.page-hero h1 {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: clamp(48px, 6vw, 76px);
  font-weight: 600;
  color: #fff;
  line-height: 1.05;
  margin-bottom: 20px;
}
.page-hero h1 .accent { color: var(--orange); }
.page-hero p {
  font-size: 17px;
  color: rgba(255,255,255,.6);
  max-width: 540px;
  line-height: 1.8;
  margin-bottom: 36px;
}
.page-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: rgba(255,255,255,.35);
  margin-bottom: 24px;
}
.breadcrumb a { color: rgba(255,255,255,.5); transition: color .2s; }
.breadcrumb a:hover { color: var(--orange); }
.breadcrumb span { color: var(--orange); }

/* =========================================================
   CONTENT SECTIONS (sous-pages)  ← NOUVEAU
   ========================================================= */
.page-section { padding: 90px 0; }
.page-section-alt { padding: 90px 0; background: var(--off-white); }

/* Feature grid */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.feature-card {
  background: #fff;
  border-radius: var(--r);
  border: 1.5px solid var(--border-l);
  padding: 32px;
  transition: all .3s var(--ease);
}
.feature-card:hover {
  border-color: var(--orange-20);
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.feature-card .fc-icon {
  width: 56px; height: 56px;
  background: var(--orange-10);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  margin-bottom: 20px;
}
.feature-card h3 { font-size: 18px; margin-bottom: 10px; }
.feature-card p { font-size: 13.5px; color: var(--text-muted); line-height: 1.7; }

/* Process steps */
.process-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.process-steps::before {
  content: '';
  position: absolute;
  top: 28px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: linear-gradient(90deg, var(--orange), var(--navy));
  z-index: 0;
}
.step-card {
  text-align: center;
  padding: 0 20px;
  position: relative;
  z-index: 1;
}
.step-num {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--orange);
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  box-shadow: 0 6px 24px rgba(244,93,0,.3);
}
.step-card h4 { font-size: 15px; font-weight: 700; margin-bottom: 8px; }
.step-card p { font-size: 12.5px; color: var(--text-muted); line-height: 1.6; }

/* Course grid (eLearning) */
.course-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.course-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border-l);
  box-shadow: var(--shadow-sm);
  transition: all .3s;
}
.course-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.course-thumb {
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 64px;
  position: relative;
}
.course-thumb::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.3),transparent 50%); }
.course-body { padding: 24px; }
.course-level {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.level-debutant { background: #dcfce7; color: #166534; }
.level-intermediaire { background: #fef3c7; color: #92400e; }
.level-avance { background: var(--orange-10); color: var(--orange); }
.course-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 8px; line-height: 1.3; }
.course-desc { font-size: 12.5px; color: var(--text-muted); line-height: 1.6; margin-bottom: 16px; }
.course-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--border-l);
}
.course-duration { font-size: 12px; color: var(--text-muted); }
.course-price { font-size: 16px; font-weight: 800; color: var(--orange); }

/* Boutique / Product grid */
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.product-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1.5px solid var(--border-l);
  transition: all .3s;
  display: flex;
  flex-direction: column;
}
.product-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.product-img {
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  background: var(--off-white);
}
.product-body { padding: 18px; flex: 1; display: flex; flex-direction: column; }
.product-cat { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--orange); margin-bottom: 6px; }
.product-name { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 6px; line-height: 1.3; }
.product-desc { font-size: 12.5px; color: var(--text-muted); line-height: 1.6; flex: 1; }
.product-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; margin-top: 14px; border-top: 1px solid var(--border-l); }
.product-price { font-size: 18px; font-weight: 800; color: var(--navy); }
.product-price small { font-size: 11px; font-weight: 500; color: var(--text-muted); }
.btn-sm { padding: 8px 18px !important; font-size: 11.5px !important; }

/* Actualités */
.actu-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 32px;
}
.actu-main {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1.5px solid var(--border-l);
}
.actu-main-thumb {
  height: 280px;
  background: linear-gradient(135deg, var(--navy), var(--navy-light));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 96px;
}
.actu-main-body { padding: 36px; }
.actu-tag { display: inline-flex; align-items: center; gap: 6px; padding: 5px 14px; border-radius: 100px; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: var(--orange-10); color: var(--orange); margin-bottom: 14px; }
.actu-main h3 { font-size: 24px; font-weight: 700; color: var(--text); margin-bottom: 12px; line-height: 1.3; }
.actu-main p { font-size: 14.5px; color: var(--text-mid); line-height: 1.8; margin-bottom: 20px; }
.actu-meta { font-size: 12px; color: var(--text-muted); }
.actu-side { display: flex; flex-direction: column; gap: 16px; }
.actu-card {
  background: #fff;
  border-radius: var(--r);
  border: 1.5px solid var(--border-l);
  overflow: hidden;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  transition: border-color .2s, box-shadow .2s;
}
.actu-card:hover { border-color: var(--orange-20); box-shadow: var(--shadow-sm); }
.actu-card-thumb { width: 90px; height: 90px; background: var(--off-white); display: flex; align-items: center; justify-content: center; font-size: 36px; flex-shrink: 0; }
.actu-card-body { padding: 14px 14px 14px 0; flex: 1; }
.actu-card h4 { font-size: 13.5px; font-weight: 700; color: var(--text); margin-bottom: 6px; line-height: 1.35; }
.actu-card p { font-size: 12px; color: var(--text-muted); line-height: 1.6; }
.actu-card-date { font-size: 11px; color: var(--orange); font-weight: 600; margin-bottom: 4px; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1100px){
  .container{padding:0 32px}
  #navbar{padding:0 48px}
  .about-grid{grid-template-columns:1fr}
  .about-right{position:static}
  .why-grid{grid-template-columns:1fr 1fr}
  .livres-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .feature-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:40px}
  .process-steps::before{display:none}
  .product-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{display:none}
  .marketing-grid{grid-template-columns:1fr}
  .service-layout{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .temo-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .form-field.full{grid-column:1}
  .course-grid{grid-template-columns:1fr 1fr}
  .actu-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .container{padding:0 20px}
  #navbar{padding:0 20px}
  section,#services,#about,#pourquoi,#marketing,#livres,#temoignages{padding:72px 0}
  h2{font-size:clamp(28px,6vw,40px)}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .stats-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  .livres-grid{grid-template-columns:1fr}
  .temo-grid{grid-template-columns:1fr}
  .contact-left{padding:52px 24px}
  .contact-right{padding:52px 24px}
  .footer-grid{grid-template-columns:1fr}
  .cta-strip-inner{flex-direction:column;text-align:center}
  .hero-badges{gap:16px}
  .livres-header{flex-direction:column;gap:16px}
  .service-tabs-nav{gap:6px}
  .stab{padding:10px 18px;font-size:12px}
  .feature-grid{grid-template-columns:1fr}
  .course-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-h1{font-size:clamp(40px,10vw,56px)}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{justify-content:center}
  .stats-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr}
}
