
:root {
  --navy:#071b35;
  --navy-2:#102b4e;
  --blue:#155f98;
  --teal:#087c80;
  --teal-2:#12a6a6;
  --green:#8bc53f;
  --lime:#d6ee29;
  --orange:#f47a20;
  --gold:#d9a529;
  --ink:#11233c;
  --muted:#65758a;
  --soft:#f2f8fa;
  --line:#dce8ee;
  --white:#fff;
  --shadow:0 26px 70px rgba(7,27,53,.16);
  --container:min(1220px, calc(100% - 36px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;color:var(--ink);background:#fff;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:var(--container);margin-inline:auto}
.top-bar{background:var(--navy);color:#dce7ef;font-size:.78rem}
.top-bar .container{min-height:36px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.top-bar strong{color:var(--lime)}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);box-shadow:0 16px 42px rgba(7,27,53,.10)}
.header-row{height:86px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.logo img{height:64px;width:auto;object-fit:contain}
.nav{display:flex;align-items:center;gap:5px;background:#f5fafc;border:1px solid var(--line);border-radius:999px;padding:8px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.6)}
.nav a{font-weight:900;font-size:.82rem;color:#172942;border-radius:999px;padding:10px 13px;white-space:nowrap;transition:.25s ease}
.nav a:hover,.nav a.active{background:linear-gradient(135deg,#e6fbf6,#efffdd);color:var(--teal);transform:translateY(-2px);box-shadow:0 12px 24px rgba(8,124,128,.12)}
.header-actions{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 19px;border-radius:999px;font-weight:950;border:0;cursor:pointer;transition:.25s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px);filter:saturate(1.08)}
.btn-primary{background:linear-gradient(135deg,var(--orange),#ff9a35);color:#fff;box-shadow:0 18px 34px rgba(244,122,32,.28)}
.btn-dark{background:var(--navy);color:#fff;box-shadow:0 18px 34px rgba(7,27,53,.20)}
.btn-soft{background:#e8f8f5;color:var(--teal)}
.btn-outline{border:1px solid rgba(255,255,255,.42);color:#fff;background:rgba(255,255,255,.10)}
.menu-toggle{display:none;width:46px;height:46px;border-radius:16px;border:1px solid var(--line);background:#fff;font-size:1.25rem}
.color-strip{height:8px;background:linear-gradient(90deg,var(--teal) 0 24%,var(--lime) 24% 42%,var(--orange) 42% 61%,var(--teal-2) 61% 79%,var(--blue) 79% 100%)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;text-transform:uppercase;font-size:.72rem;letter-spacing:.12em;font-weight:950;color:var(--teal)}
.eyebrow::before{content:"";width:42px;height:3px;background:currentColor;border-radius:999px}
.section{position:relative;padding:90px 0}
.section.soft{background:linear-gradient(180deg,#f6fbfc,#eff8f2)}
.section.dark{background:var(--navy);color:#fff;overflow:hidden}
.section.dark::before{content:"";position:absolute;inset:auto -15% -30% auto;width:640px;height:640px;border-radius:50%;background:rgba(139,197,63,.14)}
.section-head{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:end;margin-bottom:36px}
.section-head h2,.page-text h1{font-size:clamp(2.2rem,4.8vw,4rem);line-height:1.02;margin:12px 0 0;letter-spacing:-.055em}
.section-head p{margin:0;color:var(--muted);font-size:1.02rem}
.section.dark .section-head p{color:#c6d7e2}
.email-pill{display:inline-flex;align-items:center;gap:8px;margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:999px;color:var(--teal);font-weight:900;padding:10px 14px;font-size:.82rem}

/* Hero */
.hero{position:relative;min-height:720px;background:var(--navy);color:#fff;overflow:hidden}
.hero-slider,.hero-slide{position:absolute;inset:0}
.hero-slide{opacity:0;transition:opacity 1s ease, transform 7s ease;transform:scale(1.04)}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(7,27,53,.97) 0%,rgba(7,27,53,.86) 40%,rgba(7,27,53,.44) 72%,rgba(7,27,53,.18) 100%),
  radial-gradient(circle at 80% 30%,rgba(139,197,63,.25),transparent 27%)}
.hero-shape{position:absolute;z-index:2;left:-14%;top:0;width:58%;height:100%;background:linear-gradient(135deg,rgba(139,197,63,.93),rgba(8,124,128,.76));clip-path:polygon(0 0,82% 0,58% 100%,0 100%);mix-blend-mode:multiply}
.hero-content{position:relative;z-index:3;min-height:720px;display:grid;grid-template-columns:.92fr 1.08fr;align-items:center}
.hero h1{font-size:clamp(3.2rem,7vw,6.6rem);line-height:.92;margin:18px 0 18px;letter-spacing:-.08em;max-width:780px}
.hero h1 span{color:var(--lime)}
.hero p{font-size:1.14rem;max-width:660px;color:#e7eff5}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:720px;margin-top:34px}
.metric{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:15px;backdrop-filter:blur(10px)}
.metric strong{display:block;font-size:1.05rem}
.metric span{display:block;color:#d5e3ec;font-size:.8rem}
.hero-dots{position:absolute;z-index:5;left:50%;bottom:28px;transform:translateX(-50%);display:flex;gap:9px}
.hero-dots button{width:12px;height:12px;border:0;border-radius:999px;background:rgba(255,255,255,.48);cursor:pointer;transition:.25s}
.hero-dots button.active{width:38px;background:var(--lime)}

/* Feature strips */
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:-48px;position:relative;z-index:10}
.quick-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:center}
.quick-card i{width:48px;height:48px;display:grid;place-items:center;border-radius:16px;background:#e9faf5;color:var(--teal);font-style:normal;font-size:1.3rem}
.quick-card strong,.quick-card span{display:block}
.quick-card span{font-size:.82rem;color:var(--muted)}

/* Cards */
.card-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.program-card,.career-card{background:#fff;border:1px solid var(--line);border-radius:30px;overflow:hidden;box-shadow:0 18px 48px rgba(7,27,53,.10);transition:.28s ease;display:flex;flex-direction:column}
.program-card:hover,.career-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.card-image{height:236px;position:relative;overflow:hidden;background:#eef8fa}
.card-image img{width:100%;height:100%;object-fit:cover;transition:.4s ease}
.program-card:hover .card-image img,.career-card:hover .card-image img{transform:scale(1.055)}
.card-badge{position:absolute;left:16px;top:16px;z-index:2;background:var(--lime);color:var(--navy);border-radius:999px;padding:8px 12px;font-size:.72rem;font-weight:950;box-shadow:0 10px 22px rgba(7,27,53,.10)}
.card-body{padding:21px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.08rem;line-height:1.16;margin:0 0 9px;letter-spacing:-.015em}
.card-body p{color:var(--muted);font-size:.88rem;margin:0 0 17px;min-height:82px}
.card-meta{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 16px}
.card-meta span{font-size:.74rem;font-weight:850;border-radius:999px;background:#f2f7fa;color:#33546d;padding:7px 9px}
.card-link{margin-top:auto;border:0;background:transparent;color:var(--teal);font-weight:950;text-align:left;cursor:pointer;padding:0}
.career-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.career-card .card-image{height:280px}

/* Split sections */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:center}
.visual-panel{position:relative;border-radius:38px;overflow:hidden;min-height:520px;background:#fff;box-shadow:var(--shadow)}
.visual-panel img{width:100%;height:100%;min-height:520px;object-fit:cover}
.visual-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,27,53,.16),transparent 52%)}
.text-panel{position:relative;background:#fff;color:var(--ink);border-radius:38px;padding:40px;box-shadow:var(--shadow)}
.section.dark .text-panel{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(10px)}
.text-panel h2{font-size:clamp(2.2rem,4.2vw,3.5rem);line-height:1.02;margin:12px 0;letter-spacing:-.055em}
.text-panel p{color:var(--muted);font-size:1.02rem}
.section.dark .text-panel p{color:#d1dfe8}
.chips{display:flex;gap:9px;flex-wrap:wrap;margin:24px 0}
.chips span{background:#e8f8f5;color:var(--teal);border-radius:999px;font-size:.8rem;font-weight:900;padding:9px 12px}
.section.dark .chips span{background:rgba(255,255,255,.12);color:#fff}

.agreement{display:grid;grid-template-columns:.9fr auto .9fr;gap:18px;align-items:center;margin:24px 0 34px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:22px;box-shadow:0 20px 55px rgba(7,27,53,.10)}
.agreement-logo{height:94px;border:1px solid var(--line);border-radius:24px;background:#fff;display:grid;place-items:center;padding:14px}
.agreement-logo img{max-height:70px;width:auto;object-fit:contain}
.agreement-label{font-weight:950;text-transform:uppercase;text-align:center;color:#fff;background:linear-gradient(135deg,var(--teal),var(--green));border-radius:999px;padding:12px 16px;font-size:.78rem;letter-spacing:.06em}

.homologation-box{display:grid;grid-template-columns:1fr .9fr;gap:26px;align-items:center;background:linear-gradient(135deg,#f7ffe6,#fff);border:1px solid #dcefb2;border-radius:36px;padding:30px;box-shadow:var(--shadow);margin-top:32px}
.homologation-box p{color:var(--muted)}
.homologation-box img{height:340px;width:100%;object-fit:cover;border-radius:28px}

/* Contact */
.contact-section{background:linear-gradient(135deg,var(--navy),#0e365b);color:#fff;overflow:hidden}
.contact-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:34px;align-items:start}
.route-card{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);border-radius:20px;padding:15px;margin:10px 0}
.route-card strong,.route-card a,.route-card span{display:block}
.route-card a{color:var(--lime);font-weight:950;margin:4px 0;word-break:break-word}
.route-card span{color:#cbdce7;font-size:.82rem}
.form-card{background:#fff;color:var(--ink);border-radius:34px;padding:28px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-card label{display:grid;gap:7px;font-weight:850;font-size:.8rem;color:#24354d}
.form-card input,.form-card select,.form-card textarea{border:1px solid var(--line);border-radius:15px;padding:12px 13px;background:#fff;outline:0}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(8,124,128,.10)}
.form-card textarea{grid-column:1/-1;min-height:116px;resize:vertical}
.route-preview{grid-column:1/-1;background:#e9f8f5;border:1px solid #cdeae5;color:var(--teal);border-radius:16px;padding:13px;font-weight:900;font-size:.84rem}
.status{margin-top:14px;color:var(--teal);font-weight:850}

/* Secondary pages */
.page-hero{position:relative;min-height:540px;background:var(--navy);color:#fff;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,27,53,.98),rgba(7,27,53,.78) 55%,rgba(7,27,53,.25))}
.page-hero::after{content:"";position:absolute;left:-14%;top:0;width:58%;height:100%;background:linear-gradient(135deg,rgba(139,197,63,.92),rgba(8,124,128,.72));clip-path:polygon(0 0,84% 0,58% 100%,0 100%);mix-blend-mode:multiply}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero .container{position:relative;z-index:3;min-height:540px;display:grid;grid-template-columns:.9fr 1.1fr;align-items:center}
.page-hero p{color:#d8e5ee;max-width:720px;font-size:1.08rem}
.page-content{padding:86px 0}
.module-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.module{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:0 18px 50px rgba(7,27,53,.09)}
.module strong{display:block;color:var(--teal);margin-bottom:8px}
.module p,.module li{color:var(--muted)}
.timeline{display:grid;gap:14px}
.timeline-item{display:grid;grid-template-columns:54px 1fr;gap:14px;align-items:start}
.timeline-item i{width:54px;height:54px;border-radius:18px;background:var(--lime);display:grid;place-items:center;font-style:normal;font-weight:950;color:var(--navy)}
.timeline-item div{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 12px 30px rgba(7,27,53,.06)}

/* Simulator */
.sim-shell{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start}
.sim-form{background:#fff;border:1px solid var(--line);border-radius:34px;padding:28px;box-shadow:var(--shadow)}
.sim-result{background:linear-gradient(135deg,#f4ffe3,#fff);border:1px solid #d7efae;border-radius:30px;padding:26px;box-shadow:var(--shadow);position:sticky;top:116px}
.result-cycle{font-size:3rem;line-height:1;font-weight:950;color:var(--teal);letter-spacing:-.05em}
.result-list{display:grid;gap:10px;margin-top:16px}
.result-list div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed #cfe2d4;padding-bottom:8px;color:#46596e}

/* Campus */
.login-card{width:min(460px,100%);background:#fff;border-radius:34px;padding:30px;box-shadow:var(--shadow)}
.login-card h2{font-size:2rem;line-height:1;margin:0 0 18px}
.login-card label{display:grid;gap:7px;font-weight:850;font-size:.82rem;margin:12px 0}
.login-card input{border:1px solid var(--line);border-radius:15px;padding:13px}
.campus-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:center}

/* Footer and modals */
.footer{background:#07101f;color:#fff;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1.05fr 1fr;gap:28px}
.footer img{height:72px;width:auto;object-fit:contain}
.footer h4{margin:0 0 12px}
.footer p,.footer a,.footer button{color:#aebbc9;font-size:.84rem}
.footer a,.footer button{display:block;margin:8px 0}
.footer button{border:0;background:transparent;padding:0;cursor:pointer;text-align:left}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:26px;padding-top:18px;display:flex;justify-content:space-between;gap:14px;color:#8f9bad;font-size:.78rem}
.modal{position:fixed;inset:0;z-index:4000;background:rgba(3,10,22,.78);display:none;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal-dialog{width:min(1060px,100%);max-height:92vh;background:#fff;border-radius:32px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.38)}
.modal-hero{height:310px;position:relative;background:#eef8fa;overflow:hidden}
.modal-hero img{width:100%;height:100%;object-fit:cover}
.modal-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,27,53,.92),rgba(7,27,53,.52),rgba(7,27,53,.08))}
.modal-title{position:absolute;z-index:2;left:28px;bottom:26px;color:#fff;max-width:660px}
.modal-title h2{font-size:clamp(1.8rem,4vw,3rem);line-height:1.04;margin:8px 0}
.modal-title p{margin:0;color:#dce8ef}
.modal-close{position:absolute;right:18px;top:18px;z-index:4;width:44px;height:44px;border:0;border-radius:50%;background:#fff;color:var(--navy);font-size:1.4rem;cursor:pointer}
.modal-content{padding:28px;max-height:calc(92vh - 310px);overflow:auto}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.info-box{background:#f4f8fa;border:1px solid var(--line);border-radius:22px;padding:20px}
.info-box p,.info-box li{color:var(--muted)}
.accordion{display:grid;gap:10px;margin-top:18px}
.acc-item{border:1px solid var(--line);border-radius:18px;overflow:hidden}
.acc-head{width:100%;display:flex;justify-content:space-between;gap:12px;border:0;background:#fff;padding:15px 17px;font-weight:950;text-align:left;cursor:pointer}
.acc-body{display:none;padding:0 17px 15px;color:var(--muted)}
.acc-item.open .acc-body{display:block}
.policy-modal{position:fixed;inset:0;background:rgba(3,10,22,.78);display:none;z-index:4100;align-items:center;justify-content:center;padding:18px}
.policy-modal.open{display:flex}
.policy-box{width:min(850px,100%);max-height:88vh;overflow:auto;background:#fff;border-radius:28px;box-shadow:var(--shadow)}
.policy-head{position:sticky;top:0;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;padding:22px 26px}
.policy-head button{position:absolute;right:18px;top:18px;border:0;border-radius:50%;width:38px;height:38px;background:#fff;color:var(--navy);font-size:1.2rem}
.policy-body{padding:26px}
.policy-body p,.policy-body li{color:var(--muted)}

.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:1200;width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;font-size:1.7rem;box-shadow:0 18px 34px rgba(37,211,102,.36)}

@media(max-width:1140px){
  .nav{position:absolute;left:18px;right:18px;top:108px;display:none;flex-direction:column;align-items:stretch;border-radius:24px;background:#fff;box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .header-actions .btn-primary{display:none}
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(3,1fr)}
  .career-grid{grid-template-columns:repeat(2,1fr)}
  .split,.contact-grid,.homologation-box,.sim-shell,.campus-layout,.page-hero .container{grid-template-columns:1fr}
}
@media(max-width:820px){
  .top-bar .container{display:block;padding:8px 0}
  .header-row{height:auto;padding:12px 0}
  .logo img{height:54px}
  .hero,.hero-content{min-height:auto}
  .hero-content{padding:72px 0 88px;grid-template-columns:1fr}
  .hero h1{font-size:3.2rem}
  .hero-shape{width:82%}
  .hero-metrics,.quick-grid,.section-head,.card-grid,.career-grid,.agreement,.module-grid,.form-grid,.info-grid,.footer-grid{grid-template-columns:1fr}
  .section{padding:70px 0}
  .agreement-label{order:3}
  .form-card textarea{grid-column:auto}
  .footer-bottom{display:grid}
  .modal-hero{height:260px}
  .page-hero,.page-hero .container{min-height:470px}
}


/* ===== Correcciones visuales V13.1 ===== */
.footer{
  padding-bottom:86px;
}
.footer img{
  max-width:210px;
  height:auto;
}
.whatsapp-float{
  bottom:26px;
  right:26px;
  font-size:1.45rem;
}
.homologation-box img{
  object-fit:contain;
  background:linear-gradient(135deg,#ffffff,#f3fbf3);
  padding:16px;
}
.visual-panel img[src*="englishscore_clean"]{
  object-position:center;
}
.page-hero.clean-sim{
  background:linear-gradient(135deg,#071b35 0%,#102b4e 58%,#087c80 100%);
  min-height:560px;
}
.page-hero.clean-sim::before,
.page-hero.clean-sim::after{
  display:none;
}
.clean-sim .container{
  position:relative;
  z-index:3;
  min-height:560px;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:center;
}
.clean-sim .sim-hero-text h1{
  font-size:clamp(2.7rem,6vw,5.2rem);
  line-height:.96;
  letter-spacing:-.065em;
  margin:18px 0;
}
.clean-sim .sim-hero-text p{
  color:#d6e5ee;
  font-size:1.08rem;
  max-width:650px;
}
.sim-hero-visual{
  background:linear-gradient(135deg,#f7ffe6,#ffffff);
  border:1px solid rgba(255,255,255,.32);
  border-radius:42px;
  padding:22px;
  box-shadow:0 28px 90px rgba(0,0,0,.24);
  min-height:390px;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.sim-hero-visual img{
  position:relative !important;
  inset:auto !important;
  width:100%;
  height:auto;
  max-height:430px;
  object-fit:contain;
}
.page-hero.clean-englishscore{
  min-height:540px;
}
.page-hero.clean-englishscore img{
  object-position:center;
}
img[src*="homologacion_clean.png"]{
  image-rendering:auto;
}
@media(max-width:1140px){
  .clean-sim .container{grid-template-columns:1fr}
}
@media(max-width:820px){
  .clean-sim .container{min-height:auto;padding:54px 0}
  .sim-hero-visual{min-height:auto}
}


/* ===== Correcciones V13.2: EnglishScore y WhatsApp real ===== */
.whatsapp-float{
  background:#25D366 !important;
  overflow:hidden;
}
.whatsapp-float img{
  width:58px;
  height:58px;
  display:block;
}

.englishscore-hero-v2{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 88% 18%, rgba(18,166,166,.14), transparent 28%),
    linear-gradient(135deg,#ffffff 0%,#f5fbfc 48%,#eaf6f2 100%);
  padding:90px 0;
  border-bottom:1px solid var(--line);
}
.englishscore-hero-v2::before{
  content:"";
  position:absolute;
  left:-10%;
  top:-22%;
  width:520px;
  height:520px;
  border-radius:50%;
  background:rgba(139,197,63,.18);
}
.englishscore-hero-v2::after{
  content:"";
  position:absolute;
  right:-10%;
  bottom:-34%;
  width:680px;
  height:680px;
  border-radius:50%;
  background:rgba(8,124,128,.12);
}
.englishscore-hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.86fr 1.14fr;
  gap:44px;
  align-items:center;
}
.englishscore-copy h1{
  font-size:clamp(3rem,6vw,5.6rem);
  line-height:.94;
  letter-spacing:-.075em;
  margin:18px 0;
  color:var(--navy);
}
.englishscore-copy h1::first-line{
  color:var(--navy);
}
.englishscore-copy p{
  color:var(--muted);
  font-size:1.12rem;
  max-width:620px;
}
.englishscore-skills{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:25px 0 30px;
}
.englishscore-skills span{
  background:#e8f8f5;
  color:var(--teal);
  border:1px solid #c9e9e5;
  border-radius:999px;
  padding:10px 14px;
  font-weight:950;
}
.englishscore-visual{
  position:relative;
  min-height:520px;
  border-radius:42px;
  background:linear-gradient(135deg,#ffffff,#eaf7f7);
  box-shadow:var(--shadow);
  overflow:hidden;
  border:1px solid var(--line);
}
.englishscore-visual img{
  position:absolute;
  inset:0;
  width:78%;
  height:100%;
  object-fit:cover;
  object-position:left center;
}
.englishscore-card{
  position:absolute;
  right:30px;
  top:50%;
  transform:translateY(-50%);
  width:min(360px,45%);
  background:rgba(255,255,255,.96);
  border:1px solid var(--line);
  border-radius:28px;
  padding:26px;
  box-shadow:0 24px 60px rgba(7,27,53,.18);
  backdrop-filter:blur(12px);
}
.englishscore-card strong{
  display:block;
  font-size:2rem;
  line-height:1;
  letter-spacing:-.04em;
  color:var(--navy);
}
.englishscore-card span{
  display:block;
  color:var(--teal);
  font-weight:950;
  margin:8px 0 16px;
}
.englishscore-card ul{
  margin:0;
  padding-left:18px;
  color:var(--muted);
}
.englishscore-card li{
  margin:8px 0;
}
@media(max-width:1040px){
  .englishscore-hero-grid{grid-template-columns:1fr}
  .englishscore-visual{min-height:480px}
}
@media(max-width:720px){
  .englishscore-hero-v2{padding:62px 0}
  .englishscore-visual img{width:100%;opacity:.78}
  .englishscore-card{position:relative;right:auto;top:auto;transform:none;width:auto;margin:250px 18px 18px}
}


/* ===== Correcciones V13.3: modales profesionales ===== */
.modal{
  padding:22px;
  align-items:center;
}
.modal-dialog{
  width:min(1180px,100%);
  max-height:91vh;
  display:grid;
  grid-template-columns:42% 58%;
  border-radius:34px;
  overflow:hidden;
  background:#fff;
}
.modal-hero{
  height:auto !important;
  min-height:91vh;
  position:relative;
  background:linear-gradient(135deg,#071b35,#102b4e);
}
.modal-hero img{
  width:100%;
  height:100%;
  min-height:91vh;
  object-fit:cover;
  object-position:center;
  filter:saturate(.98) contrast(.96);
}
.modal-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(0deg,rgba(7,27,53,.86) 0%,rgba(7,27,53,.52) 42%,rgba(7,27,53,.08) 100%),
    linear-gradient(90deg,rgba(7,27,53,.18),rgba(7,27,53,.04));
}
.modal-title{
  left:24px;
  right:24px;
  bottom:24px;
  max-width:none;
  padding:22px;
  border-radius:24px;
  background:rgba(7,27,53,.78);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 22px 60px rgba(0,0,0,.28);
  backdrop-filter:blur(16px);
}
.modal-title .eyebrow{
  color:var(--lime);
  font-size:.68rem;
  letter-spacing:.14em;
}
.modal-title h2{
  font-size:clamp(1.45rem,2.75vw,2.8rem);
  line-height:1.03;
  letter-spacing:-.045em;
  margin:10px 0 10px;
}
.modal-title p{
  font-size:.95rem;
  line-height:1.45;
  color:#e8f1f6;
}
.modal-close{
  right:18px;
  top:18px;
  width:46px;
  height:46px;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}
.modal-content{
  max-height:91vh;
  overflow:auto;
  padding:30px;
  background:
    radial-gradient(circle at 100% 0%,rgba(139,197,63,.10),transparent 30%),
    linear-gradient(180deg,#ffffff,#f8fbfc);
}
.modal-kpi-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:0 0 18px;
}
.modal-kpi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:15px;
  box-shadow:0 10px 26px rgba(7,27,53,.06);
}
.modal-kpi small{
  display:block;
  color:var(--muted);
  font-size:.72rem;
  font-weight:850;
}
.modal-kpi strong{
  display:block;
  color:var(--navy);
  font-size:.92rem;
  line-height:1.25;
  margin-top:4px;
}
.modal-section-title{
  margin:22px 0 12px;
  font-size:1.1rem;
  letter-spacing:-.015em;
  color:var(--navy);
}
.info-grid{
  margin-top:6px;
}
.info-box{
  background:#fff;
  box-shadow:0 12px 34px rgba(7,27,53,.07);
}
.info-box h3{
  margin-top:0;
  color:var(--teal);
}
.accordion{
  margin-top:8px;
}
.acc-item{
  background:#fff;
  border-color:#d7e5ec;
  box-shadow:0 10px 26px rgba(7,27,53,.05);
}
.acc-head{
  padding:17px 18px;
  color:var(--navy);
  background:#fff;
}
.acc-head span:first-child{
  max-width:90%;
}
.acc-head span:last-child{
  color:var(--teal);
}
.acc-body{
  border-top:1px solid #edf3f6;
  background:#fbfdfe;
}
.acc-body ul{
  margin:12px 0 0;
}
.acc-body li{
  margin:8px 0;
}
@media(max-width:980px){
  .modal-dialog{
    grid-template-columns:1fr;
    max-height:92vh;
  }
  .modal-hero{
    min-height:330px;
  }
  .modal-hero img{
    min-height:330px;
  }
  .modal-content{
    max-height:calc(92vh - 330px);
  }
}
@media(max-width:680px){
  .modal{
    padding:10px;
  }
  .modal-title{
    left:14px;
    right:14px;
    bottom:14px;
    padding:17px;
  }
  .modal-title h2{
    font-size:1.55rem;
  }
  .modal-kpi-row,
  .info-grid{
    grid-template-columns:1fr;
  }
}


/* ===== FUNCAM V13.4: transiciones dinámicas y movimiento visual ===== */
html{
  scroll-padding-top:118px;
}
body{
  animation:pageFadeIn .55s ease both;
}
@keyframes pageFadeIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

/* Barra de progreso de navegación */
.scroll-progress{
  position:fixed;
  left:0;
  top:0;
  height:4px;
  width:0;
  z-index:5000;
  background:linear-gradient(90deg,var(--lime),var(--orange),var(--teal));
  box-shadow:0 0 18px rgba(139,197,63,.45);
}

/* Transición fluida entre bloques */
.flow-section{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.flow-section > .container{
  position:relative;
  z-index:2;
}
.flow-section::before{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  border-radius:50%;
  right:-260px;
  top:12%;
  z-index:0;
  background:radial-gradient(circle,rgba(139,197,63,.12),transparent 66%);
  animation:floatGlow 12s ease-in-out infinite;
  pointer-events:none;
}
.flow-section:nth-of-type(even)::before{
  left:-240px;
  right:auto;
  background:radial-gradient(circle,rgba(8,124,128,.12),transparent 66%);
  animation-delay:-4s;
}
@keyframes floatGlow{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(-24px,34px,0) scale(1.12)}
}
.flow-wave{
  height:72px;
  margin-top:-1px;
  background:
    radial-gradient(120% 80px at 50% -20px, rgba(8,124,128,.10), transparent 60%),
    linear-gradient(90deg,rgba(8,124,128,.12),rgba(214,238,41,.16),rgba(244,122,32,.12));
  clip-path:polygon(0 18%,12% 28%,26% 18%,42% 34%,57% 20%,75% 31%,100% 16%,100% 100%,0 100%);
  opacity:.9;
}

/* Hero más vivo */
.hero-slide img{
  animation:heroKenburns 9s ease-in-out infinite alternate;
}
.hero-slide.active img{
  animation-play-state:running;
}
@keyframes heroKenburns{
  from{transform:scale(1.02) translate3d(0,0,0)}
  to{transform:scale(1.08) translate3d(-12px,8px,0)}
}
.hero-content .reveal.visible{
  animation:heroTextEnter .8s cubic-bezier(.2,.75,.2,1) both;
}
@keyframes heroTextEnter{
  from{opacity:0;transform:translateY(28px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* Entrada por bloques menos esquelética */
.reveal{
  will-change:transform,opacity;
}
.reveal.visible{
  animation:softRise .8s cubic-bezier(.2,.75,.2,1) both;
}
@keyframes softRise{
  from{opacity:0;transform:translateY(34px) scale(.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.card-grid .reveal:nth-child(1),
.career-grid .reveal:nth-child(1),
.module-grid .reveal:nth-child(1){animation-delay:.02s}
.card-grid .reveal:nth-child(2),
.career-grid .reveal:nth-child(2),
.module-grid .reveal:nth-child(2){animation-delay:.09s}
.card-grid .reveal:nth-child(3),
.career-grid .reveal:nth-child(3),
.module-grid .reveal:nth-child(3){animation-delay:.16s}
.card-grid .reveal:nth-child(4),
.career-grid .reveal:nth-child(4),
.module-grid .reveal:nth-child(4){animation-delay:.23s}
.card-grid .reveal:nth-child(5),
.career-grid .reveal:nth-child(5),
.module-grid .reveal:nth-child(5){animation-delay:.30s}
.career-grid .reveal:nth-child(6){animation-delay:.37s}

/* Hover más moderno en tarjetas */
.program-card,
.career-card,
.module,
.quick-card,
.text-panel,
.visual-panel,
.form-card,
.sim-form,
.sim-result,
.login-card{
  transform-style:preserve-3d;
}
.program-card:hover,
.career-card:hover,
.quick-card:hover,
.module:hover{
  transform:translateY(-10px) scale(1.01);
}
.card-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.16),transparent 48%,rgba(8,124,128,.10));
  opacity:0;
  transition:.35s ease;
}
.program-card:hover .card-image::after,
.career-card:hover .card-image::after{
  opacity:1;
}
.card-badge{
  transition:.28s ease;
}
.program-card:hover .card-badge,
.career-card:hover .card-badge{
  transform:translateY(-3px);
  box-shadow:0 18px 30px rgba(7,27,53,.18);
}

/* Imágenes con respiración visual */
.visual-panel img,
.homologation-box img,
.englishscore-visual img,
.sim-hero-visual img{
  transition:transform .7s cubic-bezier(.2,.75,.2,1), filter .7s ease;
}
.visual-panel:hover img,
.homologation-box:hover img,
.englishscore-visual:hover img,
.sim-hero-visual:hover img{
  transform:scale(1.045);
  filter:saturate(1.05) contrast(1.03);
}

/* Botones más vivos */
.btn{
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:"";
  position:absolute;
  inset:0;
  transform:translateX(-120%) skewX(-18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);
  transition:.65s ease;
}
.btn:hover::after{
  transform:translateX(120%) skewX(-18deg);
}

/* Navegación activa y dinámica */
.nav a{
  position:relative;
}
.nav a::after{
  content:"";
  position:absolute;
  left:16px;
  right:16px;
  bottom:5px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--teal),var(--lime));
  transform:scaleX(0);
  transform-origin:left;
  transition:.25s ease;
}
.nav a:hover::after,
.nav a.active::after{
  transform:scaleX(1);
}

/* WhatsApp: pulso suave */
.whatsapp-float{
  animation:whatsappPulse 2.6s ease-in-out infinite;
}
@keyframes whatsappPulse{
  0%,100%{box-shadow:0 18px 34px rgba(37,211,102,.36),0 0 0 0 rgba(37,211,102,.28)}
  50%{box-shadow:0 18px 34px rgba(37,211,102,.36),0 0 0 14px rgba(37,211,102,0)}
}

/* Modales: entrada más elegante */
.modal.open .modal-dialog{
  animation:modalEnter .34s cubic-bezier(.2,.75,.2,1) both;
}
@keyframes modalEnter{
  from{opacity:0;transform:translateY(22px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* Transiciones internas de página */
.page-hero .page-text.reveal.visible,
.clean-sim .sim-hero-text.reveal.visible,
.englishscore-copy.reveal.visible{
  animation:pageHeroText .85s cubic-bezier(.2,.75,.2,1) both;
}
@keyframes pageHeroText{
  from{opacity:0;transform:translateX(-26px)}
  to{opacity:1;transform:translateX(0)}
}

/* Reducir movimiento si el dispositivo lo solicita */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
}


/* ===== FUNCAM V13.5: programas profesionales, simulador y WhatsApp fijo ===== */
.whatsapp-float{
  position:fixed !important;
  right:26px !important;
  bottom:26px !important;
  z-index:6500 !important;
  width:64px !important;
  height:64px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  background:#25D366 !important;
  box-shadow:0 22px 46px rgba(37,211,102,.42),0 0 0 0 rgba(37,211,102,.32) !important;
}
.whatsapp-float img{
  width:64px !important;
  height:64px !important;
}
.career-link{
  display:inline-flex;
  align-items:center;
  color:var(--teal);
  font-weight:950;
  margin-top:auto;
}
.program-page-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#071b35,#102b4e);
  color:#fff;
}
.program-page-hero .container{
  min-height:560px;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:38px;
  align-items:center;
}
.program-page-copy h1{
  font-size:clamp(2.8rem,5.7vw,5.4rem);
  line-height:.95;
  letter-spacing:-.07em;
  margin:18px 0;
}
.program-page-copy p{
  color:#dbe8f0;
  font-size:1.08rem;
}
.program-page-img{
  position:relative;
  min-height:430px;
  border-radius:42px;
  overflow:hidden;
  background:linear-gradient(135deg,#fff,#f1fbf7);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 28px 90px rgba(0,0,0,.25);
}
.program-page-img img{
  width:100%;
  height:100%;
  min-height:430px;
  object-fit:cover;
}
.program-plan-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.program-plan-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:24px;
  box-shadow:0 18px 48px rgba(7,27,53,.08);
}
.program-plan-card h3{
  color:var(--teal);
  margin-top:0;
}
.program-plan-card li{
  color:var(--muted);
  margin:8px 0;
}
.sim-shell-v2{
  grid-template-columns:1fr 1fr;
}
.sim-result-v2 .result-list div{
  align-items:start;
}
.sim-result-v2 .result-list strong{
  text-align:right;
  max-width:56%;
}
@media(max-width:980px){
  .program-page-hero .container,
  .program-plan-grid,
  .sim-shell-v2{
    grid-template-columns:1fr;
  }
  .program-page-hero .container{
    min-height:auto;
    padding:60px 0;
  }
}


/* ===== FUNCAM V13.6: interfaces internas tipo canal y WhatsApp permanente ===== */
.channel-hero{
  position:relative;
  min-height:640px;
  overflow:hidden;
  color:#fff;
  background:#071b35;
  isolation:isolate;
}
.channel-hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.channel-hero-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:saturate(1.02) contrast(1.02);
}
.channel-hero-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(7,27,53,.94) 0%,rgba(7,27,53,.80) 43%,rgba(7,27,53,.30) 72%,rgba(7,27,53,.18) 100%),
    radial-gradient(circle at 82% 28%,rgba(139,197,63,.16),transparent 28%);
}
.channel-hero-shape{
  position:absolute;
  z-index:1;
  left:-15%;
  top:0;
  height:100%;
  width:58%;
  background:linear-gradient(135deg,rgba(139,197,63,.78),rgba(8,124,128,.56));
  clip-path:polygon(0 0,83% 0,57% 100%,0 100%);
  mix-blend-mode:multiply;
}
.channel-hero .container{
  position:relative;
  z-index:2;
  min-height:640px;
  display:grid;
  grid-template-columns:minmax(0,.86fr) minmax(0,1.14fr);
  gap:40px;
  align-items:center;
}
.channel-copy{
  max-width:720px;
}
.channel-copy h1{
  font-size:clamp(3rem,6.5vw,6.15rem);
  line-height:.92;
  letter-spacing:-.08em;
  margin:18px 0 18px;
}
.channel-copy p{
  color:#e0edf4;
  font-size:1.1rem;
  max-width:660px;
}
.channel-card{
  justify-self:end;
  width:min(470px,100%);
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:34px;
  padding:24px;
  backdrop-filter:blur(16px);
  box-shadow:0 34px 90px rgba(0,0,0,.28);
}
.channel-card h3{
  margin:0 0 10px;
  font-size:1.35rem;
}
.channel-card ul{
  margin:0;
  padding-left:19px;
  color:#dce8ef;
}
.channel-card li{
  margin:9px 0;
}
.channel-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:24px 0 30px;
}
.channel-meta span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border-radius:999px;
  padding:10px 13px;
  font-size:.82rem;
  font-weight:950;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.program-detail-block{
  background:linear-gradient(180deg,#f6fbfc,#eef8f2);
}
.program-intro-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:26px;
  align-items:start;
}
.program-summary-card{
  position:sticky;
  top:126px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:28px;
  box-shadow:var(--shadow);
}
.program-summary-card h2{
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:1;
  letter-spacing:-.06em;
  margin:12px 0;
}
.program-summary-card p{
  color:var(--muted);
}
.program-summary-card .email-pill{
  word-break:break-word;
  white-space:normal;
}
.program-plan-grid.v13-6{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.program-plan-card{
  transition:.28s ease;
}
.program-plan-card:hover{
  transform:translateY(-7px);
  box-shadow:var(--shadow);
}
.program-note{
  margin-top:24px;
  padding:20px;
  border-radius:24px;
  background:#fff7e9;
  border:1px solid #f4d5a8;
  color:#6b4b20;
}
.homologation-mini{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:24px;
  box-shadow:0 18px 48px rgba(7,27,53,.08);
}
.whatsapp-float{
  position:fixed !important;
  right:24px !important;
  bottom:24px !important;
  z-index:99999 !important;
  width:64px !important;
  height:64px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  background:#25D366 !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:none !important;
}
.whatsapp-float img{
  width:64px !important;
  height:64px !important;
  display:block !important;
}
body.modal-open .whatsapp-float{
  z-index:99999 !important;
}
.sim-shell-v2{
  align-items:stretch;
}
.sim-result-v2{
  top:126px;
}
@media(max-width:1040px){
  .channel-hero .container,
  .program-intro-grid,
  .program-plan-grid.v13-6{
    grid-template-columns:1fr;
  }
  .channel-card{
    justify-self:start;
  }
  .program-summary-card{
    position:relative;
    top:auto;
  }
}
@media(max-width:720px){
  .channel-hero,
  .channel-hero .container{
    min-height:auto;
  }
  .channel-hero .container{
    padding:72px 0;
  }
  .channel-hero-shape{
    width:86%;
  }
  .channel-copy h1{
    font-size:3.15rem;
  }
}


/* ===== FUNCAM V13.7: reparación visual de canales, planes completos y WhatsApp dinámico ===== */
.channel-hero{
  min-height:620px;
}
.channel-hero .container{
  min-height:620px;
  grid-template-columns:1fr .82fr;
}
.channel-hero-bg::after{
  background:
    linear-gradient(90deg,rgba(7,27,53,.96) 0%,rgba(7,27,53,.87) 42%,rgba(7,27,53,.52) 70%,rgba(7,27,53,.26) 100%),
    radial-gradient(circle at 82% 28%,rgba(139,197,63,.12),transparent 28%);
}
.channel-hero-shape{
  width:52%;
  opacity:.90;
}
.channel-copy{
  max-width:640px;
}
.channel-copy h1{
  font-size:clamp(2.55rem,5.1vw,4.95rem);
  line-height:.96;
  letter-spacing:-.068em;
  text-shadow:0 18px 45px rgba(0,0,0,.32);
}
.channel-copy p{
  font-size:1.03rem;
  max-width:570px;
}
.channel-card{
  width:min(430px,100%);
  background:rgba(7,27,53,.54);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 28px 76px rgba(0,0,0,.32);
}
.channel-card li{
  color:#edf6f9;
}
.channel-meta span{
  background:rgba(255,255,255,.13);
  box-shadow:0 12px 26px rgba(0,0,0,.12);
}
.program-kpis{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
  margin:22px 0 0;
}
.program-kpi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:16px;
  box-shadow:0 14px 34px rgba(7,27,53,.07);
}
.program-kpi small{
  display:block;
  color:var(--muted);
  font-weight:850;
  font-size:.73rem;
}
.program-kpi strong{
  display:block;
  margin-top:4px;
  color:var(--navy);
  font-size:.92rem;
  line-height:1.25;
}
.program-source{
  margin-top:18px;
  padding:16px 18px;
  border-radius:20px;
  background:#edf8f5;
  border:1px solid #cae8e3;
  color:#295a5e;
  font-size:.86rem;
}
.program-plan-grid.v13-7{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.program-plan-card{
  min-height:100%;
}
.program-plan-card ul{
  padding-left:18px;
}
.program-plan-card li{
  font-size:.88rem;
  line-height:1.42;
}
.whatsapp-float{
  position:fixed !important;
  right:18px !important;
  top:56% !important;
  bottom:auto !important;
  z-index:2147483000 !important;
  width:64px !important;
  height:64px !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  background:#25D366 !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(-50%) !important;
  animation:waSideFloat 3.2s ease-in-out infinite !important;
}
.whatsapp-float img{
  width:64px !important;
  height:64px !important;
}
.whatsapp-float span{
  position:absolute;
  right:74px;
  top:50%;
  transform:translateY(-50%);
  background:#071b35;
  color:#fff;
  font-weight:950;
  padding:9px 12px;
  border-radius:999px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:.25s ease;
  box-shadow:0 16px 34px rgba(7,27,53,.22);
}
.whatsapp-float:hover span{
  opacity:1;
  transform:translateY(-50%) translateX(-4px);
}
@keyframes waSideFloat{
  0%,100%{margin-top:0; box-shadow:0 22px 48px rgba(37,211,102,.42),0 0 0 0 rgba(37,211,102,.30)}
  50%{margin-top:-18px; box-shadow:0 22px 48px rgba(37,211,102,.42),0 0 0 15px rgba(37,211,102,0)}
}
@media(max-width:1120px){
  .program-plan-grid.v13-7{
    grid-template-columns:repeat(2,1fr);
  }
  .program-kpis{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:720px){
  .channel-hero .container{
    grid-template-columns:1fr;
    min-height:auto;
    padding:70px 0;
  }
  .channel-copy h1{
    font-size:3rem;
  }
  .program-plan-grid.v13-7,
  .program-kpis{
    grid-template-columns:1fr;
  }
  .whatsapp-float{
    top:auto !important;
    bottom:22px !important;
    right:18px !important;
    transform:none !important;
  }
  .whatsapp-float span{
    display:none;
  }
}


/* ===== FUNCAM V13.8: imagen no cortada y temáticas técnicas ampliadas ===== */
.channel-hero-bg.safe-bg{
  overflow:hidden;
  background:#071b35;
}
.channel-hero-bg.safe-bg img{
  position:absolute;
  inset:0;
}
.channel-hero-bg.safe-bg .bg-blur{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:blur(18px) brightness(.62) saturate(1.08);
  transform:scale(1.08);
}
.channel-hero-bg.safe-bg .bg-main{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:right center;
  filter:saturate(1.02) contrast(1.02);
  transform:scale(.96);
  transform-origin:right center;
}
.channel-hero-bg.safe-bg::after{
  z-index:2;
}
.channel-hero-shape{
  z-index:3;
}
.channel-hero .container{
  z-index:4;
}
.channel-card{
  max-height:420px;
  overflow:auto;
}
.program-plan-grid.v13-8{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}
.program-plan-grid.v13-8 .program-plan-card{
  padding:24px;
}
.program-plan-grid.v13-8 .program-plan-card li{
  font-size:.88rem;
  line-height:1.42;
  margin:7px 0;
}
.program-kpis.tech-kpis{
  grid-template-columns:repeat(4,1fr);
}
.whatsapp-float{
  position:fixed !important;
  right:20px !important;
  top:55% !important;
  bottom:auto !important;
  z-index:2147483647 !important;
  width:66px !important;
  height:66px !important;
  border-radius:50% !important;
  background:#25D366 !important;
  display:grid !important;
  place-items:center !important;
  transform:translateY(-50%) !important;
  animation:waMoveSide 3s ease-in-out infinite !important;
  opacity:1 !important;
  visibility:visible !important;
}
.whatsapp-float img{
  width:66px !important;
  height:66px !important;
}
.whatsapp-float span{
  position:absolute;
  right:76px;
  top:50%;
  transform:translateY(-50%);
  background:#071b35;
  color:#fff;
  font-weight:950;
  border-radius:999px;
  padding:9px 13px;
  opacity:0;
  transition:.25s ease;
  white-space:nowrap;
  box-shadow:0 18px 38px rgba(7,27,53,.22);
}
.whatsapp-float:hover span{
  opacity:1;
  transform:translateY(-50%) translateX(-4px);
}
@keyframes waMoveSide{
  0%,100%{margin-top:0; box-shadow:0 20px 42px rgba(37,211,102,.38),0 0 0 0 rgba(37,211,102,.28)}
  50%{margin-top:-20px; box-shadow:0 20px 42px rgba(37,211,102,.38),0 0 0 16px rgba(37,211,102,0)}
}
@media(max-width:1100px){
  .program-plan-grid.v13-8,
  .program-kpis.tech-kpis{
    grid-template-columns:1fr;
  }
}
@media(max-width:720px){
  .channel-hero-bg.safe-bg .bg-main{
    object-position:center;
    transform:scale(1);
    opacity:.82;
  }
  .whatsapp-float{
    top:auto !important;
    bottom:20px !important;
    right:18px !important;
    transform:none !important;
  }
  .whatsapp-float span{
    display:none;
  }
}


/* ===== FUNCAM V13.9: hover animado y eliminación de cuadros sobre imagen ===== */

/* Elimina los cuadros laterales del hero interno porque la información ya aparece abajo */
.channel-card{
  display:none !important;
}

/* El hero mantiene el diseño, pero el texto respira mejor sin el cuadro lateral */
.channel-hero .container{
  grid-template-columns:1fr !important;
}
.channel-copy{
  max-width:720px !important;
}
.channel-copy h1{
  max-width:760px;
}
.channel-copy p{
  max-width:640px;
}

/* Imagen del hero más limpia al no tener cuadro encima */
.channel-hero-bg.safe-bg .bg-main{
  object-position:right center;
  transform:scale(.94);
}
.channel-hero-bg.safe-bg::after{
  background:
    linear-gradient(90deg,rgba(7,27,53,.96) 0%,rgba(7,27,53,.82) 42%,rgba(7,27,53,.36) 76%,rgba(7,27,53,.12) 100%),
    radial-gradient(circle at 82% 28%,rgba(139,197,63,.10),transparent 28%) !important;
}

/* Animación tipo programas académicos: el card sobresale y cambia de color */
.card-grid:hover .program-card:not(:hover),
.career-grid:hover .career-card:not(:hover){
  opacity:.62;
  filter:saturate(.72) contrast(.92);
  transform:scale(.985);
}

.program-card,
.career-card{
  position:relative;
  isolation:isolate;
  overflow:hidden;
}

.program-card::before,
.career-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  opacity:0;
  background:
    linear-gradient(135deg,rgba(214,238,41,.98),rgba(8,124,128,.94) 52%,rgba(244,122,32,.92));
  transform:translateY(100%);
  transition:opacity .35s ease, transform .45s cubic-bezier(.2,.75,.2,1);
}

.program-card:hover::before,
.career-card:hover::before{
  opacity:1;
  transform:translateY(0);
  animation:funcamColorFlow 4.5s ease-in-out infinite alternate;
}

@keyframes funcamColorFlow{
  0%{filter:hue-rotate(0deg) saturate(1)}
  50%{filter:hue-rotate(18deg) saturate(1.18)}
  100%{filter:hue-rotate(-10deg) saturate(1.08)}
}

.program-card .card-image,
.program-card .card-body,
.career-card .card-image,
.career-card .card-body{
  position:relative;
  z-index:1;
}

.program-card:hover,
.career-card:hover{
  transform:translateY(-14px) scale(1.025) !important;
  box-shadow:0 34px 90px rgba(7,27,53,.28) !important;
  border-color:rgba(255,255,255,.42);
}

.program-card:hover .card-image,
.career-card:hover .card-image{
  background:transparent;
}

.program-card:hover .card-image img,
.career-card:hover .card-image img{
  transform:scale(1.08);
  filter:saturate(1.08) contrast(1.04);
  mix-blend-mode:multiply;
  opacity:.88;
}

.program-card:hover .card-body,
.career-card:hover .card-body{
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.96));
  border-top:1px solid rgba(255,255,255,.45);
}

.program-card:hover .card-body h3,
.career-card:hover .card-body h3{
  color:#071b35;
}

.program-card:hover .card-body p,
.career-card:hover .card-body p{
  color:#23384f;
}

.program-card:hover .card-badge,
.career-card:hover .card-badge{
  background:#071b35;
  color:#fff;
  box-shadow:0 16px 34px rgba(7,27,53,.28);
}

.program-card:hover .card-meta span,
.career-card:hover .card-meta span{
  background:rgba(7,27,53,.08);
  color:#071b35;
}

.program-card:hover .career-link,
.career-card:hover .career-link,
.program-card:hover .card-link,
.career-card:hover .card-link{
  color:#071b35;
  font-weight:1000;
}

/* Efecto de luz al pasar el cursor */
.program-card::after,
.career-card::after{
  content:"";
  position:absolute;
  z-index:2;
  top:-30%;
  left:-50%;
  width:42%;
  height:150%;
  opacity:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);
  transform:rotate(18deg) translateX(-120%);
  pointer-events:none;
}

.program-card:hover::after,
.career-card:hover::after{
  opacity:1;
  animation:shineCard 1.15s ease forwards;
}

@keyframes shineCard{
  from{transform:rotate(18deg) translateX(-130%)}
  to{transform:rotate(18deg) translateX(420%)}
}

/* Cards más parecidas a bloque académico con impacto visual */
.program-card .card-image,
.career-card .card-image{
  transition:height .3s ease, background .3s ease;
}

.program-card:hover .card-image,
.career-card:hover .card-image{
  height:250px;
}

.career-card:hover .card-image{
  height:292px;
}

/* Mejor transición de entrada de las tarjetas */
.card-grid .program-card,
.career-grid .career-card{
  transition:
    transform .38s cubic-bezier(.2,.75,.2,1),
    box-shadow .38s ease,
    opacity .28s ease,
    filter .28s ease,
    border-color .28s ease;
}

/* En móvil se mantiene estable sin exagerar el hover */
@media(max-width:720px){
  .card-grid:hover .program-card:not(:hover),
  .career-grid:hover .career-card:not(:hover){
    opacity:1;
    filter:none;
    transform:none;
  }
  .program-card:hover,
  .career-card:hover{
    transform:translateY(-6px) scale(1.01) !important;
  }
  .program-card:hover .card-image,
  .career-card:hover .card-image{
    height:236px;
  }
  .career-card:hover .card-image{
    height:280px;
  }
}
