@import url("https://fonts.googleapis.com/css2?family=Sora:wght@300;400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap");

:root {
  --navy:  #1B2A4A;
  --blue:  #2563A8;
  --teal:  #0EA5C0;
  --teal2: #0C7A90;
  --light: #F0F4F8;
  --gray1: #64748B;
  --gray2: #CBD5E1;
  --gray3: #E8EEF4;
  --white: #FFFFFF;
  --text:  #1E293B;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'DM Sans', sans-serif; background: var(--white); color: var(--text); overflow-x: hidden; }

/* ── REVEAL ── */
.reveal, .reveal-left, .reveal-right {
  opacity: 0; transition: opacity .7s ease, transform .7s ease;
}
.reveal       { transform: translateY(36px); }
.reveal-left  { transform: translateX(-48px); }
.reveal-right { transform: translateX(48px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity: 1; transform: none; }
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s}
.d4{transition-delay:.32s} .d5{transition-delay:.40s}

/* ── PROGRESS ── */
#progress { position:fixed; top:0; left:0; height:3px; background:var(--teal); z-index:999; width:0%; transition:width .1s; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:60px; display:flex; align-items:center; padding:0 5%;
  justify-content:space-between;
  background:rgba(27,42,74,.94); backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(14,165,192,.2);
}
.nav-brand { font-family:'Sora',sans-serif; font-weight:800; font-size:18px; color:var(--teal); }
.nav-links  { display:flex; gap:24px; }
.nav-links a {
  font-size:11px; color:rgba(255,255,255,.6); text-decoration:none;
  letter-spacing:.04em; text-transform:uppercase; transition:color .2s;
}
.nav-links a:hover { color:var(--teal); }
@media(max-width:680px){ .nav-links { display:none; } }

/* ── SECTION ── */
section { width:100%; padding:96px 7% 72px; }
.section-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(14,165,192,.12); border:1px solid rgba(14,165,192,.3);
  color:var(--teal); font-size:11px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:6px 16px; border-radius:40px; margin-bottom:20px;
}
.section-tag::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--teal); }
h2.section-title {
  font-family:'Sora',sans-serif; font-weight:800;
  font-size:clamp(28px,4vw,50px); color:var(--navy);
  line-height:1.1; margin-bottom:16px;
}
h2.section-title.light { color:var(--white); }
.section-lead { font-size:16px; color:var(--gray1); line-height:1.7; max-width:600px; margin-bottom:48px; }
.section-lead.light { color:rgba(255,255,255,.68); }
.teal { color:var(--teal); }

/* ── HERO ── */
#hero {
  min-height:100vh; background:var(--navy);
  display:flex; align-items:center; padding:80px 7%;
  position:relative; overflow:hidden;
}
.hero-orb1 { position:absolute; right:-80px; top:-100px; width:560px; height:560px; border-radius:50%; background:radial-gradient(circle,rgba(37,99,168,.3) 0%,transparent 70%); pointer-events:none; }
.hero-orb2 { position:absolute; right:100px; bottom:-60px; width:300px; height:300px; border-radius:50%; background:radial-gradient(circle,rgba(14,165,192,.18) 0%,transparent 70%); pointer-events:none; }
.hero-bar  { position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--teal); }
.hero-content { max-width:680px; position:relative; z-index:1; }
.hero-pill {
  display:inline-block; background:var(--teal); color:#fff;
  font-family:'Sora',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:.2em; padding:7px 20px; border-radius:4px;
  margin-bottom:28px; text-transform:uppercase;
}
.hero-h1 {
  font-family:'Sora',sans-serif; font-weight:800;
  font-size:clamp(40px,6vw,76px); color:var(--white);
  line-height:1.0; margin-bottom:22px;
}
.hero-h1 em { color:var(--teal); font-style:normal; }
.hero-sub { font-size:18px; color:rgba(255,255,255,.68); margin-bottom:40px; line-height:1.6; }
.hero-tags { display:flex; gap:12px; flex-wrap:wrap; }
.hero-tag {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8); font-size:13px; padding:8px 18px; border-radius:40px;
}
.hero-scroll {
  position:absolute; bottom:38px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  color:rgba(255,255,255,.35); font-size:10px; letter-spacing:.1em;
  cursor:pointer; animation:bounce 2.2s infinite;
}
.hero-scroll::after { content:'↓'; font-size:20px; color:var(--teal); }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* ── DIAGNÓSTICO ── */
#diagnostico { background:var(--light); }
.diag-banner {
  background:var(--navy); border-radius:10px; padding:20px 32px;
  margin-bottom:44px; font-family:'Sora',sans-serif; font-weight:700;
  font-size:clamp(14px,1.5vw,17px); color:var(--white);
  text-align:center; line-height:1.6; border-left:5px solid var(--teal);
}
.diag-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; }
@media(max-width:640px){ .diag-grid { grid-template-columns:1fr; } }
.diag-col-title {
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:17px; color:var(--navy); margin-bottom:24px;
  display:flex; align-items:center; gap:10px;
}
.diag-col-title::after { content:''; flex:1; height:2px; background:var(--gray2); }
.diag-item { display:flex; gap:14px; margin-bottom:20px; }
.diag-accent { width:4px; min-width:4px; border-radius:2px; margin-top:3px; }
.diag-item strong { display:block; font-size:14px; font-weight:600; color:var(--navy); margin-bottom:3px; }
.diag-item span   { font-size:13px; color:var(--gray1); line-height:1.5; }

/* ── EQUIPO ── */
#quienes { background:var(--white); }
.team-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
@media(max-width:900px){ .team-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .team-grid { grid-template-columns:1fr; max-width:380px; } }
.person-card {
  background:var(--white); border:1px solid var(--gray2);
  border-radius:16px; overflow:hidden;
  box-shadow:0 8px 36px rgba(27,42,74,.09);
  display:flex; flex-direction:column; align-items:center;
  padding-bottom:28px; transition:transform .25s, box-shadow .25s;
}
.person-card:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(27,42,74,.14); }
.person-card-top { height:6px; width:100%; background:var(--teal); }
.person-photo-wrap {
  width:150px; height:150px; border-radius:50%;
  overflow:hidden; margin:26px auto 18px;
  border:4px solid var(--teal);
  box-shadow:0 6px 28px rgba(14,165,192,.2);
}
.person-photo { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.person-name {
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:17px; color:var(--navy); text-align:center;
  margin-bottom:14px; padding:0 18px; line-height:1.3;
}
.person-creds { display:flex; flex-direction:column; gap:7px; align-items:center; padding:0 18px; }
.cred       { font-size:12.5px; color:var(--gray1); text-align:center; line-height:1.4; }
.cred.badge {
  background:var(--gray3); border-radius:30px;
  padding:4px 14px; font-weight:600; color:var(--blue); font-size:11.5px;
}
.cred.years { font-weight:600; color:var(--navy); font-size:12px; }

/* ── CLIENTES ── */
#clientes { background:var(--navy); }
.client-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px; margin-bottom:44px;
}
@media(max-width:700px){ .client-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:420px){ .client-grid { grid-template-columns:repeat(2,1fr); } }
.client-pill {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.15);
  border-radius:8px; padding:13px 8px; text-align:center;
  font-weight:700; font-size:12.5px; color:var(--white);
  position:relative; overflow:hidden;
  transition:background .2s, border-color .2s;
}
.client-pill:hover { background:rgba(14,165,192,.18); border-color:var(--teal); }
.client-pill::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:3px; background:var(--teal);
  transform:scaleX(0); transition:transform .3s; transform-origin:left;
}
.client-pill:hover::after { transform:scaleX(1); }
.testimonial {
  background:rgba(255,255,255,.06); border:1px solid rgba(14,165,192,.3);
  border-radius:12px; padding:28px 32px;
  display:flex; gap:18px; align-items:flex-start;
  border-left:5px solid var(--teal);
}
.quote-mark { font-family:'Sora',sans-serif; font-size:60px; color:var(--teal); line-height:.6; flex-shrink:0; }
.quote-text { font-size:15px; color:rgba(255,255,255,.85); font-style:italic; line-height:1.7; margin-bottom:10px; }
.quote-attr { font-size:12px; color:var(--teal); font-weight:600; letter-spacing:.04em; }

/* ── PILARES ── */
#pilares { background:var(--light); }
.pilares-grid {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
}
@media(max-width:1100px){ .pilares-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:680px){  .pilares-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:420px){  .pilares-grid { grid-template-columns:1fr; } }
.pilar-card {
  background:var(--white); border-radius:12px;
  border:1px solid var(--gray2);
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  padding:24px 18px;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.pilar-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(27,42,74,.11); }
.pilar-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--teal); }
.pilar-num   { font-family:'Sora',sans-serif; font-weight:700; font-size:11px; color:var(--teal); margin-bottom:14px; letter-spacing:.08em; }
.pilar-icon  { font-size:26px; margin-bottom:14px; }
.pilar-title { font-family:'Sora',sans-serif; font-weight:700; font-size:14px; color:var(--navy); margin-bottom:9px; line-height:1.3; }
.pilar-desc  { font-size:13px; color:var(--gray1); line-height:1.55; }

/* ── PROCESO ── */
#proceso { background:var(--white); }
.proceso-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
@media(max-width:720px){ .proceso-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:440px){ .proceso-grid { grid-template-columns:1fr; } }
.paso-card {
  background:var(--gray3); border:1px solid var(--gray2);
  border-radius:12px; padding:26px 22px;
  position:relative; overflow:hidden;
  transition:background .2s;
}
.paso-card:hover { background:var(--white); }
.paso-card::before { content:''; position:absolute; top:0; left:0; bottom:0; width:4px; background:var(--teal); }
.paso-num   { font-family:'Sora',sans-serif; font-weight:800; font-size:30px; color:var(--teal); margin-bottom:7px; padding-left:14px; }
.paso-title { font-family:'Sora',sans-serif; font-weight:700; font-size:15px; color:var(--navy); margin-bottom:7px; padding-left:14px; }
.paso-desc  { font-size:13px; color:var(--gray1); line-height:1.55; padding-left:14px; }

/* ── CASOS ── */
.caso-section { background:var(--white); }
.caso-section.bg-alt { background:var(--light); }
.caso-inner {
  display:grid; grid-template-columns:1fr 1.5fr; gap:48px; align-items:start;
}
@media(max-width:820px){ .caso-inner { grid-template-columns:1fr; } }
.caso-kpis { display:flex; flex-direction:column; gap:12px; margin-bottom:28px; }
.kpi-card {
  background:var(--navy); border-radius:10px; overflow:hidden;
  box-shadow:0 6px 24px rgba(27,42,74,.18);
  display:flex; align-items:center;
}
.kpi-bar-left { width:5px; align-self:stretch; background:var(--teal); flex-shrink:0; }
.kpi-content  { padding:13px 16px 13px 14px; }
.kpi-value    { font-family:'Sora',sans-serif; font-weight:800; font-size:26px; color:var(--teal); line-height:1; }
.kpi-label    { font-size:12px; color:rgba(255,255,255,.7); margin-top:4px; line-height:1.3; }
.antes-box    { background:var(--gray3); border:1px solid var(--gray2); border-radius:10px; padding:20px 22px; }
.antes-title  { font-family:'Sora',sans-serif; font-weight:700; font-size:14px; color:var(--navy); margin-bottom:12px; }
.antes-item   { font-size:13px; color:var(--text); margin-bottom:7px; display:flex; gap:10px; line-height:1.4; }
.antes-item::before { content:'•'; color:var(--teal); flex-shrink:0; }
.chart-wrap {
  background:var(--white); border:1px solid var(--gray2);
  border-radius:12px; padding:22px;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
}
.chart-title { font-family:'Sora',sans-serif; font-weight:600; font-size:14px; color:var(--navy); margin-bottom:16px; }
.bar-chart-outer { display:flex; flex-direction:column; gap:7px; }
.bar-row  { display:flex; align-items:center; gap:10px; }
.bar-lbl  { font-size:10px; color:var(--gray1); width:32px; text-align:right; flex-shrink:0; }
.bar-bg   { flex:1; height:26px; background:var(--gray3); border-radius:4px; overflow:hidden; }
.bar-fill {
  height:100%; border-radius:4px;
  background:linear-gradient(90deg,var(--blue),var(--teal));
  display:flex; align-items:center; justify-content:flex-end; padding-right:8px;
  transition:width 1.2s cubic-bezier(.25,.46,.45,.94);
}
.bar-val { font-size:10px; font-weight:700; color:var(--white); white-space:nowrap; }

/* ── RECURSOS ── */
#recursos { background:var(--navy); }
.recursos-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media(max-width:640px){ .recursos-grid { grid-template-columns:1fr; } }
.recurso-card {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:12px; padding:26px 22px;
  display:flex; gap:16px;
  position:relative; overflow:hidden;
  transition:background .2s, border-color .2s;
}
.recurso-card:hover { background:rgba(14,165,192,.1); border-color:rgba(14,165,192,.4); }
.recurso-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--teal); }
.recurso-icon { width:50px; height:50px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:22px; background:rgba(255,255,255,.1); }
.recurso-title { font-family:'Sora',sans-serif; font-weight:700; font-size:15px; color:var(--white); margin-bottom:7px; }
.recurso-desc  { font-size:13px; color:rgba(255,255,255,.62); line-height:1.6; }

/* ── ESCALADA ── */
#escalada { background:var(--navy); padding-top:0; }
.escalada-inner { background:#101e35; border-radius:16px; padding:44px; }
.escalada-sub   { font-size:14px; color:rgba(255,255,255,.5); font-style:italic; margin-bottom:32px; }
.tiers { display:flex; flex-direction:column; gap:11px; }
.tier {
  border-radius:8px; padding:15px 22px;
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:clamp(11px,1.2vw,14px);
  color:#fff; text-align:center;
  transition:filter .2s, transform .2s; cursor:default;
}
.tier:hover { filter:brightness(1.15); transform:scale(1.01); }
.tier-1 { background:#1E3A5F; width:38%; margin:0 auto; }
.tier-2 { background:#1A5298; width:54%; margin:0 auto; }
.tier-3 { background:var(--blue);  width:70%; margin:0 auto; }
.tier-4 { background:var(--teal2); width:84%; margin:0 auto; }
.tier-5 { background:var(--teal);  width:100%; }
.escalada-axis { display:flex; justify-content:space-between; font-size:11px; color:rgba(255,255,255,.3); font-style:italic; margin-top:18px; }

/* ── ECONÓMICA ── */
#economica { background:var(--navy); }
.eco-banner {
  background:var(--teal); border-radius:10px;
  padding:18px 28px; text-align:center;
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:clamp(13px,1.5vw,16px); color:#fff; line-height:1.55; margin-bottom:36px;
}
.opciones {
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  align-items:stretch;
}
@media(max-width:680px){ .opciones { grid-template-columns:1fr; } }
.opcion {
  background:var(--white); border-radius:14px; overflow:hidden;
  box-shadow:0 10px 40px rgba(0,0,0,.2);
  display:flex; flex-direction:column;   /* ← columna para stretch */
}
.opcion-head {
  padding:16px 22px; text-align:center;
  font-family:'Sora',sans-serif; font-weight:700;
  font-size:13px; color:#fff; letter-spacing:.1em; text-transform:uppercase;
  flex-shrink:0;
}
.op1-head { background:var(--teal); }
.op2-head { background:var(--blue); }
.opcion-body {
  padding:26px 26px; flex:1;
  display:grid;
  grid-template-rows:auto auto auto auto 1fr;
  gap:0;
}
.op-title  { font-family:'Sora',sans-serif; font-weight:700; font-size:17px; color:var(--navy); margin-bottom:12px; }
.op-text   { font-size:13.5px; color:var(--text); line-height:1.7; margin-bottom:12px; }
.op-hl     { font-weight:700; color:var(--teal2); }
.op-price  { font-family:'Sora',sans-serif; font-weight:800; font-size:28px; color:var(--blue); margin-bottom:10px; }
.op-fine   { font-size:12px; color:var(--gray1); font-style:italic; margin-bottom:12px; }
.op-hr     { border:none; border-top:1px solid var(--gray2); margin:12px 0; }
.op-spacer { flex:1; }
.op-label  { font-size:10px; font-weight:700; color:var(--gray1); letter-spacing:.12em; text-transform:uppercase; margin-bottom:6px; }
.op-price-block {
  display:flex; flex-direction:column;
  background:var(--gray3); border-radius:10px;
  padding:16px 18px; margin:14px 0;
  gap:4px;
}
.op-price-tag  { font-size:11px; font-weight:600; color:var(--gray1); letter-spacing:.06em; text-transform:uppercase; }
.op-price      { font-family:'Sora',sans-serif; font-weight:800; font-size:34px; color:var(--blue); line-height:1.1; }
.op-price.op-price-teal { color:var(--teal2); }
.op-price-sub  { font-size:12px; color:var(--gray1); }
.op-badge  {
  border-radius:8px; padding:12px 16px; text-align:center;
  font-family:'Sora',sans-serif; font-weight:700; font-size:13px; margin-top:auto;
}
.badge-dark { background:var(--navy); color:var(--teal); }
.badge-teal { background:var(--teal); color:#fff; }

/* ── FOOTER ── */
footer {
  background:#0d1828; padding:44px 7%;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
}
.footer-brand    { font-family:'Sora',sans-serif; font-weight:800; font-size:22px; color:var(--teal); }
.footer-tagline  { font-size:13px; color:var(--gray1); margin-top:5px; }
.footer-url      { font-size:14px; color:rgba(255,255,255,.35); }