/* ═══════════════════════════════════════════════════════════════
   G-CORE GROUP SA — FEUILLE DE STYLE PREMIUM WORLD-CLASS
   Holding & Investment West Africa
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

/* ── VARIABLES ── */
:root {
  --navy:      #1B2A6B;
  --navy-deep: #0F1D52;
  --gold:      #C9A227;
  --gold-lt:   #E8C547;
  --gold-dk:   #A8841E;
  --dark:      #0D1635;
  --darker:    #080F25;
  --white:     #FFFFFF;
  --gray-50:   #F8F9FC;
  --gray-100:  #EEF0F7;
  --gray-200:  #DDE0ED;
  --gray-400:  #9CA3AF;
  --gray-700:  #374151;
  --text:      #1A1A2E;
  --green:     #4ade80;
  --shadow:    0 4px 32px rgba(27,42,107,.12);
  --shadow-lg: 0 20px 60px rgba(27,42,107,.2);
  --radius:    14px;
  --radius-lg: 20px;
  --transition: .35s cubic-bezier(.4,0,.2,1);
  --transition-spring: .5s cubic-bezier(.34,1.56,.64,1);
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body {
  font-family:'Inter',sans-serif;
  color:var(--text);
  background:#fff;
  overflow-x:hidden;
  line-height:1.6;
  cursor:none;
}
body.loaded { cursor:none }
img { max-width:100%; display:block }
a { text-decoration:none; color:inherit }
ul { list-style:none }
button { cursor:pointer }

/* ── TYPOGRAPHY ── */
.serif { font-family:'Playfair Display',serif }
.grotesk { font-family:'Space Grotesk',sans-serif }
h1,h2,h3 { font-family:'Playfair Display',serif; line-height:1.2 }

/* ── UTILITIES ── */
.container { max-width:1200px; margin:0 auto; padding:0 28px }
.section { padding:110px 0 }
.section-alt { background:var(--gray-50) }
.text-gold { color:var(--gold) }
.text-navy { color:var(--navy) }
.badge {
  display:inline-block; padding:6px 18px; border-radius:50px;
  font-size:.72rem; font-weight:700; letter-spacing:1.8px; text-transform:uppercase;
  border:1px solid transparent;
}
.badge-gold { background:rgba(201,162,39,.12); color:var(--gold); border-color:rgba(201,162,39,.3) }
.badge-navy { background:rgba(27,42,107,.08); color:var(--navy); border-color:rgba(27,42,107,.2) }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 34px; border-radius:50px;
  font-weight:600; font-size:.9rem; letter-spacing:.5px;
  transition:var(--transition); cursor:pointer; border:none; outline:none;
  position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,0);
  transition:var(--transition);
}
.btn:hover::after { background:rgba(255,255,255,0.08) }
.btn-primary { background:linear-gradient(135deg,var(--gold),var(--gold-lt)); color:var(--navy) }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 32px rgba(201,162,39,.45) }
.btn-glass {
  background:rgba(255,255,255,.1);
  color:var(--white);
  border:1.5px solid rgba(255,255,255,.25);
  backdrop-filter:blur(10px);
}
.btn-glass:hover { background:rgba(255,255,255,.2); transform:translateY(-3px); border-color:rgba(255,255,255,.4) }
.btn-outline { background:transparent; color:var(--white); border:2px solid var(--white) }
.btn-outline:hover { background:var(--white); color:var(--navy); transform:translateY(-2px) }
.btn-navy { background:var(--navy); color:var(--white) }
.btn-navy:hover { background:var(--dark); transform:translateY(-2px); box-shadow:var(--shadow) }
.btn-gold-outline {
  background:transparent; color:var(--gold);
  border:2px solid var(--gold); border-radius:50px;
  padding:12px 28px;
  display:inline-flex; align-items:center; gap:10px;
  font-weight:600; font-size:.875rem;
  transition:var(--transition);
}
.btn-gold-outline:hover { background:var(--gold); color:var(--navy); transform:translateY(-2px) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SCROLL PROGRESS BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#scroll-progress {
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg, var(--gold), var(--gold-lt), var(--gold));
  z-index:9999; transition:width .1s linear;
  box-shadow: 0 0 10px rgba(201,162,39,.8);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PRELOADER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#loader {
  position:fixed; inset:0; z-index:10000;
  background:linear-gradient(135deg,var(--darker) 0%,var(--dark) 50%,var(--navy-deep) 100%);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .7s ease, visibility .7s ease;
}
#loader.hidden { opacity:0; visibility:hidden; pointer-events:none }
.loader-inner {
  text-align:center;
  animation:loaderIn .6s ease both;
}
@keyframes loaderIn {
  from { opacity:0; transform:scale(.9) translateY(20px) }
  to   { opacity:1; transform:scale(1)  translateY(0) }
}
.loader-logo-wrap {
  position:relative;
  width:120px; height:120px;
  margin:0 auto 28px;
}
.loader-logo {
  width:80px; height:80px;
  object-fit:contain;
  position:absolute; inset:0; margin:auto;
  animation:logoPulse 2s ease-in-out infinite;
}
@keyframes logoPulse {
  0%,100% { opacity:1; transform:scale(1) }
  50%      { opacity:.8; transform:scale(1.05) }
}
.loader-ring {
  position:absolute; inset:0; border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--gold);
  border-right-color:rgba(201,162,39,.3);
  animation:spin 1.8s linear infinite;
}
.loader-ring-2 {
  inset:10px;
  border-top-color:rgba(201,162,39,.5);
  border-right-color:transparent;
  border-bottom-color:var(--gold);
  animation:spin 2.4s linear infinite reverse;
}
@keyframes spin { to { transform:rotate(360deg) } }
.loader-name {
  font-family:'Playfair Display',serif;
  font-size:1.6rem; font-weight:800;
  color:#fff; letter-spacing:4px; text-transform:uppercase;
  margin-bottom:20px;
}
.loader-bar-wrap { width:240px; margin:0 auto 20px }
.loader-bar {
  height:2px; background:rgba(255,255,255,.12); border-radius:2px; overflow:hidden;
}
.loader-fill {
  height:100%; width:0%; background:linear-gradient(90deg,var(--gold),var(--gold-lt));
  animation:loadFill 2.2s ease-in-out forwards;
}
@keyframes loadFill { to { width:100% } }
.loader-tagline {
  font-size:.65rem; letter-spacing:4px; color:rgba(255,255,255,.4);
  text-transform:uppercase; font-weight:600;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CUSTOM CURSOR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#cursor-glow {
  position:fixed; pointer-events:none; z-index:9998;
  width:400px; height:400px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,39,.06) 0%, transparent 70%);
  transform:translate(-50%,-50%);
  transition:opacity .3s ease;
}
#cursor-dot {
  position:fixed; pointer-events:none; z-index:9999;
  width:10px; height:10px;
  border-radius:50%;
  background:var(--gold);
  transform:translate(-50%,-50%);
  transition:transform .1s ease, width .2s ease, height .2s ease, opacity .3s ease;
  mix-blend-mode:normal;
}
#cursor-dot.hovering {
  width:40px; height:40px;
  background:rgba(201,162,39,.3);
  border:2px solid var(--gold);
}
body:not(.loaded) #cursor-glow,
body:not(.loaded) #cursor-dot { opacity:0 }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TOP STRIP MARQUEE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.top-strip {
  background:linear-gradient(90deg,var(--dark),var(--navy));
  padding:10px 0; overflow:hidden;
  position:relative; z-index:999;
}
.strip-track {
  display:flex; gap:28px; align-items:center;
  animation:stripScroll 30s linear infinite;
  white-space:nowrap;
}
.strip-track span {
  font-size:.72rem; font-weight:600; letter-spacing:1.5px;
  color:rgba(255,255,255,.55); text-transform:uppercase; flex-shrink:0;
}
.strip-track span:nth-child(odd) { color:var(--gold) }
@keyframes stripScroll { from { transform:translateX(0) } to { transform:translateX(-50%) } }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   NAVIGATION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:16px 0; transition:var(--transition);
}
#navbar.scrolled {
  background:rgba(9,14,40,.95);
  backdrop-filter:blur(24px) saturate(180%);
  padding:10px 0;
  box-shadow:0 4px 30px rgba(0,0,0,.4);
  border-bottom:1px solid rgba(201,162,39,.1);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between }
.nav-logo img { height:50px; width:auto; transition:var(--transition) }
.nav-logo:hover img { transform:scale(1.05) }
.nav-menu { display:flex; align-items:center; gap:32px }
.nav-link {
  color:rgba(255,255,255,.8); font-size:.85rem; font-weight:500;
  letter-spacing:.4px; transition:var(--transition);
  position:relative; padding:4px 0;
}
.nav-link::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:2px; background:var(--gold); transition:var(--transition);
}
.nav-link:hover, .nav-link.active { color:var(--gold) }
.nav-link:hover::after, .nav-link.active::after { width:100% }
.nav-cta {
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:var(--navy)!important; padding:10px 22px;
  border-radius:50px; font-weight:700; transition:var(--transition);
  font-size:.82rem;
}
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,162,39,.4) }
.nav-cta::after { display:none }
.nav-toggle { display:none; flex-direction:column; gap:5px }
.nav-toggle span { width:24px; height:2px; background:#fff; transition:var(--transition) }

/* Language toggle */
.lang-toggle {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
  border-radius:50px; padding:6px 14px;
  color:rgba(255,255,255,.7); font-size:.75rem; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  transition:var(--transition); display:flex; align-items:center; gap:4px;
}
.lang-toggle:hover { background:rgba(201,162,39,.15); border-color:var(--gold); color:var(--gold) }
.lang-sep { color:rgba(255,255,255,.3) }
[data-lang="fr"] .lang-fr { color:var(--gold) }
[data-lang="en"] .lang-en { color:var(--gold) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HERO
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#hero {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,var(--darker) 0%,var(--dark) 40%,var(--navy-deep) 70%,#0F2050 100%);
}

/* Aurora orbs */
.aurora { position:absolute; inset:0; overflow:hidden; pointer-events:none }
.aurora-orb {
  position:absolute; border-radius:50%;
  filter:blur(100px); mix-blend-mode:screen;
  animation:auroraFloat 12s ease-in-out infinite;
  opacity:.6;
}
.orb-1 {
  width:600px; height:600px; top:-100px; right:-100px;
  background:radial-gradient(circle, rgba(27,42,107,.9) 0%, transparent 70%);
  animation-delay:0s; animation-duration:14s;
}
.orb-2 {
  width:500px; height:500px; bottom:-100px; left:-100px;
  background:radial-gradient(circle, rgba(201,162,39,.25) 0%, transparent 70%);
  animation-delay:-4s; animation-duration:18s;
}
.orb-3 {
  width:400px; height:400px; top:30%; left:30%;
  background:radial-gradient(circle, rgba(201,162,39,.12) 0%, transparent 70%);
  animation-delay:-8s; animation-duration:22s;
}
.orb-4 {
  width:300px; height:300px; top:10%; left:15%;
  background:radial-gradient(circle, rgba(15,32,80,.8) 0%, transparent 70%);
  animation-delay:-2s; animation-duration:16s;
}
@keyframes auroraFloat {
  0%,100% { transform:translate(0,0) scale(1) }
  25%      { transform:translate(40px,-30px) scale(1.08) }
  50%      { transform:translate(-20px,40px) scale(.95) }
  75%      { transform:translate(30px,20px) scale(1.05) }
}

/* Hero grid */
.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(201,162,39,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,162,39,.04) 1px, transparent 1px);
  background-size:64px 64px;
}

/* Particles */
.hero-particles { position:absolute; inset:0; overflow:hidden; pointer-events:none }
.particle {
  position:absolute; border-radius:50%; opacity:0;
  animation:particleFloat linear infinite;
}
@keyframes particleFloat {
  0%   { transform:translateY(110vh) scale(0); opacity:0 }
  10%  { opacity:.6 }
  90%  { opacity:.4 }
  100% { transform:translateY(-20px) scale(1); opacity:0 }
}

/* Hero content */
.hero-content {
  position:relative; z-index:2;
  text-align:center; color:#fff;
  max-width:900px; padding:0 28px;
  margin-top:60px;
}
.hero-tagline {
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom:32px; padding:9px 22px;
  border:1px solid rgba(201,162,39,.35); border-radius:50px;
  font-size:.75rem; font-weight:600; letter-spacing:2.5px;
  color:var(--gold); text-transform:uppercase;
  animation:fadeInDown .8s ease .2s both;
  background:rgba(201,162,39,.05); backdrop-filter:blur(10px);
}
.tagline-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--gold); opacity:.7;
  animation:taglinePulse 2s ease-in-out infinite;
}
.tagline-dot:last-child { animation-delay:.5s }
@keyframes taglinePulse { 0%,100% { opacity:.7 } 50% { opacity:1; transform:scale(1.3) } }
@keyframes fadeInDown { from { opacity:0; transform:translateY(-20px) } to { opacity:1; transform:translateY(0) } }

.hero-title {
  font-size:clamp(3.2rem,8vw,6rem);
  font-weight:800; line-height:1.05; margin-bottom:24px;
  animation:fadeInUp .9s ease .3s both;
}
.hero-title-line { display:block }
.hero-title-line:last-child { color:var(--gold) }
@keyframes fadeInUp { from { opacity:0; transform:translateY(30px) } to { opacity:1; transform:translateY(0) } }

/* Rotating badge */
.hero-badge {
  position:absolute; right:60px; top:50%;
  transform:translateY(-50%);
  animation:badgeSpin 0s linear infinite, fadeInRight .8s ease .6s both;
  animation-iteration-count:infinite, 1;
}
@keyframes fadeInRight { from { opacity:0; transform:translateX(30px) translateY(-50%) } to { opacity:1; transform:translateX(0) translateY(-50%) } }
.hero-badge-inner {
  position:relative; width:110px; height:110px;
}
.hero-badge-text {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-size:.6rem; font-weight:800; letter-spacing:3px;
  color:var(--gold); text-transform:uppercase; line-height:1.4; text-align:center;
  font-family:'Playfair Display',serif;
}
.hero-badge-circle {
  position:absolute; inset:0;
  animation:rotateBadge 18s linear infinite;
}
@keyframes rotateBadge { to { transform:rotate(360deg) } }

.hero-subtitle {
  font-size:clamp(1rem,2.2vw,1.3rem);
  color:rgba(255,255,255,.7); font-weight:300;
  letter-spacing:5px; text-transform:uppercase;
  margin-bottom:24px; min-height:2rem;
  animation:fadeInUp .9s ease .5s both;
}
.hero-divider {
  display:flex; align-items:center; justify-content:center; gap:16px;
  margin:20px auto 32px; animation:fadeIn .8s ease .6s both;
}
.hero-divider span { flex:1; max-width:80px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)) }
.hero-divider span:last-child { background:linear-gradient(90deg,var(--gold),transparent) }
.hero-divider i { color:var(--gold); font-size:.6rem; opacity:.8 }
@keyframes fadeIn { from { opacity:0 } to { opacity:1 } }

.hero-desc {
  font-size:1rem; color:rgba(255,255,255,.65);
  max-width:580px; margin:0 auto 44px; line-height:1.9;
  animation:fadeInUp .9s ease .7s both;
}
.hero-actions {
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  margin-bottom:72px; animation:fadeInUp .9s ease .8s both;
}

/* Hero stats */
.hero-stats {
  display:flex; align-items:center; justify-content:center; flex-wrap:wrap;
  padding-top:44px; border-top:1px solid rgba(255,255,255,.08);
  animation:fadeInUp .9s ease .9s both;
}
.hero-stat { text-align:center; padding:0 32px }
.hero-stat-inner {}
.hero-stat .num {
  font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:800;
  color:var(--gold); line-height:1; display:flex; align-items:baseline; justify-content:center; gap:4px;
}
.hero-stat .lbl {
  font-size:.7rem; color:rgba(255,255,255,.45);
  letter-spacing:2px; text-transform:uppercase; margin-top:8px;
}
.hero-stat-divider { width:1px; height:60px; background:rgba(255,255,255,.1) }
.unit { font-size:1.4rem; vertical-align:super; color:var(--gold) }
.unit-small { font-size:.75rem; color:rgba(255,255,255,.5); font-weight:400; margin-left:2px }

/* Hero scroll */
.hero-scroll {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:12px;
  color:rgba(255,255,255,.4); font-size:.65rem;
  letter-spacing:3px; text-transform:uppercase;
}
.scroll-mouse {
  width:24px; height:38px; border:2px solid rgba(201,162,39,.4);
  border-radius:12px; display:flex; align-items:flex-start; justify-content:center;
  padding-top:6px; animation:mouseAnim 1.5s ease-in-out infinite;
}
.scroll-wheel {
  width:3px; height:8px; border-radius:3px;
  background:var(--gold); opacity:.8;
  animation:wheelScroll 1.5s ease-in-out infinite;
}
@keyframes wheelScroll {
  0%,100% { transform:translateY(0); opacity:.8 }
  50%      { transform:translateY(6px); opacity:.3 }
}
@keyframes mouseAnim {
  0%,100% { border-color:rgba(201,162,39,.4) }
  50%      { border-color:rgba(201,162,39,.8) }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SECTION HEADERS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sec-header { text-align:center; margin-bottom:72px }
.sec-header .badge { margin-bottom:18px }
.sec-header h2 { font-size:clamp(1.9rem,4vw,2.9rem); color:var(--navy); margin-bottom:18px }
.sec-header p { color:var(--gray-700); max-width:580px; margin:0 auto; font-size:1rem; line-height:1.8 }
.sec-line { display:flex; align-items:center; justify-content:center; gap:16px; margin:24px 0 0 }
.sec-line::before,.sec-line::after { content:''; flex:1; max-width:60px; height:1px; background:var(--gold) }
.sec-line span { font-size:.65rem; letter-spacing:4px; color:var(--gold); font-weight:700; text-transform:uppercase }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   3D CARD EFFECT
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.card-3d {
  transform-style:preserve-3d;
  transition:transform .4s ease, box-shadow .4s ease;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ABOUT
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center }
.about-visual { position:relative }
.about-img-main {
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 24px 70px rgba(27,42,107,.25);
  position:relative;
}
.about-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(13,22,53,.8) 0%, transparent 60%);
  display:flex; align-items:flex-end; padding:28px;
  opacity:0; transition:var(--transition);
}
.about-img-main:hover .about-img-overlay { opacity:1 }
.about-img-overlay-inner {
  display:flex; align-items:center; gap:12px;
  color:#fff; font-weight:600; font-size:.85rem;
}
.about-img-overlay-inner i { color:var(--gold); font-size:1.2rem }
.about-badge-float {
  position:absolute; bottom:-28px; right:-28px;
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:var(--navy); padding:24px 28px; border-radius:var(--radius);
  box-shadow:0 16px 48px rgba(201,162,39,.4);
  text-align:center; min-width:145px;
  animation:floatBadge 4s ease-in-out infinite;
}
.about-badge-float .num { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:800; line-height:1 }
.about-badge-float .lbl { font-size:.65rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-top:4px }
.about-badge-float-2 {
  position:absolute; top:-20px; left:-20px;
  background:var(--navy); color:var(--gold);
  padding:14px 18px; border-radius:12px;
  font-size:.75rem; font-weight:700; letter-spacing:1px;
  box-shadow:var(--shadow);
  display:flex; align-items:center; gap:10px;
  animation:floatBadge 4s ease-in-out 2s infinite;
}
.about-badge-float-2 i { font-size:1rem }
@keyframes floatBadge {
  0%,100% { transform:translateY(0) }
  50%      { transform:translateY(-8px) }
}
.about-content .badge { margin-bottom:20px }
.about-content h2 { font-size:clamp(1.8rem,3.5vw,2.5rem); color:var(--navy); margin-bottom:20px }
.about-content .lead { font-size:1.05rem; color:var(--gray-700); margin-bottom:24px; line-height:1.9; font-style:italic; border-left:3px solid var(--gold); padding-left:20px }
.about-content p { color:var(--gray-700); line-height:1.85; margin-bottom:16px }
.about-points { margin:28px 0; display:flex; flex-direction:column; gap:14px }
.about-point {
  display:flex; align-items:flex-start; gap:16px;
  padding:16px 20px; background:var(--gray-50);
  border-radius:12px; border-left:3px solid var(--gold);
  transition:var(--transition);
}
.about-point:hover { background:var(--gray-100); transform:translateX(4px) }
.about-point .icon {
  width:40px; height:40px; background:var(--navy); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:.95rem; color:var(--gold);
}
.about-point h4 { font-size:.875rem; font-weight:700; color:var(--navy); margin-bottom:3px }
.about-point p { font-size:.8rem; color:var(--gray-400); margin:0; line-height:1.5 }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   VALUES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#values {
  background:linear-gradient(145deg,var(--darker) 0%,var(--dark) 40%,var(--navy) 100%);
  padding:110px 0; position:relative; overflow:hidden;
}
#values::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 15% 50%,rgba(201,162,39,.08) 0%,transparent 55%),
             radial-gradient(ellipse at 85% 30%,rgba(201,162,39,.05) 0%,transparent 50%);
}
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; position:relative; z-index:1 }
.value-card {
  text-align:center; padding:52px 36px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg);
  transition:var(--transition);
  position:relative; overflow:hidden;
}
.value-card:hover {
  transform:translateY(-10px);
  background:rgba(255,255,255,.08);
  border-color:rgba(201,162,39,.4);
  box-shadow:0 24px 60px rgba(0,0,0,.3);
}
.value-hover-line {
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0); transform-origin:center;
  transition:transform .4s ease;
}
.value-card:hover .value-hover-line { transform:scaleX(1) }
.value-icon {
  width:80px; height:80px;
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  border-radius:50%; margin:0 auto 32px;
  display:flex; align-items:center; justify-content:center;
  font-size:2rem; box-shadow:0 12px 32px rgba(201,162,39,.35);
  transition:var(--transition);
}
.value-card:hover .value-icon { transform:scale(1.1) rotate(5deg) }
.value-card h3 {
  font-family:'Playfair Display',serif; font-size:1.7rem;
  color:var(--gold); margin-bottom:18px; letter-spacing:1px;
}
.value-card p { color:rgba(255,255,255,.6); line-height:1.85; font-size:.9rem }
.value-number {
  position:absolute; top:20px; right:24px;
  font-family:'Playfair Display',serif; font-size:4.5rem; font-weight:800;
  color:rgba(255,255,255,.03); line-height:1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SUBSIDIARIES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sub-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px }
.sub-card {
  background:#fff; border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:0 4px 24px rgba(27,42,107,.08);
  border:1px solid var(--gray-100); transition:var(--transition);
  display:flex; flex-direction:column;
}
.sub-card:hover {
  transform:translateY(-12px) perspective(1000px) rotateX(2deg);
  box-shadow:0 32px 64px rgba(27,42,107,.18);
  border-color:rgba(201,162,39,.4);
}
.sub-card-header { padding:40px 32px 28px; position:relative; overflow:hidden }
.sub-card-header::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:160px; height:160px; border-radius:50%;
  background:rgba(255,255,255,.06);
}
.sub-card-header::after {
  content:''; position:absolute; bottom:-60px; left:-30px;
  width:200px; height:200px; border-radius:50%;
  background:rgba(255,255,255,.04);
}
.sub-logo {
  width:68px; height:68px; border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:800;
  color:#fff; margin-bottom:20px; box-shadow:0 10px 24px rgba(0,0,0,.25);
  position:relative; z-index:1;
}
.sub-gtx .sub-card-header { background:linear-gradient(135deg,#1B2A6B,#2E4099) }
.sub-glx .sub-card-header { background:linear-gradient(135deg,#1a5a8a,#2980b9) }
.sub-ggx .sub-card-header { background:linear-gradient(135deg,#1e6b3e,#27ae60) }
.sub-gtx .sub-logo { background:rgba(201,162,39,.35) }
.sub-glx .sub-logo { background:rgba(255,255,255,.2) }
.sub-ggx .sub-logo { background:rgba(255,255,255,.2) }
.sub-ref {
  font-size:.65rem; letter-spacing:2.5px; color:rgba(255,255,255,.55);
  text-transform:uppercase; font-weight:600; margin-bottom:10px;
  position:relative; z-index:1;
}
.sub-card-header h3 {
  font-family:'Playfair Display',serif; font-size:1.35rem;
  color:#fff; margin-bottom:8px; position:relative; z-index:1;
}
.sub-card-header p { font-size:.82rem; color:rgba(255,255,255,.7); position:relative; z-index:1 }
.sub-card-body { padding:28px 32px; flex:1; display:flex; flex-direction:column }
.sub-services { display:flex; flex-direction:column; gap:12px; margin-bottom:24px; flex:1 }
.sub-service {
  display:flex; align-items:center; gap:12px;
  font-size:.875rem; color:var(--gray-700); line-height:1.4;
}
.sub-service::before {
  content:''; width:7px; height:7px; border-radius:50%;
  background:var(--gold); flex-shrink:0;
}
.sub-kpi {
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
  padding:20px; background:var(--gray-50); border-radius:12px; margin-bottom:24px;
}
.sub-kpi-item { text-align:center }
.sub-kpi-item .num { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--navy) }
.sub-kpi-item .lbl { font-size:.6rem; color:var(--gray-400); letter-spacing:1.5px; text-transform:uppercase; margin-top:2px }
.sub-card-footer { padding:0 32px 32px }
.sub-link {
  display:inline-flex; align-items:center; gap:10px;
  color:var(--navy); font-size:.875rem; font-weight:700; transition:var(--transition);
}
.sub-link:hover { color:var(--gold); gap:16px }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   KEY FIGURES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#figures { background:linear-gradient(135deg,var(--navy),var(--dark)); padding:90px 0 }
.figures-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0 }
.figure-item {
  text-align:center; padding:44px 28px; position:relative;
  transition:var(--transition);
}
.figure-item:hover { background:rgba(255,255,255,.03) }
.figure-item:not(:last-child)::after {
  content:''; position:absolute; right:0; top:25%; height:50%;
  width:1px; background:rgba(255,255,255,.1);
}
.figure-icon {
  width:52px; height:52px; border-radius:14px;
  background:rgba(201,162,39,.15); border:1px solid rgba(201,162,39,.2);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px; color:var(--gold); font-size:1.2rem;
}
.figure-item .num {
  font-family:'Playfair Display',serif; font-size:3.2rem; font-weight:800;
  color:var(--gold); line-height:1; display:block;
}
.figure-item .unit { font-size:1.4rem; vertical-align:super; font-weight:700; color:var(--gold) }
.figure-item .lbl {
  font-size:.7rem; color:rgba(255,255,255,.5); letter-spacing:2px;
  text-transform:uppercase; margin-top:12px; display:block;
}
.figure-item .desc { font-size:.78rem; color:rgba(255,255,255,.3); margin-top:6px }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   STRATEGY TIMELINE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.timeline { position:relative; padding-left:48px }
.timeline::before {
  content:''; position:absolute; left:16px; top:0; bottom:0; width:2px;
  background:linear-gradient(to bottom,var(--gold),rgba(201,162,39,.1));
}
.timeline-item { position:relative; padding:0 0 52px 48px }
.timeline-dot {
  position:absolute; left:-48px; top:4px;
  width:34px; height:34px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  border:3px solid #fff;
  box-shadow:0 0 0 3px var(--gold), 0 4px 16px rgba(201,162,39,.4);
  display:flex; align-items:center; justify-content:center;
  font-size:.7rem; font-weight:800; color:var(--navy);
}
.timeline-period {
  display:inline-block; padding:5px 16px;
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:var(--navy); border-radius:50px; font-size:.75rem; font-weight:800;
  letter-spacing:1px; margin-bottom:14px;
}
.timeline-item h3 { font-size:1.25rem; color:var(--navy); margin-bottom:12px }
.timeline-item ul { display:flex; flex-direction:column; gap:10px }
.timeline-item ul li {
  display:flex; align-items:flex-start; gap:12px;
  font-size:.875rem; color:var(--gray-700); line-height:1.6;
}
.timeline-item ul li::before { content:'→'; color:var(--gold); font-weight:700; flex-shrink:0; margin-top:1px }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   AFRICA MAP SECTION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#africa-map {
  background:linear-gradient(145deg,var(--darker) 0%,#0a1628 50%,var(--dark) 100%);
  padding:110px 0; position:relative; overflow:hidden;
}
#africa-map::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 30% 50%,rgba(201,162,39,.06) 0%,transparent 60%);
}
.africa-layout {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center; position:relative; z-index:1;
}
.africa-map-visual { display:flex; justify-content:center; align-items:center }
.africa-svg { width:100%; max-width:360px; height:auto; filter:drop-shadow(0 0 40px rgba(201,162,39,.1)) }
.africa-continent { transition:fill .3s ease }
.pulsing-dot { animation:dotPulse 2s ease-in-out infinite }
.pulse-ring { animation:ringExpand 2s ease-out infinite }
.pulse-ring-2 { animation:ringExpand 2s ease-out .7s infinite }
@keyframes dotPulse { 0%,100% { r:12 } 50% { r:14 } }
@keyframes ringExpand {
  0%   { r:12; opacity:.8; stroke-width:2 }
  100% { r:32; opacity:0; stroke-width:.5 }
}
.guinea-glow { animation:glowPulse 3s ease-in-out infinite }
@keyframes glowPulse { 0%,100% { opacity:.5 } 50% { opacity:.9 } }
.expansion-dot { animation:expandDot 3s ease-in-out infinite }
.future-dot { animation:none; opacity:.4 }
@keyframes expandDot { 0%,100% { opacity:.5 } 50% { opacity:.9; r:8 } }

.africa-stats { display:flex; flex-direction:column; gap:16px }
.africa-stat-card {
  display:flex; align-items:center; gap:20px;
  padding:20px 24px; border-radius:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  transition:var(--transition);
}
.africa-stat-card:hover {
  background:rgba(201,162,39,.08); border-color:rgba(201,162,39,.25);
  transform:translateX(6px);
}
.africa-stat-icon {
  width:44px; height:44px; flex-shrink:0; border-radius:12px;
  background:rgba(201,162,39,.15); color:var(--gold);
  display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.africa-stat-num {
  font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:800;
  color:var(--gold); line-height:1; margin-bottom:4px;
}
.africa-stat-label { font-size:.78rem; color:rgba(255,255,255,.55); line-height:1.4 }
.africa-cta {
  margin-top:8px; padding:28px; border-radius:16px;
  background:rgba(201,162,39,.06); border:1px solid rgba(201,162,39,.15);
}
.africa-cta p {
  font-size:.88rem; color:rgba(255,255,255,.65); line-height:1.8; margin-bottom:20px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PARTNERS TICKER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.partners-section { background:var(--dark); padding:40px 0; overflow:hidden }
.partners-label {
  text-align:center; font-size:.65rem; letter-spacing:3px;
  color:rgba(255,255,255,.3); text-transform:uppercase; font-weight:700;
  margin-bottom:24px;
}
.partners-ticker { overflow:hidden; padding:4px 0 }
.ticker-track {
  display:flex; gap:0; align-items:center;
  animation:tickerScroll 25s linear infinite;
  width:max-content;
}
.ticker-track:hover { animation-play-state:paused }
@keyframes tickerScroll { from { transform:translateX(0) } to { transform:translateX(-50%) } }
.ticker-item {
  display:flex; align-items:center; gap:12px;
  padding:12px 36px; border-right:1px solid rgba(255,255,255,.08);
  white-space:nowrap;
}
.ticker-item i { color:var(--gold); font-size:1.1rem }
.ticker-item span { font-size:.8rem; color:rgba(255,255,255,.5); font-weight:600; letter-spacing:1px; text-transform:uppercase }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LEADERSHIP
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.leader-card {
  display:grid; grid-template-columns:auto 1fr; gap:48px; align-items:start;
  background:#fff; border-radius:var(--radius-lg); padding:52px;
  box-shadow:var(--shadow-lg); border:1px solid var(--gray-100);
  max-width:860px; margin:0 auto; position:relative; overflow:hidden;
}
.leader-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--navy),var(--gold),var(--navy));
}
.leader-avatar-wrap { position:relative; flex-shrink:0 }
.leader-avatar {
  width:160px; height:160px; border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--dark));
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif; font-size:3.5rem; font-weight:800;
  color:var(--gold); flex-shrink:0;
  box-shadow:0 16px 48px rgba(27,42,107,.3);
  border:4px solid var(--gold); position:relative; z-index:1;
}
.leader-avatar-ring {
  position:absolute; inset:-12px; border-radius:50%;
  border:1.5px solid rgba(201,162,39,.25);
  animation:ringRotate 8s linear infinite;
}
.leader-avatar-ring-2 {
  inset:-24px; border-color:rgba(201,162,39,.12);
  animation-duration:12s; animation-direction:reverse;
}
@keyframes ringRotate { to { transform:rotate(360deg) } }
.leader-info .title {
  font-size:.7rem; letter-spacing:2.5px; color:var(--gold);
  font-weight:700; text-transform:uppercase; margin-bottom:10px;
}
.leader-info h3 { font-size:2rem; color:var(--navy); margin-bottom:6px }
.leader-info .role { color:var(--gray-400); font-size:.9rem; margin-bottom:24px }
.leader-quote {
  background:var(--gray-50); border-left:4px solid var(--gold);
  border-radius:0 12px 12px 0; padding:20px 24px;
  margin-bottom:20px; position:relative;
}
.leader-quote i { color:var(--gold); font-size:1.2rem; position:absolute; top:16px; left:24px }
.leader-quote p {
  font-family:'Playfair Display',serif; font-style:italic;
  color:var(--navy); line-height:1.7; font-size:.95rem;
  padding-left:28px;
}
.leader-info p { color:var(--gray-700); line-height:1.85; font-size:.9rem }
.leader-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:24px }
.leader-tag {
  padding:5px 16px; background:var(--gray-50); border:1px solid var(--gray-100);
  border-radius:50px; font-size:.75rem; color:var(--navy); font-weight:500;
  transition:var(--transition); display:flex; align-items:center; gap:6px;
}
.leader-tag:hover { background:rgba(201,162,39,.1); border-color:var(--gold); color:var(--navy) }
.leader-tag i { color:var(--gold) }

/* ── Founder Professional Background Block ── */
.founder-background {
  max-width:860px; margin:40px auto 0;
  background:linear-gradient(135deg,var(--dark) 0%,var(--navy) 100%);
  border-radius:var(--radius-lg); padding:48px 52px;
  border:1px solid rgba(201,162,39,.2);
  position:relative; overflow:hidden;
}
.founder-background::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt),var(--gold));
}
.founder-bg-header { margin-bottom:36px }
.founder-bg-header h3 {
  font-size:1.05rem; color:var(--gold); font-weight:700;
  text-transform:uppercase; letter-spacing:2.5px; margin-bottom:12px;
}
.founder-bg-line {
  width:48px; height:2px; background:var(--gold); margin-bottom:14px; opacity:.6;
}
.founder-bg-header p {
  color:rgba(255,255,255,.55); font-size:.85rem; line-height:1.7;
}
.founder-career-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:28px;
}
.founder-career-item {
  background:rgba(255,255,255,.05); border:1px solid rgba(201,162,39,.15);
  border-radius:var(--radius); padding:24px 20px;
  transition:var(--transition); position:relative;
}
.founder-career-item:hover {
  background:rgba(255,255,255,.08); border-color:rgba(201,162,39,.35);
  transform:translateY(-3px);
}
.founder-career-icon {
  width:44px; height:44px; border-radius:12px;
  background:linear-gradient(135deg,rgba(201,162,39,.25),rgba(201,162,39,.1));
  border:1px solid rgba(201,162,39,.3);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.1rem; margin-bottom:16px;
}
.founder-career-company {
  font-size:.8rem; font-weight:700; color:var(--gold);
  letter-spacing:.5px; margin-bottom:12px;
}
.founder-career-roles {
  display:flex; flex-direction:column; gap:5px; margin-bottom:14px;
}
.founder-career-roles span {
  font-size:.75rem; color:rgba(255,255,255,.78); line-height:1.5;
  padding-left:10px; border-left:2px solid rgba(201,162,39,.3);
}
.founder-career-sector {
  font-size:.7rem; color:rgba(255,255,255,.35); letter-spacing:.5px;
  text-transform:uppercase; margin-bottom:16px;
}
.founder-career-link {
  margin-top:auto;
}
.founder-career-link span {
  font-size:.72rem; font-weight:700; color:var(--gold); letter-spacing:.5px;
  text-transform:uppercase; opacity:.7; transition:var(--transition);
}
.founder-career-item:hover .founder-career-link span { opacity:1 }
.founder-formation {
  display:flex; align-items:center; gap:14px;
  padding:16px 20px; border-top:1px solid rgba(201,162,39,.15);
  color:rgba(255,255,255,.6); font-size:.8rem; line-height:1.5;
}
.founder-formation i { color:var(--gold); font-size:1rem; flex-shrink:0 }

@media (max-width:900px) {
  .founder-background { padding:32px 24px }
  .founder-career-grid { grid-template-columns:1fr }
}
@media (max-width:640px) {
  .leader-card { grid-template-columns:1fr; text-align:center }
  .leader-tags { justify-content:center }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   GOVERNANCE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.gov-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.gov-card {
  background:#fff; border-radius:var(--radius); padding:32px 24px;
  text-align:center; box-shadow:var(--shadow);
  border:1px solid var(--gray-100); transition:var(--transition);
  position:relative; overflow:hidden;
}
.gov-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt));
  transform:scaleX(0); transition:var(--transition);
}
.gov-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg) }
.gov-card:hover::after { transform:scaleX(1) }
.gov-icon {
  width:56px; height:56px;
  background:linear-gradient(135deg,var(--navy),var(--dark));
  border-radius:14px; display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px; font-size:1.3rem; color:var(--gold);
  transition:var(--transition);
}
.gov-card:hover .gov-icon { transform:scale(1.1) }
.gov-card h4 { font-size:.95rem; color:var(--navy); font-weight:700; margin-bottom:10px }
.gov-card p { font-size:.8rem; color:var(--gray-400); line-height:1.65 }

.gov-docs-grid {
  margin-top:48px; display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.gov-doc {
  background:#fff; border-radius:var(--radius); padding:24px 28px;
  display:flex; align-items:flex-start; gap:16px;
  box-shadow:var(--shadow); border-left:4px solid;
  transition:var(--transition);
}
.gov-doc:nth-child(1) { border-color:var(--gold) }
.gov-doc:nth-child(2) { border-color:var(--navy) }
.gov-doc:nth-child(3) { border-color:var(--green) }
.gov-doc:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg) }
.gov-doc > i { font-size:1.4rem; flex-shrink:0; margin-top:2px }
.gov-doc h4 { font-size:.9rem; color:var(--navy); font-weight:700; margin-bottom:6px }
.gov-doc p { font-size:.78rem; color:var(--gray-400); line-height:1.6; margin:0 }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RSE / ESG BANNER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#rse {
  background:linear-gradient(145deg,#062018 0%,#0a3d2e 45%,#1e6b3e 100%);
  padding:110px 0; position:relative; overflow:hidden;
}
#rse::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.rse-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:28px; position:relative; z-index:1 }
.rse-pillar {
  padding:40px 32px; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg); transition:var(--transition);
}
.rse-pillar:hover { background:rgba(255,255,255,.1); transform:translateY(-8px); box-shadow:0 20px 50px rgba(0,0,0,.3) }
.rse-icon { font-size:2.5rem; margin-bottom:22px }
.rse-pillar h3 { font-family:'Playfair Display',serif; font-size:1.4rem; color:#fff; margin-bottom:16px }
.rse-pillar p { color:rgba(255,255,255,.65); font-size:.875rem; line-height:1.85; margin-bottom:20px }
.rse-commitments { display:flex; flex-direction:column; gap:10px }
.rse-commitment {
  display:flex; align-items:center; gap:12px;
  font-size:.82rem; color:rgba(255,255,255,.75);
}
.rse-commitment::before {
  content:'✓'; min-width:22px; height:22px;
  background:rgba(74,222,128,.15); border:1px solid rgba(74,222,128,.3);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.65rem; color:var(--green); flex-shrink:0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   INSIGHTS / ACTUALITÉS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.insights-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px }
.insight-card {
  background:#fff; border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow);
  border:1px solid var(--gray-100); transition:var(--transition);
  display:flex; flex-direction:column;
}
.insight-card:hover { transform:translateY(-10px); box-shadow:var(--shadow-lg); border-color:rgba(201,162,39,.3) }
.insight-category {
  position:absolute; top:16px; left:16px;
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:var(--navy); font-size:.65rem; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  padding:5px 14px; border-radius:50px;
  z-index:1;
}
.insight-img {
  height:180px; position:relative;
  display:flex; align-items:center; justify-content:center;
}
.insight-img-1 { background:linear-gradient(135deg,#1B2A6B,#2E4099) }
.insight-img-2 { background:linear-gradient(135deg,#1a5a8a,#2980b9) }
.insight-img-3 { background:linear-gradient(135deg,#1e6b3e,#27ae60) }
.insight-img-overlay {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  opacity:.7;
}
.insight-body { padding:28px; flex:1; display:flex; flex-direction:column }
.insight-date { font-size:.7rem; color:var(--gray-400); letter-spacing:1px; margin-bottom:12px; text-transform:uppercase; font-weight:600 }
.insight-body h4 { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--navy); margin-bottom:14px; line-height:1.4 }
.insight-body p { font-size:.85rem; color:var(--gray-700); line-height:1.75; flex:1; margin-bottom:20px }
.insight-link {
  color:var(--gold); font-size:.82rem; font-weight:700;
  letter-spacing:.5px; transition:var(--transition);
  align-self:flex-start;
}
.insight-link:hover { gap:8px; letter-spacing:1px }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CONTACT
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:64px }
.contact-info h3 { font-size:1.6rem; color:var(--navy); margin-bottom:28px }
.contact-items { display:flex; flex-direction:column; gap:20px; margin-bottom:36px }
.contact-item { display:flex; align-items:flex-start; gap:18px }
.contact-item-icon {
  width:46px; height:46px; background:var(--navy); border-radius:12px;
  display:flex; align-items:center; justify-content:center; color:var(--gold);
  font-size:1rem; flex-shrink:0; transition:var(--transition);
}
.contact-item:hover .contact-item-icon { background:var(--gold); color:var(--navy) }
.contact-item-text .label {
  font-size:.65rem; color:var(--gray-400); letter-spacing:2px;
  text-transform:uppercase; font-weight:700; margin-bottom:4px;
}
.contact-item-text .value { font-size:.9rem; color:var(--text); font-weight:500; line-height:1.6 }
.contact-partnership {
  background:linear-gradient(135deg,var(--navy),var(--dark));
  border-radius:16px; padding:32px;
}
.contact-partnership h4 {
  color:var(--gold); margin-bottom:12px; font-size:1rem;
  display:flex; align-items:center; gap:10px;
}
.contact-partnership p { font-size:.875rem; color:rgba(255,255,255,.65); line-height:1.75; margin-bottom:18px }
.partnership-tags { display:flex; flex-wrap:wrap; gap:8px }
.partnership-tags span {
  background:rgba(201,162,39,.15); color:var(--gold);
  padding:4px 14px; border-radius:50px; font-size:.72rem; font-weight:700;
}
.contact-form {
  background:#fff; border-radius:var(--radius-lg);
  padding:44px; box-shadow:var(--shadow-lg);
  border:1px solid var(--gray-100);
}
.contact-form h3 { font-size:1.4rem; color:var(--navy); margin-bottom:28px }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:4px }
.form-group { display:flex; flex-direction:column; gap:7px; margin-bottom:18px }
.form-group label {
  font-size:.72rem; font-weight:700; color:var(--navy);
  letter-spacing:.8px; text-transform:uppercase;
}
.form-group input,.form-group select,.form-group textarea {
  padding:13px 18px; border:1.5px solid var(--gray-100); border-radius:10px;
  font-family:'Inter',sans-serif; font-size:.9rem; color:var(--text);
  transition:var(--transition); background:#fff; outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {
  border-color:var(--navy); box-shadow:0 0 0 4px rgba(27,42,107,.07);
}
.form-group textarea { resize:vertical; min-height:110px }
.form-submit {
  width:100%; padding:15px; border-radius:10px;
  background:linear-gradient(135deg,var(--navy),var(--navy-deep));
  color:#fff; border:none;
  font-family:'Inter',sans-serif; font-size:.9rem; font-weight:700;
  cursor:pointer; transition:var(--transition); letter-spacing:.5px;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.form-submit:hover { background:linear-gradient(135deg,var(--dark),var(--navy)); transform:translateY(-2px); box-shadow:0 10px 32px rgba(27,42,107,.3) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FOOTER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
footer { background:var(--darker); padding:90px 0 0 }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:64px; margin-bottom:72px }
.footer-brand .logo { height:52px; margin-bottom:24px }
.footer-brand p { color:rgba(255,255,255,.4); font-size:.85rem; line-height:1.85; max-width:280px; margin-bottom:8px }
.footer-motto {
  font-size:.7rem; color:rgba(255,255,255,.2); margin-top:12px;
  font-style:italic; line-height:1.8;
}
.footer-social { display:flex; gap:10px; margin-top:20px }
.social-btn {
  width:40px; height:40px; background:rgba(255,255,255,.07); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.45); font-size:.9rem; transition:var(--transition);
}
.social-btn:hover { background:var(--gold); color:var(--navy); transform:translateY(-3px) }
.footer-col h4 {
  color:#fff; font-size:.82rem; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase; margin-bottom:20px;
  padding-bottom:12px; border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-links { display:flex; flex-direction:column; gap:12px }
.footer-links a {
  color:rgba(255,255,255,.4); font-size:.83rem;
  transition:var(--transition); display:flex; align-items:center; gap:8px;
}
.footer-links a:hover { color:var(--gold); gap:14px }
.footer-links a::before { content:'›'; color:var(--gold); font-size:1rem }
.footer-address {
  margin-top:20px; padding:18px; border-radius:12px;
  background:rgba(201,162,39,.06); border:1px solid rgba(201,162,39,.12);
}
.footer-address-title {
  font-size:.65rem; color:var(--gold); font-weight:700;
  letter-spacing:2px; text-transform:uppercase; margin-bottom:10px;
}
.footer-address-text { font-size:.78rem; color:rgba(255,255,255,.35); line-height:1.8 }
.footer-devise {
  border-top:1px solid rgba(255,255,255,.06);
  padding:20px 0; overflow:hidden;
}
.devise-track {
  font-size:.72rem; color:rgba(255,255,255,.18);
  letter-spacing:3px; text-transform:uppercase;
  white-space:nowrap; animation:deviseScroll 30s linear infinite;
  display:inline-block;
}
@keyframes deviseScroll { from { transform:translateX(0) } to { transform:translateX(-50%) } }
.footer-bottom { border-top:1px solid rgba(255,255,255,.05); padding:28px 0 }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between }
.footer-bottom p { color:rgba(255,255,255,.2); font-size:.75rem }
.footer-bottom-links { display:flex; gap:28px }
.footer-bottom-links a { color:rgba(255,255,255,.2); font-size:.75rem; transition:var(--transition) }
.footer-bottom-links a:hover { color:var(--gold) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FLOATING ACTION BUTTON
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.fab-group {
  position:fixed; bottom:40px; right:32px; z-index:800;
  display:flex; flex-direction:column; align-items:flex-end; gap:12px;
}
.fab {
  display:flex; align-items:center; justify-content:center;
  border-radius:50px; text-decoration:none;
  transition:var(--transition-spring); box-shadow:0 8px 28px rgba(0,0,0,.25);
}
.fab-main {
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:var(--navy); gap:12px; padding:0 24px;
  height:54px; font-weight:700; font-size:.85rem;
}
.fab-main:hover { transform:scale(1.05) translateY(-3px); box-shadow:0 16px 40px rgba(201,162,39,.45) }
.fab-mail {
  width:44px; height:44px; border-radius:50%;
  background:rgba(27,42,107,.9); color:var(--gold);
  opacity:0; transform:translateY(20px);
  transition:var(--transition);
}
.fab-group:hover .fab-mail { opacity:1; transform:translateY(0) }
.fab-label { letter-spacing:.5px }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BACK TO TOP
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#back-top {
  position:fixed; bottom:108px; right:32px;
  width:44px; height:44px;
  background:var(--gold); color:var(--navy); border:none;
  border-radius:50%; font-size:1rem; display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(201,162,39,.4); transition:var(--transition);
  opacity:0; pointer-events:none; z-index:800;
}
#back-top.visible { opacity:1; pointer-events:all }
#back-top:hover { transform:translateY(-4px); background:var(--gold-lt) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ANIMATIONS — AOS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
[data-aos="fade-up"]    { opacity:0; transform:translateY(40px); transition:opacity .8s ease,transform .8s ease }
[data-aos="fade-left"]  { opacity:0; transform:translateX(40px); transition:opacity .8s ease,transform .8s ease }
[data-aos="fade-right"] { opacity:0; transform:translateX(-40px); transition:opacity .8s ease,transform .8s ease }
[data-aos].aos-animate  { opacity:1; transform:translate(0) }
[data-aos-delay="100"]  { transition-delay:.1s }
[data-aos-delay="150"]  { transition-delay:.15s }
[data-aos-delay="200"]  { transition-delay:.2s }
[data-aos-delay="300"]  { transition-delay:.3s }
[data-aos-delay="400"]  { transition-delay:.4s }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:1200px) {
  .hero-badge { display:none }
  .africa-layout { grid-template-columns:1fr; gap:48px }
  .africa-map-visual { max-width:320px; margin:0 auto }
}
@media(max-width:1024px) {
  .about-grid { grid-template-columns:1fr; gap:56px }
  .about-visual { order:-1; max-width:520px; margin:0 auto }
  .about-badge-float { bottom:-16px; right:0 }
  .figures-grid { grid-template-columns:repeat(2,1fr) }
  .figure-item:nth-child(2)::after { display:none }
  .gov-grid { grid-template-columns:repeat(2,1fr) }
  .gov-docs-grid { grid-template-columns:1fr }
  .footer-grid { grid-template-columns:1fr 1fr }
  .leader-card { max-width:100% }
}
@media(max-width:768px) {
  body { cursor:auto }
  #cursor-glow, #cursor-dot { display:none }
  .section { padding:80px 0 }
  .top-strip { display:none }
  .nav-menu {
    display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(9,14,40,.98); backdrop-filter:blur(24px);
    flex-direction:column; justify-content:center; align-items:center;
    gap:32px; z-index:999;
  }
  .nav-menu.open { display:flex }
  .nav-link { font-size:1.2rem }
  .nav-cta { font-size:1rem }
  .nav-toggle { display:flex; z-index:1001; position:relative }
  .nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px) }
  .nav-toggle.open span:nth-child(2) { opacity:0 }
  .nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px) }
  .hero-badge { display:none }
  .hero-stats { gap:0; flex-direction:column; padding-top:32px }
  .hero-stat { padding:16px 24px }
  .hero-stat-divider { width:80px; height:1px }
  .values-grid,.sub-grid,.rse-grid,.insights-grid { grid-template-columns:1fr }
  .contact-grid { grid-template-columns:1fr }
  .form-row { grid-template-columns:1fr }
  .footer-grid { grid-template-columns:1fr }
  .footer-bottom-inner { flex-direction:column; gap:16px; text-align:center }
  .leader-card { grid-template-columns:1fr; text-align:center; padding:36px 28px }
  .leader-avatar-wrap { margin:0 auto }
  .leader-quote p { text-align:left }
  .africa-layout { grid-template-columns:1fr }
  .gov-grid { grid-template-columns:1fr 1fr }
  .gov-docs-grid { grid-template-columns:1fr }
  .hero-title { font-size:clamp(2.6rem,10vw,4rem) }
  .fab-main { font-size:.78rem; padding:0 18px }
}
@media(max-width:480px) {
  .gov-grid { grid-template-columns:1fr }
  .hero-tagline { font-size:.65rem; letter-spacing:1.5px }
  .hero-divider span { max-width:40px }
  .leader-card { padding:28px 20px }
  .contact-form { padding:28px 20px }
  .fab-group { bottom:28px; right:20px }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   GUINÉE — POURQUOI INVESTIR ?
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#guinea { background:linear-gradient(160deg, #0a1128 0%, #0f1c3d 40%, #0a1128 100%); position:relative; overflow:hidden }
#guinea::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 50% at 50% 100%, rgba(201,162,39,.08) 0%, transparent 70%);
}

/* Commodity bar */
.commodity-bar {
  display:flex; align-items:center; gap:24px;
  background:rgba(201,162,39,.06); border:1px solid rgba(201,162,39,.15);
  border-radius:var(--radius-full); padding:14px 28px;
  margin-bottom:64px; overflow-x:auto; scrollbar-width:none;
}
.commodity-bar::-webkit-scrollbar { display:none }
.commodity-label {
  font-size:.68rem; font-weight:700; letter-spacing:2px;
  color:var(--gold); text-transform:uppercase; white-space:nowrap;
  display:flex; align-items:center; gap:8px; flex-shrink:0;
}
.commodity-label i { font-size:.85rem; animation:pulse 2s ease-in-out infinite }
.commodity-prices { display:flex; align-items:center; gap:20px; flex:1 }
.commodity-item { display:flex; align-items:baseline; gap:5px; white-space:nowrap; flex-shrink:0 }
.c-name { font-size:.7rem; color:rgba(255,255,255,.5); letter-spacing:.5px }
.c-price { font-size:.88rem; font-weight:700; color:#fff; font-variant-numeric:tabular-nums }
.c-unit { font-size:.65rem; color:rgba(255,255,255,.35) }
.c-up { font-size:.68rem; color:#4ade80; font-weight:600 }
.c-down { font-size:.68rem; color:#f87171; font-weight:600 }
.commodity-sep { width:1px; height:20px; background:rgba(255,255,255,.1); flex-shrink:0 }

/* Guinea facts grid */
.guinea-grid {
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:20px;
}
.guinea-facts-col { display:flex; flex-direction:column; gap:20px }

.guinea-fact {
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg); padding:28px 28px 24px;
  position:relative; overflow:hidden;
  transition:var(--transition);
}
.guinea-fact:hover { background:rgba(255,255,255,.05); border-color:rgba(201,162,39,.25); transform:translateY(-3px) }
.guinea-fact::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, rgba(201,162,39,.5), transparent);
  transform:translateX(-100%); transition:transform .6s ease;
}
.guinea-fact:hover::before { transform:translateX(0) }

.fact-hero { background:linear-gradient(135deg, rgba(201,162,39,.12) 0%, rgba(201,162,39,.04) 100%); border-color:rgba(201,162,39,.3) }
.fact-badge {
  display:inline-block; font-size:.62rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--gold); background:rgba(201,162,39,.1); border:1px solid rgba(201,162,39,.2);
  padding:3px 10px; border-radius:var(--radius-full); margin-bottom:16px;
}
.fact-number { font-family:'Playfair Display',serif; font-size:4rem; font-weight:800; color:var(--gold); line-height:1; margin-bottom:8px }
.fact-number-sm { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:800; color:var(--gold); line-height:1; margin-bottom:6px }
.fact-title { font-size:.82rem; font-weight:600; color:#fff; margin-bottom:8px; line-height:1.4 }
.fact-desc { font-size:.72rem; color:rgba(255,255,255,.45); line-height:1.6 }
.fact-icon { position:absolute; bottom:20px; right:20px; font-size:2rem; color:rgba(201,162,39,.15) }
.fact-icon-lg { font-size:2.8rem; color:rgba(201,162,39,.6); margin-bottom:12px }
.guinea-fact-cta { display:flex; flex-direction:column; justify-content:center; text-align:center; align-items:center; background:linear-gradient(135deg,rgba(27,42,107,.6),rgba(13,22,53,.8)); border-color:rgba(27,42,107,.6) }
.btn-gold-outline {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:var(--radius-full);
  border:1.5px solid var(--gold); color:var(--gold);
  font-size:.78rem; font-weight:600; letter-spacing:.5px; text-decoration:none;
  transition:var(--transition);
}
.btn-gold-outline:hover { background:var(--gold); color:var(--darker) }

@media(max-width:1200px) {
  .guinea-grid { grid-template-columns:1fr 1fr }
  .guinea-facts-col { flex-direction:row }
  .guinea-fact-cta { grid-column:span 2 }
}
@media(max-width:768px) {
  .guinea-grid { grid-template-columns:1fr }
  .guinea-facts-col { flex-direction:column }
  .guinea-fact-cta { grid-column:span 1 }
  .fact-hero .fact-number { font-size:3rem }
  .commodity-bar { flex-direction:column; align-items:flex-start; border-radius:var(--radius-lg); padding:16px 20px }
  .commodity-prices { flex-wrap:wrap; gap:14px }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PDG PHOTO BADGE & LEADER ENHANCEMENTS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.leader-avatar-logo { width:60%; height:60%; object-fit:contain; filter:brightness(0) invert(1); opacity:.6 }
.leader-photo-badge {
  position:absolute; bottom:-8px; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg, var(--gold), var(--gold-lt));
  color:var(--darker); font-size:.62rem; font-weight:800; letter-spacing:2px;
  text-transform:uppercase; padding:4px 14px; border-radius:var(--radius-full);
  white-space:nowrap; box-shadow:0 4px 16px rgba(201,162,39,.4);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CACHET OFFICIEL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cachet-section {
  display:grid; grid-template-columns:220px 1fr; gap:56px; align-items:center;
  background:rgba(201,162,39,.04); border:1px solid rgba(201,162,39,.12);
  border-radius:var(--radius-lg); padding:40px 48px; margin-bottom:48px;
}
.cachet-visual { position:relative; display:flex; justify-content:center }
.cachet-img {
  width:160px; height:160px; object-fit:contain;
  filter:drop-shadow(0 0 20px rgba(201,162,39,.4));
  animation:auroraFloat 8s ease-in-out infinite;
}
.cachet-glow {
  position:absolute; inset:-20px; border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,39,.15) 0%, transparent 70%);
  pointer-events:none;
}
.cachet-info h4 { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--gold); margin-bottom:12px }
.cachet-info p { font-size:.88rem; color:rgba(255,255,255,.55); line-height:1.8; margin-bottom:20px }
.cachet-refs { display:flex; flex-wrap:wrap; gap:12px }
.cachet-refs span {
  font-size:.72rem; color:rgba(255,255,255,.6); font-weight:600; letter-spacing:.5px;
  display:flex; align-items:center; gap:6px;
}
.cachet-refs i { color:var(--gold) }
@media(max-width:768px) {
  .cachet-section { grid-template-columns:1fr; text-align:center; padding:28px 20px }
  .cachet-refs { justify-content:center }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DOCUMENTS OFFICIELS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#documents { background:var(--darker) }
.badge-navy {
  background:rgba(27,42,107,.4); color:rgba(255,255,255,.8);
  border:1px solid rgba(27,42,107,.6);
}
.btn-navy {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:var(--radius-full);
  background:var(--navy); color:#fff; font-size:.82rem; font-weight:600;
  letter-spacing:.5px; text-decoration:none; transition:var(--transition);
  border:none; cursor:pointer;
}
.btn-navy:hover { background:var(--navy-deep) }

.docs-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:32px;
}
.doc-card {
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column;
  transition:var(--transition);
}
.doc-card:hover { border-color:rgba(201,162,39,.25); transform:translateY(-4px) }
.doc-icon {
  background:linear-gradient(135deg, var(--navy), var(--navy-deep));
  padding:20px; text-align:center; font-size:1.6rem; color:var(--gold);
}
.doc-preview {
  position:relative; padding:16px 16px 8px; flex:1;
  background:rgba(255,255,255,.02);
}
.doc-blur-lines { display:flex; flex-direction:column; gap:7px }
.doc-blur-lines span {
  height:7px; border-radius:4px;
  background:rgba(255,255,255,.07); backdrop-filter:blur(2px);
}
.doc-blur-lines span:nth-child(1) { width:90% }
.doc-blur-lines span:nth-child(2) { width:75% }
.doc-blur-lines span:nth-child(3) { width:85% }
.doc-blur-lines span:nth-child(4) { width:60% }
.doc-blur-lines span:nth-child(5) { width:80% }
.doc-lock {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(13,22,53,.7); backdrop-filter:blur(6px);
  font-size:1.4rem; color:rgba(201,162,39,.7);
}
.doc-info { padding:16px }
.doc-ref { font-size:.6rem; letter-spacing:2px; color:var(--gold); opacity:.7; font-weight:700; margin-bottom:6px }
.doc-info h4 { font-size:.82rem; font-weight:600; color:#fff; margin-bottom:4px }
.doc-info p { font-size:.7rem; color:rgba(255,255,255,.4) }
.doc-request {
  display:block; text-align:center; padding:10px 16px;
  background:rgba(201,162,39,.08); border-top:1px solid rgba(201,162,39,.15);
  color:var(--gold); font-size:.72rem; font-weight:600; letter-spacing:.5px;
  text-decoration:none; transition:var(--transition);
}
.doc-request:hover { background:rgba(201,162,39,.18) }
.docs-cta {
  display:flex; align-items:center; gap:20px;
  background:rgba(27,42,107,.15); border:1px solid rgba(27,42,107,.3);
  border-radius:var(--radius-lg); padding:24px 28px;
}
.docs-cta > i { font-size:1.4rem; color:rgba(255,255,255,.3); flex-shrink:0 }
.docs-cta > p { font-size:.82rem; color:rgba(255,255,255,.45); line-height:1.7; margin:0; flex:1 }
@media(max-width:1024px) { .docs-grid { grid-template-columns:repeat(2,1fr) } }
@media(max-width:600px) { .docs-grid { grid-template-columns:1fr }; .docs-cta { flex-direction:column; text-align:center } }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WHATSAPP FAB & CONTACT ENHANCEMENTS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.fab-wa {
  width:46px; height:46px; border-radius:50%;
  background:#25D366; color:#fff; font-size:1.2rem;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; opacity:0; transform:translateY(20px);
  transition:var(--transition); box-shadow:0 4px 16px rgba(37,211,102,.35);
}
.fab-group:hover .fab-wa { opacity:1; transform:translateY(0) }
.fab-wa:hover { background:#20b858; transform:translateY(-2px) scale(1.05) }

.maps-link {
  display:inline-flex; align-items:center; gap:8px; color:var(--gold);
  font-size:.85rem; font-weight:600; text-decoration:none;
  transition:var(--transition);
}
.maps-link:hover { color:var(--gold-lt); text-decoration:underline }
.maps-link i { font-size:.75rem }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   VIDEO HERO
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.hero-video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; opacity:.18;
  filter:saturate(.6) brightness(.5);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PDG PHOTO — RETOUCHE PREMIUM
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.leader-photo {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 12%; /* cadrage serré haut du visage */
  border-radius:50%;
  display:block;
  /* Retouche CSS : contraste +, luminosité légère, saturation pro */
  filter: contrast(1.08) brightness(1.04) saturate(1.15);
  transition: filter .4s ease, transform .4s ease;
}
.leader-photo:hover {
  filter: contrast(1.12) brightness(1.06) saturate(1.18);
  transform: scale(1.03);
}
.leader-photo.hidden { display:none }

/* Halo glow premium autour du cercle PDG */
.leader-avatar {
  box-shadow:
    0 0 0 2px rgba(201,162,39,.6),
    0 0 0 6px rgba(13,22,53,.95),
    0 0 32px rgba(201,162,39,.4),
    0 0 64px rgba(201,162,39,.18) !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   THEME TOGGLE BUTTON
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.theme-toggle {
  background:none; border:1px solid rgba(201,162,39,.3); color:var(--gold);
  border-radius:50%; width:36px; height:36px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; transition:var(--transition);
}
.theme-toggle:hover { background:rgba(201,162,39,.1); border-color:var(--gold) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SPLIT-TEXT ANIMATION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.split-char {
  display:inline-block; opacity:0; transform:translateY(30px) rotate(4deg);
  transition:opacity .5s ease, transform .5s ease;
}
.split-char.revealed { opacity:1; transform:translateY(0) rotate(0deg) }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   COOKIE BANNER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cookie-banner {
  position:fixed; bottom:24px; left:24px; z-index:9990; max-width:480px;
  background:linear-gradient(135deg, #0f1c3d, #1B2A6B);
  border:1px solid rgba(201,162,39,.3); border-radius:var(--radius-lg);
  padding:20px 24px; box-shadow:0 20px 60px rgba(0,0,0,.5);
  transform:translateY(120%); opacity:0; pointer-events:none;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1), opacity .4s ease;
}
.cookie-banner.visible { transform:translateY(0); opacity:1; pointer-events:all }
.cookie-inner { display:flex; align-items:flex-start; gap:16px }
.cookie-icon { font-size:1.6rem; color:var(--gold); flex-shrink:0; margin-top:2px }
.cookie-text strong { display:block; color:#fff; font-size:.88rem; margin-bottom:4px }
.cookie-text p { font-size:.78rem; color:rgba(255,255,255,.55); margin:0 0 14px; line-height:1.6 }
.cookie-btns { display:flex; gap:10px }
.cookie-btn-accept {
  padding:8px 18px; border-radius:var(--radius-full); border:none; cursor:pointer;
  background:linear-gradient(135deg, var(--gold), var(--gold-lt));
  color:var(--darker); font-size:.78rem; font-weight:700; letter-spacing:.5px;
  transition:var(--transition);
}
.cookie-btn-accept:hover { opacity:.9; transform:translateY(-1px) }
.cookie-btn-reject {
  padding:8px 18px; border-radius:var(--radius-full); cursor:pointer;
  background:transparent; border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.6); font-size:.78rem; transition:var(--transition);
}
.cookie-btn-reject:hover { border-color:rgba(255,255,255,.4); color:#fff }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LIGHT MODE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
[data-theme="light"] {
  --darker: #f0ede4;
  --dark: #e8e3d8;
}
[data-theme="light"] body {
  background:#f0ede4; color:#1a1835;
}
[data-theme="light"] #navbar {
  background:rgba(255,255,255,.95); border-bottom:1px solid rgba(27,42,107,.1);
}
[data-theme="light"] #navbar.scrolled { background:rgba(255,255,255,.98); box-shadow:0 4px 20px rgba(27,42,107,.08) }
[data-theme="light"] .nav-link { color:#1a1835 }
[data-theme="light"] .nav-link:hover, [data-theme="light"] .nav-link.active { color:var(--navy) }
[data-theme="light"] #hero { background:linear-gradient(135deg,#1B2A6B 0%,#0D1635 100%) }
[data-theme="light"] .section { background:#f0ede4 }
[data-theme="light"] .section-alt { background:#e8e3d8 }
[data-theme="light"] h2 { color:#0D1635 }
[data-theme="light"] p { color:#3a3a5c }
[data-theme="light"] .about-img-main { box-shadow:0 20px 60px rgba(27,42,107,.15) }
[data-theme="light"] .sub-card, [data-theme="light"] .value-card,
[data-theme="light"] .gov-card, [data-theme="light"] .insight-card {
  background:#fff; border-color:rgba(27,42,107,.1); color:#1a1835;
}
[data-theme="light"] .sub-card p, [data-theme="light"] .value-card p,
[data-theme="light"] .gov-card p { color:#4a4a6a }
[data-theme="light"] footer { background:#0D1635 }
[data-theme="light"] #figures { background:linear-gradient(135deg,#1B2A6B,#0D1635) }
[data-theme="light"] .contact-form { background:#fff; border:1px solid rgba(27,42,107,.1) }
[data-theme="light"] .contact-form input,
[data-theme="light"] .contact-form textarea,
[data-theme="light"] .contact-form select { background:#f8f7f4; color:#1a1835; border-color:rgba(27,42,107,.2) }
[data-theme="light"] #theme-icon::before { content:"\f186" }
@media(max-width:768px) {
  [data-theme="light"] .nav-menu { background:#fff }
  .cookie-banner { left:16px; right:16px; max-width:none; bottom:16px }
}

/* ═══════════════════════════════════════
   TIMELINE 2024 → 2030
═══════════════════════════════════════ */
.timeline { position:relative; max-width:800px; margin:48px auto 0; }
.timeline::before { content:''; position:absolute; left:24px; top:0; bottom:0; width:2px; background:linear-gradient(180deg,rgba(201,162,39,0),rgba(201,162,39,.5) 20%,rgba(201,162,39,.5) 80%,rgba(201,162,39,0)); }
.tl-item { display:flex; gap:32px; margin-bottom:40px; position:relative; }
.tl-marker { width:48px; height:48px; border-radius:50%; background:rgba(201,162,39,.12); border:2px solid rgba(201,162,39,.3); display:flex; align-items:center; justify-content:center; color:rgba(201,162,39,.6); font-size:.9rem; flex-shrink:0; position:relative; z-index:1; transition:.3s; }
.tl-done .tl-marker { background:rgba(201,162,39,.2); border-color:var(--gold); color:var(--gold); }
.tl-active .tl-marker { background:var(--gold); border-color:var(--gold); color:#0D1635; box-shadow:0 0 20px rgba(201,162,39,.4); animation:tlPulse 2s ease-in-out infinite; }
.tl-marker-gold { background:linear-gradient(135deg,#C9A227,#E8C547) !important; border-color:var(--gold) !important; color:#0D1635 !important; box-shadow:0 0 24px rgba(201,162,39,.5) !important; }
@keyframes tlPulse { 0%,100%{box-shadow:0 0 20px rgba(201,162,39,.4)} 50%{box-shadow:0 0 32px rgba(201,162,39,.7)} }
.tl-content { flex:1; padding:24px 28px; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-radius:16px; transition:.3s; }
.tl-item:hover .tl-content { background:rgba(201,162,39,.04); border-color:rgba(201,162,39,.2); transform:translateX(4px); }
.tl-year { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:rgba(201,162,39,.5); margin-bottom:6px; }
.tl-year-gold { color:var(--gold) !important; }
.tl-done .tl-year { color:var(--gold); }
.tl-active .tl-year { color:var(--gold-lt); }
.tl-content h4 { color:#fff; font-size:1rem; font-weight:600; margin-bottom:10px; }
.tl-content p { color:rgba(255,255,255,.5); font-size:.85rem; line-height:1.8; margin-bottom:14px; }
.tl-status { display:inline-block; padding:4px 14px; border-radius:50px; font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.tl-status-done { background:rgba(39,174,96,.15); color:#27ae60; border:1px solid rgba(39,174,96,.3); }
.tl-status-active { background:rgba(201,162,39,.2); color:var(--gold); border:1px solid rgba(201,162,39,.4); }
.tl-status-future { background:rgba(255,255,255,.05); color:rgba(255,255,255,.4); border:1px solid rgba(255,255,255,.1); }
.tl-status-vision { background:linear-gradient(135deg,rgba(201,162,39,.25),rgba(232,197,71,.1)); color:var(--gold-lt); border:1px solid rgba(201,162,39,.5); }

@media(max-width:768px){
  .timeline::before { left:20px; }
  .tl-marker { width:40px; height:40px; font-size:.8rem; }
  .tl-item { gap:20px; }
  .tl-content { padding:18px 20px; }
}

/* ═══════════════════════════════════════
   NEWSLETTER SECTION
═══════════════════════════════════════ */
.newsletter-section { background:linear-gradient(135deg,rgba(201,162,39,.06) 0%,rgba(27,42,107,.15) 50%,rgba(201,162,39,.06) 100%); border-top:1px solid rgba(201,162,39,.1); border-bottom:1px solid rgba(201,162,39,.1); }
.newsletter-wrap { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.newsletter-left h2 { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,3vw,2rem); color:#fff; margin-bottom:14px; }
.newsletter-left p { color:rgba(255,255,255,.5); font-size:.9rem; line-height:1.8; margin-bottom:24px; }
.newsletter-benefits { display:flex; flex-direction:column; gap:10px; }
.nl-benefit { display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.6); font-size:.85rem; }
.nl-benefit i { color:var(--gold); font-size:.8rem; }
.newsletter-form-main { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:20px; padding:32px; display:flex; flex-direction:column; gap:16px; }
.nl-input-wrap input, .nl-input-wrap select { width:100%; padding:13px 18px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:10px; color:#fff; font-family:'Inter',sans-serif; font-size:.9rem; outline:none; transition:.3s; appearance:none; }
.nl-input-wrap input:focus, .nl-input-wrap select:focus { border-color:rgba(201,162,39,.5); background:rgba(201,162,39,.04); }
.nl-input-wrap select option { background:#1B2A6B; color:#fff; }
.nl-legal { font-size:.75rem; color:rgba(255,255,255,.3); text-align:center; line-height:1.6; }

@media(max-width:900px){
  .newsletter-wrap { grid-template-columns:1fr; gap:36px; }
}

/* ═══════════════════════════════════════
   PAGE TRANSITIONS
═══════════════════════════════════════ */
@keyframes pageIn { from { opacity:0; transform:translateY(10px) } to { opacity:1; transform:none } }
@keyframes pageOut { to { opacity:0; transform:translateY(-8px) } }
body.page-entering { animation: pageIn .4s ease forwards; }
body.page-exiting { animation: pageOut .28s ease forwards !important; pointer-events:none !important; }

/* ═══════════════════════════════════════
   BREADCRUMB BAR
═══════════════════════════════════════ */
.breadcrumb-bar { background:rgba(8,14,36,.96); border-bottom:1px solid rgba(255,255,255,.06); padding:9px 0; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:.78rem; color:rgba(255,255,255,.35); }
.breadcrumb a { color:rgba(255,255,255,.45); text-decoration:none; transition:.2s; display:flex; align-items:center; gap:6px; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb .bc-sep { font-size:.55rem; color:rgba(255,255,255,.2); }

/* ═══════════════════════════════════════
   FORM VALIDATION — REAL-TIME
═══════════════════════════════════════ */
.form-group { position:relative; }
.form-group .field-error { border-color:rgba(220,80,80,.55) !important; background:rgba(220,80,80,.04) !important; }
.form-group .field-ok   { border-color:rgba(74,222,128,.4) !important; }
.field-err-msg { display:block; color:#e05252; font-size:.72rem; margin-top:5px; padding-left:2px; animation:errFadeIn .2s ease; }
@keyframes errFadeIn { from { opacity:0; transform:translateY(-4px) } to { opacity:1; transform:none } }
.field-val-icon { position:absolute; right:14px; top:14px; font-size:.85rem; pointer-events:none; }
.field-val-icon.err { color:#e05252; }
.field-val-icon.ok  { color:#4ade80; }

/* ═══════════════════════════════════════
   TOAST NOTIFICATION
═══════════════════════════════════════ */
.toast-container { position:fixed; bottom:32px; left:50%; transform:translateX(-50%); z-index:99999; display:flex; flex-direction:column; gap:8px; align-items:center; pointer-events:none; }
.toast { background:rgba(13,22,53,.96); border:1px solid rgba(201,162,39,.3); color:#fff; padding:12px 24px 12px 16px; border-radius:50px; font-size:.85rem; display:flex; align-items:center; gap:10px; opacity:0; transform:translateY(20px); transition:.4s cubic-bezier(.34,1.56,.64,1); white-space:nowrap; }
.toast.visible { opacity:1; transform:none; }
.toast i { color:var(--gold); }

/* ═══════════════════════════════════════
   SOCIAL SHARE BUTTONS
═══════════════════════════════════════ */
.blog-share { display:flex; align-items:center; gap:8px; margin-top:14px; padding-top:14px; border-top:1px solid rgba(255,255,255,.05); }
.blog-share-label { font-size:.7rem; color:rgba(255,255,255,.25); letter-spacing:1px; margin-right:4px; }
.share-btn { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.78rem; text-decoration:none; transition:.2s; border:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.4); background:rgba(255,255,255,.02); cursor:pointer; }
.share-btn:hover { border-color:rgba(201,162,39,.35); color:var(--gold); background:rgba(201,162,39,.06); }
.share-btn.copied { border-color:rgba(74,222,128,.4) !important; color:#4ade80 !important; }

/* ═══════════════════════════════════════
   READING TIME BADGE
═══════════════════════════════════════ */
.reading-time { display:inline-flex; align-items:center; gap:4px; font-size:.7rem; color:rgba(255,255,255,.3); margin-left:10px; }

/* ═══════════════════════════════════════
   INVESTOR PORTAL GATE
═══════════════════════════════════════ */
.inv-gate { position:fixed; inset:0; z-index:10000; display:flex; align-items:center; justify-content:center; background:rgba(8,14,36,.97); backdrop-filter:blur(24px); }
.inv-gate-box { background:rgba(255,255,255,.04); border:1px solid rgba(201,162,39,.25); border-radius:24px; padding:56px 48px; text-align:center; max-width:440px; width:90%; box-shadow:0 40px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(201,162,39,.1); }
.inv-gate-icon { font-size:3rem; color:var(--gold); margin-bottom:24px; }
.inv-gate-box h2 { font-family:'Playfair Display',serif; color:#fff; font-size:1.8rem; margin-bottom:10px; }
.inv-gate-box p { color:rgba(255,255,255,.45); font-size:.88rem; margin-bottom:32px; line-height:1.7; }
.inv-gate-input { width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(201,162,39,.3); border-radius:12px; padding:14px 20px; color:#fff; font-size:1.1rem; letter-spacing:6px; text-align:center; outline:none; margin-bottom:16px; transition:.3s; font-family:'Inter',sans-serif; }
.inv-gate-input:focus { border-color:rgba(201,162,39,.6); background:rgba(201,162,39,.06); }
.inv-gate-input::placeholder { letter-spacing:2px; font-size:.88rem; color:rgba(255,255,255,.2); }
.inv-gate-error { color:#e05252; font-size:.8rem; margin-bottom:16px; display:none; animation:errFadeIn .2s ease; }
.inv-gate-error.show { display:block; }
.inv-gate-hint { font-size:.72rem; color:rgba(255,255,255,.2); margin-top:16px; }
@keyframes gateShake { 0%,100% { transform:translateX(0) } 20%,60% { transform:translateX(-8px) } 40%,80% { transform:translateX(8px) } }
.inv-gate-box.shake { animation:gateShake .4s ease; }
@keyframes gateClose { to { opacity:0; transform:scale(1.04); } }
.inv-gate.closing { animation:gateClose .45s ease forwards; }

/* ═══════════════════════════════════════
   NAV DROPDOWNS — GROUPE & RESSOURCES
═══════════════════════════════════════ */
.nav-item-drop { position:relative; }
.nav-item-drop > .nav-link::after { content:'▾'; font-size:.6rem; margin-left:4px; }
.nav-dropdown { position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%); background:rgba(8,14,36,.97); border:1px solid rgba(201,162,39,.15); border-radius:16px; padding:12px; min-width:220px; opacity:0; pointer-events:none; transform:translateX(-50%) translateY(8px); transition:.2s; z-index:500; backdrop-filter:blur(20px); box-shadow:0 20px 60px rgba(0,0,0,.5); }
.nav-item-drop:hover .nav-dropdown { opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0); }
.nav-dropdown a { display:flex; align-items:center; gap:10px; padding:10px 16px; border-radius:10px; color:rgba(255,255,255,.6); font-size:.82rem; text-decoration:none; transition:.2s; }
.nav-dropdown a:hover { background:rgba(201,162,39,.08); color:#fff; }
.nav-dropdown a i { width:16px; text-align:center; color:var(--gold); font-size:.78rem; }

/* ═══════════════════════════════════════
   LANGUAGE SELECTOR (4 langs: FR/EN/AR/PT)
═══════════════════════════════════════ */
.lang-select { position:relative; display:inline-flex; align-items:center; }
.lang-select-btn {
  display:flex; align-items:center; gap:5px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(201,162,39,.25);
  border-radius:50px; padding:5px 12px 5px 9px;
  color:rgba(255,255,255,.75); font-size:.78rem;
  cursor:pointer; transition:.25s; white-space:nowrap;
  font-family:'Inter',sans-serif; font-weight:600;
}
.lang-select-btn:hover { border-color:rgba(201,162,39,.55); color:var(--gold); background:rgba(201,162,39,.06); }
.lang-select.open .lang-select-btn { border-color:rgba(201,162,39,.6); color:var(--gold); background:rgba(201,162,39,.08); }
.lang-flag { font-size:.92rem; line-height:1; }
.lang-code { font-weight:700; letter-spacing:.5px; font-size:.75rem; }
.lang-chevron { font-size:.55rem; opacity:.6; transition:transform .2s ease; }
.lang-select.open .lang-chevron { transform:rotate(180deg) !important; }

.lang-dropdown {
  position:absolute; top:calc(100% + 10px); right:0;
  background:rgba(8,14,36,.98); border:1px solid rgba(201,162,39,.18);
  border-radius:16px; padding:8px; min-width:180px;
  display:flex; flex-direction:column; gap:2px;
  opacity:0; pointer-events:none; transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
  z-index:700; backdrop-filter:blur(24px);
  box-shadow:0 24px 48px rgba(0,0,0,.6), 0 0 0 1px rgba(201,162,39,.06);
}
.lang-select.open .lang-dropdown { opacity:1; pointer-events:all; transform:translateY(0); }

.lang-opt {
  display:flex; align-items:center; gap:10px;
  padding:9px 14px; border-radius:10px;
  color:rgba(255,255,255,.55); font-size:.82rem;
  transition:.18s; cursor:pointer;
  background:transparent; border:none;
  width:100%; text-align:left;
  font-family:'Inter',sans-serif; font-weight:500;
}
.lang-opt:hover { background:rgba(201,162,39,.09); color:rgba(255,255,255,.9); }
.lang-opt.active { color:var(--gold); background:rgba(201,162,39,.08); font-weight:700; }
.lang-opt-flag { font-size:.9rem; line-height:1; }

/* Mobile lang selector */
.lang-select-mobile { margin-right:8px; }
.lang-dropdown-mobile { right:0; left:auto; min-width:140px; display:flex; flex-direction:column; gap:2px; }
.lang-dropdown-mobile .lang-opt { padding:7px 12px; font-size:.78rem; }

/* ── RTL Support (Arabic + Urdu) ── */
html[data-lang="ar"],
html[data-lang="ur"] { direction:rtl; }
html[data-lang="ar"] .nav-inner,
html[data-lang="ur"] .nav-inner { flex-direction:row-reverse; }
html[data-lang="ar"] .nav-menu,
html[data-lang="ur"] .nav-menu { flex-direction:row-reverse; }
html[data-lang="ar"] .lang-dropdown,
html[data-lang="ur"] .lang-dropdown { right:auto; left:0; }
html[data-lang="ar"] .lang-dropdown-mobile,
html[data-lang="ur"] .lang-dropdown-mobile { left:0; right:auto; }
html[data-lang="ar"] .footer-grid,
html[data-lang="ur"] .footer-grid { direction:rtl; }
html[data-lang="ar"] .footer-bottom-inner,
html[data-lang="ur"] .footer-bottom-inner { flex-direction:row-reverse; }
html[data-lang="ar"] .footer-links,
html[data-lang="ur"] .footer-links { direction:rtl; }
html[data-lang="ar"] .breadcrumb,
html[data-lang="ur"] .breadcrumb { flex-direction:row-reverse; }
html[data-lang="ar"] .bc-sep,
html[data-lang="ur"] .bc-sep { transform:scaleX(-1); }
html[data-lang="ar"] .hero-title,
html[data-lang="ar"] .hero-sub,
html[data-lang="ar"] .section-title,
html[data-lang="ar"] .section-sub,
html[data-lang="ur"] .hero-title,
html[data-lang="ur"] .hero-sub,
html[data-lang="ur"] .section-title,
html[data-lang="ur"] .section-sub { text-align:right; }
html[data-lang="ar"] .kpi-grid,
html[data-lang="ar"] .values-grid,
html[data-lang="ar"] .sub-grid,
html[data-lang="ur"] .kpi-grid,
html[data-lang="ur"] .values-grid,
html[data-lang="ur"] .sub-grid { direction:rtl; }
html[data-lang="ar"] .cookie-inner,
html[data-lang="ur"] .cookie-inner { flex-direction:row-reverse; }

/* ═══════════════════════════════════════
   FOOTER ADDRESS BLOCK
═══════════════════════════════════════ */
.footer-address { margin-top:20px; padding:16px; background:rgba(255,255,255,.03); border:1px solid rgba(201,162,39,.1); border-radius:12px; }
.footer-address-title { font-size:.7rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); margin-bottom:6px; font-weight:600; }
.footer-address-text { font-size:.78rem; color:rgba(255,255,255,.35); line-height:1.8; }

/* ═══════════════════════════════════════
   PRINT STYLES
═══════════════════════════════════════ */
@media print {
  #site-navbar, #site-strip, #site-fab, #site-cookie, .breadcrumb-bar, .page-transition { display:none !important; }
  body { background:#fff !important; color:#000 !important; }
  a { color:#1B2A6B !important; }
  .section-title { color:#1B2A6B !important; }
  .legal-section { border:1px solid #ddd !important; background:#fff !important; }
}

/* ═══════════════════════════════════════
   COPY-TO-CLIPBOARD
═══════════════════════════════════════ */
.copy-btn { cursor:pointer; transition:.2s; }
.copy-btn:hover { color:var(--gold); }
.copy-toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:rgba(201,162,39,.95); color:#0D1635; padding:8px 20px; border-radius:50px; font-size:.82rem; font-weight:600; z-index:9999; opacity:0; transition:.3s; pointer-events:none; }
.copy-toast.show { opacity:1; }
.nav-dropdown-sep { height:1px; background:rgba(255,255,255,.06); margin:6px 0; }

/* ═══════════════════════════════════════
   MOBILE ACTIONS BAR (lang + hamburger)
═══════════════════════════════════════ */
.nav-mobile-actions { display:flex; align-items:center; gap:8px; }
.lang-select-mobile { display:none; }
@media(max-width:768px) {
  .lang-select-mobile { display:inline-flex; }
  /* Hide desktop lang-select inside the mobile overlay menu */
  .nav-menu .lang-select:not(.lang-select-mobile) { display:none; }
}

/* ═══════════════════════════════════════
   POURQUOI G-CORE GROUP
═══════════════════════════════════════ */
.why-grid {
  display:grid; grid-template-columns:1fr 1fr 1.15fr; gap:24px;
  align-items:stretch;
}
.why-card {
  border-radius:var(--radius-lg); padding:32px 28px;
  position:relative; overflow:hidden;
}
.why-card-bad {
  background:#fff; border:1.5px solid var(--gray-100);
  box-shadow:var(--shadow);
}
.why-card-good {
  background:linear-gradient(135deg,var(--dark) 0%,var(--navy) 100%);
  border:1.5px solid rgba(201,162,39,.3);
  box-shadow:0 24px 64px rgba(27,42,107,.35);
}
.why-card-good::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt));
}
.why-card-header { display:flex; align-items:center; gap:14px; margin-bottom:20px }
.why-icon {
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.why-icon-bad { background:rgba(239,68,68,.1); color:#ef4444 }
.why-icon-good { background:rgba(201,162,39,.2); color:var(--gold) }
.why-card-bad h4 { color:var(--navy); font-size:.95rem; font-weight:700 }
.why-card-good h4 { color:var(--gold); font-size:1rem; font-weight:800 }
.why-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px }
.why-card-bad li {
  font-size:.82rem; color:var(--gray-400); padding-left:18px; position:relative; line-height:1.55;
}
.why-card-bad li::before { content:'✗'; position:absolute; left:0; color:#ef4444; font-size:.75rem }
.why-card-good li {
  font-size:.82rem; color:rgba(255,255,255,.8); padding-left:18px; position:relative; line-height:1.55;
}
.why-card-good li::before { content:'✓'; position:absolute; left:0; color:var(--gold) }
.why-badge {
  margin-top:24px; display:inline-block;
  background:rgba(201,162,39,.15); border:1px solid rgba(201,162,39,.3);
  color:var(--gold); padding:6px 18px; border-radius:50px;
  font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px;
}
@media(max-width:800px) { .why-grid { grid-template-columns:1fr } }

/* ═══════════════════════════════════════
   MESSAGE DU FONDATEUR
═══════════════════════════════════════ */
.founder-message-section {
  background:linear-gradient(135deg,var(--dark) 0%,#111827 60%,var(--navy) 100%);
  position:relative; overflow:hidden;
}
.founder-message-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 80% 50%,rgba(201,162,39,.07) 0%,transparent 60%);
}
.founder-msg-inner {
  max-width:820px; margin:0 auto; position:relative; z-index:1;
}
.founder-msg-quote-mark {
  font-family:'Playfair Display',serif; font-size:9rem; line-height:.7;
  color:rgba(201,162,39,.15); margin-bottom:-20px; user-select:none;
}
.founder-msg-text {
  margin:0 0 40px;
  border-left:3px solid rgba(201,162,39,.4); padding-left:32px;
}
.founder-msg-text p {
  font-family:'Playfair Display',serif; font-style:italic;
  color:rgba(255,255,255,.85); font-size:1.08rem; line-height:1.9;
}
.founder-msg-signature { padding-left:32px }
.founder-msg-sig-line {
  width:48px; height:2px; background:var(--gold); margin-bottom:14px; opacity:.6;
}
.founder-msg-name {
  font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700;
  color:#fff; margin-bottom:4px;
}
.founder-msg-title { font-size:.82rem; color:var(--gold); margin-bottom:4px }
.founder-msg-credential { font-size:.75rem; color:rgba(255,255,255,.35); letter-spacing:.5px }

/* ═══════════════════════════════════════
   ESG PROGRESS BARS
═══════════════════════════════════════ */
.esg-score { margin-top:20px; padding-top:16px; border-top:1px solid rgba(255,255,255,.1) }
.esg-score-label {
  display:flex; justify-content:space-between; align-items:center;
  font-size:.75rem; color:rgba(255,255,255,.5); margin-bottom:8px; font-weight:600;
}
.esg-pct { color:rgba(255,255,255,.8); font-weight:700 }
.esg-bar {
  height:6px; background:rgba(255,255,255,.1); border-radius:50px; overflow:hidden;
}
.esg-fill {
  height:100%; width:0; border-radius:50px; transition:width 1.4s cubic-bezier(.22,1,.36,1);
}

/* ═══════════════════════════════════════
   STICKY CONVERSION BAR
═══════════════════════════════════════ */
.sticky-bar {
  position:fixed; bottom:-80px; left:0; right:0; z-index:3000;
  transition:bottom .4s cubic-bezier(.22,1,.36,1);
}
.sticky-bar.visible { bottom:0 }
.sticky-bar.dismissed { display:none }
.sticky-bar-inner {
  display:flex; align-items:center; justify-content:space-between;
  background:linear-gradient(135deg,var(--dark),var(--navy));
  border-top:2px solid rgba(201,162,39,.3);
  padding:12px 24px; gap:16px;
  box-shadow:0 -8px 32px rgba(0,0,0,.4);
}
.sticky-bar-brand {
  display:flex; align-items:center; gap:10px;
  color:rgba(255,255,255,.7); font-size:.8rem; font-weight:600;
}
.sticky-bar-logo { height:24px; width:auto; filter:brightness(1.2) }
.sticky-bar-ctas { display:flex; align-items:center; gap:10px }
.sticky-cta {
  display:flex; align-items:center; gap:7px; padding:9px 18px;
  border-radius:50px; font-size:.8rem; font-weight:700; text-decoration:none;
  letter-spacing:.3px; transition:var(--transition); white-space:nowrap;
}
.sticky-cta-primary { background:var(--gold); color:var(--dark) }
.sticky-cta-primary:hover { background:var(--gold-lt); transform:translateY(-1px) }
.sticky-cta-whatsapp { background:#25D366; color:#fff }
.sticky-cta-whatsapp:hover { background:#22c55e; transform:translateY(-1px) }
.sticky-cta-secondary { background:rgba(255,255,255,.08); color:rgba(255,255,255,.8); border:1px solid rgba(255,255,255,.15) }
.sticky-cta-secondary:hover { background:rgba(255,255,255,.14); color:#fff }
.sticky-bar-close {
  background:rgba(255,255,255,.08); border:none; color:rgba(255,255,255,.5);
  width:32px; height:32px; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); flex-shrink:0;
}
.sticky-bar-close:hover { background:rgba(255,255,255,.15); color:#fff }
@media(max-width:640px) {
  .sticky-bar-brand { display:none }
  .sticky-cta span { display:none }
  .sticky-cta { padding:9px 14px }
}

/* ═══════════════════════════════════════
   PDF VIEWER MODAL
═══════════════════════════════════════ */
.pdf-modal {
  position:fixed; inset:0; z-index:9000;
  display:none; align-items:center; justify-content:center;
}
.pdf-modal.open { display:flex }
.pdf-modal-backdrop {
  position:absolute; inset:0;
  background:rgba(0,0,0,.75); backdrop-filter:blur(4px);
}
.pdf-modal-inner {
  position:relative; z-index:1; background:#fff;
  border-radius:var(--radius-lg); overflow:hidden;
  width:min(680px,94vw); max-height:85vh;
  display:flex; flex-direction:column;
  box-shadow:0 32px 80px rgba(0,0,0,.5);
}
.pdf-modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; background:var(--navy); border-bottom:1px solid rgba(201,162,39,.2);
}
.pdf-modal-title { color:var(--gold); font-size:.85rem; font-weight:700; letter-spacing:1px; text-transform:uppercase }
.pdf-modal-actions { display:flex; gap:10px }
.pdf-action-btn {
  display:flex; align-items:center; gap:6px; padding:7px 16px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
  border-radius:50px; color:rgba(255,255,255,.75); font-size:.78rem;
  font-weight:600; cursor:pointer; text-decoration:none; transition:.2s;
}
.pdf-action-btn:hover { background:rgba(201,162,39,.15); border-color:rgba(201,162,39,.4); color:var(--gold) }
.pdf-modal-body { flex:1; overflow:auto; min-height:300px }
.pdf-placeholder {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:60px 40px; gap:16px; text-align:center;
}
.pdf-placeholder i { font-size:3rem; color:var(--gray-100) }
.pdf-placeholder p { color:var(--gray-400); font-size:.88rem; max-width:360px; line-height:1.7 }

/* ═══════════════════════════════════════
   TOOLTIP SYSTEM
═══════════════════════════════════════ */
[data-tooltip] { cursor:help; position:relative }
[data-tooltip]::after {
  content:attr(data-tooltip);
  position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,var(--dark),var(--navy));
  color:rgba(255,255,255,.9); font-size:.72rem; font-family:'Inter',sans-serif;
  font-style:normal; line-height:1.5;
  padding:8px 14px; border-radius:10px; border:1px solid rgba(201,162,39,.25);
  white-space:normal; max-width:240px; text-align:center;
  pointer-events:none; opacity:0; transition:opacity .2s ease, transform .2s ease;
  z-index:8000; transform:translateX(-50%) translateY(4px);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}
[data-tooltip]:hover::after {
  opacity:1; transform:translateX(-50%) translateY(0);
}

/* ═══════════════════════════════════════
   PAGE TRANSITION OVERLAY
═══════════════════════════════════════ */
.page-transition {
  position:fixed; inset:0; z-index:9500;
  background:var(--dark); pointer-events:none;
  opacity:0; transition:opacity .35s ease;
}
.page-transition.active { opacity:1; pointer-events:all }

/* ═══════════════════════════════════════
   COMMODITY TICKER LIVE — FLASH
═══════════════════════════════════════ */
.c-price.flash-up { animation:flashUp .5s ease }
.c-price.flash-down { animation:flashDown .5s ease }
@keyframes flashUp { 0%,100%{color:inherit} 50%{color:#4ade80} }
@keyframes flashDown { 0%,100%{color:inherit} 50%{color:#f87171} }
.c-change.c-up, .c-up { color:#4ade80 }
.c-change.c-down, .c-down { color:#f87171 }

/* ═══════════════════════════════════════
   CONTACT WIZARD
═══════════════════════════════════════ */
.wizard-progress-wrap { margin-bottom:24px }
.wizard-steps-labels {
  display:flex; justify-content:space-between;
  margin-bottom:10px;
}
.wiz-label {
  font-size:.72rem; color:var(--gray-400); font-weight:600;
  text-transform:uppercase; letter-spacing:.5px; transition:.3s;
  flex:1; text-align:center;
}
.wiz-label.active { color:var(--navy) }
.wizard-progress-track {
  height:4px; background:var(--gray-100); border-radius:50px; overflow:hidden;
}
.wizard-progress {
  height:100%; background:linear-gradient(90deg,var(--navy),var(--gold));
  border-radius:50px; transition:width .4s cubic-bezier(.22,1,.36,1);
}
.wizard-step { animation:wizardFadeIn .3s ease }
@keyframes wizardFadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
.wizard-nav { display:flex; justify-content:flex-end; margin-top:20px }
.wizard-nav-split { justify-content:space-between }
.wizard-btn-back {
  display:flex; align-items:center; gap:8px;
  background:none; border:1px solid var(--gray-100); border-radius:50px;
  color:var(--gray-400); padding:11px 22px; font-size:.85rem;
  cursor:pointer; font-weight:600; transition:var(--transition); font-family:inherit;
}
.wizard-btn-back:hover { border-color:var(--navy); color:var(--navy) }
.form-group.error input, .form-group.error select, .form-group.error textarea {
  border-color:#ef4444; box-shadow:0 0 0 3px rgba(239,68,68,.1);
}
