/* ============================================
   EBURNY HOSTING GROUP — Corporate B2B Premium
   "African Tech Sovereignty" — v3.0
   ============================================ */
:root {
  /* Core Palette — Deep Gold & Navy */
  --navy:       #0A1628;   /* Marine sombre mais lisible */
  --navy-2:     #102035;
  --navy-3:     #152A45;
  --steel:      #1E3550;
  --steel-2:    #2A4565;

  /* Signature Gold — Or 24 carats */
  --gold:       #D4A843;
  --gold-dark:  #B8891E;
  --gold-light: #ECC96A;
  --gold-pale:  #FDF5DC;

  /* Signal Colors */
  --emerald:    #047857;
  --emerald-2:  #059669;
  --emerald-pale: #ECFDF5;
  --crimson:    #DC2626;
  --crimson-pale: #FEF2F2;

  /* Neutral Scale */
  --white:      #FFFFFF;
  --pearl:      #F8FAFC;
  --silver:     #F1F5F9;
  --mist:       #E2E8F0;
  --slate:      #94A3B8;
  --shadow-blue:#334155;
  --ink:        #0F172A;

  /* Typography */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'DM Sans', sans-serif;
  --font-mono:    'Bebas Neue', sans-serif;

  /* Transitions */
  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --transition: 0.3s var(--ease);

  /* Shadows */
  --shadow-sm:  0 2px 8px rgba(7,17,30,.08);
  --shadow:     0 8px 32px rgba(7,17,30,.14);
  --shadow-lg:  0 24px 64px rgba(7,17,30,.22);
  --shadow-gold: 0 8px 40px rgba(201,168,68,.25);

  /* Layout */
  --max-w: 1360px;
  --px: 56px;
  --section-py: 96px;
}

/* ============================================ RESET */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background: var(--pearl);
  color: var(--shadow-blue);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

/* ============================================ NAV */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px var(--px);
  background: rgba(10,22,40,0.96);
  border-bottom: 1px solid rgba(212,168,67,0.2);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all var(--transition);
}
.nav.scrolled {
  padding:10px var(--px);
  border-bottom-color: rgba(212,168,67,0.45);
  box-shadow: 0 4px 32px rgba(0,0,0,.5);
}
.nav-logo { display:flex; align-items:center; text-decoration:none; flex-shrink:0; }
.nav-logo img { height:40px; width:auto; }
/* Logo text — toujours visible en fallback */
.nav-logo-text {
  display:flex; align-items:center; gap:3px;
  font-family:var(--font-mono); font-size:22px; letter-spacing:4px;
  color:var(--white); line-height:1;
}
.logo-e { color:var(--gold); }
.logo-media { color:var(--gold-light); }

.nav-links { display:flex; gap:28px; align-items:center; }
.nav-links a {
  font-size:13px; font-weight:500; color:rgba(255,255,255,.65);
  position:relative; padding-bottom:4px;
  transition:color var(--transition); white-space:nowrap; letter-spacing:.3px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width var(--transition);
}
.nav-links a:hover, .nav-links a.active { color:var(--white); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }

/* Dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown-trigger {
  font-size:13px; font-weight:500; color:rgba(255,255,255,.65);
  padding-bottom:4px; cursor:pointer; position:relative;
  user-select:none; white-space:nowrap;
  background:none; border:none; font-family:var(--font-body);
  transition:color var(--transition); letter-spacing:.3px;
}
.nav-dropdown-trigger:hover,
.nav-dropdown:hover .nav-dropdown-trigger { color:var(--white); }
.nav-dropdown-trigger::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width var(--transition);
}
.nav-dropdown:hover .nav-dropdown-trigger::after { width:100%; }

.nav-dropdown-menu {
  position:absolute; top:calc(100% + 18px); left:50%;
  transform:translateX(-50%);
  background:var(--navy-2);
  border:1px solid rgba(201,168,68,.2);
  border-top:2px solid var(--gold);
  box-shadow:var(--shadow-lg); min-width:240px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .2s ease,transform .2s ease; z-index:500;
}
.nav-dropdown-menu::before {
  content:''; position:absolute; top:-18px; left:0; right:0; height:18px;
}
.nav-dropdown:hover .nav-dropdown-menu {
  opacity:1; visibility:visible; pointer-events:auto;
}
.nav-dropdown-menu a {
  display:block; padding:13px 22px; font-size:13px;
  color:rgba(255,255,255,.6);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:all var(--transition);
}
.nav-dropdown-menu a:last-child { border-bottom:none; }
.nav-dropdown-menu a:hover {
  background:rgba(201,168,68,.08);
  color:var(--gold);
  padding-left:28px;
}

.nav-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.lang-toggle {
  background:none;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.6);
  font-family:var(--font-body); font-size:11px; font-weight:800;
  letter-spacing:2px; padding:6px 11px; cursor:pointer;
  transition:all var(--transition);
}
.lang-toggle:hover { border-color:var(--gold); color:var(--gold); }

.nav-cta {
  background:var(--gold); color:var(--navy);
  border:none; font-family:var(--font-body); font-size:12px; font-weight:800;
  letter-spacing:1px; text-transform:uppercase;
  padding:10px 18px; cursor:pointer;
  transition:all var(--transition); white-space:nowrap;
}
.nav-cta:hover { background:var(--gold-light); transform:translateY(-1px); }

.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:1.5px; background:var(--white); transition:all var(--transition); }

/* ============================================ HERO — DARK SOVEREIGNTY */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  justify-content:center; position:relative; overflow:hidden;
  padding:130px var(--px) 100px;
  background: linear-gradient(145deg, var(--navy) 0%, #0C1F38 60%, #0E2440 100%);
}
.hero-bg-grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(212,168,67,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,168,67,.06) 1px, transparent 1px);
  background-size: 56px 56px;
}
.hero-bg-glow {
  position:absolute; top:-20%; right:-10%;
  width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(212,168,67,.12) 0%, transparent 60%);
  pointer-events:none;
}
.hero-bg-glow-2 {
  position:absolute; bottom:-30%; left:-5%;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(4,120,87,.09) 0%, transparent 65%);
  pointer-events:none;
}
.hero-inner {
  display:grid; grid-template-columns:1.1fr 0.9fr;
  gap:80px; align-items:center;
  width:100%; max-width:var(--max-w); margin:0 auto;
  position:relative; z-index:2;
}
.hero-content { max-width:660px; }

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-size:10px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:28px;
  opacity:0; animation:fadeUp .6s ease forwards .1s;
}
.hero-eyebrow::before {
  content:''; display:block; width:32px; height:1px;
  background:var(--gold); opacity:.6;
}
.hero-eyebrow-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--emerald-2); display:inline-block; margin-right:2px;
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.5; transform:scale(.7); }
}

.hero-title {
  font-family:var(--font-display);
  font-size: clamp(52px, 7vw, 96px);
  font-weight:900; line-height:.94;
  letter-spacing:-2px; margin-bottom:32px;
  color:var(--white);
}
.hero-line { display:block; opacity:0; transform:translateY(30px); animation:fadeUp .7s ease forwards; }
.hero-line:nth-child(1) { animation-delay:.2s; }
.hero-line:nth-child(2) {
  animation-delay:.38s;
  color:var(--gold);
  font-style:italic;
}
.hero-line:nth-child(3) {
  animation-delay:.55s;
  color:rgba(255,255,255,.9);
}

.hero-sub {
  font-size:17px; color:rgba(255,255,255,.72);
  max-width:540px; line-height:1.9; margin-bottom:44px;
  opacity:0; animation:fadeUp .7s ease forwards .7s;
}

.hero-ctas {
  display:flex; gap:14px; flex-wrap:wrap;
  opacity:0; animation:fadeUp .7s ease forwards .85s;
}

/* Hero right — network visual */
.hero-visual {
  position:relative; display:flex;
  align-items:center; justify-content:center;
  opacity:0; animation:fadeIn 1.2s ease forwards .5s;
}
.hero-network-wrap {
  position:relative; width:440px; height:440px; flex-shrink:0;
}
.hero-circle-ring {
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(201,168,68,.15);
  animation:rotateSlow 60s linear infinite;
}
.hero-circle-ring-2 {
  position:absolute; inset:28px; border-radius:50%;
  border:1px solid rgba(4,120,87,.12);
  animation:rotateSlow 40s linear infinite reverse;
}
.hero-circle-ring-3 {
  position:absolute; inset:60px; border-radius:50%;
  border:1px solid rgba(201,168,68,.08);
}
.hero-image-frame {
  position:absolute; inset:80px; border-radius:50%;
  overflow:hidden;
  border:2px solid rgba(201,168,68,.3);
  box-shadow:0 0 0 8px rgba(201,168,68,.06), var(--shadow-lg);
}
.hero-image-frame img {
  width:100%; height:100%; object-fit:cover; object-position:center top;
}
/* orbit nodes */
.orbit-node {
  position:absolute; width:10px; height:10px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 12px var(--gold);
}
.orbit-node::after {
  content:''; position:absolute; top:50%; left:12px;
  transform:translateY(-50%);
  font-size:9px; font-weight:800; letter-spacing:1.5px;
  text-transform:uppercase; color:rgba(255,255,255,.70); white-space:nowrap;
}
.orbit-node-1 { top:8%; left:50%; transform:translateX(-50%); background:var(--gold); }
.orbit-node-2 { top:50%; right:4%; transform:translateY(-50%); background:var(--emerald-2); box-shadow:0 0 12px var(--emerald-2); }
.orbit-node-3 { bottom:12%; left:15%; background:var(--gold); }
.orbit-node-4 { top:20%; left:6%; background:var(--emerald-2); box-shadow:0 0 12px var(--emerald-2); }

/* Ticker */
.hero-ticker {
  position:absolute; bottom:0; left:0; right:0;
  overflow:hidden; background:var(--steel);
  border-top:1px solid rgba(201,168,68,.12);
}
.ticker-inner { padding:13px 0; overflow:hidden; }
.ticker-track {
  display:flex; gap:56px; white-space:nowrap;
  animation:ticker 55s linear infinite;
  font-size:10px; letter-spacing:2px;
  color:rgba(255,255,255,.55); font-weight:700; text-transform:uppercase;
  font-family:var(--font-body);
}
.ticker-track:hover { animation-play-state:paused; }
.t-gold { color:var(--gold-light) !important; }
.t-green { color:var(--emerald-2) !important; }
.t-red { color:#F87171 !important; }

/* Kente stripe */
.hero-kente {
  position:absolute; bottom:52px; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--gold) 0% 33%, var(--emerald-2) 33% 66%, #EF4444 66% 100%);
  opacity:.6;
}

/* ============================================ BUTTONS */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:var(--navy);
  font-weight:800; font-size:13px; letter-spacing:.5px;
  padding:15px 30px; transition:all var(--transition);
  border:2px solid var(--gold);
}
.btn-primary:hover { background:var(--gold-light); border-color:var(--gold-light); transform:translateY(-2px); box-shadow:var(--shadow-gold); }

.btn-ghost {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:rgba(255,255,255,.75);
  font-weight:600; font-size:13px; letter-spacing:.5px;
  padding:15px 30px; border:1px solid rgba(255,255,255,.2);
  transition:all var(--transition);
}
.btn-ghost:hover { border-color:rgba(255,255,255,.75); color:var(--white); transform:translateY(-2px); }

.btn-dark {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--navy); color:var(--white);
  font-weight:700; font-size:13px; letter-spacing:.5px;
  padding:14px 28px; transition:all var(--transition);
  border:2px solid var(--navy);
}
.btn-dark:hover { background:var(--steel); border-color:var(--steel); transform:translateY(-2px); }

.btn-gold {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:var(--navy);
  font-weight:800; font-size:13px; letter-spacing:.5px;
  padding:15px 32px; border:2px solid var(--gold);
  transition:all var(--transition);
}
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:var(--shadow-gold); }

.btn-outline-gold {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:var(--gold);
  font-weight:700; font-size:13px; letter-spacing:.5px;
  padding:13px 26px; border:2px solid var(--gold);
  transition:all var(--transition);
}
.btn-outline-gold:hover { background:var(--gold); color:var(--navy); transform:translateY(-2px); }

.btn-emerald {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--emerald); color:var(--white);
  font-weight:700; font-size:13px; letter-spacing:.5px;
  padding:14px 28px; border:2px solid var(--emerald);
  transition:all var(--transition);
}
.btn-emerald:hover { background:var(--emerald-2); border-color:var(--emerald-2); transform:translateY(-2px); }

/* ============================================ STATS BAR */
.stats-bar {
  display:flex;
  background:linear-gradient(180deg, var(--navy-2) 0%, var(--navy-3) 100%);
  border-bottom:2px solid rgba(212,168,67,0.2);
}
.stat-item {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:52px 20px; border-right:1px solid rgba(212,168,67,0.08);
  position:relative; transition:background var(--transition);
}
.stat-item:hover { background:rgba(212,168,67,.04); }
.stat-item:last-child { border-right:none; }
.stat-item::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
}
.stat-item:nth-child(1)::before { background:var(--gold); }
.stat-item:nth-child(2)::before { background:var(--emerald-2); }
.stat-item:nth-child(3)::before { background:#EF4444; }
.stat-item:nth-child(4)::before { background:var(--gold-light); }
.stat-num { font-family:var(--font-mono); font-size:60px; color:var(--white); line-height:1; }
.stat-unit { font-family:var(--font-mono); font-size:28px; color:var(--gold); }
.stat-label {
  font-size:10px; letter-spacing:2px; color:rgba(255,255,255,.75);
  text-transform:uppercase; margin-top:10px; font-weight:700;
}

/* ============================================ SECTION BASE */
.section { padding:var(--section-py) var(--px); }
.section--white { background:var(--white); }
.section--pearl { background:var(--pearl); }
.section--dark { background:var(--navy); }
.section--navy2 { background:var(--navy-2); }
.section--steel { background:var(--steel); }

/* Force text visibility on light sections */
.section--white .section-title,
.section--pearl .section-title { color:var(--navy) !important; }
.section--white .section-sub,
.section--pearl .section-sub { color:#475569 !important; }
.section--white p, .section--pearl p { color:#475569; }
.section--white h3, .section--white h4,
.section--pearl h3, .section--pearl h4 { color:var(--navy); }

.section-inner { max-width:var(--max-w); margin:0 auto; }
.section-header { text-align:center; max-width:700px; margin:0 auto 72px; }

.section-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:10px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:var(--gold); margin-bottom:14px;
}
.section-tag::before { content:''; display:inline-block; width:20px; height:1px; background:var(--gold); }

.section-title {
  font-family:var(--font-display);
  font-size:clamp(32px, 4vw, 54px);
  font-weight:800; line-height:1.1; margin-bottom:18px;
  letter-spacing:-.5px; color:var(--navy);
}
.section--dark .section-title,
.section--navy2 .section-title,
.section--steel .section-title { color:var(--white); }
.section--dark .section-tag,
.section--navy2 .section-tag { color:var(--gold); }

.section-sub {
  font-size:17px; color:var(--slate); line-height:1.9;
}
.section--dark .section-sub,
.section--navy2 .section-sub { color:rgba(255,255,255,.75); }

/* ============================================ TRUST STRIP */
.trust-strip {
  background:var(--navy-3);
  padding:28px var(--px);
  border-bottom:1px solid rgba(201,168,68,.08);
  border-top:1px solid rgba(255,255,255,.04);
}
.trust-strip-inner {
  max-width:var(--max-w); margin:0 auto;
  display:flex; align-items:center; gap:48px; flex-wrap:wrap;
}
.trust-label {
  font-size:10px; font-weight:800; letter-spacing:2.5px;
  text-transform:uppercase; color:rgba(255,255,255,.55);
  flex-shrink:0; white-space:nowrap;
}
.trust-items { display:flex; align-items:center; gap:40px; flex-wrap:wrap; }
.trust-item {
  display:flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; letter-spacing:1px;
  text-transform:uppercase; color:rgba(255,255,255,.65);
  transition:color var(--transition);
}
.trust-item:hover { color:var(--gold); }
.trust-item-icon { font-size:14px; }
.trust-divider {
  width:1px; height:28px;
  background:rgba(255,255,255,.08);
}

/* ============================================ SEGMENT PILLARS (B2B) */
.segments-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:2px; max-width:var(--max-w); margin:0 auto;
}
.segment-card {
  position:relative; overflow:hidden;
  padding:60px 44px 56px;
  background:var(--navy-2);
  transition:all var(--transition);
  cursor:pointer;
}
.segment-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
}
.segment-card:nth-child(1)::before { background:var(--gold); }
.segment-card:nth-child(2)::before { background:var(--emerald-2); }
.segment-card:nth-child(3)::before { background:#EF4444; }
.segment-card::after {
  content:''; position:absolute; bottom:0; right:0;
  width:120px; height:120px; border-radius:50%;
  background:rgba(255,255,255,.02);
  transform:translate(30%, 30%);
  transition:transform var(--transition);
}
.segment-card:hover { background:var(--steel); }
.segment-card:hover::after { transform:translate(20%, 20%) scale(1.4); }

.segment-icon {
  font-size:40px; margin-bottom:24px; display:block;
  filter:grayscale(0);
}
.segment-number {
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:3px; color:rgba(255,255,255,.2);
  margin-bottom:10px; display:block;
}
.segment-card h3 {
  font-family:var(--font-display); font-size:26px;
  font-weight:700; margin-bottom:14px; color:var(--white);
  line-height:1.2;
}
.segment-card p {
  font-size:15px; color:rgba(255,255,255,.75);
  line-height:1.85; margin-bottom:28px;
}
.segment-features {
  list-style:none; margin-bottom:32px;
}
.segment-features li {
  font-size:13px; color:rgba(255,255,255,.70);
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; gap:10px;
}
.segment-features li::before {
  content:''; display:inline-block; width:5px; height:5px;
  border-radius:50%; background:var(--gold); flex-shrink:0;
}
.segment-card:nth-child(2) .segment-features li::before { background:var(--emerald-2); }
.segment-card:nth-child(3) .segment-features li::before { background:#F87171; }

.segment-link {
  font-size:12px; font-weight:800; letter-spacing:2px;
  text-transform:uppercase; color:var(--gold);
  display:inline-flex; align-items:center; gap:8px;
  transition:gap var(--transition);
}
.segment-card:nth-child(2) .segment-link { color:var(--emerald-2); }
.segment-card:nth-child(3) .segment-link { color:#F87171; }
.segment-link:hover { gap:14px; }

/* ============================================ WHY EBURNY */
.why-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1px; max-width:var(--max-w); margin:0 auto;
  background:rgba(255,255,255,.05);
}
.why-card {
  padding:52px 48px;
  background:var(--navy);
  transition:background var(--transition);
  position:relative; overflow:hidden;
}
.why-card:hover { background:var(--navy-2); }
.why-card-num {
  font-family:var(--font-mono); font-size:80px;
  color:rgba(201,168,68,.06); line-height:1;
  position:absolute; top:24px; right:28px;
  pointer-events:none;
}
.why-icon { font-size:32px; margin-bottom:20px; display:block; }
.why-card h3 {
  font-family:var(--font-display); font-size:22px;
  font-weight:700; margin-bottom:12px; color:var(--white);
}
.why-card p { font-size:15px; color:rgba(255,255,255,.70); line-height:1.85; }
.why-card-tag {
  display:inline-block; margin-top:18px;
  font-size:10px; font-weight:800; letter-spacing:2px;
  text-transform:uppercase; color:var(--gold);
  border:1px solid rgba(201,168,68,.2); padding:4px 10px;
}

/* ============================================ AFRICA NETWORK MAP */
.network-section {
  background:var(--navy);
  padding:var(--section-py) var(--px);
  position:relative; overflow:hidden;
}
.network-inner {
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:72px; align-items:center;
}
.network-content {}
.network-nodes {
  display:flex; flex-direction:column; gap:10px; margin-top:36px;
}
.network-node {
  display:flex; align-items:center; gap:14px;
  padding:14px 18px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  transition:all var(--transition);
  cursor:default;
}
.network-node:hover {
  border-color:rgba(201,168,68,.2);
  background:rgba(201,168,68,.04);
}
.node-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--emerald-2); flex-shrink:0;
  box-shadow:0 0 8px var(--emerald-2);
  animation:pulse-node 2.5s ease-in-out infinite;
}
.node-dot.gold { background:var(--gold); box-shadow:0 0 8px var(--gold); }
.node-dot.inactive { background:var(--slate); box-shadow:none; animation:none; }
@keyframes pulse-node {
  0%,100% { opacity:1; }
  50% { opacity:.4; }
}
.node-info { flex:1; }
.node-name { font-size:13px; font-weight:700; color:var(--white); }
.node-sub { font-size:11px; color:rgba(255,255,255,.55); }
.node-status {
  font-size:9px; font-weight:800; letter-spacing:1.5px;
  text-transform:uppercase; padding:3px 8px;
}
.ns-live { color:var(--emerald-2); border:1px solid rgba(4,120,87,.3); }
.ns-gold { color:var(--gold); border:1px solid rgba(201,168,68,.3); }
.ns-soon { color:var(--slate); border:1px solid rgba(148,163,184,.2); }

/* Africa SVG Map */
.africa-map-wrap {
  position:relative; display:flex;
  align-items:center; justify-content:center;
}
.africa-map-wrap svg { max-width:480px; width:100%; }

/* ============================================ CASE STUDIES */
.cases-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; max-width:var(--max-w); margin:0 auto;
}
.case-card {
  background:var(--white); border:1px solid var(--mist);
  padding:40px 36px; transition:all var(--transition);
  position:relative; overflow:hidden;
}
.case-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--gold); }
.case-card::before {
  content:''; position:absolute; top:0; left:0; width:4px; bottom:0;
}
.case-card:nth-child(1)::before { background:var(--gold); }
.case-card:nth-child(2)::before { background:var(--emerald-2); }
.case-card:nth-child(3)::before { background:var(--navy); }

.case-sector {
  font-size:10px; font-weight:800; letter-spacing:2px;
  text-transform:uppercase; color:var(--slate); margin-bottom:14px;
  display:block;
}
.case-card h3 {
  font-family:var(--font-display); font-size:20px;
  font-weight:700; margin-bottom:10px; color:var(--navy);
  line-height:1.3;
}
.case-card p {
  font-size:14px; color:var(--slate); line-height:1.8; margin-bottom:22px;
}
.case-metrics {
  display:flex; gap:22px; flex-wrap:wrap;
}
.case-metric { display:flex; flex-direction:column; }
.cm-num {
  font-family:var(--font-mono); font-size:28px;
  color:var(--navy); line-height:1;
}
.cm-label { font-size:10px; font-weight:700; letter-spacing:1px; color:var(--slate); text-transform:uppercase; }

/* ============================================ AUDIT CTA */
.audit-cta {
  background:var(--gold);
  padding:100px var(--px);
  position:relative; overflow:hidden;
}
.audit-cta::before {
  content:'';
  position:absolute; top:0; left:0; right:0; bottom:0;
  background:
    linear-gradient(135deg, transparent 60%, rgba(7,17,30,.08) 100%);
  pointer-events:none;
}
.audit-cta-inner {
  max-width:760px; margin:0 auto; text-align:center;
  position:relative; z-index:1;
}
.audit-cta h2 {
  font-family:var(--font-display); font-size:clamp(32px, 5vw, 60px);
  font-weight:900; line-height:1.05; letter-spacing:-1px;
  color:var(--navy); margin-bottom:20px;
}
.audit-cta p {
  font-size:18px; color:rgba(7,17,30,.65); line-height:1.8;
  margin-bottom:42px; max-width:560px; margin-left:auto; margin-right:auto;
}
.audit-cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================ EXPERTISE SECTION */
.expertise-inner {
  display:grid; grid-template-columns:1fr 1.5fr;
  gap:80px; align-items:center;
  max-width:var(--max-w); margin:0 auto;
}
.expertise-left {}
.expertise-left .section-title { text-align:left; color:var(--navy) !important; }
.expertise-left .section-sub { text-align:left; margin-bottom:32px; color:#475569 !important; }
.expertise-list { list-style:none; }
.expertise-list li {
  display:grid; grid-template-columns:40px 1fr auto;
  gap:14px; align-items:start;
  padding:20px 0; border-bottom:1px solid var(--mist);
  transition:padding var(--transition);
  cursor:default;
}
.expertise-list li:first-child { border-top:1px solid var(--mist); }
.expertise-list li:hover { padding-left:6px; }
.el-num {
  width:32px; height:32px; border:1px solid var(--mist);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:13px;
  color:var(--slate); flex-shrink:0;
  transition:all var(--transition);
}
.expertise-list li:hover .el-num {
  border-color:var(--gold); color:var(--gold);
}
.el-info h4 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:3px; }
.el-info p { font-size:13px; color:var(--slate); line-height:1.5; }
.el-arrow { color:var(--mist); font-size:16px; transition:all var(--transition); }
.expertise-list li:hover .el-arrow { color:var(--gold); transform:translateX(4px); }

.expertise-visual {
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.ev-card {
  padding:32px 26px; display:flex; flex-direction:column; gap:8px;
}
.ev-card:nth-child(1) { background:var(--gold); color:var(--navy); }
.ev-card:nth-child(2) { background:var(--navy); color:var(--white); }
.ev-card:nth-child(3) { background:var(--silver); border:1px solid var(--mist); }
.ev-card:nth-child(4) { background:var(--emerald); color:var(--white); }
.ev-num { font-family:var(--font-mono); font-size:48px; line-height:1; }
.ev-label { font-size:13px; font-weight:600; opacity:.7; }

/* ============================================ BRANDS TICKER */
.brands-ticker {
  background:var(--navy-3);
  border-top:2px solid var(--gold);
  border-bottom:1px solid rgba(212,168,67,0.15);
  padding:20px 0;
  overflow:hidden;
  position:relative;
}
.brands-ticker::before,
.brands-ticker::after {
  content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2;
}
.brands-ticker::before { left:0; background:linear-gradient(90deg, var(--navy-3), transparent); }
.brands-ticker::after  { right:0; background:linear-gradient(-90deg, var(--navy-3), transparent); }

.brands-ticker-label {
  text-align:center;
  font-size:9px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:rgba(212,168,67,0.5);
  margin-bottom:14px;
}
.brands-track {
  display:flex; gap:0; white-space:nowrap;
  animation:ticker 45s linear infinite;
}
.brands-track:hover { animation-play-state:paused; }
.brand-ticker-item {
  display:inline-flex; align-items:center; gap:10px;
  padding:0 36px;
  border-right:1px solid rgba(255,255,255,.06);
  font-family:var(--font-mono); font-size:15px; letter-spacing:3px;
  color:rgba(255,255,255,0.35);
  transition:color .3s ease;
  cursor:default;
  flex-shrink:0;
}
.brand-ticker-item:hover { color:var(--gold); }
.brand-ticker-item .bti-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--gold); opacity:.5; flex-shrink:0;
}

/* ============================================ FOOTER */
.footer {
  background:var(--navy); color:var(--white);
  padding:72px var(--px) 30px;
  border-top:1px solid rgba(212,168,67,0.1);
}
.footer-top {
  display:grid; grid-template-columns:1fr 2.2fr;
  gap:80px; margin-bottom:60px;
  padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-brand {}
.footer-logo {
  font-family:var(--font-mono); font-size:20px;
  letter-spacing:3px; margin-bottom:14px;
  display:flex; align-items:center; gap:4px;
}
.footer-tagline {
  font-size:10px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:16px;
}
.footer-brand p {
  font-size:14px; color:rgba(255,255,255,.70);
  max-width:280px; line-height:1.8;
  margin-bottom:24px;
}
.footer-cert {
  display:flex; align-items:center; gap:8px;
  font-size:10px; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; color:rgba(255,255,255,.25);
  margin-bottom:8px;
}
.footer-cert::before {
  content:'✓'; color:var(--emerald-2); font-size:10px;
}

.footer-links {
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
}
.footer-col h5 {
  font-size:9px; font-weight:800; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:18px; padding-bottom:10px;
  border-bottom:1px solid rgba(201,168,68,.15);
}
.footer-col a {
  display:block; font-size:13px;
  color:rgba(255,255,255,.70); margin-bottom:9px;
  transition:color var(--transition);
}
.footer-col a:hover { color:var(--white); }

.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  font-size:11px; color:rgba(255,255,255,.25);
  flex-wrap:wrap; gap:10px;
  letter-spacing:.3px;
}
.footer-kente {
  height:2px; margin-bottom:24px;
  background:linear-gradient(90deg, var(--gold) 0% 33%, var(--emerald-2) 33% 66%, #EF4444 66% 100%);
  opacity:.4;
}

/* ============================================ ADMIN (preserved) */
.admin-overlay{position:fixed;inset:0;background:rgba(7,17,30,.75);z-index:2000;display:none;align-items:center;justify-content:center;}
.admin-overlay.open{display:flex;}
.admin-panel{background:var(--white);width:min(96vw,1100px);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;}
.admin-header{padding:20px 28px;border-bottom:1px solid var(--mist);display:flex;align-items:center;justify-content:space-between;background:var(--navy);color:var(--white);position:sticky;top:0;z-index:10;}
.admin-header h2{font-family:var(--font-mono);font-size:20px;letter-spacing:2px;}
.admin-header-sub{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:2px;margin-top:2px;}
.admin-close{background:none;border:1px solid rgba(255,255,255,.2);color:var(--white);font-size:18px;width:34px;height:34px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.admin-tabs{display:flex;border-bottom:1px solid var(--mist);background:var(--pearl);overflow-x:auto;}
.admin-tab{padding:13px 20px;font-size:13px;font-weight:600;color:var(--slate);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--transition);white-space:nowrap;}
.admin-tab.active{color:var(--navy);border-bottom-color:var(--gold);background:var(--white);}
.admin-body{padding:28px;flex:1;}
.admin-section{display:none;}.admin-section.active{display:block;}
.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
.admin-toolbar h3{font-size:17px;font-weight:700;color:var(--navy);}
.admin-table{width:100%;border-collapse:collapse;font-size:13px;}
.admin-table th{background:var(--pearl);padding:10px 14px;text-align:left;font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--slate);border-bottom:2px solid var(--mist);}
.admin-table td{padding:11px 14px;border-bottom:1px solid var(--mist);vertical-align:middle;color:var(--shadow-blue);}
.admin-table tr:hover td{background:var(--pearl);}
.ab{display:inline-block;padding:2px 9px;font-size:10px;font-weight:700;border-radius:10px;}
.ab-live{background:#D1FAE5;color:#065F46;}.ab-hidden{background:#F1F5F9;color:#64748B;}.ab-soon{background:#FEF08A;color:#854D0E;}
.toggle-vis{background:none;border:1px solid var(--mist);padding:3px 9px;font-size:11px;cursor:pointer;transition:all var(--transition);color:var(--slate);}
.toggle-vis:hover{border-color:var(--crimson);color:var(--crimson);}
.toggle-vis.vis{border-color:var(--emerald);color:var(--emerald);}
.admin-form{display:flex;flex-direction:column;gap:13px;max-width:580px;}
.a-btn{background:var(--navy);color:var(--white);border:none;padding:11px 22px;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--transition);}
.a-btn:hover{background:var(--emerald);}
.a-btn-sm{padding:5px 12px;font-size:11px;}
.a-btn-gold{background:var(--gold);color:var(--navy);}
.a-btn-red{background:var(--crimson);}
.pin-screen{text-align:center;padding:52px 28px;}
.pin-screen h3{font-family:var(--font-display);font-size:26px;margin-bottom:6px;}
.pin-screen p{color:var(--slate);margin-bottom:24px;}
.pin-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:18px;}
.pin-inputs input{width:50px;height:56px;text-align:center;font-size:22px;font-weight:700;border:2px solid var(--mist);background:var(--pearl);color:var(--navy);font-family:var(--font-body);}
.pin-inputs input:focus{border-color:var(--gold);outline:none;}
.pin-error{color:var(--crimson);font-size:13px;margin-top:6px;display:none;}
.admin-success{background:#D1FAE5;color:#065F46;padding:10px 16px;font-size:13px;font-weight:600;margin-bottom:16px;display:none;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group label{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--slate);}
.form-group input,.form-group select,.form-group textarea{background:var(--white);border:1.5px solid var(--mist);color:var(--shadow-blue);font-family:var(--font-body);font-size:15px;padding:12px 14px;transition:border-color var(--transition);outline:none;width:100%;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);}
.form-group select{appearance:none;cursor:pointer;}
.form-group textarea{resize:vertical;min-height:128px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ============================================ MOBILE MENU */
.mobile-menu{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--navy);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;transform:translateX(100vw);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow:hidden;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{font-family:var(--font-display);font-size:clamp(22px,7vw,32px);font-weight:700;color:rgba(255,255,255,.75);transition:color var(--transition);text-align:center;}
.mobile-menu a:hover{color:var(--gold);}
.mobile-close{position:absolute;top:18px;right:18px;background:none;border:1px solid rgba(255,255,255,.15);color:var(--white);font-size:18px;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;}
.mobile-stripe{position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold) 0% 33%,var(--emerald-2) 33% 66%,#EF4444 66% 100%);}

/* ============================================ PAGE HERO */
.page-hero{padding:140px var(--px) 64px;background:var(--navy);border-bottom:1px solid rgba(201,168,68,.1);position:relative;overflow:hidden;}
.page-hero-inner{max-width:860px;position:relative;z-index:2;}
.page-hero-deco{position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;pointer-events:none;opacity:.04;z-index:1;}
.page-hero-eyebrow{font-size:10px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.page-hero-title{font-family:var(--font-display);font-size:clamp(36px,5.5vw,68px);font-weight:900;line-height:1;letter-spacing:-2px;max-width:820px;margin-bottom:18px;color:var(--white);}
.page-hero-sub{font-size:16px;color:rgba(255,255,255,.75);max-width:560px;line-height:1.85;}
.page-hero-stripe{height:3px;background:linear-gradient(90deg,var(--gold) 0% 33%,var(--emerald-2) 33% 66%,#EF4444 66% 100%);margin-top:32px;max-width:160px;}

/* ============================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;max-width:1200px;margin:0 auto;}
.contact-info h3{font-family:var(--font-display);font-size:28px;font-weight:700;margin-bottom:16px;color:var(--navy);}
.contact-info p{font-size:16px;color:var(--slate);line-height:1.8;margin-bottom:32px;}
.contact-detail{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;}
.contact-detail-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;background:var(--silver);border:1px solid var(--mist);}
.contact-detail-text h5{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--emerald-2);margin-bottom:2px;}
.contact-detail-text p{font-size:14px;color:var(--slate);}
.contact-form{display:flex;flex-direction:column;gap:14px;}

/* ============================================ ANIMATIONS */
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { to { opacity:1; } }
@keyframes rotateSlow { to { transform:rotate(360deg); } }
@keyframes ticker { from { transform:translateX(0); } to { transform:translateX(-50%); } }
@keyframes spinShape { to { transform:rotate(405deg); } }
@keyframes floatShape { 0%,100%{transform:translate(0,0);}50%{transform:translate(12px,-12px);} }

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

/* ============================================ RESPONSIVE */
html,body{overflow-x:hidden;max-width:100%;}

@media(max-width:1100px){
  :root { --px: 32px; }
  .segments-grid { grid-template-columns:1fr; }
  .cases-grid { grid-template-columns:1fr 1fr; }
  .footer-links { grid-template-columns:repeat(2,1fr); }
  .network-inner { grid-template-columns:1fr; }
  .africa-map-wrap { display:none; }
  .why-grid { grid-template-columns:1fr; }
  .expertise-inner { grid-template-columns:1fr; gap:40px; }
}

@media(max-width:900px){
  :root { --px: 20px; --section-py: 64px; }
  .nav { padding:12px var(--px); }
  .nav.scrolled { padding:8px var(--px); }
  .nav-links, .nav-actions { display:none; }
  .hamburger { display:flex; }
  .hero { padding:110px var(--px) 90px; }
  .hero-inner { grid-template-columns:1fr; gap:40px; }
  .hero-network-wrap { width:300px; height:300px; }
  .hero-image-frame { inset:50px; }
  .stats-bar { flex-wrap:wrap; }
  .stat-item { flex:0 0 50%; border-right:none; border-bottom:1px solid rgba(255,255,255,.06); }
  .trust-items { gap:24px; }
  .cases-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; gap:40px; }
}

@media(max-width:600px){
  :root { --px: 16px; --section-py: 52px; }
  .hero { padding:96px var(--px) 80px; }
  .hero-title { font-size:clamp(38px, 11vw, 58px); }
  .hero-ctas { flex-direction:column; }
  .hero-ctas .btn-primary, .hero-ctas .btn-ghost { justify-content:center; }
  .hero-network-wrap { width:240px; height:240px; }
  .hero-image-frame { inset:40px; }
  .stat-item { flex:0 0 50%; }
  .segment-card { padding:40px 28px; }
  .why-card { padding:36px 28px; }
  .case-card { padding:32px 24px; }
  .footer { padding:52px var(--px) 24px; }
  .footer-links { grid-template-columns:1fr 1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .audit-cta { padding:72px var(--px); }
  .audit-cta-btns { flex-direction:column; align-items:center; }
  .expertise-visual { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
}
