:root{
  --brand:#0f4c81;
  --brand-dark:#0a3457;
  --accent:#1ec8a5;
  --accent-dark:#13997c;
  --ink:#0f172a;
  --ink-strong:#0b1221;
  --ink-soft:#1f2937;
  --muted:#64748b;
  --muted-2:#e2e8f0;
  --bg:#f5f7fb;
  --surface:#ffffff;
  --surface-soft:#f0f4fb;
  --surface-elevated:#ffffff;
  --line:rgba(15,36,68,.12);
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-heading:"Sora","Inter",system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;border-radius:inherit}

.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section{padding:78px 0}
.section.alt{background:var(--surface-soft)}
.lead{color:var(--muted);font-size:1.05rem}

/* ===== Focus ===== */
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
input:focus-visible,
textarea:focus-visible{
  outline:3px solid rgba(15,76,129,.25);
  outline-offset:3px;
  border-radius:12px;
}

/* ===== Topbar ===== */
.topbar{
  background:var(--brand-dark);
  color:#fff;
  font-size:.85rem;
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 20px;
}
.topbar-tag{
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.topbar-contact{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.85);
}
.topbar-contact a{color:#fff;font-weight:600}
.topbar .separator{opacity:.4}

/* ===== Header & navigation ===== */
.header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(15,36,68,.05);
  backdrop-filter:blur(12px);
  box-shadow:none;
}
.header.is-scrolled{box-shadow:0 10px 26px rgba(15,36,68,.12)}
#scroll-progress{
  position:absolute;
  left:0;
  bottom:0;
  height:3px;
  width:0;
  background:linear-gradient(90deg,var(--accent),var(--brand));
  box-shadow:0 6px 18px rgba(20,158,135,.2);
  transition:width .25s ease;
  pointer-events:none;
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:118px;
  gap:32px;
}
.brand{
  display:flex;
  align-items:center;
  gap:16px;
  font-weight:800;
  letter-spacing:.02em;
  color:var(--brand-dark);
}
.logo{height:110px;width:auto}
.brand span{
  display:flex;
  flex-direction:column;
  line-height:1;
  text-align:left;
}
.brand span strong{font-size:1.12rem;color:var(--brand-dark)}
.brand span small{font-size:1rem;color:var(--brand)}

.menu{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  font-weight:600;
  font-size:1rem;
}
.menu a{
  position:relative;
  color:var(--ink-soft);
  padding:6px 0;
  transition:color .2s ease;
}
.menu a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:100%;
  height:2px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s ease;
}
.menu a:hover{color:var(--brand)}
.menu a:hover::after,
.menu a.active::after{transform:scaleX(1)}
.menu .btn{margin-left:16px}
.menu .btn::after{display:none}

.nav-toggle{
  display:none;
  background:none;
  border:0;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  color:var(--brand);
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.5rem;
  border-radius:999px;
  border:2px solid transparent;
  font-weight:700;
  font-size:1rem;
  transition:all .25s ease;
  cursor:pointer;
}
.btn-primary{
  background:var(--brand);
  color:#fff;
  border-color:var(--brand);
  box-shadow:0 12px 28px rgba(15,76,129,.22);
}
.btn-primary:hover{
  background:var(--brand-dark);
  border-color:var(--brand-dark);
}
.btn-secondary{
  background:#fff;
  color:var(--brand);
  border-color:var(--muted-2);
  box-shadow:0 10px 24px rgba(15,36,68,.12);
}
.btn-secondary:hover{
  border-color:var(--brand);
  color:var(--brand-dark);
}
.btn-outline{
  background:transparent;
  color:inherit;
  border-color:currentColor;
  box-shadow:none;
}
.btn-outline:hover{
  background:rgba(255,255,255,.12);
}
.btn-secondary.btn-outline{
  color:#fff;
  border-color:rgba(255,255,255,.6);
  box-shadow:none;
}
.btn-secondary.btn-outline:hover{
  border-color:#fff;
  background:rgba(255,255,255,.16);
}

/* ===== Hero ===== */
.hero {
  position: relative;
  overflow: hidden;
  color: #fff;
}

.hero-vexa {
  background: linear-gradient(135deg, #0f172a 0%, #0f4c81 55%, #155e75 100%);
}

.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  filter: brightness(0.45) saturate(1.05); 
}

.hero-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(
      120deg,
      rgba(9, 12, 22, 0.88) 0%,
      rgba(9, 12, 22, 0.78) 40%,
      rgba(9, 12, 22, 0.55) 70%,
      transparent 95%
    ),
    radial-gradient(circle at 18% 28%, rgba(30, 200, 165, 0.32), transparent 52%),
    radial-gradient(circle at 80% 18%, rgba(125, 211, 252, 0.28), transparent 58%);
  opacity: 0.85;
  mix-blend-mode: screen;
  z-index: 1;
}

/* === Distribución y Altura (CORRECCIÓN CLAVE: Altura) === */
.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;  
  min-height: calc(100vh - 100px); /* Ajusta la altura para descontar el header */
  padding: 100px 6vw 60px; /* Reducimos el padding superior para ahorrar espacio */
  gap: 40px; /* Reducimos el espacio entre el texto y las estadísticas */
  position: relative;
  z-index: 3;
}

/* === Bloque principal de texto === */
.hero-text {
  max-width: 900px; 
  width: 100%;
  background: rgba(15, 35, 70, 0.92); 
  border-radius: 28px;
  padding: 40px 50px;
  box-shadow: 0 24px 50px rgba(9, 25, 42, 0.65); 
  line-height: 1.5; /* Ligeramente más compacto */
  color: #eaf3ff;
  backdrop-filter: blur(8px);
  text-align: center;
}

/* Título principal (AJUSTE DE TAMAÑO ADICIONAL) */
.hero-text h1 {
  font-family: var(--font-heading);  font-size: clamp(2.2rem, 3.5vw + 0.5rem, 3rem); 
  line-height: 1.2; /* Más compacto */
  margin-bottom: 20px; /* Menos margen */
  color: #ffffff;
  font-weight: 800;
}

.hero-text h1 .highlight {
  color: var(--accent);
}

/* Párrafo */
.hero-text p {
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: rgba(230, 240, 255, 0.9);
  margin-bottom: 25px; /* Menos margen */
  max-width: 100%; 
}

/* === Bloque de estadísticas (Optimizamos los márgenes) === */
.hero-stats-box {
  width: 100%;
  max-width: 1000px;
}

.hero-stats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: row; 
  gap: 16px; /* Reducimos el espacio entre las tarjetas */
  justify-content: center; 
}

.hero-stats li {
  flex: 1 1 180px;
  text-align: center;
  background: rgba(255, 255, 255, 0.1); 
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 16px;
  padding: 20px 15px; /* Menor padding */
  box-shadow: 0 10px 25px rgba(10, 52, 87, 0.3); 
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  min-width: 160px; 
}

.hero-stats li:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(10, 52, 87, 0.45);
}

.hero-stats strong {
  font-family: var(--font-heading);
  font-size: 1.6rem; 
  font-weight: 800;
  display: block;
  margin-bottom: 4px;
}

.hero-stats span {
  font-size: 0.9rem;
  line-height: 1.2;
  color: rgba(255, 255, 255, 0.85);
  display: block;
}

/* ===== Sections & layout ===== */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 14px;
  border-radius:999px;
  background:rgba(30,200,165,.12);
  color:var(--brand-dark);
  font-size:.9rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.eyebrow::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(30,200,165,.18);
}
.section-header{
  text-align:center;
  margin-bottom:32px;
}
.section-header.align-center{
  margin-left:auto;
  margin-right:auto;
  max-width:760px;
}
.section-header h2,
.section-copy h2{
  font-family:var(--font-heading);
  font-size:clamp(1.8rem,1vw+1.4rem,2.4rem);
  margin:12px 0;
  color:var(--ink-strong);
}
.section-header p{margin:0 auto}
.section-copy{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.section-copy .eyebrow{margin-left:auto;margin-right:auto;}
.section-copy h2{text-align:center;}
.section-copy p{margin:0 0 12px;color:var(--ink-soft)}
.section p{color:var(--ink-soft)}

.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:36px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.card{
  position:relative;
  overflow:hidden;
  background:var(--surface);
  border:1px solid var(--muted-2);
  border-radius:24px;
  padding:28px 24px;
  box-shadow:0 16px 34px rgba(15,36,68,.12);
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.card.shadow{box-shadow:0 22px 48px rgba(15,36,68,.15)}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 56px rgba(15,36,68,.18);
  border-color:rgba(15,76,129,.28);
}
.card::after{
  content:"";
  position:absolute;
  inset:-120% 10% 20% -120%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);
  opacity:0;
  transform:rotate(18deg);
  transition:opacity .4s ease;
}
.card:hover::after{
  opacity:1;
  animation:cardShine 1.2s ease forwards;
}
.cards .card h3{margin-top:0;font-family:var(--font-heading);font-size:1.35rem;color:var(--ink-strong)}
.card-icon{
  width:64px;
  height:64px;
  border-radius:18px;
  background:linear-gradient(135deg,var(--brand),var(--accent));
  display:flex;
  justify-content:center;
  align-items:center;
  color:#fff;
  margin-bottom:18px;
  box-shadow:0 16px 32px rgba(15,76,129,.25);
}
.card-icon svg{width:30px;height:30px;fill:currentColor}

.checklist{list-style:none;padding:0;margin:0}
.checklist li{
  position:relative;
  padding-left:28px;
  margin:12px 0;
  color:var(--ink-soft);
}
.checklist li::before{
  content:"";
  position:absolute;
  left:0;
  top:.45rem;
  width:16px;
  height:16px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(30,200,165,.18);
}

.cards .card ul{margin:0;padding-left:18px;color:var(--ink-soft)}
.cards .card li{margin:6px 0}

/* ===== Sectores ===== */
.sector-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}
.sector-card{display:flex;flex-direction:column;text-align:left;align-items:flex-start;gap:14px;height:100%}
.sector-card ul{margin:0;padding-left:20px;color:var(--ink-soft)}
.sector-card li{margin:6px 0}
.sector-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:52px;
  height:52px;
  border-radius:16px;
  font-size:1.6rem;
  background:linear-gradient(135deg,rgba(15,76,129,.12),rgba(30,200,165,.2));
}

/* ===== Indicadores ===== */
.metrics-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:flex-start}
.metrics-card{display:flex;flex-direction:column;gap:22px}
.metric{display:flex;flex-direction:column;gap:10px}
.metric-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:var(--ink-strong)}
.metric-header strong{font-family:var(--font-heading);font-size:1.2rem;color:var(--brand)}
.progress-track{
  position:relative;
  width:100%;
  height:10px;
  border-radius:999px;
  background:var(--surface-soft);
  border:1px solid rgba(15,36,68,.08);
  overflow:hidden;
}
.progress-bar{
  display:block;
  width:0;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--brand),var(--accent));
  box-shadow:0 10px 20px rgba(15,76,129,.25);
  transition:width .95s ease-out;
}
.metric small{color:var(--muted);font-size:.9rem}

/* ===== Timeline ===== */
.timeline{position:relative;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-top:36px}
.timeline::before{
  content:"";
  position:absolute;
  top:34px;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient(90deg,rgba(15,76,129,.15),rgba(30,200,165,.25));
  z-index:0;
}
.timeline-step{
  position:relative;
  background:var(--surface);
  border:1px solid var(--muted-2);
  border-radius:22px;
  padding:28px 24px;
  box-shadow:0 18px 40px rgba(15,36,68,.14);
  display:flex;
  flex-direction:column;
  gap:12px;
  text-align:left;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  z-index:1;
}
.timeline-step:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 56px rgba(15,36,68,.2);
  border-color:rgba(15,76,129,.28);
}
.timeline-step ul{margin:0;padding-left:20px;color:var(--ink-soft)}
.timeline-step li{margin:4px 0}
.step-index{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--brand),var(--accent));
  color:#fff;
  font-weight:700;
  font-size:1rem;
  box-shadow:0 16px 32px rgba(15,76,129,.25);
}
.timeline-step h3{margin:0;font-family:var(--font-heading);font-size:1.25rem;color:var(--ink-strong)}
.timeline-step p{margin:0;color:var(--ink-soft)}

/* ===== Accordion ===== */
.accordion{
  border-radius:26px;
  border:1px solid var(--muted-2);
  background:var(--surface);
  overflow:hidden;
  box-shadow:0 18px 40px rgba(15,36,68,.12);
}
.acc-item + .acc-item{border-top:1px solid var(--muted-2)}
.acc-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:22px 28px;
  background:none;
  border:0;
  font-family:var(--font-body);
  font-weight:600;
  font-size:1.05rem;
  color:var(--ink);
  cursor:pointer;
  transition:color .2s ease,background .2s ease;
}
.acc-trigger:hover{background:var(--surface-soft)}
.acc-trigger[aria-expanded="true"]{color:var(--brand)}
.acc-icon{
  position:relative;
  width:18px;
  height:18px;
  flex-shrink:0;
}
.acc-icon::before,
.acc-icon::after{
  content:"";
  position:absolute;
  left:0;
  top:50%;
  width:18px;
  height:2px;
  background:var(--brand);
  border-radius:999px;
  transition:transform .2s ease,opacity .2s ease;
}
.acc-icon::after{
  width:2px;
  height:18px;
  left:8px;
  top:0;
}
.acc-trigger[aria-expanded="true"] .acc-icon::after{transform:scaleY(0);opacity:0}

.acc-panel{
  overflow:hidden;
  background:var(--surface-soft);
  transition:max-height .3s ease;
}
.acc-content{padding:0 28px 28px}
.acc-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,320px);
  gap:28px;
  align-items:center;
}
.acc-copy p{margin:0 0 12px;color:var(--ink-soft)}
.acc-copy ul{margin:0;padding-left:20px;color:var(--ink-soft)}
.acc-media img{width:100%;border-radius:20px;height:220px;object-fit:cover;box-shadow:0 18px 40px rgba(15,36,68,.18)}

/* ===== Capacidades & Media ===== */
.card-media-grid{
  margin-top:18px;
  display:grid;
  gap:16px;
}
.card-figure{
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--muted-2);
  box-shadow:0 20px 44px rgba(15,36,68,.16);
}
.card-figure video{
  width:100%;
  height:240px;
  object-fit:cover;
  display:block;
  background:rgba(15,36,68,.12);
}

.contact-card{
  display:flex;
  flex-direction:column;
  gap:22px;
  padding:32px 28px;
  background:var(--surface);
  border:1px solid var(--muted-2);
}
.contact-card > *{position:relative;z-index:1}
.contact-badge{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 14px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--brand-dark);
  background:rgba(30,200,165,.18);
  box-shadow:0 12px 24px rgba(15,76,129,.12);
}
.contact-badge::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 10px rgba(30,200,165,.4);
}
.contact-title{
  margin:0;
  font-family:var(--font-heading);
  font-size:1.45rem;
  color:var(--ink-strong);
}
.contact-subtitle{
  margin:0;
  color:var(--muted);
}
.contact-address{
  margin:0;
  padding:18px 20px;
  border-radius:18px;
  background:rgba(15,76,129,.06);
  display:flex;
  flex-direction:column;
  gap:8px;
  font-style:normal;
  color:var(--ink-strong);
  text-transform:lowercase;
  letter-spacing:.01em;
}
.contact-address span{font-size:1rem}
.contact-address strong{
  text-transform:uppercase;
  letter-spacing:.08em;
}
.contact-address small{
  font-size:.85rem;
  letter-spacing:.04em;
  color:var(--muted);
  text-transform:lowercase;
}
.contact-map{margin-top:0;box-shadow:0 24px 48px rgba(15,36,68,.18);}
.contact-map iframe{border:0;border-radius:18px;height:260px}
.contact-meta{
  display:flex;
  flex-direction:column;
  gap:6px;
  background:rgba(15,76,129,.05);
  border-radius:16px;
  padding:16px 18px;
  border:1px solid rgba(15,76,129,.12);
}
.contact-meta-label{font-weight:600;color:var(--muted);text-transform:none}
.contact-mail{
  font-weight:700;
  color:var(--brand);
  font-size:1.05rem;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.contact-mail::after{
  content:"";
  width:38px;
  height:2px;
  background:var(--accent);
  border-radius:999px;
  transform-origin:left;
}

/* ===== Forms & contacto ===== */
.form{
  background:var(--surface);
  border:1px solid var(--muted-2);
  border-radius:24px;
  padding:28px;
  box-shadow:0 20px 48px rgba(15,36,68,.15);
}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:18px}
label{display:flex;flex-direction:column;font-weight:600;color:var(--ink-soft);gap:8px}
input,textarea{
  font:inherit;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid var(--muted-2);
  background:#fff;
  transition:border .2s ease,box-shadow .2s ease;
  color:var(--ink);
}
textarea{resize:vertical;min-height:140px}
input:focus,textarea:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(15,76,129,.15);
  outline:none;
}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}
.reveal p,
.reveal .checklist li,
.reveal ul li{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease,transform .55s ease;
}
.reveal.is-visible p,
.reveal.is-visible .checklist li,
.reveal.is-visible ul li{opacity:1;transform:none}

.reveal .card,
.reveal .timeline-step{
  opacity:0;
  transform:translateY(28px) scale(.94);
}
.reveal.is-visible .card,
.reveal.is-visible .timeline-step{
  animation:cardPop .72s cubic-bezier(.18,.89,.32,1.28) forwards;
}
.reveal.is-visible .cards .card:nth-child(1),
.reveal.is-visible .sector-grid .card:nth-child(1),
.reveal.is-visible .timeline .timeline-step:nth-child(1){animation-delay:.08s}
.reveal.is-visible .cards .card:nth-child(2),
.reveal.is-visible .sector-grid .card:nth-child(2),
.reveal.is-visible .timeline .timeline-step:nth-child(2){animation-delay:.16s}
.reveal.is-visible .cards .card:nth-child(3),
.reveal.is-visible .sector-grid .card:nth-child(3),
.reveal.is-visible .timeline .timeline-step:nth-child(3){animation-delay:.24s}
.reveal.is-visible .cards .card:nth-child(4),
.reveal.is-visible .sector-grid .card:nth-child(4),
.reveal.is-visible .timeline .timeline-step:nth-child(4){animation-delay:.32s}
.reveal.is-visible .cards .card:nth-child(5){animation-delay:.4s}
.reveal.is-visible .cards .card:nth-child(6){animation-delay:.48s}


/* ===== Footer ===== */
.footer{
  background:#f1f5f9;
  border-top:1px solid rgba(15,36,68,.08);
  padding:28px 0;
  color:var(--muted);
}
.footer-inner{
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content: center;
  text-align: center;
}
.footer .mini{display:flex;gap:18px;font-size:.9rem}
.footer .mini a{color:var(--muted)}
.footer .mini a:hover{color:var(--brand)}

/* ===== Back to top ===== */
#backToTop{
  position:fixed;
  right:18px;
  bottom:18px;
  display:none;
  padding:.75rem .9rem;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  border:0;
  box-shadow:0 14px 32px rgba(30,200,165,.3);
  cursor:pointer;
  z-index:1001;
}
#backToTop.show{display:inline-flex}

/* ===== Keyframes ===== */
@keyframes heroFlow{
  0%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
  100%{background-position:0% 50%;}
}
@keyframes heroOrbDrift{
  0%{transform:translate3d(0,0,0) scale(1);opacity:.7;}
  40%{transform:translate3d(40px,-30px,0) scale(1.06);opacity:.85;}
  80%{transform:translate3d(-30px,20px,0) scale(.98);opacity:.65;}
  100%{transform:translate3d(0,0,0) scale(1);opacity:.7;}
}
@keyframes heroSpark{
  0%{transform:translate3d(0,0,0) scale(.85);opacity:0;}
  10%{opacity:1;}
  45%{transform:translate3d(0,-40px,0) scale(1);opacity:.8;}
  75%{transform:translate3d(0,-70px,0) scale(.9);opacity:.4;}
  100%{transform:translate3d(0,-90px,0) scale(.8);opacity:0;}
}
@keyframes cardPop{
  0%{opacity:0;transform:translateY(28px) scale(.92);}
  55%{opacity:1;transform:translateY(-8px) scale(1.02);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}
@keyframes cardShine{
  0%{transform:translate(-140%,0) rotate(18deg);opacity:0;}
  30%{opacity:.9;}
  100%{transform:translate(120%,0) rotate(18deg);opacity:0;}
}

/* ===== Responsive ===== */

@media(max-width:980px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .nav{height:102px}
  .logo{height:94px}
  .nav-toggle{display:block}
  .menu{
    position:fixed;
    top:calc(102px + 44px);
    right:20px;
    left:20px;
    background:#fff;
    border-radius:20px;
    box-shadow:0 24px 60px rgba(15,36,68,.2);
    padding:24px 24px 28px;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:18px;
    z-index:1100;
  }
  .menu a{font-size:1.05rem;color:var(--ink)}
  .menu.open{display:flex}
  .menu .btn{align-self:stretch;justify-content:center}
  .hero-inner{padding:98px 0 88px}
  .hero-media{flex-direction:column;align-items:center;width:100%}
  .metrics-layout{grid-template-columns:1fr}
}
@media(max-width:780px){
  .topbar-inner{flex-direction:column;align-items:flex-start;gap:6px}
}
@media(max-width:720px){
  .hero-inner{
      padding: 100px 30px 40px; 
      gap: 25px;
  }
  .hero-text {
      max-width: 90%; 
      margin: 0 auto; 
      padding: 25px 20px;
  }
  .hero-text h1 {
      font-size: clamp(1.8rem, 7vw, 2.4rem);
  }
  .hero-stats-box {
      max-width: 90%;
      margin: 0 auto;
  }
  .hero-stats {
      flex-direction: column; 
      gap: 12px;
      min-width: unset;
      width:100%;
  }
  .grid-3{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .sector-grid{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
  .timeline::before{display:none}
}
@media(max-width:560px){
  .topbar{display:none}
  .nav{height:92px}
  .menu{top:92px;right:16px;left:16px}
  .brand span strong{font-size:1.05rem}
  .brand span small{font-size:1rem}
  .logo{height:84px}
}

/* ===== Motion preferences ===== */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
