*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#25335A;--navy2:#25335A;--blue:#25335A;--accent:#3B5A9A;
  --gold:#E9B72D;--white:#fff;--g50:#F8FAFC;--g100:#F1F5F9;
  --g200:#E2E8F0;--g400:#94A3B8;--g600:#475569;--g800:#1E293B;
  --text:#1E293B;--muted:#64748B;
  --rsm:8px;--rmd:16px;--rlg:24px;--rxl:32px;
  --sh1:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 16px rgba(0,0,0,.1),0 2px 4px rgba(0,0,0,.06);
  --sh3:0 20px 40px rgba(0,0,0,.14),0 8px 16px rgba(0,0,0,.08);
  --sh4:0 32px 64px rgba(0,0,0,.18),0 16px 32px rgba(0,0,0,.10);
  --navh:80px;--tr:all .28s cubic-bezier(.4,0,.2,1);
  --btn-pri: linear-gradient(135deg, #25335A, #25335A);
  --btn-pri-hover: linear-gradient(135deg, #3B5A9A, #25335A);
}

body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--text);background:var(--white);
  -webkit-font-smoothing:antialiased;overflow-x:hidden
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
::selection{background:rgba(46,142,255,.2);color:var(--navy)}
::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--g100)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:4px}
.wrap{max-width:1420px;margin:0 auto;padding:0 32px}
section{scroll-margin-top:var(--navh)}
.py{padding:80px 0}
.lbl{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.h2{font-size:clamp(38px,5vw,60px);font-weight:850;line-height:1.05;color:var(--navy);margin-bottom:24px;letter-spacing:-2.2px}
.lead{font-size:19px;line-height:1.7;color:var(--muted);letter-spacing:-0.4px;font-weight:500}

/* NAV */
#nav{
  position:fixed;top:0;left:0;right:0;height:var(--navh);z-index:1000;
  padding:0;background:linear-gradient(180deg,rgba(37,51,90,.96),rgba(37,51,90,.98));
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 12px 30px rgba(0,0,0,.22);transition:var(--tr)
}
#nav.scrolled{
  background:linear-gradient(180deg,rgba(37,51,90,.98),rgba(37,51,90,.99));
  box-shadow:0 16px 34px rgba(0,0,0,.28)
}
#nav.nav-hidden{
  transform:translateY(calc(-100% - 8px));
  box-shadow:none;
}
.nav-in{
  max-width:1420px;margin:0 auto;padding:0 32px;height:100%;
  display:flex;align-items:center;position:relative;
  background:transparent;border:none;border-radius:0;box-shadow:none
}
.nav-brand{display:flex;align-items:center;min-width:max-content}
.nav-logo{display:inline-flex;align-items:center}
.nav-logo img{height:38px;width:auto;flex-shrink:0}
.nav-links{
  display:flex;align-items:center;gap:0px;justify-content:flex-end;
  margin-left:auto;min-width:0;
  margin-right:20px
}
.nav-links a{
  display:inline-flex;align-items:center;justify-content:center;min-height:46px;
  font-size:12.5px;font-weight:600;letter-spacing:0.2px;
  color:rgba(255,255,255,.78);padding:0 12px;border-radius:12px;
  transition:var(--tr);white-space:nowrap
}
.nav-links a:hover,.nav-links a.act{color:#fff;background:rgba(255,255,255,.07)}
.nav-div{display:none}
.nav-r{
  display:flex;align-items:center;gap:8px;flex-shrink:0
}
.nab{
  min-height:44px;padding:0 16px;border-radius:999px;white-space:nowrap;
  transition:var(--tr);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-size:12.5px;font-weight:700;letter-spacing:0.1px;font-family:inherit;border:1px solid transparent;
  box-shadow:none
}
.nab-pur{
  background:rgba(255,255,255,.04);
  color:#fff;border-color:rgba(255,255,255,.14)
}
.nab-pur:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.18);background:rgba(255,255,255,.08);color:#fff}
.nab-blu{
  background:linear-gradient(180deg, var(--blue), var(--navy));
  color:#fff;border-color:rgba(132,181,241,.2);
  box-shadow:0 10px 24px rgba(8,22,47,.2)
}
.nab-blu:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(8,22,47,.28);filter:brightness(1.04);color:#fff}
.nab-out{color:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.18)}
.nab-out:hover{border-color:rgba(255,255,255,.5);color:#fff;background:rgba(255,255,255,.08)}
.nab-firma{
  background:rgba(255,255,255,.04);
  color:#d6ebff;border-color:rgba(101,166,228,.26)
}
.nab-firma:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(8,22,47,.22);
  background:rgba(37,94,166,.16);
  color:#fff
}
.nab-enrol{
  background:rgba(30,77,140,.1);
  color:var(--accent);border-color:rgba(30,77,140,.24)
}
.nab-enrol:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(8,22,47,.22);
  background:rgba(233,183,45,.2);
  color:#ffe5a0
}
.nav-bar{display:none}
.nav-menu-btn{display:none}

/* HERO */
#inicio{position:relative;height:100vh;min-height:680px;overflow:hidden;background:var(--navy)}
.h-slides{position:absolute;inset:0}
.h-slide{
  position:absolute;inset:0;background-size:cover;background-position:center center;
  opacity:0;transition:opacity 1.1s ease
}
.h-slide.on{opacity:1}
.h-slide::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(130deg,rgba(7,18,40,.78) 0%,rgba(17,41,75,.5) 55%,rgba(0,0,0,.18) 100%)
}
.h-over{
  position:relative;z-index:10;height:100%;display:flex;flex-direction:column;
  justify-content:center;padding:calc(var(--navh) + 64px) 32px 96px;
  max-width:1420px;margin:0 auto
}
.h-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(233,183,45,.14);border:1px solid rgba(233,183,45,.38);
  border-radius:20px;padding:6px 14px;font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);
  width:fit-content;margin-bottom:22px
}
.h-badge::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%}
.h-title{
  font-size:clamp(38px,5.4vw,74px);font-weight:900;line-height:0.95;
  letter-spacing:-4.5px;color:#fff;text-shadow:0 10px 40px rgba(0,0,0,0.6);
  margin-bottom:26px;
}
.h-title em{font-style:normal;color:var(--gold)}
.h-sub{font-size:17px;line-height:1.75;color:rgba(255,255,255,.82);max-width:580px;margin-bottom:42px}
/* ═══ VENTAJAS SECTION REFINED ═══ */
#ventajas {
  background: linear-gradient(180deg, #f0f4fb 0%, #e8eef8 100%);
  position: relative;
  overflow: hidden;
}

.ven-unified-bg {
  background: var(--white);
  border-radius: 40px;
  padding: 56px;
  margin-top: 48px;
  box-shadow: 0 8px 40px rgba(15, 30, 70, 0.08);
  border: 1px solid var(--g200);
}

.ven-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}

.ven-card {
  background: #f6f9ff;
  border: 1px solid rgba(46,142,255,0.12);
  border-radius: 24px;
  padding: 36px;
  transition: all 0.4s ease;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.03);
}

.ven-card:hover {
  transform: translateY(-6px);
  border-color: var(--accent);
  box-shadow: 0 16px 40px rgba(46, 142, 255, 0.1);
  background: #fff;
}

.ven-card h3 { color: var(--navy); font-size: 18px; font-weight: 800; margin-bottom: 14px; }
.ven-card p { color: var(--muted); font-size: 14px; line-height: 1.65; }
.ven-card ul { color: var(--muted); font-size: 14px; }
.ven-card li { margin-bottom: 8px; }

.ven-ico {
  width: 46px; height: 46px;
  background: rgba(46,142,255,0.08);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 22px;
  border: 1px solid rgba(46,142,255,0.15);
}

.ven-ico img { height: 24px; filter: none; opacity: 1; }

/* divider between cards and info box */
.ven-info-box {
  margin-top: 24px;
  box-shadow: none;
}

@media (max-width: 900px) {
  .ven-unified-bg { padding: 32px; border-radius: 28px; }
  .ven-grid { grid-template-columns: 1fr; gap: 16px; }
}
.btn-pri{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--blue),var(--accent));
  color:#fff;font-size:14px;font-weight:800;padding:0 28px;min-height:48px;
  border-radius:999px;transition:var(--tr);border:none;cursor:pointer;
  font-family:inherit;box-shadow:0 10px 26px rgba(46,142,255,.34)
}
.btn-pri:hover{box-shadow:0 16px 34px rgba(46,142,255,.42);filter:saturate(1.05)}
.btn-out{
  display:inline-flex;align-items:center;gap:8px;background:transparent;
  color:#fff;font-size:14px;font-weight:700;padding:0 24px;min-height:48px;
  border-radius:999px;border:1.5px solid rgba(255,255,255,.4);
  transition:var(--tr);cursor:pointer;font-family:inherit;
  background:rgba(255,255,255,.03);backdrop-filter:blur(6px)
}
.btn-out:hover{border-color:#fff;background:rgba(255,255,255,.14);box-shadow:0 14px 30px rgba(0,0,0,.18)}
.btn-pri,.btn-out,.btn-trab,.f-sub,.cto-mini,.modal-link,.nab{text-decoration:none;line-height:1.1}
.btn-pri:active,.btn-out:active,.btn-trab:active,.f-sub:active,.cto-mini:active,.modal-link:active,.nab:active{transform:scale(0.96); transition: transform 0.1s cubic-bezier(0.4,0,0.2,1) !important;}
.h-arrow:active{transform:translateX(-50%) scale(0.96) !important; transition: transform 0.1s cubic-bezier(0.4,0,0.2,1) !important;}
.h-dots{
  position:absolute;bottom:38px;z-index:20;display:flex;gap:10px;
  left: max(32px, calc(50% - 710px + 32px));
}
.h-dot{
  width:32px;height:4px;border-radius:2px;background:rgba(255,255,255,.32);
  cursor:pointer;transition:var(--tr);border:none
}
.h-dot.on{background:var(--gold);width:48px}
.h-stats{
  position:absolute;bottom:38px;z-index:20;display:flex;gap:36px;align-items:center;
  right: max(32px, calc(50% - 710px + 32px));
}
.h-stat strong{display:block;font-size:28px;font-weight:800;color:#fff;line-height:1}
.h-stat span{font-size:12px;color:rgba(255,255,255,.62);font-weight:600}
.h-sdiv{width:1px;background:rgba(255,255,255,.2);align-self:stretch}

/* EMPRESA */
#nuestra_empresa{background:var(--white)}
.emp-grid{display:grid;grid-template-columns:1fr 1fr;gap:84px;align-items:center}
.emp-txt h2{font-size:clamp(30px,3.2vw,40px);font-weight:800;line-height:1.16;color:var(--navy);margin-bottom:24px}
.emp-txt h2 em{font-style:normal;color:var(--accent)}
.emp-txt p{font-size:16px;line-height:1.82;color:var(--muted);margin-bottom:16px}
.emp-txt p:last-of-type{margin-bottom:0}
.emp-txt strong{color:var(--navy);font-weight:700}
.emp-img{position:relative;border-radius:var(--rxl);overflow:hidden;box-shadow:var(--sh4)}
.emp-img img{width:100%;height:440px;object-fit:cover}
.emp-bdg{
  position:absolute;bottom:24px;left:24px;
  background:rgba(37,51,90,.88);backdrop-filter:blur(12px);
  border-radius:var(--rmd);padding:14px 18px;border:1px solid rgba(255,255,255,.1)
}
.emp-bdg strong{display:block;font-size:22px;font-weight:800;color:var(--gold);line-height:1}
.emp-bdg span{font-size:11px;color:rgba(255,255,255,.6);font-weight:500}
.emp-cta{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:26px
}
.emp-cta-note{
  font-size:12.5px;line-height:1.6;color:var(--muted);max-width:250px
}
.emp-cta-note strong{display:block;color:var(--navy);font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;margin-bottom:3px}
.btn-trab{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:52px;font-size:14px;font-weight:800;color:var(--navy);border:1px solid rgba(233,183,45,.4);
  border-radius:999px;padding:0 28px;cursor:pointer;background:linear-gradient(135deg,#f3c746,#e0a816);
  font-family:inherit;transition:transform 0.1s cubic-bezier(0.4,0,0.2,1), filter 0.3s ease, box-shadow 0.3s ease;
  box-shadow:0 12px 28px rgba(212,157,31,.25), inset 0 2px 2px rgba(255,255,255,.45);position:relative;overflow:hidden;
  letter-spacing:-0.2px
}
.btn-trab::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(180deg,rgba(255,255,255,.15),rgba(255,255,255,0));
  pointer-events:none
}
.btn-trab svg { stroke: var(--navy); opacity: 0.85; }
.btn-trab:hover{box-shadow:0 16px 36px rgba(212,157,31,.35), inset 0 2px 2px rgba(255,255,255,.55);filter:saturate(1.1) brightness(1.05)}

/* VENTAJAS */
#ventajas{background:var(--g50)}
.ven-hd{text-align:center;max-width:680px;margin:0 auto 64px}
.ven-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:56px}
.ven-card{
  background:var(--white);border-radius:var(--rlg);padding:38px 30px;
  box-shadow:var(--sh1);border:1px solid var(--g200);transition:var(--tr)
}
.ven-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);border-color:rgba(46,142,255,.2)}
.ven-ico{
  width:60px;height:60px;border-radius:var(--rmd);margin-bottom:20px;
  background:linear-gradient(135deg,rgba(30,77,140,.07),rgba(46,142,255,.12));
  display:flex;align-items:center;justify-content:center
}
.ven-ico img{width:30px;height:30px;object-fit:contain}
.ven-card h3{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:12px}
.ven-card p,.ven-card li{font-size:15px;line-height:1.78;color:var(--muted)}
.ven-card ul{list-style:none;margin-top:10px}
.ven-card li{padding:3px 0 3px 16px;position:relative}
.ven-card li::before{content:'·';position:absolute;left:4px;color:var(--gold);font-weight:700}
.ven-box{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--rxl);padding:52px 60px;
  display:grid;grid-template-columns:56px 1fr;gap:36px;align-items:start;
  box-shadow:var(--sh4)
}
.ven-box-ico img{width:52px;height:52px;object-fit:contain}
.ven-box h3{font-size:17px;font-weight:700;color:#fff;margin-bottom:14px}
.ven-box ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 28px}
.ven-box li{font-size:13px;line-height:1.6;color:rgba(255,255,255,.78);padding-left:18px;position:relative}
.ven-box li::before{content:'›';position:absolute;left:0;color:var(--gold);font-size:15px;line-height:1.4}

/* SERVICIOS */
#servicios{background:var(--white)}
.srv-hd{text-align:center;max-width:560px;margin:0 auto 52px}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.srv-card{
  background:var(--g50);border-radius:var(--rlg);padding:36px 30px;
  border:1px solid var(--g200);transition:var(--tr);position:relative;overflow:hidden
}
.srv-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--accent));
  transform:scaleX(0);transform-origin:left;transition:var(--tr)
}
.srv-card:hover::before{transform:scaleX(1)}
.srv-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);background:var(--white)}
.srv-ico{width:48px;height:48px;margin-bottom:18px}
.srv-ico img{width:100%;height:100%;object-fit:contain}
.srv-card h3{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:10px}
.srv-card p{font-size:15px;line-height:1.78;color:var(--muted)}
.srv-list { list-style: none; margin-top: 16px; padding: 0; }
.srv-list li { font-size: 14px; line-height: 1.62; color: var(--muted); padding-left: 22px; position: relative; margin-bottom: 10px; font-weight: 500; }
.srv-list li::before { content: ''; position: absolute; left: 0; top: 8px; width: 6px; height: 6px; background: var(--gold); border-radius: 50%; opacity: 0.8; }

/* REQUISITOS */
#requisitos{background:var(--g50)}
.req-grid{display:grid;grid-template-columns:360px 1fr;gap:72px;align-items:center}
.req-img{border-radius:var(--rxl);overflow:hidden;box-shadow:var(--sh4)}
.req-img img{width:100%;height:480px;object-fit:cover}
.req-logo{margin-bottom:28px}
.req-logo img{height:44px;width:auto}
.req-blk{margin-bottom:28px}
.req-blk h3{
  font-size:14px;font-weight:700;color:var(--navy);
  margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--g200)
}
.req-blk li{font-size:13px;line-height:1.7;color:var(--muted);padding:4px 0 4px 18px;position:relative;list-style:none}
.req-blk li::before{content:attr(data-l);position:absolute;left:0;font-weight:700;color:var(--accent)}
.req-lgs{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:20px;padding-top:18px;border-top:1px solid var(--g200)}
.req-lgs img{height:28px;width:auto;object-fit:contain;opacity:.65;transition:var(--tr)}
.req-lgs a:hover img{opacity:1}

/* FAQ */
#preguntas {
  background: 
    radial-gradient(circle at 10% 20%, rgba(30, 77, 140, 0.03) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(46, 142, 255, 0.04) 0%, transparent 40%),
    var(--g50);
  background-attachment: fixed;
  position: relative;
}

#preguntas::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(var(--g200) 1px, transparent 1px);
  background-size: 32px 32px;
  opacity: 0.3; pointer-events: none;
}

.faq-hd { text-align: center; max-width: 700px; margin: 0 auto 64px; position: relative; z-index: 2; }

.faq-shell {
  max-width: 900px; margin: 0 auto;
  position: relative; z-index: 2;
}

.faq-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }

.faq-item {
  background: var(--white);
  border: 1px solid var(--g200);
  border-radius: 24px;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.03);
}

.faq-item:hover {
  border-color: rgba(46, 142, 255, 0.3);
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08);
  transform: translateY(-4px);
}

.faq-item.open {
  border-color: var(--accent);
  background: var(--white);
  box-shadow: 0 24px 50px rgba(30, 77, 140, 0.12);
}

.faq-q {
  width: 100%; text-align: left; background: none; border: none;
  padding: 20px 24px; display: flex; justify-content: space-between;
  align-items: center; gap: 16px; cursor: pointer;
  font-family: inherit; transition: var(--tr);
}

.faq-copy { display: flex; align-items: center; gap: 18px; min-width: 0; }

.faq-no {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  background: var(--g100); color: var(--blue);
  font-size: 11px; font-weight: 800; transition: var(--tr);
}

.faq-item:hover .faq-no, .faq-item.open .faq-no {
  background: var(--accent); color: var(--white);
}

.faq-title {
  display: block; font-size: 16px; font-weight: 700;
  color: var(--navy); line-height: 1.4; transition: var(--tr);
}

.faq-item.open .faq-title { color: var(--accent); }

.faq-ic {
  width: 30px; height: 30px; border-radius: 50%; border: 1.5px solid var(--g200);
  display: inline-flex; align-items: center; justify-content: center;
  transition: all 0.4s ease; flex-shrink: 0; position: relative;
}

.faq-ic::before, .faq-ic::after {
  content: ''; position: absolute; background: currentColor;
  border-radius: 2px; transition: all 0.4s ease;
}

/* Horizontal line */
.faq-ic::before { width: 14px; height: 2px; }
/* Vertical line */
.faq-ic::after { width: 2px; height: 14px; }

.faq-item:hover .faq-ic { border-color: var(--accent); color: var(--accent); }

.faq-item.open .faq-ic {
  background: var(--accent); border-color: var(--accent);
  color: var(--white); transform: rotate(45deg);
}

.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
.faq-item.open .faq-a { grid-template-rows: 1fr; }

.faq-a-in { overflow: hidden; padding: 0 24px 0 78px; }
.faq-item.open .faq-a-in { padding: 0 24px 20px 78px; border-top: 1px solid var(--g100); margin-top: 0; padding-top: 18px; }

.faq-a p { font-size: 15px; line-height: 1.7; color: var(--g800); margin-bottom: 12px; opacity: 0.9; }
.faq-a p:last-child { margin-bottom: 0; }
.faq-a strong { color: var(--navy); font-weight: 700; }

@media (max-width: 768px) {
  .faq-q { padding: 24px; }
  .faq-copy { gap: 16px; }
  .faq-no { width: 36px; height: 36px; font-size: 11px; }
  .faq-title { font-size: 16px; }
  .faq-a-in { padding: 0 24px 0 76px; }
  .faq-item.open .faq-a-in { padding: 20px 24px 24px 76px; }
}

/* ═══ FAQ REQUISITES GRID ═══ */
.faq-req-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 16px;
}

.faq-req-col strong {
  display: block;
  font-size: 13px;
  color: var(--navy);
  margin-bottom: 12px;
  border-bottom: 1px solid var(--g100);
  padding-bottom: 8px;
}

.faq-req-col ul { list-style: none; padding: 0; margin: 0; }

.faq-req-col li {
  font-size: 13.5px;
  color: var(--g800);
  margin-bottom: 10px;
  display: flex;
  gap: 10px;
  line-height: 1.4;
}

.faq-req-col li span {
  color: var(--accent);
  font-weight: 800;
  font-size: 12px;
}

@media (max-width: 600px) {
  .faq-req-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* OFICINAS */
#oficinas{background:var(--g50)}
.ofi-hd{text-align:center;max-width:620px;margin:0 auto 56px}
.ofi-lay{display:grid;grid-template-columns:1fr 300px;gap:44px;align-items:start}
.ofi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ofi-card{
  background:var(--white);border-radius:var(--rmd);padding:26px;
  border:1px solid var(--g200);box-shadow:var(--sh1);transition:var(--tr)
}
.ofi-card:hover{border-color:rgba(46,142,255,.2);box-shadow:var(--sh2);transform:translateY(-3px)}
.ofi-card h3{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:8px}
.ofi-card p{font-size:14px;line-height:1.7;color:var(--muted)}
.ofi-card .tel{font-size:14px;font-weight:700;color:var(--accent);margin-top:8px}

/* MAPA DE PRESENCIA NACIONAL */
.ofi-pres {
  position: relative;
  max-width: 1140px;
  margin: 64px auto 0;
  display: grid;
  grid-template-columns: 380px 1fr;
  align-items: start;
  gap: 80px;
  min-height: 950px;
}

.chi-map-cont {
  position: relative;
  display: flex;
  justify-content: center;
  height: 900px;
  background: transparent;
  padding: 40px 0;
}

.chi-lines-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
  z-index: 1;
}

/* ═══ INFO ADVANTAGES ULTRA-PREMIUM ═══ */
.ven-info-box {
  margin-top: 64px;
  background: radial-gradient(circle at top left, #25335A, #25335A 80%);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 40px;
  display: flex;
  overflow: hidden;
  box-shadow: 0 50px 100px -20px rgba(0, 0, 0, 0.5);
  position: relative;
  transform: translateZ(0); /* Anti fallback para sangrado de webkit filters en esquinas redondas */
}

.ven-info-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(233, 183, 45, 0.4), transparent);
}

.ven-info-side {
  width: 340px;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  padding: 60px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
  border-radius: 40px 0 0 40px; /* Fuerza el mismo redondeo interior */
}

.ven-info-ico {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--gold), #b38600);
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin-bottom: 28px;
  box-shadow: 0 10px 20px rgba(233, 183, 45, 0.25);
}

.ven-info-ico svg { width: 34px; height: 34px; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2)); }

.ven-info-side h3 {
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -0.5px;
  margin-bottom: 20px;
}

.ven-info-side p {
  font-size: 14.5px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 400;
}

.ven-info-main {
  flex: 1;
  padding: 60px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  position: relative;
  z-index: 1;
}

.ven-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}

.ven-info-item strong {
  display: block;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--gold);
  margin-bottom: 24px;
  opacity: 0.9;
}

.ven-info-item ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ven-info-item li {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 16px;
  padding-left: 28px;
  position: relative;
  line-height: 1.4;
}

.ven-info-item li::before {
  content: '';
  position: absolute;
  left: 0; top: 6px;
  width: 12px; height: 12px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232e8eff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
}

.ven-alert-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 28px;
  padding: 24px 32px;
  display: flex;
  gap: 28px;
  align-items: center;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

.ven-alert-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20%, rgba(46, 142, 255, 0.15), transparent 60%);
  opacity: 0.3;
  transition: opacity 0.5s ease;
}

.ven-alert-card:hover {
  transform: translateY(-5px);
  border-color: rgba(46, 142, 255, 0.5);
  background: rgba(46, 142, 255, 0.06);
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
}

.ven-alert-ico {
  width: 64px;
  height: 64px;
  background: rgba(46, 142, 255, 0.15);
  border: 1.5px solid rgba(46, 142, 255, 0.3);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
  box-shadow: 0 8px 16px rgba(46, 142, 255, 0.2);
  position: relative;
  z-index: 2;
}

.ven-alert-ico svg { width: 32px; height: 32px; filter: drop-shadow(0 0 8px rgba(46, 142, 255, 0.4)); }

.ven-alert-txt { position: relative; z-index: 2; }

.ven-alert-txt h4 {
  font-size: 19px;
  font-weight: 850;
  color: #fff;
  margin-bottom: 4px;
  letter-spacing: -0.2px;
}

.ven-alert-txt p {
  font-size: 14.5px;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.5;
  margin: 0;
}

.badge-new {
  display: inline-block;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 12px;
  background: linear-gradient(135deg, var(--gold), #b38600);
  color: var(--navy);
  border-radius: 8px;
  margin-top: 12px;
  letter-spacing: 0.8px;
  box-shadow: 0 4px 12px rgba(233, 183, 45, 0.3);
  text-transform: uppercase;
}

@media (max-width: 1024px) {
  .ven-info-box { flex-direction: column; border-radius: 32px; }
  .ven-info-side { width: 100%; border-right: none; border-bottom: 1px solid rgba(255, 255, 255, 0.08); padding: 40px; border-radius: 32px 32px 0 0; }
  .ven-info-main { padding: 40px; }
}

@media (max-width: 600px) {
  .ven-info-grid { grid-template-columns: 1fr; gap: 32px; }
  .ven-alert-card { flex-direction: column; text-align: center; padding: 24px; }
  .ven-alert-ico { margin-bottom: 12px; }
  .badge-new { display: block; margin: 8px auto 0; width: fit-content; }
}

.chi-lines-svg path {
  fill: none;
  stroke: var(--gold);
  stroke-width: 1.5;
  opacity: 0.2;
  transition: opacity var(--tr), stroke-width var(--tr);
}

.chi-lines-svg path.act {
  opacity: 0.9;
  stroke-width: 2.5;
}

.chi-silhouette {
  height: 900px;
  width: auto;
  max-width: none;
  opacity: 1;
  filter: drop-shadow(0 4px 25px rgba(0,0,0,.15));
}

.chi-point {
  position: absolute;
  width: 12px;
  height: 12px;
  background: var(--gold);
  border: 2.5px solid var(--white);
  border-radius: 50%;
  box-shadow: 0 0 15px var(--gold);
  z-index: 10;
  cursor: pointer;
  transition: var(--tr);
}

.chi-point::after {
  content: ''; position: absolute; inset: -10px; border-radius: 50%;
  background: var(--gold); opacity: 0; transition: var(--tr);
}

.chi-point:hover, .chi-point.act {
  transform: scale(1.5);
  box-shadow: 0 0 30px var(--gold), 0 0 60px rgba(233,183,45,.4);
}

@keyframes ptPulse {
  0% { transform: scale(1); opacity: 0.8; }
  50% { transform: scale(1.8); opacity: 0; }
  100% { transform: scale(1); opacity: 0; }
}

.chi-point.act::after { animation: ptPulse 1.5s infinite; opacity: 0.4; }

.chi-list {
  display: flex;
  flex-direction: column;
  position: relative;
  height: 900px;
  border-left: 1px solid var(--g200);
}

.chi-branch {
  position: absolute;
  left: -1px;
  width: 100%;
  max-width: 520px;
  padding: 12px 0 12px 48px;
  transition: var(--tr);
  cursor: pointer;
}

.chi-branch::before {
  content: '';
  position: absolute;
  left: -8px;
  top: 22px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--white);
  border: 3.5px solid var(--g200);
  z-index: 5;
  transition: var(--tr);
}

.chi-branch:hover { transform: translateX(8px); }
.chi-branch:hover::before, .chi-branch.act::before { border-color: var(--gold); background: var(--gold); transform: scale(1.3); }

.chi-branch h4 {
  font-size: 16px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 4px;
  transition: var(--tr);
}

.chi-branch:hover h4, .chi-branch.act h4 { color: var(--accent); }

.chi-branch p { font-size: 13.5px; line-height: 1.5; color: var(--muted); margin-bottom: 2px; }
.chi-branch .tel { font-size: 13.5px; font-weight: 700; color: var(--accent); margin-top: 6px; }

@media (max-width: 900px) {
  .ofi-pres { grid-template-columns: 1fr; min-height: auto; gap: 40px; }
  .chi-map-cont { display: none; }
  .chi-list { border-left: none; height: auto; padding-bottom: 0; }
  .chi-branch { position: static; padding-left: 0; margin-bottom: 32px; }
  .chi-branch::before { display: none; }
}
.ofi-card .tel a{color:inherit}
.ofi-card .tel a:hover{text-decoration:underline}
.ofi-map{border-radius:var(--rlg);overflow:hidden;box-shadow:var(--sh2);border:1px solid var(--g200);height:320px;position:sticky;top:calc(var(--navh) + 20px)}
.ofi-map iframe{width:100%;height:100%;border:none}

/* CONTACTO */
#contacto{background:linear-gradient(135deg,#41588E 0%,#324878 100%);position:relative;overflow:hidden}
#contacto::before{content:'';position:absolute;top:-80px;right:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(46,142,255,.07) 0%,transparent 70%);pointer-events:none}
#contacto::after{content:'';position:absolute;bottom:-80px;left:-80px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(233,183,45,.05) 0%,transparent 70%);pointer-events:none}
.cto-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;position:relative;z-index:1}
.cto-info h2{font-size:clamp(24px,3vw,34px);font-weight:800;color:#fff;line-height:1.2;margin-bottom:14px}
.cto-info h2 em{font-style:normal;color:var(--gold)}
.cto-info>p{font-size:14px;line-height:1.7;color:rgba(255,255,255,.62);margin-bottom:28px}
.cto-points{display:grid;gap:10px;margin:0 0 28px;padding:0;list-style:none}
.cto-points li{
  font-size:13px;line-height:1.6;color:rgba(255,255,255,.82);
  padding:12px 14px 12px 42px;position:relative;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:14px
}
.cto-points li::before{
  content:'✓';position:absolute;left:14px;top:11px;
  width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(233,183,45,.18);color:var(--gold);font-size:11px;font-weight:800
}
.cto-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.cto-ico{
  width:44px;height:44px;border-radius:12px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;color:#F3F7FF;flex-shrink:0
}
.cto-ico svg{stroke:currentColor}
.cto-txt strong{display:block;font-size:11px;font-weight:800;color:rgba(255,255,255,.45);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.cto-txt span{display:block;font-size:14.5px;color:rgba(255,255,255,.9);font-weight:500;line-height:1.4}
.cto-txt a{color:#DCE8FF;font-weight:700;text-decoration:none}
.cto-txt a:hover{text-decoration:underline;color:#FFFFFF}
.cto-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.cto-mini{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:42px;padding:0 18px;border-radius:999px;
  font-size:12px;font-weight:800;letter-spacing:.2px;transition:var(--tr);box-shadow:0 8px 20px rgba(3,10,22,.12)
}
.cto-mini.pri{background:rgba(233,183,45,.14);border:1px solid rgba(233,183,45,.32);color:var(--gold)}
.cto-mini.sec{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:#fff}
.cto-mini:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(3,10,22,.18);filter:saturate(1.06)}
.cto-form{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.20);
  border-radius:var(--rxl);
  padding:42px;
  backdrop-filter:blur(14px);
  box-shadow:0 24px 56px rgba(17, 28, 56, .22);
}
.f-ttl{font-size:20px;font-weight:700;color:#fff;margin-bottom:22px}
.f-kicker{
  display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;
  padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);font-size:11px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.72)
}
.f-kicker::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--gold)}
.f-note{font-size:12px;line-height:1.6;color:rgba(255,255,255,.56);margin:-10px 0 18px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-grp{margin-bottom:14px}
.field-hint{
  display:none;
  margin-top:6px;
  font-size:11.5px;
  line-height:1.4;
  font-weight:600;
}
.field-hint.show{display:block}
.field-hint.err{color:#FCA5A5}
.field-hint.ok{color:#86EFAC}
.f-full{grid-column:1/-1}
.f-optional{
  margin-top:4px;border:1px dashed rgba(255,255,255,.14);
  border-radius:16px;padding:14px 14px 2px;background:rgba(255,255,255,.03)
}
.f-optional summary{
  cursor:pointer;list-style:none;font-size:12px;font-weight:700;
  color:rgba(255,255,255,.74);margin-bottom:14px
}
.f-optional summary::-webkit-details-marker{display:none}
.f-optional[open] summary{color:#fff}
.f-optional-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-lbl{display:block;font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:5px}
.f-lbl sup{color:var(--gold)}
.f-in,.f-ta{
  width:100%;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.11);
  border-radius:var(--rsm);padding:10px 13px;font-family:inherit;font-size:13px;
  color:#fff;transition:var(--tr);outline:none
}
.f-in::placeholder,.f-ta::placeholder{color:rgba(255,255,255,.22)}
.f-in:focus,.f-ta:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(46,142,255,.14);background:rgba(255,255,255,.1)}
.f-ta{resize:none;min-height:82px}
.f-radios{display:flex;gap:16px;flex-wrap:wrap}
.f-rlbl{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,.78);cursor:pointer}
.f-rlbl input{accent-color:var(--accent);width:15px;height:15px}
.f-sub{
  width:100%;background:linear-gradient(135deg,var(--blue),var(--accent));
  color:#fff;border:none;border-radius:16px;min-height:50px;padding:0 18px;
  font-family:inherit;font-size:14px;font-weight:800;cursor:pointer;
  transition:var(--tr);margin-top:6px;box-shadow:0 14px 28px rgba(46,142,255,.26)
}
.f-sub:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(46,142,255,.36);filter:saturate(1.04)}
.f-sub:disabled{opacity:.6;cursor:not-allowed;transform:none}
.f-sub.alt{
  width:auto;padding:0 18px;min-height:40px;border-radius:999px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);
  box-shadow:none;font-size:12px;font-weight:700;text-transform:none;letter-spacing:normal;color:#fff
}
.f-sub.alt:hover{background:rgba(255,255,255,.18);box-shadow:none}
.f-msg{text-align:center;font-size:12.5px;padding:9px;border-radius:var(--rsm);margin-top:10px;display:none}
.f-msg.ok{background:rgba(16,185,129,.14);color:#6EE7B7;display:block;border:1px solid rgba(16,185,129,.23)}
.f-msg.err{background:rgba(239,68,68,.14);color:#FCA5A5;display:block;border:1px solid rgba(239,68,68,.23)}
.f-msg.ld{background:rgba(255,255,255,.07);color:rgba(255,255,255,.65);display:block}

/* FOOTER */
footer{background:#25335A;padding:36px 0;border-top:1px solid rgba(255,255,255,.05)}
.ft-in{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.ft-logo img{height:34px;width:auto;opacity:.75}
.ft-addr{font-size:12px;color:rgba(255,255,255,.38);line-height:1.6}
.ft-note{font-size:11px;color:rgba(255,255,255,.22)}

/* MODAL */
.modal-ov{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.78);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px}
.modal-ov.open{display:flex}
.modal-bx{max-height:calc(100vh - 40px);overflow-y:auto;background:linear-gradient(160deg,var(--navy),#25335A);border-radius:var(--rxl);border:1px solid rgba(255,255,255,.1);padding:44px;max-width:540px;width:100%;position:relative;box-shadow:var(--sh4)}
.modal-cl{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.08);border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.55);font-size:18px;transition:var(--tr)}
.modal-cl:hover{background:rgba(255,255,255,.14);color:#fff}
.modal-bx h3{font-size:20px;font-weight:800;color:#fff;margin:20px 0 6px}
.modal-bx>p{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:22px}
.modal-title{font-size:24px;border:none;padding:0;margin:0 0 16px;font-weight:700}
.modal-title.center{text-align:center;margin-bottom:18px}
.modal-brand{display:block;height:48px;margin:20px auto 28px;filter:brightness(0) invert(1)}
.modal-brand.compact{height:36px;display:inline-block;margin:0;vertical-align:middle}
.modal-head{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}
.modal-intro{font-size:13.5px;color:rgba(255,255,255,.8);line-height:1.6;margin-bottom:0}
.modal-footer-note{text-align:center;font-size:13px;color:rgba(255,255,255,.5);margin-top:24px}
.modal-close-row{display:flex;justify-content:flex-end;margin-top:20px}
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;margin-bottom:16px;
  background:rgba(233,183,45,.12);border:1px solid rgba(233,183,45,.28);
  color:var(--gold);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase
}
.status-pill::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor}
.modal-steps{display:grid;gap:10px;margin:18px 0 22px;padding:0;list-style:none}
.modal-steps li{
  padding:12px 14px 12px 40px;border-radius:14px;position:relative;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.82);font-size:13px;line-height:1.6
}
.modal-steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:14px;top:12px;width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(46,142,255,.2);color:#fff;font-size:11px;font-weight:800
}
.modal-steps{counter-reset:step}
.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.modal-link{
  display:inline-flex;align-items:center;justify-content:center;min-height:42px;
  padding:0 18px;border-radius:999px;font-size:12px;font-weight:800;transition:var(--tr);box-shadow:0 10px 24px rgba(3,10,22,.16)
}
.modal-link.pri{background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff}
.modal-link.sec{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:#fff}
.modal-link:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(3,10,22,.24);filter:saturate(1.05)}
.modal-note{font-size:12px;line-height:1.6;color:rgba(255,255,255,.58);margin-top:18px}

/* ═══ SCROLL REVEAL ═══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.rv{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.rv.visible{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}
.rv-fade{opacity:0;transition:opacity .7s ease}
.rv-fade.visible{opacity:1}

/* ═══ HERO SCROLL ARROW ═══ */
.h-arrow{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:20;
  display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;
  text-decoration:none;border:none;background:none
}
.h-arrow span{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.5)}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
.h-arrow svg{animation:bounce 1.8s ease-in-out infinite;opacity:.55}

/* ═══ TRUST BAR ═══ */
#trust{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.06)}
.trust-in{
  max-width:1200px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:center;
  gap:0;height:64px;overflow:hidden;position:relative
}
.trust-item{
  display:flex;align-items:center;gap:10px;padding:0 36px;
  border-right:1px solid rgba(255,255,255,.08);flex-shrink:0
}
.trust-item:last-child{border-right:none}
.trust-icon{font-size:18px;line-height:1}
.trust-text{font-size:12px;color:rgba(255,255,255,.6);font-weight:500;white-space:nowrap}
.trust-text strong{color:var(--gold);font-weight:700}

/* ═══ SECTION ACCENT LINE ═══ */
.s-accent{
  width:48px;height:4px;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  margin-bottom:20px
}
.s-accent.center{margin-left:auto;margin-right:auto}

/* ═══ NUMBER BADGE ON CARDS ═══ */
.card-num{
  position:absolute;top:20px;right:20px;
  width:28px;height:28px;border-radius:50%;
  background:rgba(46,142,255,.1);border:1px solid rgba(46,142,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--accent)
}

/* ═══ IMPROVED EMPRESA STATS ROW ═══ */
.emp-stats{
  display:flex;gap:0;margin-top:32px;border-top:1px solid var(--g200);
  padding-top:28px
}
.emp-stat{flex:1;text-align:center;padding:0 16px;border-right:1px solid var(--g200)}
.emp-stat:first-child{padding-left:0;text-align:left}
.emp-stat:last-child{border-right:none}
.emp-stat strong{display:block;font-size:22px;font-weight:800;color:var(--navy);line-height:1;margin-bottom:4px}
.emp-stat span{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.2px}

/* ═══ SECTION DIVIDER (wave) ═══ */
.wave-divider{
  display:block;width:100%;overflow:hidden;line-height:0;
  background:var(--g50) /* color del SIGUIENTE fondo */
}
.wave-divider svg{display:block;width:100%;height:56px}

/* ═══ FEATURE TAGS ═══ */
.feature-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:24px}
.ftag{
  display:inline-flex;align-items:center;gap:8px;
  background:#f2f7ff;border:1px solid #d4e8ff;
  border-radius:999px;padding:8px 18px;font-size:13.5px;font-weight:800;color:#1d4d88;
  box-shadow:0 4px 12px rgba(46,142,255,.05)
}
.ftag::before{content:'✓';color:#156ceb;font-weight:900;font-size:14.5px}

a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:3px solid rgba(46,142,255,.45);
  outline-offset:3px
}
.btn-pri:focus-visible,.btn-out:focus-visible,.btn-trab:focus-visible,.f-sub:focus-visible,.modal-link:focus-visible,.cto-mini:focus-visible,.nab:focus-visible{
  outline-color:rgba(233,183,45,.72)
}

body.modal-open{overflow:hidden}

/* ═══ FLOATING ACTIONS ═══ */
.float-actions{
  position:fixed;bottom:28px;right:28px;z-index:999;
  display:flex;flex-direction:column;gap:14px;align-items:center
}
.btn-float{
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow:0 10px 36px rgba(0,0,0,.35);border:1.5px solid rgba(255,255,255,.2);
  position:relative;text-decoration:none
}
.btn-wsp{
  background:rgba(37,211,102,0.92);backdrop-filter:blur(10px);
  color:#fff;animation:btnFloat 3s ease-in-out infinite
}
.btn-wsp svg{width:36px;height:36px}
.btn-wsp:hover{transform:scale(1.1);background:#25d366;box-shadow:0 12px 30px rgba(37,211,102,.4)}

#btt{
  width:44px;height:44px;border-radius:50%;
  background:rgba(30,77,140,.85);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--tr);opacity:0;transform:translateY(20px);
  border:1px solid rgba(255,255,255,.1);pointer-events:none;color:#fff
}
#btt.show{opacity:1;transform:translateY(0);pointer-events:auto}
#btt:hover{background:var(--accent)}
#btt svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.5;fill:none}

@keyframes btnFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@media (max-width: 768px) {
  .float-actions { bottom: 20px; right: 20px; gap: 10px; }
  .btn-float { width: 54px; height: 54px; }
  .btn-wsp svg { width: 32px; height: 32px; }
  #btt { width: 44px; height: 44px; }
}

/* ═══ FOOTER ENHANCED ═══ */
footer{background:#25335A;padding:60px 0 32px;border-top:1px solid rgba(255,255,255,.06)}
.ft-grid{
  max-width:1200px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:280px 1fr auto;
  gap:48px;align-items:start;margin-bottom:48px
}
.ft-brand p{font-size:13px;line-height:1.65;color:rgba(255,255,255,.38);margin-top:14px}
.ft-logo img{height:36px;width:auto;opacity:.8}
.ft-cols{display:flex;gap:60px}
.ft-col h4{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:16px}
.ft-col a{display:block;font-size:13px;color:rgba(255,255,255,.82);margin-bottom:9px;transition:var(--tr)}
.ft-col a:hover{color:#fff;transform:translateX(3px)}
.ft-contact p{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:8px;line-height:1.5}
.ft-contact a{color:#DCE8FF;font-weight:700}
.ft-bottom{
  max-width:1200px;margin:0 auto;padding:20px 40px 0;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;
  gap:16px
}
.ft-copy{font-size:11px;color:rgba(255,255,255,.2)}
.ft-tags{display:flex;gap:10px}
.ft-badge{
  font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  color:rgba(255,255,255,.25);border:1px solid rgba(255,255,255,.1);
  border-radius:4px;padding:3px 8px
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1440px) {
  .nav-in { padding: 0 24px; min-height: 64px; }
  .nav-logo img { height: 32px; }
  .nav-links { margin-right: 12px; }
  .nav-links a { font-size: 11px; padding: 0 8px; }
  .nav-r { gap: 6px; }
  .nab { font-size: 11px; padding: 0 12px; min-height: 40px; }
}

@media (max-width: 1180px) {
  .nav-in { padding: 10px 18px; min-height: 74px; }
  .nav-logo img { height: 38px; }
  .nav-links {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: rgba(37,51,90,0.99); backdrop-filter: blur(20px);
    flex-direction: column; padding: 10px 12px 14px;
    box-shadow: 0 16px 30px rgba(0,0,0,.24);
    border-top: 1px solid rgba(255,255,255,.05);
    border-bottom: 1px solid rgba(255,255,255,.06);
    border-radius: 0; margin-right: 0; margin-left: 0;
  }
  .nav-links.open { display: flex; }
  .nav-links a { width: 100%; justify-content: flex-start; min-height: 46px; padding: 0 14px; font-size: 12.5px; }
  .nav-r { margin-left: auto; gap: 8px; }
  .nab { min-height: 44px; padding: 0 14px; font-size: 11px; }
  .nav-menu-btn {
    display: flex; flex-direction: column; justify-content: space-around;
    width: 40px; height: 40px; background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08); border-radius: 12px;
    cursor: pointer; padding: 9px; margin-left: 8px;
  }
  .nav-menu-btn span { width: 100%; height: 2px; background: #fff; border-radius: 2px; transition: var(--tr); }
  .nav-menu-btn.open span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
  .nav-menu-btn.open span:nth-child(2) { opacity: 0; }
  .nav-menu-btn.open span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }
}

@media (max-width: 1024px) {
  .wrap, .trust-in, .ft-grid, .ft-bottom { padding-left: 32px; padding-right: 32px; }
  .py { padding: 92px 0; }
  .lead { font-size: 16px; }
  .emp-grid, .req-grid { gap: 48px; }
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .ven-grid, .srv-grid { grid-template-columns: repeat(2, 1fr); }
  .ofi-lay { grid-template-columns: 1fr; }
  .ofi-map { height: 280px; position: static; }
  #nav { padding: 0; }
  .nav-in { padding: 10px 20px; gap: 10px; min-height: 74px; }
  .nav-logo img { height: 40px; }
  .nav-r { gap: 6px; }
  .nab { min-height: 44px; padding: 0 14px; font-size: 11px; }
}

/* ═══ PASOS PARA OPERAR (Integrados en Servicios) ═══ */
.srv-steps-wrap { margin-top: 64px; border-top: 1px solid rgba(0,0,0,0.05); padding-top: 56px; }
.srv-steps-hd { text-align: center; max-width: 700px; margin: 0 auto 48px auto; }
.srv-steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; align-items: stretch; }
.step-card { 
  background: #fff; 
  border: 1px solid var(--g200); 
  border-radius: 28px; 
  padding: 60px 36px 44px; 
  position: relative; 
  transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1); 
  box-shadow: 0 4px 24px rgba(0,0,0,0.03); 
  text-align: center; 
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
}
.step-card:hover { transform: translateY(-10px); border-color: rgba(30, 77, 140, 0.4); box-shadow: 0 24px 56px rgba(30, 77, 140, 0.12); }
.step-badge { position: absolute; top: -20px; left: 50%; transform: translateX(-50%); width: 44px; height: 44px; background: linear-gradient(135deg, var(--blue), var(--navy)); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 19px; font-weight: 850; box-shadow: 0 10px 20px rgba(30, 77, 140, 0.3); border: 4px solid #fff; }
.step-card h3 { font-size: 22px; font-weight: 850; color: var(--navy); margin-bottom: 16px; letter-spacing: -0.6px; }
.step-card p { font-size: 14.5px; color: var(--muted); line-height: 1.7; margin-bottom: 24px; flex-grow: 1; }
.btn-step { 
  margin-top: auto; 
  background: linear-gradient(180deg, var(--blue), var(--navy)); 
  color: #fff; 
  border: 1px solid rgba(132, 181, 241, 0.2); 
  padding: 13px 28px; 
  border-radius: 999px; 
  font-size: 13px; 
  font-weight: 750; 
  letter-spacing: 0.5px;
  text-transform: uppercase;
  cursor: pointer; 
  transition: var(--tr); 
  width: fit-content; 
  margin-left: auto;
  margin-right: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 16px rgba(8, 22, 47, 0.15);
}
.btn-step:hover { 
  transform: translateY(-2px); 
  box-shadow: 0 12px 24px rgba(8, 22, 47, 0.25); 
  filter: brightness(1.08); 
}

.nav-mob-btn { display: none; }

/* BOTON FINTECH PRINCIPAL (btn-pri) */
.btn-pri {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 34px;
  border-radius: 999px;
  background: var(--btn-pri);
  color: #fff !important;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.1);
  cursor: pointer;
  transition: var(--tr);
  box-shadow: 0 10px 25px rgba(37, 51, 90, 0.2);
  font-family: inherit;
}
.btn-pri:hover {
  background: var(--btn-pri-hover);
  transform: translateY(-3px);
  box-shadow: 0 15px 40px rgba(46, 142, 255, 0.3);
  border-color: rgba(255,255,255,0.2);
  color: #fff !important;
}

/* BUTTON REFINEMENTS */
.btn-pri,
.btn-out,
.btn-trab,
.f-sub,
.modal-link,
.nab,
.btn-step,
.cto-mini,
.nav-mob-btn {
  transition:
    background-color .22s ease,
    background .22s ease,
    color .22s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    transform .16s ease,
    filter .22s ease;
}

.btn-pri {
  background: #25335A;
  color: #FFFFFF !important;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 18px rgba(37, 51, 90, 0.20);
}

.btn-pri:hover {
  background: #314271;
  color: #FFFFFF !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(37, 51, 90, 0.24);
  filter: none;
}

.btn-out {
  color: #FFFFFF;
  border-color: rgba(255,255,255,.42);
  background: rgba(255,255,255,.05);
  box-shadow: 0 6px 14px rgba(0,0,0,.10);
}

.btn-out:hover {
  color: #FFFFFF;
  border-color: rgba(255,255,255,.65);
  background: rgba(255,255,255,.12);
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
  transform: translateY(-1px);
}

.nab {
  color: #FFFFFF;
  box-shadow: 0 6px 14px rgba(0,0,0,.10);
}

.nab-pur,
.nab-firma {
  background: rgba(255,255,255,.08);
  color: #FFFFFF;
  border-color: rgba(255,255,255,.18);
}

.nab-blu {
  background: #3B5A9A;
  color: #FFFFFF;
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 8px 18px rgba(16, 26, 51, 0.24);
}

.nab-out {
  color: #FFFFFF;
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.04);
}

.nab-enrol {
  background: #E9B72D;
  color: #25335A;
  border-color: rgba(233,183,45,.5);
  box-shadow: 0 8px 18px rgba(173, 130, 18, 0.22);
}

.nab-pur:hover,
.nab-firma:hover,
.nab-blu:hover,
.nab-out:hover,
.nab-enrol:hover {
  transform: translateY(-1px);
  filter: none;
}

.nab-pur:hover,
.nab-firma:hover {
  background: rgba(255,255,255,.13);
  color: #FFFFFF;
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
}

.nab-blu:hover {
  background: #4A6DB7;
  color: #FFFFFF;
  box-shadow: 0 10px 22px rgba(16, 26, 51, 0.28);
}

.nab-out:hover {
  background: rgba(255,255,255,.10);
  color: #FFFFFF;
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
}

.nab-enrol:hover {
  background: #F0C44B;
  color: #25335A;
  box-shadow: 0 10px 22px rgba(173, 130, 18, 0.26);
}

.btn-trab,
.f-sub,
.btn-step,
.modal-link.pri,
.cto-mini.pri {
  color: #FFFFFF;
}

.btn-trab {
  background: #E9B72D;
  color: #25335A;
  border-color: rgba(194, 145, 16, .45);
  box-shadow: 0 8px 18px rgba(173, 130, 18, 0.22), inset 0 1px 1px rgba(255,255,255,.35);
}

.btn-trab svg {
  stroke: #25335A;
  opacity: 1;
}

.btn-trab:hover {
  background: #F0C44B;
  color: #25335A;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(173, 130, 18, 0.26), inset 0 1px 1px rgba(255,255,255,.4);
  filter: none;
}

.f-sub,
.modal-link.pri,
.btn-step,
.cto-mini.pri {
  background: #25335A;
  color: #FFFFFF;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 8px 18px rgba(37, 51, 90, 0.20);
}

.f-sub:hover,
.modal-link:hover,
.btn-step:hover,
.cto-mini:hover {
  transform: translateY(-1px);
  filter: none;
}

.f-sub:hover,
.modal-link.pri:hover,
.btn-step:hover,
.cto-mini.pri:hover {
  background: #314271;
  color: #FFFFFF;
  box-shadow: 0 10px 22px rgba(37, 51, 90, 0.24);
}

.modal-link.sec,
.f-sub.alt,
.cto-mini.sec {
  color: #FFFFFF;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  box-shadow: none;
}

.modal-link.sec:hover,
.f-sub.alt:hover,
.cto-mini.sec:hover {
  background: rgba(255,255,255,.14);
  color: #FFFFFF;
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
}

.nav-mob-btn:hover {
  background: rgba(255,255,255,.08);
  color: #FFFFFF;
}

@media (max-width: 768px) {
  .py { padding: 72px 0; }
  .wrap, .trust-in, .ft-grid, .ft-bottom { padding-left: 24px; padding-right: 24px; }
  .h-over { padding: calc(var(--navh) + 28px) 24px 72px; }
  
  /* Nav Mobile */
  #nav { padding: 0; }
  .nav-in { padding: 10px 14px; min-height: 68px; border-radius: 0; gap: 8px; }
  .nav-logo img { height: 36px; }
  .nav-links a { width: 100%; justify-content: flex-start; min-height: 48px; padding: 0 14px; font-size: 13px; }
  .nav-div { display: none; }
  .nav-r { margin-left: auto; gap: 6px; padding: 0; background: transparent; border: none; }
  .nab { min-height: 42px; padding: 0 12px; font-size: 10.75px; }
  
  /* Nav Mobile Fallback Buttons */
  .nav-mob-btn { display: flex !important; width: 100%; align-items: center; justify-content: flex-start; min-height: 48px; padding: 0 14px; font-size: 13px; font-weight: 700; background: transparent; border: none; font-family: inherit; transition: var(--tr); }
  .cl-firma { color: var(--gold); border-top: 1px solid rgba(255,255,255,0.06); margin-top: 6px; }
  .cl-enrol { color: var(--accent); border-bottom: 1px solid rgba(255,255,255,0.06); margin-bottom: 6px; }
  .nab-firma, .nab-enrol { display: none !important; }
  
  /* Typography */
  .h-title { font-size: clamp(34px, 8.6vw, 48px); letter-spacing: -1.4px; }
  .h-sub { font-size: 16px; margin-bottom: 28px; }
  .h2 { font-size: 32px; }
  
  /* Grids Mobile */
  .emp-grid, .req-grid, .ven-grid, .srv-grid, .srv-steps-grid, .faq-grid, .ofi-grid, .cto-grid, .ft-grid { grid-template-columns: 1fr; gap: 36px; }
  .f-row { grid-template-columns: 1fr; }
  .f-optional-grid { grid-template-columns: 1fr; }
  
  /* Specific Elements */
  .ven-card, .srv-card, .ofi-card { padding: 28px 24px; }
  .faq-shell { padding: 16px; border-radius: 22px; }
  .faq-q { padding: 18px 16px; }
  .faq-copy { gap: 12px; }
  .faq-a-in { padding: 0 16px 0; }
  .faq-item.open .faq-a-in { padding: 0 16px 18px; }
  .emp-img img, .req-img img { height: 260px; }
  .ven-box { padding: 30px 24px; grid-template-columns: 1fr; text-align: center; gap: 20px; }
  .ven-box-ico { margin: 0 auto; }
  .ven-box ul { grid-template-columns: 1fr; gap: 12px; text-align: left; }
  .h-stats { display: none; } /* Ocultar stats en móvil para ahorrar espacio */
  .h-dots { left: 20px; bottom: 20px; }
  .trust-in { height: auto; padding: 20px; flex-direction: column; align-items: flex-start; gap: 16px; }
  .trust-item { padding: 0; border: none; width: 100%; justify-content: flex-start; }
  .ft-bottom { flex-direction: column; text-align: center; gap: 16px; padding-bottom: 30px; }
  .modal-bx { padding: 28px 20px; max-width: 100% !important; border-radius: 16px; }
  .cto-form { padding: 32px 24px; }
  .cto-actions, .modal-actions { flex-direction: column; }
  .cto-mini, .modal-link { width: 100%; }
  
  /* Firma/Enrolate Modal Mobile Fix */
  #modal-firma .modal-bx h3 { font-size: 22px; }
  #modal-firma .legal-tx { font-size: 11px; margin-top: 14px; }
  #modal-login h3 { font-size: 22px !important; }
}

/* MICROINTERACCIONES FORMULARIOS */
.f-in:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 4px rgba(46, 142, 255, 0.15) !important;
  transform: translateY(-1px);
}
.f-grp { position: relative; }
.f-in:valid:not(:placeholder-shown) {
  border-color: #10b981 !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2310b981' stroke-width='3'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 18px;
}

@media (max-width: 480px) {
  .nav-logo img { height: 28px; }
  .nab-out { display: none; } /* Ocultar botones secundarios de nav en pantallas muy pequeñas */
  .nav-r { margin-left: auto; }
  .h-cta { flex-direction: column; width: 100%; }
  .btn-pri, .btn-out { width: 100%; justify-content: center; }
}
