:root {
  --navy:   #0b1c4f;
  --navy2:  #0e2260;
  --blue:   #1a3a8f;
  --gold:   #f0b429;
  --gold2:  #ffc93c;
  --white:  #ffffff;
  --off:    #f4f6fb;
  --gray:   #6b7280;
  --dark:   #111827;
  --border: rgba(11,28,79,0.10);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Barlow',sans-serif;background:#fff;color:var(--dark);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
ul{list-style:none}

/* ─── SCROLL REVEAL ─────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s cubic-bezier(.22,1,.36,1), transform 0.7s cubic-bezier(.22,1,.36,1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.8s cubic-bezier(.22,1,.36,1), transform 0.8s cubic-bezier(.22,1,.36,1);
}
.reveal-left.visible { opacity: 1; transform: translateX(0); }
.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.8s cubic-bezier(.22,1,.36,1), transform 0.8s cubic-bezier(.22,1,.36,1);
}
.reveal-right.visible { opacity: 1; transform: translateX(0); }

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }
.reveal-delay-6 { transition-delay: 0.6s; }

/* ─── NAVBAR ─────────────────────────────── */
#nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5vw;
  background: rgba(255,255,255,0.97);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
  animation: slideDown 0.6s cubic-bezier(.22,1,.36,1) both;
}
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
.nav-brand {
  display: flex;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
}
.nav-brand img {
  height: 90px;
  width: auto;
  transition: transform 0.3s ease;
}
.nav-brand:hover img { transform: scale(1.05); }
.nav-links {
  display: flex;
  align-items: center;
  gap: 36px;
}
.nav-links a {
  font-size: 14px;
  font-weight: 600;
  color: #374151;
  letter-spacing: 0.02em;
  transition: color .15s;
  position: relative;
}
.nav-links a::after {
  content:'';
  position:absolute;
  bottom:-3px;left:0;right:0;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s;
}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta {
  background: var(--navy);
  color: #fff !important;
  padding: 9px 22px;
  border-radius: 4px;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  transition: background .15s, transform .15s, box-shadow .15s !important;
}
.nav-cta::after{display:none !important}
.nav-cta:hover{
  background:var(--blue) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(11,28,79,0.25) !important;
}

/* ─── BURGER ─────────────────────────────── */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  gap: 5px;
  padding: 4px;
  border-radius: 4px;
  transition: background .15s;
  flex-shrink: 0;
}
.nav-burger:hover { background: var(--off); }
.nav-burger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--navy);
  border-radius: 2px;
  transition: transform .25s, opacity .25s, width .25s;
  transform-origin: center;
}
.nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; width: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── MOBILE NAV ─────────────────────────── */
#nav-mobile {
  display: none;
  position: fixed;
  top: 72px;
  inset-inline: 0;
  z-index: 99;
  background: rgba(255,255,255,0.98);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
  padding: 0;
  overflow: hidden;
  max-height: 0;
  transition: max-height .35s ease, padding .35s ease;
}
#nav-mobile.open { max-height: 400px; padding: 16px 0 20px; }
#nav-mobile a {
  display: block;
  padding: 13px 24px;
  font-size: 15px;
  font-weight: 600;
  color: #374151;
  letter-spacing: 0.02em;
  border-bottom: 1px solid var(--border);
  transition: background .15s, color .15s;
}
#nav-mobile a:last-child { border-bottom: none; }
#nav-mobile a:hover { background: var(--off); color: var(--navy); }
#nav-mobile .mob-cta {
  margin: 14px 24px 0;
  display: block;
  background: var(--navy);
  color: #fff !important;
  padding: 12px 22px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
  border-bottom: none !important;
  transition: background .15s;
}
#nav-mobile .mob-cta:hover { background: var(--blue) !important; }

/* ─── NETWORK CANVAS BACKGROUND ──────────── */
#network-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

/* ─── HERO ───────────────────────────────── */
#hero {
  position: relative;
  height: 100vh;
  min-height: 640px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hero-img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

.hero-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    rgba(9,18,60,0.92) 0%,
    rgba(11,28,79,0.75) 42%,
    rgba(11,28,79,0.18) 100%
  );
}
.hero-rule {
  position:absolute;
  top:0;bottom:0;
  left:48%;
  width:1px;
  background:linear-gradient(to bottom,transparent,rgba(240,180,41,0.25),transparent);
  animation: rulePulse 3s ease-in-out infinite;
}
@keyframes rulePulse {
  0%,100% { opacity: 0.4; }
  50%      { opacity: 1; }
}
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 5vw;
  padding-top: 72px;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  opacity: 0;
  animation: fadeSlideUp 0.7s 0.3s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-eyebrow span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
}
.hero-eyebrow::before {
  content:'';
  display:block;
  width:28px;height:2px;
  background:var(--gold);
}
.hero-inner h1 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
  opacity: 0;
  animation: fadeSlideUp 0.8s 0.5s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-inner h1 em {
  font-style: italic;
  color: var(--gold);
  display: inline-block;
  animation: goldGlow 3s 1.5s ease-in-out infinite;
}

.hero-sub {
  font-size: 17px;
  font-weight: 400;
  color: rgba(255,255,255,0.72);
  line-height: 1.6;
  max-width: 440px;
  margin-bottom: 10px;
  opacity: 0;
  animation: fadeSlideUp 0.8s 0.7s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-ip-line {
  font-size: 12.5px;
  font-style: italic;
  color: rgba(255,255,255,0.716);
  margin-bottom: 36px;
  opacity: 0;
  animation: fadeSlideUp 0.8s 0.85s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeSlideUp 0.8s 1s cubic-bezier(.22,1,.36,1) forwards;
}

@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.btn-solid {
  background: var(--gold);
  color: var(--navy);
  padding: 13px 30px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.03em;
  transition: background .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 4px 18px rgba(240,180,41,0.30);
  position: relative;
  overflow: hidden;
}
.btn-solid::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.3) 50%, transparent 70%);
  transform:translateX(-100%);
  transition:transform 0.5s;
}
.btn-solid:hover::before { transform:translateX(100%); }
.btn-solid:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(240,180,41,0.45)}
.btn-solid:active{transform:translateY(0)}

.btn-ghost {
  border: 1.5px solid rgba(255,255,255,0.35);
  color: rgba(255,255,255,0.88);
  padding: 13px 30px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.03em;
  transition: border-color .15s, background .15s, transform .15s;
}
.btn-ghost:hover{
  border-color:rgba(255,255,255,0.70);
  background:rgba(255,255,255,0.07);
  transform:translateY(-2px);
}

/* ─── FLOATING PARTICLES ─────────────────── */
.particle {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  animation: float linear infinite;
}
@keyframes float {
  0%   { transform: translateY(0) translateX(0) scale(1); opacity: 0.6; }
  25%  { transform: translateY(-30px) translateX(10px) scale(1.1); }
  50%  { transform: translateY(-15px) translateX(-8px) scale(0.9); opacity: 0.3; }
  75%  { transform: translateY(-40px) translateX(5px) scale(1.05); }
  100% { transform: translateY(-60px) translateX(0) scale(1); opacity: 0; }
}

/* ─── STATS BAR ──────────────────────────── */
#stats {
  background: var(--navy);
  padding: 0 5vw;
  position: relative;
  overflow: hidden;
}
#stats::before {
  content:'';
  position:absolute;
  top:-1px;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  animation: scanLine 3s ease-in-out infinite;
}
@keyframes scanLine {
  0%   { transform:scaleX(0); transform-origin:left; opacity:1; }
  50%  { transform:scaleX(1); transform-origin:left; opacity:1; }
  51%  { transform:scaleX(1); transform-origin:right; opacity:1; }
  100% { transform:scaleX(0); transform-origin:right; opacity:0; }
}
.stats-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  border-left: 1px solid rgba(255,255,255,0.07);
}
.stat-item {
  padding: 32px 28px;
  border-right: 1px solid rgba(255,255,255,0.07);
  border-top: 3px solid transparent;
  transition: border-top-color .2s, background .2s;
  cursor: default;
}
.stat-item:hover{
  border-top-color:var(--gold);
  background: rgba(255,255,255,0.03);
}
.stat-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  color: var(--gold);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 4px;
  transition: transform .2s;
}
.stat-item:hover .stat-num { transform: scale(1.08); }
.stat-label {
  font-size: 12.5px;
  font-weight: 500;
  color: rgba(255,255,255,0.52);
  letter-spacing: 0.02em;
}

/* ─── ABOUT ──────────────────────────────── */
#about {
  padding: 100px 5vw;
  background: var(--off);
}
.about-wrap {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.about-media {
  position: relative;
}
.about-media-bg {
  width: 100%;
  aspect-ratio: 4/3;
  background: linear-gradient(140deg, var(--navy) 0%, var(--blue) 100%);
  border-radius: 2px;
  position: relative;
  overflow: hidden;
}
.about-media-bg::before {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 40px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 40px);
}
/* Animated grid scan effect */
.about-media-bg::after {
  content:'';
  position:absolute;
  top:-100%;left:0;right:0;
  height:60%;
  background: linear-gradient(to bottom, transparent, rgba(240,180,41,0.04), transparent);
  animation: scanGrid 4s linear infinite;
}
@keyframes scanGrid {
  from { top: -60%; }
  to   { top: 120%; }
}
.about-media-inner {
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.about-media-svg { width:72%; height:72%; }
.about-media::before {
  content:'';
  position:absolute;
  left:-16px; top:24px; bottom:24px;
  width:4px;
  background:var(--gold);
  border-radius:2px;
  animation: barPulse 2s ease-in-out infinite;
}
@keyframes barPulse {
  0%,100% { box-shadow: 0 0 0 transparent; opacity:1; }
  50%      { box-shadow: 0 0 16px var(--gold); opacity:0.8; }
}
.about-pill {
  position: absolute;
  bottom: -18px;
  right: -18px;
  background: var(--gold);
  padding: 16px 22px;
  border-radius: 2px;
  box-shadow: 0 8px 30px rgba(240,180,41,0.30);
  text-align: center;
  min-width: 110px;
  animation: pillBounce 4s ease-in-out infinite;
}
@keyframes pillBounce {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.about-pill-num {
  font-family:'Barlow Condensed',sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1;
}
.about-pill-lbl {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--navy);
  opacity: .7;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 3px;
}
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 14px;
}
.section-kicker::before {
  content:'';
  display:block;
  width:24px;height:2px;
  background:var(--gold);
}
.about-copy h2 {
  font-family:'Barlow Condensed',sans-serif;
  font-size: clamp(1.9rem,3vw,2.8rem);
  font-weight: 800;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: 18px;
}
.about-copy h2 em{font-style:normal;color:var(--blue)}
.about-copy p {
  font-size: 15.5px;
  color: #4b5563;
  line-height: 1.75;
  margin-bottom: 28px;
}
.check-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.check-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14.5px;
  color: #374151;
  line-height: 1.5;
  transition: transform .2s;
}
.check-list li:hover { transform: translateX(4px); }
.check-list li::before {
  content:'';
  flex-shrink:0;
  width:20px; height:20px;
  margin-top:1px;
  background:var(--navy);
  border-radius:3px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23f0b429' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  transition: transform .2s, box-shadow .2s;
}
.check-list li:hover::before {
  transform: scale(1.15);
  box-shadow: 0 0 10px rgba(240,180,41,0.4);
}

/* ─── WHY CHOOSE US ──────────────────────── */
#why {
  padding: 100px 5vw;
  background: var(--white);
  position: relative;
}
#why::before{
  content:'';
  position:absolute;
  top:0;left:5vw;right:5vw;
  height:1px;
  background:var(--border);
}
.why-wrap {
  max-width: 1200px;
  margin: 0 auto;
}
.section-head {
  margin-bottom: 56px;
  max-width: 560px;
}
.section-head h2 {
  font-family:'Barlow Condensed',sans-serif;
  font-size: clamp(1.9rem,3vw,2.8rem);
  font-weight: 800;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing:-0.01em;
  margin-bottom: 14px;
}
.section-head p {
  font-size: 15.5px;
  color: #6b7280;
  line-height: 1.68;
}
.why-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.why-card {
  background: #fff;
  padding: 40px 36px;
  transition: background .2s, transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.why-card:hover{
  background:#f9faff;
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(11,28,79,0.10);
  z-index: 1;
}
.why-card::after {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s cubic-bezier(.22,1,.36,1);
}
.why-card:hover::after{transform:scaleX(1)}
.why-icon {
  width: 48px; height: 48px;
  margin-bottom: 22px;
  display: flex; align-items:center; justify-content:center;
  transition: transform .3s cubic-bezier(.22,1,.36,1);
}
.why-icon svg { width:100%; height:100%; }
.why-card:hover .why-icon { transform: rotate(-5deg) scale(1.1); }
.why-card h3 {
  font-family:'Barlow Condensed',sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.01em;
  margin-bottom: 10px;
  text-transform: uppercase;
}
.why-card p {
  font-size: 14.5px;
  color: #6b7280;
  line-height: 1.65;
}

/* ─── SERVICES ───────────────────────────── */
#services {
  padding: 100px 5vw;
  background: var(--off);
  position:relative;
}
#services::before{
  content:'';
  position:absolute;
  top:0;left:5vw;right:5vw;
  height:1px;
  background:var(--border);
}
.services-wrap { max-width: 1200px; margin: 0 auto; }
.services-row {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px;
}
.svc-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 44px 36px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: box-shadow .3s, transform .3s cubic-bezier(.22,1,.36,1), border-color .3s;
  position: relative;
  overflow: hidden;
}
.svc-card::before {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.svc-card:hover::before { transform:scaleX(1); }
.svc-card::after {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%, rgba(240,180,41,0.04) 0%, transparent 70%);
  opacity:0;
  transition:opacity .3s;
}
.svc-card:hover::after { opacity:1; }
.svc-card:hover{
  box-shadow: 0 16px 48px rgba(11,28,79,0.12);
  transform: translateY(-5px);
  border-color: rgba(240,180,41,0.3);
}
.svc-icon-wrap {
  width: 64px; height: 64px;
  margin-bottom: 26px;
  display: flex; align-items:center; justify-content:center;
  border-radius: 2px;
  background: var(--off);
  border: 1px solid var(--border);
  transition: background .3s, border-color .3s, transform .3s cubic-bezier(.22,1,.36,1);
}
.svc-card:hover .svc-icon-wrap {
  background: var(--navy);
  border-color: var(--navy);
  transform: rotate(5deg) scale(1.08);
}
.svc-icon-wrap img { width:40px;height:40px;object-fit:contain; }
.svc-icon-fallback { font-size: 28px; }
.svc-card h3 {
  font-family:'Barlow Condensed',sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.02em;
  margin-bottom: 10px;
  text-transform: uppercase;
}
.svc-card p { font-size:14.5px;color:#6b7280;line-height:1.65; }

/* ─── PARTNERS ───────────────────────────── */
#partners {
  padding: 80px 5vw;
  background: #fff;
  border-top: 1px solid var(--border);
  overflow: hidden;
}
.partners-wrap { max-width: 1200px; margin: 0 auto; }
.partners-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: 32px;
  text-align: center;
}
.partners-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
  border: 1px solid var(--border);
}
.partner-cell {
  flex: 1;
  min-width: 160px;
  padding: 28px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid var(--border);
  transition: background .2s, transform .2s;
  cursor: default;
}
.partner-cell:last-child{border-right:none}
.partner-cell:hover{
  background:var(--off);
  transform: scale(1.04);
}
.partner-cell img {
  max-height: 28px;
  width: auto;
  filter: grayscale(1) opacity(.45);
  transition: filter .3s, transform .3s;
  margin: 0 auto;
}
.partner-cell:hover img{filter:grayscale(0) opacity(1);transform:scale(1.05)}
.partner-text {
  font-family:'Barlow Condensed',sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #9ca3af;
  text-transform: uppercase;
  transition: color .2s, transform .2s;
}
.partner-cell:hover .partner-text{color:var(--navy);transform:scale(1.05)}

/* ─── FOOTER ─────────────────────────────── */
#footer {
  background: var(--navy);
  position: relative;
  overflow: hidden;
}
/* Animated background dots for footer */
#footer::before {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle, rgba(240,180,41,0.04) 1px, transparent 1px);
  background-size: 32px 32px;
  animation: dotDrift 20s linear infinite;
}
@keyframes dotDrift {
  from { background-position: 0 0; }
  to   { background-position: 32px 32px; }
}
.footer-deco {
  width: 100%;
  line-height: 0;
  display: block;
  position: relative;
  z-index: 1;
}
.footer-deco img{
  width:100%;
  opacity:.45;
  display:block;
}
.footer-main {
  padding: 60px 5vw 0;
  position: relative;
  z-index: 1;
}
.footer-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1.5fr 1fr 1.2fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.footer-logo-col img {
  height: 38px;
  width: auto;
  filter: brightness(0) invert(1);
  margin-bottom: 16px;
  transition: filter .2s;
}
.footer-logo-col img:hover { filter: brightness(0) invert(1) drop-shadow(0 0 8px var(--gold)); }
.footer-tagline {
  font-size: 13.5px;
  color: rgba(255,255,255,0.45);
  line-height: 1.65;
  max-width: 240px;
}
.fc-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
  margin-bottom: 18px;
}
.fc-list li{margin-bottom:11px}
.fc-list li, .fc-list li a {
  font-size: 13.5px;
  color: rgba(255,255,255,0.60);
  line-height: 1.5;
  transition: color .15s, transform .15s;
  display: inline-block;
}
.fc-list li a:hover{color:var(--gold);transform:translateX(3px)}
.footer-bottom {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
.footer-copy { font-size:12.5px;color:rgba(255,255,255,0.28); }
.footer-member { display:flex;align-items:center;gap:10px; }
.footer-member span { font-size:11px;color:rgba(255,255,255,0.28);text-transform:uppercase;letter-spacing:0.08em; }
.footer-member img { height:22px;width:auto;filter:brightness(0) invert(1);opacity:.45; }
.footer-member-text { font-size:12px;font-weight:700;color:rgba(255,255,255,0.40);letter-spacing:0.06em;text-transform:uppercase; }

/* ─── COUNTER ANIMATION ──────────────────── */
.count-up { display: inline-block; }

/* ─── PROGRESS BAR (for stats) ──────────── */
.stat-bar {
  height: 2px;
  background: rgba(255,255,255,0.1);
  border-radius: 1px;
  margin-top: 10px;
  overflow: hidden;
}
.stat-bar-fill {
  height: 100%;
  background: var(--gold);
  border-radius: 1px;
  width: 0;
  transition: width 1.5s cubic-bezier(.22,1,.36,1);
}
.stat-item.visible .stat-bar-fill { width: var(--fill); }

/* ─── PULSE DOTS (hero) ──────────────────── */
.pulse-dot {
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gold);
}
.pulse-dot::before, .pulse-dot::after {
  content:'';
  position:absolute;
  inset:-4px;
  border-radius:50%;
  border:2px solid var(--gold);
  animation: pulseDot 2s ease-out infinite;
}
.pulse-dot::after { animation-delay: 0.6s; }
@keyframes pulseDot {
  from { transform:scale(1); opacity:1; }
  to   { transform:scale(3); opacity:0; }
}

/* ─── TYPEWRITER ─────────────────────────── */
.typewriter {
  border-right: 2px solid var(--gold);
  animation: blink 0.8s step-end infinite;
  display: inline;
}
@keyframes blink {
  0%,100% { border-color: var(--gold); }
  50%      { border-color: transparent; }
}

/* ─── RESPONSIVE ─────────────────────────── */
@media(max-width:1024px){
  .about-wrap{grid-template-columns:1fr;gap:52px}
  .about-media::before{display:none}
  .about-pill{bottom:-14px;right:-10px}
  .why-grid{grid-template-columns:1fr 1fr}
  .services-row{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .stats-inner{grid-template-columns:1fr 1fr}
  .partners-row{flex-wrap:wrap}
  .partner-cell{min-width:140px;border-bottom:1px solid var(--border)}
}
@media(max-width:768px){
  .nav-links { display: none; }
  .nav-burger { display: flex; }
  #nav-mobile { display: block; }
}
@media(max-width:640px){
  #nav{padding:0 20px}
  #hero{min-height:100svh}
  .hero-inner{padding:0 20px;padding-top:72px}
  .hero-inner h1{font-size:2.4rem}
  #stats{padding:0 20px}
  .stats-inner{grid-template-columns:1fr 1fr}
  .stat-item{padding:24px 20px}
  #about,#why,#services,#partners{padding:64px 20px}
  .why-grid{grid-template-columns:1fr}
  .why-card{padding:32px 24px}
  .services-row{grid-template-columns:1fr}
  .footer-main{padding:44px 20px 0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;padding:20px 0}
  .partners-row{flex-direction:column}
  .partner-cell{width:100%;border-right:none}
}