*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden;}
body{font-family:'Montserrat','Segoe UI',system-ui,sans-serif;background:#ffffff;color:var(--text-primary);line-height:1.6;overflow-x:hidden;max-width:100vw;}
a{text-decoration:none;cursor:pointer;color:inherit;}
img{max-width:100%;display:block;}
button{cursor:pointer;font-family:inherit;}
input,select,textarea{font-family:inherit;}
:root{
  --gold:#57B9FF;--gold-light:#90D5FF;--gold-dim:#517891;
  --dark-bg:#06080f;--dark-surface:#f0f6ff;--dark-card:#ffffff;
  --dark-border:rgba(87,185,255,.22);--dark-border-strong:rgba(87,185,255,.45);
  --text-primary:#0c1a25;--text-secondary:#2d5068;--text-muted:#5a7d93;
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:32px;
  --transition:.25s cubic-bezier(.4,0,.2,1);
  --shadow-gold:0 0 40px rgba(87,185,255,.15);--shadow-card:0 4px 20px rgba(87,185,255,.1);
  --wa-number:522229480240;
}

/* ══ SCOPE OSCURO: hero, footer, paneles auxiliares ══ */
.hero,
footer,
#quickView{
  --dark-surface:#0c1018;
  --dark-card:#111820;
  --dark-border:rgba(87,185,255,.18);
  --dark-border-strong:rgba(87,185,255,.35);
  --text-primary:#eef4ff;
  --text-secondary:#8bafc8;
  --text-muted:#476070;
}
.hero{background:var(--dark-bg);}
footer{background:#080810;color:var(--text-primary);}
#quickView{background:var(--dark-bg);color:var(--text-primary);}

/* ══ DETALLE: tema blanco ══ */
#detalle{background:#ffffff;color:var(--text-primary);min-height:100vh;}
#detalle .dv-body{background:#ffffff;}
#detalle .side-cta{background:#f5f9ff;}
#detalle .dv-body .dv-card,
#detalle .dv-body .side-card,
#detalle .dv-body .side-cta{box-shadow:0 2px 16px rgba(87,185,255,.08),0 1px 4px rgba(0,0,0,.05);}

/* ══ CAMPUS VIEW: tema blanco + hero #36beee ══ */
#campusView{background:#ffffff;color:var(--text-primary);min-height:100vh;}
#campusView .dv-hero{
  background:linear-gradient(135deg,rgba(54,190,238,.92) 0%,rgba(20,130,180,.78) 45%,rgba(6,8,20,.96) 100%);
  position:relative;overflow:hidden;
}
#campusView .dv-body{background:#ffffff;}
#campusView .side-cta{background:#f5f9ff;}
#campusView .dv-body .dv-card,
#campusView .dv-body .side-card,
#campusView .dv-body .side-cta{box-shadow:0 2px 16px rgba(87,185,255,.08),0 1px 4px rgba(0,0,0,.05);}
/* Texto legible sobre el hero */
#campusView .dv-hero h1{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.4);}
#campusView .dv-hero p{color:rgba(255,255,255,.88);}
#campusView .dv-hero .dv-badge{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.28);color:#fff;}
#campusView .dv-hero .breadcrumb{color:rgba(255,255,255,.6);}
#campusView .dv-hero .breadcrumb .current{color:#fff;}
#campusView .dv-hero .breadcrumb span:hover{color:#fff;}
#campusView .dv-hero .gold-line{background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);}
#campusView .dv-hero .btn-back{color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.3);}
#campusView .dv-hero .btn-back:hover{color:#fff;border-color:#fff;}
#campusView .dv-hero .gold-line,
#campusView .dv-hero .breadcrumb,
#campusView .dv-hero .dv-hero-body,
#campusView .dv-hero .dv-badge,
#campusView .dv-hero h1,
#campusView .dv-hero p,
#campusView .dv-hero .dv-btns{position:relative;z-index:1;}
/* Partículas campus hero */
#cvParticles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
#cvParticles .particle{background:rgba(255,255,255,.75);}
.cursor-glow{position:fixed;width:400px;height:400px;background:radial-gradient(circle,rgba(87,185,255,.06) 0%,transparent 70%);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:left .06s,top .06s;}
#navbar{
  position:fixed;left:50%;transform:translateX(-50%);
  width:calc(100% - 2.5rem);max-width:1020px;
  z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:0 1.25rem;height:64px;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(87,185,255,.22);
  border-radius:50px;
  box-shadow:0 6px 28px rgba(87,185,255,.12),0 2px 6px rgba(0,0,0,.07);
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,transform .35s cubic-bezier(.4,0,.2,1),opacity .3s ease;
}
#navbar.scrolled{
  background:rgba(255,255,255,.97);
  border-color:rgba(87,185,255,.35);
  box-shadow:0 8px 36px rgba(87,185,255,.18),0 2px 8px rgba(0,0,0,.09);
}
#navbar.nav-hidden{
  transform:translateX(-50%) translateY(calc(-100% - 60px));
  opacity:0;
  pointer-events:none;
}
.nav-logo{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;}
.nav-logo img{height:42px;width:auto;object-fit:contain;}
.nav-logo-inicio{font-size:10px;font-weight:600;color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase;line-height:1;}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.2;}
.nav-logo-text strong{font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:.03em;}
.nav-logo-text span{font-size:10px;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;}
.nav-links li a{padding:6px 12px;border-radius:30px;font-size:12.5px;font-weight:500;color:var(--text-secondary);transition:var(--transition);cursor:pointer;white-space:nowrap;}
.nav-links li a:hover{color:var(--text-primary);background:rgba(87,185,255,.1);}
.nav-links li a.nav-active{color:var(--gold);background:rgba(87,185,255,.12);font-weight:600;}
.nav-links li a.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;font-weight:700;letter-spacing:.02em;border-radius:30px;}
.nav-links li a.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(87,185,255,.4);}
.nav-dropdown{position:relative;}
.nav-drop-trigger{display:flex!important;align-items:center;gap:.3rem;}
.nav-drop-trigger .drop-arrow{font-size:9px;transition:transform .2s ease;display:inline-block;}
.nav-dropdown.open .drop-arrow{transform:rotate(180deg);}
.nav-drop-menu{position:absolute;top:100%;left:0;background:rgba(10,11,20,.97);backdrop-filter:blur(20px);border:1px solid rgba(87,185,255,.15);border-radius:12px;padding:.45rem 0;padding-top:10px;min-width:210px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease;box-shadow:0 10px 36px rgba(0,0,0,.45);z-index:200;}
.nav-dropdown.open .nav-drop-menu{opacity:1;pointer-events:all;transform:translateY(0);}
.nav-drop-menu li{list-style:none;}
.nav-drop-menu li a{display:block;padding:.58rem 1.1rem;color:rgba(255,255,255,.78);font-size:12.5px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease;border-radius:0;}
.nav-drop-menu li a:hover{background:rgba(87,185,255,.1);color:#fff;}
/* Wide 2-column dropdown */
.nav-drop-menu.nav-drop-wide{min-width:400px;display:flex!important;padding:.5rem 0;flex-direction:row;}
.drop-col{flex:1;display:flex;flex-direction:column;padding:.25rem 0;}
.drop-col:first-child{border-right:1px solid rgba(87,185,255,.1);}
.drop-col-label{font-size:9px;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;padding:.4rem 1.1rem .3rem;display:block;white-space:nowrap;}
.drop-col a{display:block;padding:.48rem 1.1rem;color:rgba(255,255,255,.78);font-size:12px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;font-weight:500;}
.drop-col a:hover{background:rgba(87,185,255,.1);color:#fff;}
/* ── MEGA-MENU ── */
.drop-mega{position:absolute;top:calc(100% + 8px);left:0;background:rgba(8,9,18,.97);backdrop-filter:blur(24px);border:1px solid rgba(87,185,255,.13);border-radius:14px;padding:.5rem;display:grid;grid-template-columns:1fr;gap:2px;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .18s ease,transform .18s ease;box-shadow:0 12px 40px rgba(0,0,0,.55);z-index:200;min-width:230px;}
.drop-mega-2col{grid-template-columns:1fr 1fr;min-width:370px;}
.drop-mega-3col{grid-template-columns:1fr 1fr 1fr;min-width:560px;}
.nav-dropdown.open .drop-mega{opacity:1;pointer-events:all;transform:translateY(0);}
.dmeg-item{display:flex;align-items:center;gap:.65rem;padding:.52rem .65rem;border-radius:10px;text-decoration:none;cursor:pointer;transition:background .15s ease;color:inherit;}
.dmeg-item:hover{background:rgba(87,185,255,.06);}
.dmeg-icon{width:36px;height:36px;border-radius:9px;background:rgba(var(--ic),.12);border:1px solid rgba(var(--ic),.2);display:flex;align-items:center;justify-content:center;color:rgb(var(--ic));flex-shrink:0;transition:background .15s;}
.dmeg-item:hover .dmeg-icon{background:rgba(var(--ic),.22);}
.dmeg-text{display:flex;flex-direction:column;gap:1px;min-width:0;}
.dmeg-text strong{font-size:12px;font-weight:600;color:rgba(255,255,255,.9);line-height:1.2;white-space:nowrap;}
.dmeg-text span{font-size:10px;color:rgba(255,255,255,.42);}
/* Mobile menu section labels */
.mobile-menu .mm-label{display:block;padding:10px 16px 3px;font-size:9.5px;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;border-top:1px solid rgba(87,185,255,.1);margin-top:6px;pointer-events:none;}
.nav-social-mobile{display:none;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;}
.hamburger span{width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:var(--transition);}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;z-index:999;background:rgba(6,8,15,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--dark-border);flex-direction:column;padding:1.5rem 5% 2rem;gap:4px;transform:translateY(-10px);opacity:0;pointer-events:none;transition:var(--transition);overflow-y:auto;-webkit-overflow-scrolling:touch;}
.mobile-menu.open{display:flex;transform:translateY(0);opacity:1;pointer-events:all;}
.mobile-menu a{padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:15px;cursor:pointer;transition:var(--transition);}
.mobile-menu a:hover{color:var(--text-primary);background:rgba(255,255,255,.05);}
.mm-social{display:flex;gap:10px;padding:6px 16px 14px;flex-wrap:wrap;}
.mm-social-btn{width:40px;height:40px;border-radius:50%;background:rgba(87,185,255,.07);border:1px solid rgba(87,185,255,.18);display:flex;align-items:center;justify-content:center;color:rgba(87,185,255,.8);transition:background .2s,color .2s,border-color .2s;padding:0 !important;}
.mm-social-btn:hover{background:rgba(87,185,255,.22) !important;color:#fff !important;border-color:rgba(87,185,255,.5);}
.mm-fb:hover{background:rgba(24,119,242,.25) !important;color:#4a90e2 !important;}
.mm-ig:hover{background:rgba(214,41,118,.2) !important;color:#e1306c !important;}
.mm-li:hover{background:rgba(10,102,194,.2) !important;color:#0a66c2 !important;}
.mm-tt:hover{background:rgba(0,0,0,.35) !important;color:#fff !important;}
.mm-yt:hover{background:rgba(255,0,0,.2) !important;color:#ff0000 !important;}
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:rgba(6,8,15,.95);backdrop-filter:blur(20px);border-top:1px solid var(--dark-border);padding:8px 0 max(8px,env(safe-area-inset-bottom));}
.mobile-bar-inner{display:flex;justify-content:space-around;}
.mobile-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-muted);font-size:10px;font-weight:500;padding:6px 16px;border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;}
.mobile-bar a:hover{color:var(--gold);}
.bar-icon{font-size:18px;display:block;}
.float-wa{position:fixed;bottom:90px;right:24px;z-index:900;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#25d366,#128c7e);display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--transition);text-decoration:none;}
.float-wa:hover{transform:scale(1.1);}

/* ══ SOCIAL FLOAT IZQUIERDO ══ */
.social-float{
  position:fixed;left:0;top:50%;transform:translateY(-50%);
  z-index:850;display:flex;flex-direction:column;gap:5px;
}
.sf-btn{
  display:flex;align-items:center;
  height:46px;max-width:46px;overflow:hidden;
  white-space:nowrap;text-decoration:none;color:#fff;
  border-radius:0 24px 24px 0;
  box-shadow:2px 2px 12px rgba(0,0,0,.22);
  transition:max-width .38s cubic-bezier(.34,1.15,.64,1),box-shadow .25s;
}
.sf-btn:hover{max-width:190px;box-shadow:3px 5px 20px rgba(0,0,0,.32);}
.sf-icon{
  flex-shrink:0;width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
}
.sf-label{
  font-size:12.5px;font-weight:700;letter-spacing:.03em;
  padding-right:18px;
}
.sf-fb{background:#1877F2;}
.sf-ig{background:linear-gradient(160deg,#f09433 0%,#e6683c 22%,#dc2743 48%,#cc2366 73%,#bc1888 100%);}
.sf-li{background:#0A66C2;}
.sf-tt{background:#010101;}
.sf-yt{background:#FF0000;}

@media(max-width:768px){
  .sf-btn{height:40px;max-width:40px;}
  .sf-btn:hover{max-width:170px;}
  .sf-icon{width:40px;height:40px;}
  .sf-label{font-size:11.5px;}
}
@media(max-width:480px){.social-float{display:none;}}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:100px 5% 60px;overflow:hidden;}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(87,185,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(87,185,255,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent);}
.hero-glow{position:absolute;top:-20%;left:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(87,185,255,.08),transparent 65%);pointer-events:none;}
.gold-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%;max-width:1200px;margin:0 auto;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(87,185,255,.12);border:1px solid var(--dark-border-strong);color:var(--gold);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:var(--radius-xl);margin-bottom:1.5rem;}
.hero-content h1{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#fff;margin-bottom:1.25rem;}
.hero-content h1 em{font-style:normal;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-content p{font-size:1.1rem;color:var(--text-secondary);line-height:1.7;max-width:520px;margin-bottom:2.5rem;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:3rem;}
.btn-primary{display:inline-flex;align-items:center;background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;font-weight:700;font-size:14px;letter-spacing:.03em;padding:14px 28px;border-radius:var(--radius-md);transition:var(--transition);border:none;cursor:pointer;text-decoration:none;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(87,185,255,.45);}
.btn-primary span{position:relative;z-index:1;}
.btn-outline{display:inline-flex;align-items:center;border:1px solid var(--dark-border-strong);color:var(--text-primary);font-size:14px;font-weight:500;padding:14px 28px;border-radius:var(--radius-md);transition:var(--transition);text-decoration:none;}
.btn-outline:hover{background:rgba(87,185,255,.08);border-color:var(--gold);}
.btn-back{display:inline-flex;align-items:center;border:1px solid var(--dark-border);color:var(--text-secondary);font-size:14px;font-weight:500;padding:12px 22px;border-radius:var(--radius-md);transition:var(--transition);}
.btn-back:hover{border-color:var(--dark-border-strong);color:var(--text-primary);}
/* back button always visible on dark hero backgrounds */
.dv-hero .btn-back{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.07);}
.dv-hero .btn-back:hover{color:#fff;border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.14);}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;}
.hero-stats .stat{display:flex;flex-direction:column;}
.hero-stats .num{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-stats .lbl{font-size:12px;color:var(--text-muted);font-weight:500;letter-spacing:.04em;}
.hero-image-wrap{display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;gap:1.4rem;}
/* typewriter below hero globe */
.hero-typewriter{display:flex;align-items:center;gap:.55rem;font-size:14.5px;font-style:italic;color:rgba(160,175,210,.65);letter-spacing:.03em;white-space:nowrap;}
.tw-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);display:inline-block;flex-shrink:0;box-shadow:0 0 8px rgba(212,175,55,.6);}
.tw-word{color:var(--gold);font-weight:600;font-style:italic;}
.tw-cursor{color:var(--gold);font-weight:300;font-style:normal;animation:twBlink .75s step-end infinite;}
@keyframes twBlink{0%,100%{opacity:1;}50%{opacity:0;}}
#heroGlobe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:0;}
.hero-img-ring{position:relative;width:380px;height:380px;border-radius:50%;border:2px solid var(--dark-border);display:flex;align-items:center;justify-content:center;background:radial-gradient(circle,rgba(87,185,255,.06),transparent 70%);animation:heroRingPulse 6s ease-in-out infinite;}
.hero-img-ring::before{content:'';position:absolute;inset:-12px;border-radius:50%;border:1px solid rgba(87,185,255,.12);animation:heroRingPulse 6s ease-in-out infinite reverse;}
.hero-img-ring::after{content:'';position:absolute;inset:-24px;border-radius:50%;border:1px solid rgba(87,185,255,.06);}
.hero-img-ring img{width:100%;height:100%;object-fit:contain;animation:logoPulse 2.2s ease-in-out infinite;transform-origin:center;}
@keyframes logoPulse{
  0%   {transform:scale(1);   filter:drop-shadow(0 0 28px rgba(87,185,255,.30));}
  10%  {transform:scale(1.07);filter:drop-shadow(0 0 50px rgba(87,185,255,.75));}
  20%  {transform:scale(1.02);filter:drop-shadow(0 0 32px rgba(87,185,255,.38));}
  30%  {transform:scale(1.05);filter:drop-shadow(0 0 42px rgba(87,185,255,.58));}
  45%  {transform:scale(1);   filter:drop-shadow(0 0 28px rgba(87,185,255,.30));}
  100% {transform:scale(1);   filter:drop-shadow(0 0 28px rgba(87,185,255,.30));}
}
@keyframes heroRingPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.03);}}
.hero-logo{margin-bottom:1.5rem;}
.hero-logo img{height:140px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 18px rgba(87,185,255,.45));}
#particles{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.particle{position:absolute;bottom:-10px;width:2px;height:2px;background:var(--gold);border-radius:50%;opacity:.6;animation:floatUp var(--duration,8s) ease-in-out infinite;animation-delay:var(--delay,0s);}
@keyframes floatUp{0%{transform:translateY(0) translateX(0);opacity:.6;}50%{opacity:.2;}100%{transform:translateY(-100vh) translateX(var(--drift,0));opacity:0;}}
/* ── Beneficios 100% en línea ── */
.quick-access{padding:4rem 5% 4.5rem;background:var(--dark-surface);border-top:1px solid var(--dark-border);border-bottom:1px solid var(--dark-border);}
.qb-header{text-align:center;margin-bottom:2.5rem;max-width:760px;margin-left:auto;margin-right:auto;}
.qb-title{font-size:clamp(1.3rem,2.5vw,1.95rem);font-weight:800;color:var(--text-primary);letter-spacing:-.01em;line-height:1.2;}
.qb-title em{font-style:normal;background:linear-gradient(135deg,var(--gold),var(--gold-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.quick-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:1.1rem;max-width:1300px;margin:0 auto;
  padding:.8rem .2rem 1.2rem;/* espacio para que floten sin clippearse */
}
.quick-item{
  background:var(--dark-card);
  border:1px solid var(--dark-border);
  border-radius:var(--radius-lg);
  padding:2rem 1.4rem;
  box-shadow:0 4px 18px rgba(87,185,255,.08);
  animation:qi-float 3.8s ease-in-out infinite;
  transition:box-shadow .3s ease,border-color .3s ease,background .3s ease;
}
.quick-item:nth-child(1){animation-delay:0s;}
.quick-item:nth-child(2){animation-delay:-.76s;}
.quick-item:nth-child(3){animation-delay:-1.52s;}
.quick-item:nth-child(4){animation-delay:-2.28s;}
.quick-item:nth-child(5){animation-delay:-3.04s;}
@keyframes qi-float{
  0%,100%{transform:translateY(0);box-shadow:0 4px 18px rgba(87,185,255,.08);}
  50%{transform:translateY(-9px);box-shadow:0 14px 32px rgba(87,185,255,.16);}
}
.quick-item:hover{background:rgba(87,185,255,.05);border-color:var(--dark-border-strong);animation-play-state:paused;}
.qi-icon{font-size:2rem;margin-bottom:.75rem;}
.quick-item h4{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;line-height:1.35;}
.quick-item p{font-size:12.5px;color:var(--text-muted);line-height:1.55;}
.qi-link{font-size:13px;color:var(--gold);font-weight:600;}
.marquee-band{overflow:hidden;padding:18px 0;background:linear-gradient(135deg,#57B9FF,#517891);border-top:none;border-bottom:none;}
.marquee-track{display:flex;gap:0;animation:marquee 55s linear infinite;width:max-content;}
.marquee-item{font-size:12px;font-weight:700;color:#fff;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;padding:0 32px;text-shadow:0 1px 3px rgba(0,0,0,.2);}
.marquee-dot{display:inline-block;width:5px;height:5px;background:rgba(255,255,255,.7);border-radius:50%;margin-left:32px;vertical-align:middle;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.stats-band{padding:4rem 5%;background:linear-gradient(135deg,rgba(87,185,255,.06),transparent);border-bottom:1px solid var(--dark-border);}
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;max-width:1200px;margin:0 auto;}
.stat-big{text-align:center;padding:2rem 1rem;border-right:1px solid var(--dark-border);}
.stat-big:last-child{border-right:none;}
.stat-big .n{display:block;font-size:2.8rem;font-weight:800;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem;}
.stat-big .l{font-size:13px;color:var(--text-muted);font-weight:500;letter-spacing:.04em;}
.section-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);background:rgba(87,185,255,.1);border:1px solid var(--dark-border);padding:4px 12px;border-radius:var(--radius-xl);margin-bottom:1rem;}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2;margin-bottom:1rem;}
.section-sub{font-size:1rem;color:var(--text-secondary);line-height:1.7;max-width:600px;}
.programs{padding:5rem 5%;max-width:1300px;margin:0 auto;}
.programs .reveal{margin-bottom:2.5rem;}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:1.2rem;}
.subtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:2rem;}
.subtab{padding:7px 18px;border-radius:var(--radius-xl);border:1px solid rgba(87,185,255,.2);background:rgba(87,185,255,.05);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.subtab:hover{border-color:rgba(87,185,255,.45);color:var(--text-primary);}
.subtab.active{background:linear-gradient(135deg,rgba(87,185,255,.18),rgba(26,110,191,.25));color:#57B9FF;border-color:rgba(87,185,255,.5);}
.tab{padding:10px 22px;border-radius:var(--radius-xl);border:1px solid var(--dark-border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);}
.tab:hover{border-color:var(--dark-border-strong);color:var(--text-primary);}
.tab.active{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;border-color:transparent;}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;counter-reset:prog-counter;}
.prog-card{
  background:var(--dark-card);border:1px solid var(--dark-border);
  border-radius:18px;padding:1.6rem 1.4rem 1.3rem;
  cursor:pointer;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
  display:flex;flex-direction:column;gap:0;
  position:relative;overflow:hidden;
  box-shadow:0 2px 14px rgba(0,0,0,.28);
  counter-increment:prog-counter;
}
/* coloured top accent line */
.prog-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--pc-line,linear-gradient(90deg,#57B9FF,#818CF8));}
/* auto-number */
.prog-card::after{content:counter(prog-counter,decimal-leading-zero);position:absolute;top:1.1rem;left:1.3rem;font-size:10px;font-weight:700;color:rgba(255,255,255,.22);letter-spacing:.05em;}
.prog-card:hover{transform:translateY(-6px);border-color:var(--pc-border,rgba(87,185,255,.28));box-shadow:0 16px 40px rgba(0,0,0,.38),0 0 0 1px var(--pc-border,rgba(87,185,255,.18));}
/* badge — absolute top-right */
.prog-tag{position:absolute;top:1rem;right:1rem;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:var(--pc-badge-bg,rgba(37,99,235,.13));color:var(--pc-badge-color,#1e40af);border-radius:20px;padding:3px 10px;border:1px solid rgba(37,99,235,.35);}
/* icon */
.prog-icon{font-size:2.4rem;margin-top:1.6rem;margin-bottom:.55rem;display:block;transition:transform .45s cubic-bezier(.34,1.56,.64,1);will-change:transform;}
.prog-card:hover .prog-icon{transform:translateY(-10px) scale(1.12);}
/* title */
.prog-card h3{font-size:14.5px;font-weight:700;color:var(--text-primary);line-height:1.35;margin-bottom:.4rem;}
/* description */
.prog-card p{font-size:12.5px;color:var(--text-secondary);line-height:1.6;flex:1;margin-bottom:.6rem;}
/* bottom row */
.prog-card>div:last-child{display:flex;align-items:center;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--dark-border);}
/* VER DETALLES button — hidden by default, revealed on hover */
.ver-mas{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--pc-link-hover,#57B9FF);background:var(--pc-badge-bg,rgba(87,185,255,.12));border:1px solid var(--pc-border,rgba(87,185,255,.32));border-radius:20px;padding:5px 15px;opacity:0;transform:translateY(6px);transition:opacity .28s ease,transform .28s ease,background .25s;}
.prog-card:hover .ver-mas{opacity:1;transform:translateY(0);}
.prog-card:hover .ver-mas:hover{background:var(--pc-border,rgba(87,185,255,.25));}
.pc-bottom-row{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding-top:.5rem;}
.pc-icon-row{display:flex;align-items:center;justify-content:space-between;margin-top:1.4rem;margin-bottom:.3rem;}
.pc-icon-row .prog-icon{margin-top:0;margin-bottom:0;}
.pc-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(87,185,255,.1),rgba(26,110,191,.07));border:1px solid rgba(87,185,255,.2);border-radius:10px;padding:7px 12px;min-width:52px;}
.pc-date-day{font-size:26px;font-weight:800;line-height:1;color:#2563eb;transition:color .25s;}
.pc-date-mon{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(37,99,235,.8);margin-top:2px;transition:color .25s;}
.prog-card:hover .pc-date-day{color:#8dd4ff;}
.prog-card:hover .pc-date-mon{color:rgba(141,212,255,.85);}
/* ── per-tab accent colours ── */
#enf .prog-card{--pc-line:linear-gradient(90deg,#57B9FF,#818CF8);--pc-border:rgba(87,185,255,.28);--pc-badge-bg:rgba(87,185,255,.13);--pc-badge-color:#7DD3FC;--pc-link:rgba(87,185,255,.65);--pc-link-hover:#57B9FF;}
#salud .prog-card{--pc-line:linear-gradient(90deg,#34D399,#0EA5E9);--pc-border:rgba(52,211,153,.28);--pc-badge-bg:rgba(52,211,153,.13);--pc-badge-color:#6EE7B7;--pc-link:rgba(52,211,153,.65);--pc-link-hover:#34D399;}
#trabajo .prog-card{--pc-line:linear-gradient(90deg,#F97316,#EF4444);--pc-border:rgba(249,115,22,.28);--pc-badge-bg:rgba(249,115,22,.13);--pc-badge-color:#FDBA74;--pc-link:rgba(249,115,22,.65);--pc-link-hover:#F97316;}
#otros .prog-card{--pc-line:linear-gradient(90deg,#C084FC,#A855F7);--pc-border:rgba(192,132,252,.28);--pc-badge-bg:rgba(192,132,252,.13);--pc-badge-color:#E879F9;--pc-link:rgba(192,132,252,.65);--pc-link-hover:#C084FC;}
/* ── OTROS TAB ── */
.otros-info{grid-column:1/-1;display:flex;flex-direction:column;gap:1.5rem;padding:.5rem 0;}
.otros-intro{text-align:center;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem;}
.otros-tag{font-size:11px;font-weight:700;color:#2563eb;letter-spacing:.1em;text-transform:uppercase;}
.otros-title{font-size:1.4rem;font-weight:700;color:#0f172a;}
.otros-desc{font-size:.92rem;color:#475569;line-height:1.6;}
.otros-grid{display:flex;flex-direction:column;gap:1.1rem;width:100%;}
.ocamp-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:1.3rem 1.5rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 2px 12px rgba(0,0,0,.06);}
.ocamp-city{display:flex;align-items:center;gap:.65rem;padding-bottom:.85rem;border-bottom:1px solid #e2e8f0;}
.ocamp-city-num{font-size:12px;font-weight:800;color:#2563eb;letter-spacing:.06em;}
.ocamp-city-name{font-size:17px;font-weight:700;color:#0f172a;}
.ocamp-section{display:flex;flex-direction:column;gap:.55rem;}
.ocamp-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:20px;width:fit-content;margin-bottom:2px;}
.ocamp-label-ec{background:rgba(16,185,129,.15);color:#059669;border:1px solid rgba(16,185,129,.3);}
.ocamp-label-pos{background:rgba(99,102,241,.15);color:#4338ca;border:1px solid rgba(99,102,241,.3);}
.ocamp-label-dip{background:rgba(37,99,235,.15);color:#1d4ed8;border:1px solid rgba(37,99,235,.3);}
.ocamp-label-mae{background:rgba(147,51,234,.15);color:#7e22ce;border:1px solid rgba(147,51,234,.3);}
.ocamp-label-doc{background:rgba(220,38,38,.13);color:#b91c1c;border:1px solid rgba(220,38,38,.28);}
.ocamp-label-cur{background:rgba(6,182,212,.13);color:#0e7490;border:1px solid rgba(6,182,212,.28);}
.ocamp-prog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;}
.ocamp-prog{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem .7rem;border-radius:8px;border-left:3px solid #bfdbfe;background:#fff;transition:background .15s,border-color .15s;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.ocamp-prog:hover{background:#eff6ff;border-left-color:#2563eb;}
.ocamp-prog-link{display:flex;align-items:center;justify-content:space-between;width:100%;text-decoration:none;gap:.75rem;}
.ocamp-prog-link:hover .ocamp-prog-name{color:#2563eb;}
.ocamp-prog-name{font-size:14px;color:#1e293b;flex:1;line-height:1.4;font-weight:500;}
.ocamp-prog-date{font-size:12px;font-weight:700;color:#2563eb;white-space:nowrap;flex-shrink:0;}
.ocamp-prog-soon{color:#94a3b8!important;font-weight:400!important;font-style:italic;}
.ocamp-note{font-size:10px;font-weight:400;color:#94a3b8;display:block;}
.ocamp-num-pue{color:#9B59B6!important;}
.ocamp-num-gdl{color:#27AE60!important;}
.ocamp-num-mid{color:#E67E22!important;}
.ocamp-num-mty{color:#E74C3C!important;}
.acred{padding:3rem 5%;border-top:1px solid var(--dark-border);}
.acred-label{text-align:center;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.5rem;}
.acred-inner{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;max-width:800px;margin:0 auto;}
.acred-badge{display:flex;align-items:center;gap:8px;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-md);padding:10px 18px;transition:var(--transition);}
.acred-badge:hover{border-color:var(--dark-border-strong);}
.ab-icon{font-size:16px;}
.ab-text{font-size:13px;font-weight:600;color:var(--text-secondary);}
.campus{padding:3rem 5%;max-width:1300px;margin:0 auto;}
.campus .reveal{margin-bottom:2rem;}
.campus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.campus-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-lg);padding:2rem;cursor:pointer;transition:var(--transition);}
.campus-card:hover{border-color:var(--dark-border-strong);transform:translateY(-4px);box-shadow:var(--shadow-card);}
.campus-icon{font-size:2.5rem;margin-bottom:1rem;}
.campus-card h3{font-size:17px;font-weight:700;color:#fff;margin-bottom:.35rem;}
.campus-city{font-size:12px;color:var(--gold);font-weight:600;letter-spacing:.04em;margin-bottom:.75rem;}
.campus-card p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:1.25rem;}
.campus-link{font-size:13px;color:var(--text-muted);font-weight:500;}
.campus-card:hover .campus-link{color:var(--gold);}
/* ═══ WHY SECTION – ORBITAL ═══ */
.why{padding:5rem 5%;background:var(--dark-surface);border-top:1px solid var(--dark-border);overflow:hidden;}
.why-inner{max-width:1200px;margin:0 auto;}
.why-header{text-align:center;margin-bottom:4rem;}
.why-header em{font-style:normal;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.why-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
/* Orbital side */
.why-orbit-side{display:flex;flex-direction:column;align-items:center;gap:2.5rem;}
.why-orbit-canvas{position:relative;width:560px;height:560px;flex-shrink:0;}
/* Rings */
.wo-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;}
.wo-ring-1{width:482px;height:482px;border:1px dashed rgba(87,185,255,.15);animation:wo-spin 65s linear infinite;}
.wo-ring-2{width:347px;height:347px;border:1px dashed rgba(212,175,55,.26);animation:wo-spin 42s linear infinite reverse;}
.wo-ring-3{width:226px;height:226px;border:1px dashed rgba(87,185,255,.12);animation:wo-spin 28s linear infinite;}
@keyframes wo-spin{to{transform:translate(-50%,-50%) rotate(360deg);}}
/* Hub */
.wo-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:143px;height:143px;background:var(--dark-card);border:1px solid rgba(87,185,255,.28);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:4;animation:wo-pulse 3.5s ease-in-out infinite;}
.wo-hub img{width:70px;height:70px;object-fit:contain;display:block;margin-bottom:4px;filter:drop-shadow(0 0 12px rgba(87,185,255,.45));}
.wo-hub-stat{font-size:13px;font-weight:800;color:var(--gold);line-height:1.2;}
.wo-hub-lbl{font-size:9px;color:var(--text-muted);}
@keyframes wo-pulse{0%,100%{box-shadow:0 0 0 0 rgba(87,185,255,0);}50%{box-shadow:0 0 0 14px rgba(87,185,255,.06),0 0 30px rgba(87,185,255,.14);}}
/* SVG overlay */
.wo-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;}
/* Nodes — center 250,250; orbit r=176; node r=31 */
.wo-node{position:absolute;display:flex;flex-direction:column;align-items:center;gap:5px;z-index:5;cursor:pointer;}
.wo-dot{width:70px;height:70px;border-radius:50%;background:var(--dark-card);border:1px solid rgba(87,185,255,.18);display:flex;align-items:center;justify-content:center;font-size:1.6rem;transition:all .3s ease;}
.wo-node.active .wo-dot{border-color:var(--gold);background:rgba(212,175,55,.1);box-shadow:0 0 22px rgba(212,175,55,.3);transform:scale(1.12);}
.wo-nlabel{font-size:12px;font-weight:600;color:rgba(255,255,255,.82);text-align:center;white-space:nowrap;transition:color .3s;}
.wo-node.active .wo-nlabel{color:var(--gold);}
.wo-n1{top:48px;left:245px;}
.wo-n2{top:245px;left:442px;}
.wo-n3{top:442px;left:245px;}
.wo-n4{top:245px;left:48px;}
/* Stats */
.wo-stats{display:flex;gap:2.5rem;justify-content:center;}
.wo-stat{text-align:center;}
.wo-snum{display:block;font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;}
.wo-slbl{font-size:10px;color:var(--text-muted);}
/* Feature list – nicocherubin style */
.why-features{display:flex;flex-direction:column;}
.wf-item{position:relative;display:flex;align-items:flex-start;gap:1rem;padding:1.4rem 0 1.4rem 1.2rem;border-bottom:1px solid var(--dark-border);cursor:pointer;}
.wf-item:first-child{border-top:1px solid var(--dark-border);}
.wf-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold);opacity:0;transition:opacity .35s ease;}
.wf-item.active::before{opacity:1;}
.wf-num{font-size:2.8rem;font-weight:900;color:rgba(87,185,255,.55);line-height:1;min-width:64px;text-align:right;transition:color .3s;padding-top:3px;}
.wf-item.active .wf-num{color:rgba(212,175,55,.9);}
.wf-body h3{font-size:15px;font-weight:700;color:rgba(255,255,255,.88);margin-bottom:.35rem;transition:color .3s;}
.wf-item.active .wf-body h3{color:var(--text-primary);}
.wf-body p{font-size:13px;color:var(--text-secondary);line-height:1.6;opacity:.92;transition:opacity .3s;}
.wf-item.active .wf-body p{opacity:1;}
.testimonials{padding:5rem 0;overflow:hidden;background:var(--dark-surface);}
.testimonials .reveal{max-width:1200px;margin:0 auto 3rem;padding:0 5%;}
.tiktok-section-title{font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:800;text-align:center;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;}
.tiktok-section-sub{font-size:14px;text-align:center;color:var(--text-muted);}
.tiktok-track-wrap{overflow:hidden;padding:2.5rem 0 3rem;}
@keyframes tiktokScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes tiktokFloat{
  0%,100%{transform:translateY(0);}
  40%{transform:translateY(-14px);}
  70%{transform:translateY(-8px);}
}
.tiktok-track{display:flex;gap:2.8rem;width:max-content;animation:tiktokScroll 32s linear infinite;}
.tiktok-track:hover{animation-play-state:paused;}
.tiktok-item{display:flex;flex-direction:column;align-items:center;gap:.9rem;cursor:pointer;flex-shrink:0;}
.tiktok-circle{width:150px;height:150px;border-radius:50%;overflow:hidden;position:relative;border:3px solid var(--dark-border);box-shadow:0 4px 20px rgba(87,185,255,.15);transition:border-color .25s,box-shadow .25s,transform .25s;background:#e8eef8;animation:tiktokFloat 3.8s ease-in-out infinite;}
.tiktok-item:nth-child(2n)   .tiktok-circle{animation-duration:4.4s;animation-delay:-.8s;}
.tiktok-item:nth-child(3n)   .tiktok-circle{animation-duration:3.5s;animation-delay:-1.6s;}
.tiktok-item:nth-child(4n)   .tiktok-circle{animation-duration:5s;animation-delay:-2.4s;}
.tiktok-item:nth-child(5n)   .tiktok-circle{animation-duration:4.1s;animation-delay:-1.1s;}
.tiktok-item:hover .tiktok-circle{animation-play-state:paused;transform:scale(1.08);border-color:var(--gold);box-shadow:0 10px 36px rgba(87,185,255,.35);}
.tiktok-circle img{width:100%;height:100%;object-fit:cover;display:block;}
.tiktok-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.18);opacity:0;transition:.25s;}
.tiktok-item:hover .tiktok-play{opacity:1;}
.tiktok-play svg{filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));}
.tiktok-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-align:center;max-width:145px;line-height:1.4;}

/* ══ CV GRID (Experiencias Campus Virtual) ══ */
.cv-section{background:var(--dark-bg);}
.cv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:1100px;margin:0 auto;padding:0 1.5rem 1rem;}
.cv-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;aspect-ratio:9/16;background:#0d1117;border:1px solid rgba(87,185,255,.18);transition:transform .3s ease,box-shadow .3s ease;}
.cv-card:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(87,185,255,.30);}
.cv-card img{width:100%;height:100%;object-fit:cover;display:block;}
.cv-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.20);opacity:0;transition:opacity .25s ease;}
.cv-card:hover .cv-play{opacity:1;}
.cv-label{position:absolute;bottom:0;left:0;right:0;padding:.7rem .8rem;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 100%);color:#fff;font-size:.72rem;font-weight:600;line-height:1.35;}
.cv-card.cv-fb{background:linear-gradient(135deg,#1a5fa8,#0a3870);}
.cv-card.cv-fb .cv-play{opacity:1;background:transparent;}
@media(max-width:860px){.cv-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.cv-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;}}

/* ══ MODAL VIDEO YOUTUBE ══ */
#ytModal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);align-items:center;justify-content:center;padding:1rem;}
#ytModal.open{display:flex;}
.yt-modal-inner{position:relative;width:min(900px,94vw);}
.yt-modal-frame{position:relative;padding-bottom:56.25%;height:0;border-radius:16px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.7);}
.yt-modal-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:none;}
.yt-modal-close{position:absolute;top:-38px;right:0;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;transition:.2s;}
.yt-modal-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1);}

/* ══ MODAL VIDEO TIKTOK ══ */
#tiktokModal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.82);backdrop-filter:blur(8px);align-items:center;justify-content:center;}
#tiktokModal.open{display:flex;}
.tiktok-modal-inner{position:relative;width:min(340px,92vw);border-radius:20px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.6);}
.tiktok-modal-inner iframe{display:block;width:100%;height:min(620px,80vh);border:none;}
.tiktok-modal-close{position:absolute;top:10px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.6);border:none;color:#fff;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;transition:.2s;}
.tiktok-modal-close:hover{background:rgba(0,0,0,.9);transform:scale(1.1);}
/* ══ LEONES MASCOTA ══ */
@keyframes leonFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-14px);}}
@keyframes leonaFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.form-card{position:relative;overflow:visible!important;}
.leon-mascot{position:absolute;top:50%;pointer-events:none;z-index:10;transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .4s;}
#leonMascot{left:-105px;transform:translateY(-50%) translateX(-30px);opacity:0;}
#leonaMascot{right:-105px;transform:translateY(-50%) translateX(30px);opacity:0;}
.form-card:hover #leonMascot{transform:translateY(-50%) translateX(0);opacity:1;}
.form-card:hover #leonaMascot{transform:translateY(-50%) translateX(0);opacity:1;}
.leon-mascot img{height:120px;width:auto;object-fit:contain;filter:drop-shadow(0 6px 18px rgba(87,185,255,.30));animation:leonFloat 3.6s ease-in-out infinite;}
#leonaMascot img{animation-name:leonaFloat;animation-duration:4.1s;animation-delay:-.8s;}

/* ── Globe CTA ── */
.globe-cta{position:relative;overflow:hidden;min-height:520px;display:flex;align-items:center;justify-content:center;background:#05060d;}
#ctaGlobe{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;}
.globe-cta-content{position:relative;z-index:1;text-align:center;padding:6rem 5%;max-width:640px;}
.globe-cta-tag{font-size:11px!important;font-weight:700;letter-spacing:.15em;color:var(--gold)!important;text-transform:uppercase;margin-bottom:.75rem!important;opacity:1!important;}
.globe-cta-content h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;line-height:1.2;margin-bottom:1.25rem;}
.globe-cta-content h2 em{font-style:normal;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.globe-cta-content>p{color:rgba(255,255,255,.6);font-size:15px;line-height:1.7;margin-bottom:2.5rem;}

.contact{padding:5rem 5%;background:var(--dark-surface);border-top:1px solid var(--dark-border);}
.contact .reveal{max-width:1200px;margin:0 auto 3rem;}
.contact-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;max-width:1200px;margin:0 auto;}
.contact-info h3{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;}
.contact-info p{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-bottom:2rem;}
.info-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--dark-border);}
.info-item:last-child{border-bottom:none;}
.info-item .ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ic-email{background:rgba(37,99,235,.12);}
.ic-phone{background:rgba(219,39,119,.12);}
.ic-chat{background:rgba(5,150,105,.12);}
.ic-pin{background:rgba(220,38,38,.12);}
.info-item span{font-size:13px;color:var(--text-secondary);}
.info-item a{font-size:13px;color:var(--text-secondary);transition:var(--transition);}
.info-item a:hover{color:var(--gold);}
.form-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-card);}
.form-card h3{font-size:1.1rem;font-weight:700;color:var(--gold);margin-bottom:1.75rem;letter-spacing:.02em;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-group{margin-bottom:1.25rem;}
.form-group label{display:block;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--text-muted);text-transform:uppercase;margin-bottom:.5rem;}
.form-group input,.form-group select,.form-group textarea{width:100%;background:#f4f8ff;border:1px solid var(--dark-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;padding:11px 14px;outline:none;transition:var(--transition);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);background:rgba(87,185,255,.04);}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);}
.form-group select option{background:var(--dark-card);color:var(--text-primary);}
.form-group textarea{height:100px;resize:vertical;}
.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;font-weight:700;font-size:14px;letter-spacing:.04em;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(87,185,255,.4);}
.success-msg{display:none;margin-top:1rem;padding:12px 16px;background:rgba(87,185,255,.1);border:1px solid var(--dark-border-strong);border-radius:var(--radius-sm);color:var(--gold);font-size:13px;font-weight:600;text-align:center;}
footer{background:#080810;border-top:1px solid var(--dark-border);padding:4rem 5% 2rem;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto 3rem;}
.footer-brand img{height:40px;width:auto;margin-bottom:1rem;}
.footer-brand p{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:1.25rem;}
.footer-social{display:flex;gap:8px;}
.social-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--dark-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);text-decoration:none;color:var(--text-secondary);}
.social-btn:hover{border-color:var(--gold);background:rgba(87,185,255,.08);color:#fff;}
.social-btn svg{display:block;flex-shrink:0;}
.footer-col h4{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem;}
.footer-col li a{font-size:13px;color:var(--text-muted);transition:var(--transition);cursor:pointer;}
.footer-col li a:hover{color:var(--text-primary);}
.footer-bottom{max-width:1200px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--dark-border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.footer-bottom p{font-size:12px;color:var(--text-muted);}
.footer-acred{display:flex;gap:8px;align-items:center;font-size:11px;color:var(--text-muted);}
.footer-bottom a{font-size:12px;color:var(--text-muted);cursor:pointer;transition:var(--transition);}
.footer-bottom a:hover{color:var(--text-primary);}
#quickView{background:var(--dark-bg);}
.dv-hero{padding:120px 5% 4rem;position:relative;background:var(--dark-surface);border-bottom:1px solid var(--dark-border);}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);margin-bottom:1.5rem;flex-wrap:wrap;}
.breadcrumb span{cursor:pointer;transition:var(--transition);}
.breadcrumb span:hover{color:var(--text-primary);}
.breadcrumb .sep{color:var(--text-muted);cursor:default;}
.breadcrumb .current{color:var(--gold);}
.dv-badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--gold);background:rgba(87,185,255,.1);border:1px solid var(--dark-border);border-radius:var(--radius-xl);padding:4px 14px;margin-bottom:1rem;}
.dv-hero h1{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;color:#fff;line-height:1.2;margin-bottom:1rem;}
.dv-hero p{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2rem;}
.dv-hero-body{display:flex;align-items:center;gap:2.5rem;}
.dv-hero-left{flex:1;min-width:0;}
.dv-meta{display:flex;flex-direction:column;flex-shrink:0;width:300px;background:rgba(255,255,255,.11);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:20px 22px;margin-bottom:0;box-shadow:0 4px 24px rgba(0,0,0,.18);}
.dv-meta-header{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.48);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.12);}
.meta-chip{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.09);}
.meta-chip:last-child{border-bottom:none;}
.mc-icon{width:28px;height:28px;border-radius:7px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:1px;}
.meta-chip .mc-icon{filter:none;}
.meta-chip .mc-icon .mc-img{width:20px;height:20px;object-fit:contain;filter:brightness(0) invert(1);display:block;}
.mc-text{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:5px;}
.mc-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);line-height:1.4;white-space:nowrap;}
.mc-val{font-size:12px;font-weight:700;color:#fff;line-height:1.4;word-break:break-word;}
.dv-btns{display:flex;gap:12px;flex-wrap:wrap;}
.dv-body{padding:3rem 5%;max-width:1200px;margin:0 auto;}
.dv-grid{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start;}
.dv-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;}
.dv-card h2{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem;display:flex;align-items:center;gap:.6rem;}
.dv-card h2 span{font-size:20px;}
.dv-card p{font-size:14px;color:var(--text-secondary);line-height:1.7;}
.dv-card ul{list-style:none;display:flex;flex-direction:column;gap:.75rem;}
.dv-card ul li{font-size:14px;color:var(--text-secondary);line-height:1.6;padding-left:1.25rem;position:relative;}
.dv-card ul li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:10px;top:2px;}
.dv-card strong{color:var(--text-primary);}

/* ══ PROCESO DE INSCRIPCIÓN ══ */
.dv-inscripcion{border-color:rgba(87,185,255,.25);background:linear-gradient(160deg,var(--dark-card) 80%,rgba(87,185,255,.05) 100%);}
#detalle .dv-inscripcion{border-color:rgba(87,185,255,.18);background:linear-gradient(160deg,#fff 80%,#f0f7ff 100%);}
.ins-intro{font-size:13.5px;color:var(--text-secondary);line-height:1.65;margin-bottom:1.75rem;margin-top:-.25rem;}
.ins-steps{list-style:none;display:flex;flex-direction:column;gap:0;padding:0;margin:0 0 1.5rem;}
.ins-step{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;position:relative;}
.ins-step:not(.ins-step-last)::after{content:'';position:absolute;left:17px;top:52px;bottom:-12px;width:2px;background:linear-gradient(to bottom,rgba(87,185,255,.4),rgba(87,185,255,.1));z-index:0;}
.ins-num{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#57B9FF,#3a6dd8);color:#fff;font-size:10.5px;font-weight:800;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 10px rgba(87,185,255,.35);position:relative;z-index:1;}
.ins-step-cta .ins-num{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 12px rgba(34,197,94,.4);}
.ins-step-last .ins-num{background:linear-gradient(135deg,var(--gold),#c87830);box-shadow:0 2px 10px rgba(212,175,55,.35);}
.ins-body{flex:1;padding-top:4px;}
.ins-body strong{display:block;font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;}
.ins-body p{font-size:12.5px;color:var(--text-secondary);line-height:1.6;margin:0;}
.ins-tag{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:rgba(34,197,94,.15);color:#22c55e;border:1px solid rgba(34,197,94,.3);border-radius:20px;padding:2px 9px;margin-bottom:.4rem;}
.ins-cta-btn{display:inline-block;margin-top:.6rem;font-size:12px;font-weight:700;color:#fff;background:linear-gradient(135deg,#57B9FF,#3a6dd8);border-radius:24px;padding:8px 20px;text-decoration:none;letter-spacing:.04em;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 14px rgba(87,185,255,.35);}
.ins-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(87,185,255,.5);}
.ins-footer{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:1rem;border-top:1px solid var(--dark-border);}
.ins-badge{font-size:11px;font-weight:600;color:var(--text-secondary);background:var(--dark-card);border:1px solid var(--dark-border);border-radius:20px;padding:4px 12px;white-space:nowrap;}
#detalle .ins-badge{background:#f5f9ff;border-color:rgba(87,185,255,.2);color:#2d5068;}

.dv-side{position:sticky;top:90px;}
.side-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:1.25rem;}
.side-card h3{font-size:14px;font-weight:700;color:var(--gold);margin-bottom:1rem;letter-spacing:.04em;text-transform:uppercase;}
.side-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--dark-border);}
.side-row:last-child{border-bottom:none;}
.side-row .label{font-size:12px;color:var(--text-muted);}
.side-row .value{font-size:12px;font-weight:600;color:var(--text-primary);}
.side-cta{background:var(--dark-surface);border:1px solid var(--dark-border-strong);border-radius:var(--radius-lg);padding:1.75rem;}
.side-cta h3{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;}
.side-cta p{font-size:13px;color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.6;}
.side-cta button{width:100%;padding:12px;background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#fff;font-weight:700;font-size:13px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);}
.side-cta button:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.2);}
.btn-pagar{display:block;width:100%;margin-top:.75rem;padding:13px;color:#fff !important;font-weight:700;font-size:13px;letter-spacing:.02em;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);}
.btn-pagar:hover{filter:brightness(1.12);transform:translateY(-1px);}
.mini-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.25rem;}
.mini-card{background:rgba(255,255,255,.03);border:1px solid var(--dark-border);border-radius:var(--radius-md);padding:1.25rem;cursor:pointer;transition:var(--transition);}
.mini-card:hover{border-color:var(--dark-border-strong);background:rgba(0,0,0,.04);}
.mc-icon{font-size:1.75rem;margin-bottom:.5rem;}
.mini-card h4{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;}
.mini-card p{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:.5rem;}
.mc-tag{display:inline-block;font-size:10px;font-weight:600;background:rgba(0,0,0,.06);color:var(--gold);border-radius:var(--radius-xl);padding:2px 8px;}
/* ══ MOD ACCORDION ══ */
.mod-accordion{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-top:.85rem;}
.mod-acc-item{border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#f8fafc;transition:border-color .25s ease,box-shadow .25s ease;}
.mod-acc-item.mod-acc-expanded{grid-column:1/-1;border-left:3px solid var(--mod-accent,#57b9ff);background:#fff;box-shadow:0 4px 20px var(--mod-bg,rgba(87,185,255,.12));}
.mod-acc-header{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;cursor:pointer;user-select:none;}
.mod-acc-simple .mod-acc-header{cursor:default;}
.mod-acc-badge{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;width:46px;height:46px;border-radius:10px;color:#fff;}
.mod-acc-label{font-size:7.5px;font-weight:800;letter-spacing:.1em;line-height:1;}
.mod-acc-num{font-size:1.2rem;font-weight:900;line-height:1.1;}
.mod-acc-title{flex:1;font-size:13px;font-weight:600;color:#1a202c;line-height:1.4;}
.mod-acc-toggle{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:#edf2f7;border:1px solid #e2e8f0;color:#718096;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease;}
.mod-acc-item.mod-acc-expanded .mod-acc-toggle{background:var(--mod-accent,#57b9ff);color:#fff;border-color:var(--mod-accent,#57b9ff);}
.mod-acc-body{max-height:0;overflow:hidden;transition:max-height .38s ease,padding .25s ease;}
.mod-acc-item.mod-acc-expanded .mod-acc-body{max-height:500px;padding:0 1rem 1rem;}
.mod-acc-chips{display:flex;flex-wrap:wrap;gap:.45rem;}
.mod-acc-chip{font-size:11.5px;padding:.28rem .78rem;border-radius:999px;border:1px solid;background:transparent;font-weight:500;transition:background .18s ease;cursor:default;}
.mod-acc-chip:hover{background:rgba(0,0,0,.04);}
@media(max-width:580px){.mod-accordion{grid-template-columns:1fr;}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:none;}
@media(max-width:1024px){.prog-grid{grid-template-columns:repeat(2,1fr);}.campus-grid{grid-template-columns:repeat(2,1fr);}.footer-top{grid-template-columns:1fr 1fr;}.quick-grid{grid-template-columns:repeat(2,1fr);}.stats-grid{grid-template-columns:repeat(2,1fr);}.stat-big{border-right:none;border-bottom:1px solid var(--dark-border);}.stat-big:last-child{border-bottom:none;}.dv-grid{grid-template-columns:1fr;}.dv-side{position:static;}.why-orbit-canvas{transform:scale(.86);transform-origin:top center;margin-bottom:-59px;}}
@media(max-width:768px){.nav-links{display:none;}.hamburger{display:flex;}.mobile-bar{display:block;}.float-wa{bottom:80px;}.hero{padding:90px 5% 80px;}.hero-inner{grid-template-columns:1fr;}.hero-image-wrap{display:none;}.hero-stats{gap:20px;}.why-layout{grid-template-columns:1fr;}.why-orbit-canvas{transform:scale(.68);transform-origin:top center;margin-bottom:-134px;}.contact-wrap{grid-template-columns:1fr;}.form-row{grid-template-columns:1fr;}.prog-grid{grid-template-columns:1fr;}.campus-grid{grid-template-columns:1fr;}.quick-grid{grid-template-columns:1fr 1fr;}.mini-cards-grid{grid-template-columns:repeat(2,1fr);}.dv-hero{padding:100px 5% 2.5rem;}}
@media(max-width:480px){.quick-grid{grid-template-columns:1fr;}.mini-cards-grid{grid-template-columns:1fr 1fr;}.stats-grid{grid-template-columns:1fr 1fr;}.hero-btns{flex-direction:column;}.hero-btns .btn-primary,.hero-btns .btn-outline{width:100%;justify-content:center;}.footer-top{grid-template-columns:1fr;}body{padding-bottom:72px;}}

/* ══ TOP BAR ══ */
.top-bar{position:fixed;top:0;left:0;right:0;z-index:1001;height:36px;background:rgba(8,8,14,.95);border-bottom:1px solid var(--dark-border);display:flex;align-items:center;}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 5%;}
.top-bar-left{}
.top-bar-badge{font-size:11px;font-weight:600;color:var(--gold);letter-spacing:.04em;}
.top-bar-right{display:flex;align-items:center;gap:20px;}
.top-bar-link{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);text-decoration:none;transition:var(--transition);white-space:nowrap;}
.top-bar-link:hover{color:var(--text-primary);}
.top-bar-wa{color:var(--gold)!important;font-weight:600;}
.top-bar-social{display:flex;align-items:center;gap:6px;border-left:1px solid rgba(255,255,255,.1);padding-left:16px;margin-left:4px;}
.top-bar-social-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;color:var(--text-muted);transition:var(--transition);}
.top-bar-social-btn:hover{color:var(--gold);}
#navbar{top:44px;}
.mobile-menu{top:120px;bottom:0;}
.hero{padding:130px 5% 60px;}

/* ══ NAV STHETO ══ */

/* ══ NAV CONTACT ICONS ══ */
.nav-contact{display:flex;align-items:center;gap:5px;margin-left:6px;}
.nav-contact-btn{width:32px;height:32px;border-radius:50%;border:1px solid rgba(87,185,255,.25);display:flex;align-items:center;justify-content:center;font-size:14px;text-decoration:none;transition:var(--transition);background:rgba(87,185,255,.06);}
.nav-contact-btn:hover{border-color:var(--gold);background:rgba(87,185,255,.14);}
.nav-contact-wa{border-color:rgba(37,211,102,.3);background:rgba(37,211,102,.05);}
.nav-contact-wa:hover{border-color:#25d366;background:rgba(37,211,102,.12);}

/* ══ CTA STRIP ══ */
.cta-strip{background:linear-gradient(135deg,var(--gold),var(--gold-dim));padding:1.25rem 5%;}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;max-width:1200px;margin:0 auto;flex-wrap:wrap;}
.cta-strip-text{display:flex;flex-direction:column;gap:.2rem;}
.cta-strip-tag{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(6,8,15,.65);}
.cta-strip-text strong{font-size:1.1rem;font-weight:800;color:#06080f;letter-spacing:-.01em;}
.cta-strip-sub{font-size:12px;color:rgba(6,8,15,.65);font-weight:500;}
.cta-strip-actions{display:flex;align-items:center;gap:12px;}
.cta-strip-btn{display:inline-flex;align-items:center;background:#06080f;color:var(--gold);font-weight:700;font-size:13px;letter-spacing:.03em;padding:10px 22px;border-radius:var(--radius-md);transition:var(--transition);text-decoration:none;white-space:nowrap;}
.cta-strip-btn:hover{background:#1a1a26;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.3);}
.cta-strip-link{font-size:13px;font-weight:600;color:rgba(6,8,15,.7);text-decoration:none;cursor:pointer;transition:var(--transition);}
.cta-strip-link:hover{color:#06080f;}


/* ══ PROG CARD IMAGE ══ */
.prog-card-color{display:none;}
.prog-card-color::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(6,8,15,0) 0%,rgba(6,8,15,.65) 100%);
}
.prog-card-label{
  position:absolute;bottom:9px;left:13px;right:13px;z-index:2;
  font-size:12px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:#57b9ff;line-height:1.3;
}

/* ══ CAMPUS CARDS ══ */
.campus-accordion{
  max-width:1200px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.875rem;
}

.ca-item{
  position:relative;height:210px;
  border-radius:var(--radius-lg);
  border:2px solid rgba(87,185,255,.35);
  cursor:pointer;overflow:hidden;
  display:flex;flex-direction:column;
  align-items:stretch;justify-content:flex-end;
  transition:transform .35s ease,box-shadow .35s ease;
}
.ca-item:hover{
  transform:translateY(-7px);
  box-shadow:0 18px 44px rgba(87,185,255,.35);
}

/* Foto siempre visible */
.ca-img-wrap{
  position:absolute;inset:0;
  width:100%!important;height:100%!important;
  z-index:0;
}
.ca-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;}

/* Sin overlay */
.ca-item::after{display:none;}

/* Barra azul inferior */
.ca-body{
  position:relative;z-index:2;
  background:rgba(22,115,220,.88);
  display:flex;flex-direction:row;
  align-items:center;justify-content:center;
  padding:.5rem .75rem .55rem;
  gap:.6rem;
}
.ca-title{
  font-size:.78rem;font-weight:800;
  color:#fff;letter-spacing:.08em;
  text-transform:uppercase;line-height:1.2;
}

/* Icono a la izquierda */
.ca-icon{
  width:26px;height:26px;object-fit:contain;flex-shrink:0;
  position:relative;z-index:2;
  filter:brightness(1.6) saturate(2.5) contrast(1.15);
}

/* Ocultar meta */
.ca-meta,.ca-city,.ca-desc,.ca-link{display:none;}

@media(max-width:920px){.campus-accordion{grid-template-columns:repeat(2,1fr);}}
@media(max-width:580px){.campus-accordion{grid-template-columns:repeat(2,1fr);}.ca-item{height:170px;}}

/* ══ CAMPUS VIRTUAL INFO ══ */
.cv-info-section{
  padding:5rem 0;
  background:
    linear-gradient(160deg,#0d2a4a 0%,#0f3d6e 18%,#1a6fa3 38%,#1e8fbf 55%,#1a7aaa 68%,#0f3d6e 82%,#091d36 100%);
  position:relative;overflow:hidden;
}
.cv-info-section::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 45% at 15% 25%,rgba(87,185,255,.14) 0%,transparent 65%),
    radial-gradient(ellipse 55% 40% at 85% 60%,rgba(30,100,180,.22) 0%,transparent 60%),
    radial-gradient(ellipse 80% 35% at 50% 100%,rgba(10,30,70,.35) 0%,transparent 70%);
  pointer-events:none;
}
#cvInfoCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}
.cv-info-inner{max-width:1100px;margin:0 auto;padding:0 5%;display:flex;flex-direction:column;gap:4.5rem;position:relative;z-index:1;}

/* Hero: logo + descripción */
.cv-info-hero{display:grid;grid-template-columns:1fr 1.6fr;gap:3.5rem;align-items:center;}
.cv-info-logo{
  width:100%;max-width:280px;margin:0 auto;
  filter:drop-shadow(0 0 32px rgba(87,185,255,.35)) drop-shadow(0 4px 16px rgba(0,0,0,.5));
  animation:cvLogoPulse 4s ease-in-out infinite;
}
@keyframes cvLogoPulse{0%,100%{filter:drop-shadow(0 0 28px rgba(87,185,255,.3)) drop-shadow(0 4px 16px rgba(0,0,0,.5));}50%{filter:drop-shadow(0 0 48px rgba(87,185,255,.55)) drop-shadow(0 4px 20px rgba(0,0,0,.5));}}
.cv-info-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:#fff;line-height:1.2;margin:.5rem 0 1rem;}
.cv-info-title span{color:#ffe07a;}
.cv-info-desc p{font-size:14px;color:rgba(255,255,255,.88);line-height:1.75;margin-bottom:.85rem;}
.cv-info-stats{display:flex;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap;}
.cv-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;
  background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.25);
  border-radius:12px;padding:.75rem 1.1rem;min-width:68px;}
.cv-stat-n{font-size:1.25rem;font-weight:900;color:#ffe07a;letter-spacing:-.02em;}
.cv-stat-l{font-size:10px;font-weight:600;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.06em;}

/* ¿Por qué elegir? */
.cv-why-title{font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:800;color:#fff;text-align:center;margin-bottom:2.5rem;}
.cv-why-title span{color:#ffe07a;}
.cv-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.cv-why-card{
  background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--radius-lg);padding:1.5rem;
  display:flex;flex-direction:column;gap:.65rem;
  transition:border-color .3s ease,transform .3s ease,box-shadow .3s ease;
}
.cv-why-card:hover{border-color:rgba(87,185,255,.35);transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,0,0,.35),0 0 0 1px rgba(87,185,255,.12);}
.cv-why-icon{font-size:1.8rem;line-height:1;}
.cv-why-card h3{font-size:14px;font-weight:700;color:#fff;}
.cv-why-card p{font-size:13px;color:rgba(255,255,255,.82);line-height:1.65;}

@media(max-width:860px){.cv-info-hero{grid-template-columns:1fr;text-align:center;}.cv-info-logo{max-width:200px;}.cv-info-stats{justify-content:center;}.cv-why-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.cv-why-grid{grid-template-columns:1fr;}}

/* ══ LO QUE NOS HACE DIFERENTES ══ */
.cv-diff{display:flex;flex-direction:column;gap:3.5rem;}
.cv-diff-header{text-align:center;}
.cv-diff-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffe07a;background:rgba(255,224,122,.12);border:1px solid rgba(255,224,122,.28);border-radius:20px;padding:.28rem .9rem;margin-bottom:1rem;}
.cv-diff-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:#fff;line-height:1.2;margin:.4rem 0 .8rem;}
.cv-diff-title span{color:#ffe07a;}
.cv-diff-sub{font-size:14px;color:rgba(255,255,255,.78);max-width:560px;margin:0 auto;line-height:1.7;}
.cv-diff-block{display:flex;flex-direction:column;gap:1.5rem;}
.cv-diff-block-label{display:flex;align-items:center;gap:.6rem;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.12);}
.cv-blabel-icon{font-size:1.05rem;}

/* Badge cards */
.cv-badges-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}
.cv-badge-card{
  background:linear-gradient(145deg,rgba(0,0,0,.28) 0%,rgba(10,30,65,.38) 100%);
  border:1px solid rgba(255,224,122,.22);border-radius:var(--radius-lg);
  padding:2rem 1.6rem;position:relative;overflow:hidden;
  transition:opacity .6s ease,transform .6s ease,border-color .3s ease,box-shadow .3s ease;
  transition-delay:var(--bd,0s);
}
.cv-badge-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 10%,#ffe07a 50%,transparent 90%);opacity:.55;}
.cv-badge-card:hover{border-color:rgba(255,224,122,.5);transform:translateY(-6px);box-shadow:0 18px 42px rgba(0,0,0,.4),0 0 0 1px rgba(255,224,122,.12);}
.cv-badge-star-wrap{display:flex;justify-content:center;margin-bottom:1.1rem;}
.cv-badge-star{font-size:3rem;line-height:1;color:#ffe07a;display:inline-block;animation:starGlow 2.6s ease-in-out infinite;}
@keyframes starGlow{
  0%,100%{filter:drop-shadow(0 0 8px rgba(255,224,122,.4));transform:scale(1);}
  50%{filter:drop-shadow(0 0 22px rgba(255,224,122,.95));transform:scale(1.14);}
}
.cv-badge-card h3{font-size:15px;font-weight:800;color:#fff;text-align:center;margin-bottom:.65rem;}
.cv-badge-card>p{font-size:13px;color:rgba(255,255,255,.82);line-height:1.7;text-align:center;margin-bottom:1.1rem;}
.cv-badge-card>p strong{color:#ffe07a;}
.cv-badge-criteria{background:rgba(0,0,0,.22);border-radius:8px;padding:.9rem 1.1rem;}
.cv-badge-crit-title{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#ffe07a;margin-bottom:.55rem;}
.cv-badge-criteria ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.42rem;}
.cv-badge-criteria li{font-size:12.5px;color:rgba(255,255,255,.8);padding-left:1.3rem;position:relative;line-height:1.55;}
.cv-badge-criteria li::before{content:'✓';position:absolute;left:0;color:#ffe07a;font-weight:800;font-size:11px;top:1px;}

/* Video grid */
.cv-vids-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.cv-vid-card{
  background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:opacity .6s ease,transform .6s ease,border-color .3s ease,box-shadow .3s ease;
  transition-delay:var(--bd,0s);
}
.cv-vid-card:hover{transform:translateY(-5px);box-shadow:0 16px 38px rgba(0,0,0,.4);border-color:rgba(87,185,255,.38);}
.cv-vid-wrap{position:relative;aspect-ratio:16/9;width:100%;overflow:hidden;cursor:pointer;background:#000;}
.cv-vid-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .35s ease;}
.cv-vid-wrap:hover .cv-vid-thumb{transform:scale(1.05);}
.cv-vid-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(200,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s ease,background .2s ease,box-shadow .2s ease;
  box-shadow:0 4px 18px rgba(0,0,0,.55);
}
.cv-vid-play::after{content:'';display:block;width:0;height:0;border-style:solid;border-width:10px 0 10px 20px;border-color:transparent transparent transparent #fff;margin-left:5px;}
.cv-vid-wrap:hover .cv-vid-play{transform:translate(-50%,-50%) scale(1.12);background:rgba(220,0,0,1);box-shadow:0 6px 24px rgba(0,0,0,.65);}
.cv-vid-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block;}

/* Chamilo CTA */
.cv-chamilo-cta{
  display:flex;align-items:center;gap:2rem;
  background:linear-gradient(135deg,rgba(0,20,65,.5) 0%,rgba(0,50,100,.38) 100%);
  border:1px solid rgba(87,185,255,.28);border-radius:var(--radius-lg);
  padding:2rem 2.2rem;position:relative;overflow:hidden;
}
.cv-chamilo-cta::after{content:'';position:absolute;top:-50%;right:-8%;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(87,185,255,.1) 0%,transparent 70%);pointer-events:none;}
.cv-chamilo-icon{font-size:3rem;flex-shrink:0;filter:drop-shadow(0 0 14px rgba(87,185,255,.55));animation:chamiGlow 3s ease-in-out infinite;}
@keyframes chamiGlow{0%,100%{filter:drop-shadow(0 0 10px rgba(87,185,255,.4));}50%{filter:drop-shadow(0 0 24px rgba(87,185,255,.8));}}
.cv-chamilo-body{flex:1;}
.cv-chamilo-body h3{font-size:16px;font-weight:800;color:#fff;margin-bottom:.4rem;}
.cv-chamilo-body p{font-size:13px;color:rgba(255,255,255,.8);line-height:1.65;}
.cv-chamilo-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#57b9ff,#3a9de8);color:#fff;font-size:13px;font-weight:700;padding:.7rem 1.5rem;border-radius:var(--radius-xl);text-decoration:none;white-space:nowrap;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 4px 18px rgba(87,185,255,.38);}
.cv-chamilo-btn:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(87,185,255,.55);}
.cv-chamilo-btn span{display:inline-block;transition:transform .25s ease;}
.cv-chamilo-btn:hover span{transform:translateX(4px);}

@media(max-width:860px){.cv-badges-grid{grid-template-columns:1fr;}.cv-vids-grid{grid-template-columns:1fr 1fr;}.cv-chamilo-cta{flex-wrap:wrap;}}
@media(max-width:520px){.cv-vids-grid{grid-template-columns:1fr;}.cv-chamilo-cta{flex-direction:column;align-items:center;text-align:center;}}

/* ══ CHAMILO PLATAFORMA TABS ══ */
.chm-section{display:flex;flex-direction:column;gap:2rem;}
.chm-header{text-align:center;}
.chm-sup{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:#57B9FF;
  background:rgba(87,185,255,.12);border:1px solid rgba(87,185,255,.28);
  border-radius:20px;padding:.3rem .9rem;margin-bottom:1rem;
}
.chm-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:#fff;line-height:1.2;}
.chm-title em{font-style:normal;color:#ffe07a;}

.chm-tabs{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;}
.chm-tab{
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  padding:1.1rem 1.4rem;border-radius:14px;
  border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.22);
  color:rgba(255,255,255,.65);cursor:pointer;transition:.25s;
  flex:1;min-width:130px;max-width:200px;
}
.chm-tab:hover{border-color:rgba(87,185,255,.4);background:rgba(87,185,255,.08);color:rgba(255,255,255,.9);}
.chm-tab.chm-active{background:linear-gradient(135deg,#57B9FF,#2563eb);border-color:transparent;color:#fff;box-shadow:0 6px 22px rgba(87,185,255,.38);}
.chm-tab-icon{font-size:1.6rem;line-height:1;}
.chm-tab-lbl{font-size:12px;font-weight:700;text-align:center;line-height:1.3;}

.chm-panels{position:relative;}
.chm-panel{
  background:rgba(0,10,40,.45);border:1px solid rgba(87,185,255,.22);
  border-radius:18px;padding:2rem 2.4rem;
  display:flex;align-items:flex-start;gap:2.5rem;
}
.chm-panel-icon{font-size:3.5rem;flex-shrink:0;line-height:1;margin-top:.3rem;filter:drop-shadow(0 0 16px rgba(87,185,255,.4));}
.chm-panel-copy{flex:1;}
.chm-panel-tag{
  display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:#57B9FF;margin-bottom:.75rem;
}
.chm-panel-title{font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:800;color:#fff;line-height:1.2;margin-bottom:1rem;}
.chm-panel-title em{font-style:normal;color:#ffe07a;}
.chm-panel p{font-size:14px;color:rgba(255,255,255,.85);line-height:1.75;margin-bottom:.75rem;}
.chm-panel p:last-child{margin-bottom:0;}
.chm-list{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.55rem;}
.chm-list li{font-size:13.5px;color:rgba(255,255,255,.88);line-height:1.6;padding-left:.2rem;}

.chm-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-top:.75rem;}
.chm-feat{
  background:rgba(87,185,255,.08);border:1px solid rgba(87,185,255,.2);
  border-radius:10px;padding:.9rem 1rem;
  display:flex;align-items:center;gap:.75rem;
}
.chm-feat-icon{font-size:1.25rem;flex-shrink:0;}
.chm-feat-lbl{font-size:12.5px;color:rgba(255,255,255,.88);font-weight:600;line-height:1.35;}

.chm-footer{text-align:center;}
.chm-access-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  background:linear-gradient(135deg,#57b9ff,#3a9de8);
  color:#fff;font-size:14px;font-weight:700;
  padding:.85rem 2rem;border-radius:30px;text-decoration:none;
  transition:.25s;box-shadow:0 4px 20px rgba(87,185,255,.38);
}
.chm-access-btn span{display:inline-block;transition:transform .25s;}
.chm-access-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(87,185,255,.58);}
.chm-access-btn:hover span{transform:translateX(4px);}

@media(max-width:860px){
  .chm-panel{flex-direction:column;align-items:center;text-align:center;padding:1.6rem 1.8rem;}
  .chm-panel-icon{margin-top:0;font-size:3rem;}
  .chm-panel-tag{text-align:center;display:block;}
  .chm-feats{grid-template-columns:repeat(2,1fr);}
  .chm-list{align-items:center;}
}
@media(max-width:600px){
  .chm-tabs{gap:.65rem;}
  .chm-tab{min-width:0;padding:.9rem .8rem;max-width:none;}
  .chm-tab-icon{font-size:1.4rem;}
  .chm-tab-lbl{font-size:11px;}
  .chm-panel{padding:1.3rem 1.1rem;}
  .chm-feats{grid-template-columns:repeat(2,1fr);gap:.6rem;}
  .chm-feat{padding:.75rem .85rem;}
}
@media(max-width:480px){
  .chm-tabs{flex-wrap:wrap;justify-content:center;gap:.6rem;}
  .chm-tab{flex:1 1 calc(50% - .35rem);min-width:0;max-width:calc(50% - .35rem);}
  .chm-feats{grid-template-columns:1fr;}
  .chm-panel{padding:1.1rem .9rem;}
  .chm-panel-title{font-size:1.3rem;}
}

/* ══ DV-HERO CON COLOR DE FONDO ══ */
.dv-hero.has-hero-color{position:relative;overflow:hidden;}
.dv-hero.has-hero-color .gold-line,
.dv-hero.has-hero-color .breadcrumb,
.dv-hero.has-hero-color .dv-hero-body,
.dv-hero.has-hero-color .dv-badge,
.dv-hero.has-hero-color h1,
.dv-hero.has-hero-color p,
.dv-hero.has-hero-color .dv-meta,
.dv-hero.has-hero-color .dv-btns{position:relative;z-index:1;}
/* Textos legibles sobre el gradiente de color */
.dv-hero.has-hero-color h1{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.5);}
.dv-hero.has-hero-color p{color:rgba(255,255,255,.88);}
.dv-hero.has-hero-color .dv-badge{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.28);color:#fff;}
.dv-hero.has-hero-color .breadcrumb{color:rgba(255,255,255,.58);}
.dv-hero.has-hero-color .breadcrumb .current{color:#fff;}
.dv-hero.has-hero-color .breadcrumb span:hover{color:#fff;}
.dv-hero.has-hero-color .gold-line{background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);}
/* Partículas en el hero de diplomado */
#dvParticles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
#dvParticles .particle{background:var(--dv-particle-color,#fff);}

/* ══ SHORTS / VIDEO GRID ══ */
.shorts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.short-wrap{width:100%;aspect-ratio:9/16;border-radius:var(--radius-lg);overflow:hidden;background:#000;cursor:pointer;transition:box-shadow .25s ease,transform .25s ease;}
.short-wrap:hover{box-shadow:0 8px 28px rgba(87,185,255,.25);transform:scale(1.02);}
.short-wrap iframe{width:100%;height:100%;border:none;display:block;}

/* ══ PROG STATUS BADGE ══ */
.prog-status{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;padding:3px 10px;border-radius:var(--radius-xl);margin-top:.5rem;}
.status-green{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.3);}
.status-yellow{background:rgba(234,179,8,.15);color:#facc15;border:1px solid rgba(234,179,8,.35);}
.status-red{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.3);}
.prog-card-proximamente{justify-content:center;align-items:center;text-align:center;min-height:200px;background:linear-gradient(135deg,rgba(20,20,35,.95),rgba(10,10,20,.98));border-color:rgba(212,175,55,.25);cursor:default;pointer-events:none;}
.prog-card-proximamente:hover{transform:none;border-color:rgba(212,175,55,.35);}
.prog-card-proximamente h3{font-size:15px;font-weight:700;color:#eef4ff;line-height:1.4;margin-bottom:1.25rem;}
.prox-badge{display:block;font-size:1.6rem;font-weight:900;color:#D4AF37;letter-spacing:.06em;text-transform:uppercase;text-shadow:0 0 24px rgba(212,175,55,.45);}

/* ══ PROG PAYMENT ICONS ══ */
.prog-payments{display:flex;align-items:center;gap:5px;margin-top:7px;}
.prog-payments .pay-label{font-size:9px;color:var(--text-muted);font-weight:500;margin-right:1px;}
.pay-visa{display:inline-flex;align-items:center;justify-content:center;background:#1a1f71;color:#fff;font-style:italic;font-weight:900;font-size:9px;letter-spacing:.04em;padding:2px 6px;border-radius:3px;font-family:Arial,sans-serif;line-height:1;}
.pay-mc{display:block;flex-shrink:0;}
.pay-pp{display:inline-flex;align-items:center;background:#fff;border:1px solid #dce8f5;border-radius:3px;padding:2px 5px;gap:0;}
.pay-pp .pp-pay{font-size:9px;font-weight:800;color:#003087;font-family:Arial,sans-serif;line-height:1;}
.pay-pp .pp-pal{font-size:9px;font-weight:800;color:#009cde;font-family:Arial,sans-serif;line-height:1;}

/* ══ RESPONSIVE OVERRIDES ══ */
@media(max-width:768px){
  .top-bar-right{display:none;}
  .top-bar-badge{font-size:10px;}
  .nav-contact{display:none;}
  .cta-strip-inner{flex-direction:column;align-items:flex-start;gap:.75rem;}
  .hero{padding:110px 5% 80px;}
  .dv-hero-body{flex-direction:column;align-items:stretch;}
  .dv-meta{width:100%;padding:16px 18px;border-radius:14px;}
  .dv-meta-header{margin-bottom:10px;padding-bottom:8px;}
  .meta-chip{padding:9px 0;}
}

/* ══ VIDEO SHOWCASE ══ */
.vs-section{
  background:linear-gradient(180deg,#f0f7ff 0%,#ffffff 50%,#f0f7ff 100%);
  padding:4.5rem 5%;
  text-align:center;
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(87,185,255,.12);
  border-bottom:1px solid rgba(87,185,255,.12);
}
.vs-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(87,185,255,.07) 0%,transparent 70%);
  pointer-events:none;
}
.vs-header{max-width:680px;margin:0 auto 2.8rem;}
.vs-tag{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:#2563eb;
  background:rgba(37,99,235,.08);border:1px solid rgba(37,99,235,.2);
  padding:.35rem 1rem;border-radius:20px;margin-bottom:1.4rem;
}
.vs-title{
  font-size:clamp(1.8rem,4vw,2.7rem);font-weight:800;
  color:#0c1a25;line-height:1.2;margin-bottom:1rem;
}
.vs-title em{
  font-style:normal;
  background:linear-gradient(90deg,#57B9FF,#2563eb);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.vs-sub{font-size:.98rem;color:#2d5068;line-height:1.75;max-width:520px;margin:0 auto;}
.vs-wrap{
  max-width:960px;margin:0 auto;position:relative;
  border-radius:20px;overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(87,185,255,.22),
    0 16px 52px rgba(87,185,255,.18),
    0 4px 16px rgba(0,0,0,.08);
}
.vs-wrap video{width:100%;display:block;aspect-ratio:16/9;background:#000;object-fit:cover;}
.vs-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(6,8,15,.55) 0%,rgba(8,12,28,.45) 100%);
  backdrop-filter:blur(3px);cursor:pointer;
  transition:opacity .35s ease,backdrop-filter .35s ease;
}
.vs-play-ring{
  width:100px;height:100px;border-radius:50%;
  border:2px solid rgba(87,185,255,.5);
  display:flex;align-items:center;justify-content:center;
  animation:vs-ring-pulse 2.2s ease-in-out infinite;
}
.vs-play-btn{
  width:76px;height:76px;border-radius:50%;
  background:linear-gradient(135deg,#57B9FF 0%,#2563eb 100%);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  box-shadow:0 0 28px rgba(87,185,255,.55),0 0 56px rgba(87,185,255,.22);
  transition:transform .2s,box-shadow .2s;
}
.vs-play-btn svg{width:30px;height:30px;margin-left:5px;}
.vs-overlay:hover .vs-play-btn{transform:scale(1.1);box-shadow:0 0 46px rgba(87,185,255,.75),0 0 80px rgba(87,185,255,.35);}
.vs-overlay-label{
  margin-top:1.2rem;font-size:12px;font-weight:600;
  color:rgba(200,230,255,.75);letter-spacing:.08em;text-transform:uppercase;
}
@keyframes vs-ring-pulse{
  0%,100%{transform:scale(1);opacity:.7;}
  50%{transform:scale(1.15);opacity:1;}
}
@media(max-width:768px){
  .vs-section{padding:3rem 5%;}
  .vs-play-ring{width:80px;height:80px;}
  .vs-play-btn{width:60px;height:60px;}
  .vs-play-btn svg{width:24px;height:24px;}
}

/* ══ CURSOS CARRUSEL ══ */
.cs-tab{display:flex;flex-direction:column;gap:1.8rem;}
.cs-phrase{
  font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:700;
  color:var(--text-primary);text-align:center;
  letter-spacing:-.01em;
}
.cs-track-wrap{
  overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.cs-track{
  display:flex;gap:24px;
  width:max-content;
  counter-reset:prog-counter;
  will-change:transform;
}
/* escala dinámica vía JS — también respeta el hover */
.cs-track .prog-card{
  flex-shrink:0;width:240px;
  transform:scale(var(--cs-scale,1));
  transition:box-shadow .3s ease,border-color .3s ease;
}
.cs-track .prog-card:hover{
  transform:scale(var(--cs-scale,1)) translateY(-6px);
}
#cursos .prog-card{
  --pc-line:linear-gradient(90deg,#F43F5E,#FB923C);
  --pc-border:rgba(244,63,94,.28);
  --pc-badge-bg:rgba(244,63,94,.13);
  --pc-badge-color:#FDA4AF;
  --pc-link:rgba(244,63,94,.65);
  --pc-link-hover:#F43F5E;
}

/* ══ KIT DE BIENVENIDA ══ */
.kit-section{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,#f8fbff 0%,#eef5ff 38%,#f4f9ff 68%,#ffffff 100%);
  padding:5.5rem 5%;
  border-top:1px solid rgba(87,185,255,.12);
  border-bottom:1px solid rgba(87,185,255,.12);
}
.kit-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 65% 55% at 18% 28%,rgba(87,185,255,.09) 0%,transparent 65%),
    radial-gradient(ellipse 55% 65% at 82% 72%,rgba(87,185,255,.07) 0%,transparent 65%);
}
.kit-inner{
  max-width:1100px;margin:0 auto;position:relative;z-index:1;
  display:flex;flex-direction:column;gap:3.5rem;
}

/* Floating decorative emojis */
.kit-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.kit-bubble{
  position:absolute;left:var(--kb-x,50%);top:var(--kb-y,50%);
  font-size:calc(1.6rem * var(--kb-s,1));opacity:.15;
  animation:kit-bubble-float 6s ease-in-out infinite;
  animation-delay:var(--kb-d,0s);
}
@keyframes kit-bubble-float{
  0%,100%{transform:translateY(0) rotate(0deg);opacity:.15;}
  50%{transform:translateY(-20px) rotate(10deg);opacity:.25;}
}

/* Header */
.kit-header{text-align:center;max-width:740px;margin:0 auto;}
.kit-badge{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:#2563eb;
  background:rgba(37,99,235,.09);border:1px solid rgba(37,99,235,.22);
  border-radius:20px;padding:.35rem 1.1rem;margin-bottom:1.2rem;
}
.kit-title{
  font-size:clamp(1.9rem,3.5vw,2.8rem);font-weight:800;
  color:#0c1a25;line-height:1.2;margin-bottom:1rem;
}
.kit-title em{
  font-style:normal;
  background:linear-gradient(135deg,#57B9FF,#2563eb);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.kit-desc{font-size:15px;color:#2d5068;line-height:1.75;margin-bottom:1.8rem;}
.kit-chips{display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center;}
.kit-chip{
  font-size:12.5px;font-weight:600;color:#1565c0;
  background:rgba(21,101,192,.08);border:1px solid rgba(21,101,192,.2);
  border-radius:30px;padding:.42rem 1.1rem;
  animation:kit-chip-float 3.2s ease-in-out infinite;
}
.kit-chip:nth-child(2){animation-delay:-.8s;}
.kit-chip:nth-child(3){animation-delay:-1.6s;}
.kit-chip:nth-child(4){animation-delay:-2.4s;}
@keyframes kit-chip-float{
  0%,100%{transform:translateY(0);box-shadow:0 2px 8px rgba(21,101,192,.08);}
  50%{transform:translateY(-4px);box-shadow:0 6px 18px rgba(21,101,192,.2);}
}

/* TikTok videos */
.kit-videos{
  display:grid;grid-template-columns:1fr 1fr;
  gap:2rem;max-width:680px;margin:0 auto;
}
.kit-vid-card{
  display:flex;flex-direction:column;gap:.8rem;
  animation:qi-float 4.2s ease-in-out infinite;
  animation-delay:var(--kv-delay,0s);
}
.kit-vid-label{
  font-size:12px;font-weight:700;color:#2d5068;
  text-align:center;letter-spacing:.03em;text-transform:uppercase;
}
.kit-vid-frame{
  border-radius:18px;overflow:hidden;
  box-shadow:0 8px 36px rgba(87,185,255,.2),0 2px 10px rgba(0,0,0,.1);
  background:#000;
  aspect-ratio:9/16;position:relative;
}
.kit-vid-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;border:none;display:block;
}

/* Kit phone mockup */
.kit-phone-wrap{display:flex;flex-direction:column;align-items:center;gap:1.5rem;}
.kit-phone-tabs{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;}
.kit-phone-tab{padding:9px 18px;border-radius:22px;border:2px solid rgba(45,80,104,.25);background:transparent;color:#2d5068;font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all .25s;font-family:inherit;}
.kit-phone-tab.active{background:linear-gradient(135deg,#57B9FF,#2563eb);border-color:transparent;color:#fff;box-shadow:0 4px 16px rgba(87,185,255,.38);}
.kit-phone-tab:not(.active):hover{border-color:rgba(87,185,255,.5);background:rgba(87,185,255,.07);}
.kit-phone{width:290px;background:linear-gradient(160deg,#1c2033,#111827);border-radius:48px;padding:16px;box-shadow:0 0 0 1.5px rgba(255,255,255,.1),0 0 0 10px rgba(87,185,255,.05),0 28px 70px rgba(0,0,0,.35);position:relative;flex-shrink:0;}
.kit-phone-notch{position:absolute;top:16px;left:50%;transform:translateX(-50%);width:88px;height:24px;background:linear-gradient(160deg,#1c2033,#111827);border-radius:0 0 14px 14px;z-index:10;}
.kit-phone-notch::after{content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);width:10px;height:10px;background:#0d1117;border-radius:50%;box-shadow:0 0 0 2px rgba(87,185,255,.15);}
.kit-phone-screen{border-radius:34px;overflow:hidden;aspect-ratio:9/16;background:#000;position:relative;}
.kit-phone-vid{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .4s ease;}
.kit-phone-vid.active{opacity:1;pointer-events:auto;}
.kit-phone-vid iframe{width:100%;height:100%;border:none;display:block;}

/* Kit image */
.kit-img-wrap{text-align:center;}
.kit-img{
  max-width:100%;width:900px;border-radius:22px;display:inline-block;
  box-shadow:0 18px 56px rgba(87,185,255,.2),0 4px 16px rgba(0,0,0,.08);
  animation:kit-img-float 5s ease-in-out infinite;
}
@keyframes kit-img-float{
  0%,100%{transform:translateY(0);box-shadow:0 18px 56px rgba(87,185,255,.2),0 4px 16px rgba(0,0,0,.08);}
  50%{transform:translateY(-12px);box-shadow:0 30px 72px rgba(87,185,255,.3),0 8px 24px rgba(0,0,0,.1);}
}

@media(max-width:860px){
  .kit-section{padding:4rem 5%;}
  .kit-videos{max-width:520px;gap:1.2rem;}
}
@media(max-width:600px){
  .kit-section{padding:3rem 4%;}
  .kit-videos{grid-template-columns:1fr;max-width:300px;gap:2rem;}
  .kit-title{font-size:clamp(1.6rem,5vw,2.2rem);}
  .kit-desc{font-size:14px;}
}
@media(max-width:480px){
  .kit-inner{gap:2.5rem;}
  .kit-videos{max-width:280px;}
}

/* ══ MODAL AVISO DE PRIVACIDAD ══ */
.priv-modal{
  position:fixed;inset:0;z-index:10000;
  background:rgba(6,8,15,.72);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;
  padding:16px;
}
.priv-box{
  background:#fff;border-radius:20px;
  max-width:760px;width:100%;max-height:88vh;
  display:flex;flex-direction:column;
  box-shadow:0 32px 80px rgba(0,0,0,.45);overflow:hidden;
}
.priv-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
  padding:1.8rem 2rem 1.2rem;
  border-bottom:1px solid #e8eef4;
  flex-shrink:0;
}
.priv-badge{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:#2563eb;
  background:rgba(37,99,235,.09);border:1px solid rgba(37,99,235,.2);
  padding:.3rem .85rem;border-radius:20px;margin-bottom:.6rem;
}
.priv-title{font-size:1.35rem;font-weight:800;color:#0c1a25;line-height:1.2;margin-bottom:.3rem;}
.priv-meta{font-size:12px;color:#5a7d93;}
.priv-close{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
  background:#f0f4f8;border:none;font-size:16px;cursor:pointer;
  color:#5a7d93;display:flex;align-items:center;justify-content:center;
  transition:.2s;
}
.priv-close:hover{background:#e0e8f0;color:#0c1a25;}
.priv-body{flex:1;overflow-y:auto;padding:1.5rem 2rem;}
.priv-section{
  padding:1.1rem 0;border-bottom:1px solid #eef2f6;
}
.priv-section:last-child{border-bottom:none;}
.priv-section h3{
  font-size:13.5px;font-weight:700;color:#1565c0;
  margin-bottom:.6rem;line-height:1.3;
}
.priv-section p{font-size:13px;color:#2d5068;line-height:1.7;margin-bottom:.5rem;}
.priv-section p:last-child{margin-bottom:0;}
.priv-section ul{
  margin:.5rem 0 .5rem 1.2rem;display:flex;flex-direction:column;gap:.3rem;
}
.priv-section ul li{font-size:13px;color:#2d5068;line-height:1.6;}
.priv-section a{color:#2563eb;text-decoration:underline;}
.priv-note{font-size:12px !important;color:#5a7d93 !important;font-style:italic;}
.priv-accept{background:#f8fbff;border-radius:12px;padding:1rem 1.2rem !important;margin-top:.5rem;}
.priv-date{font-size:12px !important;color:#5a7d93 !important;margin-top:.4rem !important;}
.priv-footer{
  padding:1rem 2rem;border-top:1px solid #e8eef4;
  display:flex;justify-content:flex-end;flex-shrink:0;
}
.priv-btn-close{
  background:linear-gradient(135deg,#57B9FF,#2563eb);
  color:#fff;border:none;border-radius:30px;
  padding:.6rem 1.8rem;font-size:13px;font-weight:700;
  cursor:pointer;transition:.2s;
}
.priv-btn-close:hover{opacity:.88;}
@media(max-width:600px){
  .priv-header{padding:1.2rem 1.2rem .9rem;}
  .priv-body{padding:1rem 1.2rem;}
  .priv-footer{padding:.8rem 1.2rem;}
  .priv-title{font-size:1.1rem;}
}

/* ══ BANNER COOKIES ══ */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9998;
  padding:0 5% 1rem;
  pointer-events:none;
}
.cookie-banner.cookie-show{pointer-events:auto;}
.cookie-inner{
  max-width:900px;margin:0 auto;
  background:linear-gradient(135deg,#0d1220 0%,#111827 100%);
  border:1px solid rgba(87,185,255,.22);
  border-radius:16px 16px 0 0;
  padding:1.2rem 1.6rem;
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  box-shadow:0 -8px 40px rgba(0,0,0,.45),0 0 0 1px rgba(87,185,255,.08);
  transform:translateY(120%);transition:transform .45s cubic-bezier(.34,1.1,.64,1);
}
.cookie-show .cookie-inner{transform:translateY(0);}
.cookie-hide .cookie-inner{transform:translateY(120%);transition:transform .35s ease-in;}
.cookie-icon{font-size:2rem;flex-shrink:0;}
.cookie-text{flex:1;min-width:200px;}
.cookie-text strong{font-size:14px;font-weight:700;color:#eef4ff;display:block;margin-bottom:.2rem;}
.cookie-text p{font-size:12px;color:#476070;line-height:1.55;margin:0;}
.cookie-actions{display:flex;gap:.7rem;align-items:center;flex-shrink:0;flex-wrap:wrap;}
.cookie-btn-info{
  background:transparent;border:1px solid rgba(87,185,255,.3);
  color:#57B9FF;font-size:12px;font-weight:600;
  padding:.5rem 1.1rem;border-radius:30px;cursor:pointer;
  transition:.2s;white-space:nowrap;
}
.cookie-btn-info:hover{background:rgba(87,185,255,.1);}
.cookie-btn-accept{
  background:linear-gradient(135deg,#57B9FF,#2563eb);
  color:#fff;border:none;font-size:12px;font-weight:700;
  padding:.55rem 1.4rem;border-radius:30px;cursor:pointer;
  transition:.2s;white-space:nowrap;
  box-shadow:0 4px 14px rgba(37,99,235,.35);
}
.cookie-btn-accept:hover{opacity:.88;transform:translateY(-1px);}
@media(max-width:600px){
  .cookie-inner{flex-direction:column;align-items:flex-start;gap:.9rem;border-radius:16px 16px 0 0;}
  .cookie-actions{width:100%;justify-content:flex-end;}
}

/* ══ MODAL REGISTRO VERANO 2026 ══ */
.reg-modal{
  position:fixed;inset:0;z-index:10001;
  background:rgba(6,8,15,.75);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:16px;
}
.reg-box{
  background:#f5f8fc;border-radius:20px;
  max-width:680px;width:100%;max-height:90vh;
  display:flex;flex-direction:column;
  box-shadow:0 32px 80px rgba(0,0,0,.5);overflow:hidden;
}
.reg-header{
  background:linear-gradient(135deg,#0d1220,#1a2540);
  padding:1.4rem 1.8rem;display:flex;align-items:center;
  justify-content:space-between;gap:1rem;flex-shrink:0;
}
.reg-badge{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#57B9FF;background:rgba(87,185,255,.12);border:1px solid rgba(87,185,255,.25);
  padding:.28rem .8rem;border-radius:20px;display:inline-block;margin-bottom:.45rem;}
.reg-title{font-size:1.3rem;font-weight:900;color:#eef4ff;letter-spacing:.04em;margin:0;}
.reg-close{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);
  border:none;color:#8bafc8;font-size:16px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;transition:.2s;}
.reg-close:hover{background:rgba(255,255,255,.2);color:#fff;}

.reg-body{flex:1;overflow-y:auto;padding:1.5rem 1.8rem;display:flex;flex-direction:column;gap:1.4rem;}

.reg-section{background:#fff;border-radius:14px;padding:1.3rem 1.4rem;
  box-shadow:0 2px 12px rgba(0,0,0,.06);border:1px solid #e4ecf4;}
.reg-section-title{font-size:13px;font-weight:800;color:#1565c0;text-transform:uppercase;
  letter-spacing:.06em;margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;}
.reg-section-title span:first-child{display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:#1565c0;color:#fff;
  font-size:10px;font-weight:900;flex-shrink:0;}
.reg-optional{font-size:10px;font-weight:500;color:#5a7d93;text-transform:none;letter-spacing:0;margin-left:auto;}

.reg-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem;}
.reg-group:last-child{margin-bottom:0;}
.reg-group label{font-size:11px;font-weight:700;color:#2d5068;text-transform:uppercase;letter-spacing:.06em;}
.reg-group label em{color:#e11d48;font-style:normal;}
.reg-group input,.reg-group select,.reg-group textarea{
  width:100%;padding:.6rem .85rem;border:1px solid #d0dce8;border-radius:8px;
  font-size:13px;color:#0c1a25;background:#f8fbff;
  transition:border-color .2s,box-shadow .2s;font-family:inherit;outline:none;}
.reg-group input:focus,.reg-group select:focus{border-color:#57B9FF;box-shadow:0 0 0 3px rgba(87,185,255,.15);}
.reg-group select{cursor:pointer;}
.reg-otro-estado{display:none;margin-top:.5rem !important;}

.reg-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.85rem;}
.reg-row .reg-group{margin-bottom:0;}

.reg-radio-group{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.3rem;}
.reg-radio{display:flex;align-items:center;gap:.5rem;cursor:pointer;
  background:#f0f5fb;border:1px solid #d0dce8;border-radius:30px;padding:.45rem 1.1rem;
  transition:.2s;}
.reg-radio:has(input:checked){background:rgba(21,101,192,.1);border-color:#1565c0;}
.reg-radio input{display:none;}
.reg-radio span{font-size:13px;font-weight:600;color:#2d5068;}
.reg-radio:has(input:checked) span{color:#1565c0;}

.reg-footer{padding:1rem 1.8rem;background:#fff;border-top:1px solid #e4ecf4;
  display:flex;justify-content:flex-end;gap:.75rem;flex-shrink:0;}
.reg-btn-cancel{background:transparent;border:1px solid #d0dce8;color:#5a7d93;
  font-size:13px;font-weight:600;padding:.55rem 1.3rem;border-radius:30px;cursor:pointer;transition:.2s;}
.reg-btn-cancel:hover{background:#f0f5fb;}
.reg-btn-submit{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border:none;
  font-size:13px;font-weight:700;padding:.6rem 1.5rem;border-radius:30px;cursor:pointer;
  display:flex;align-items:center;gap:.5rem;transition:.2s;
  box-shadow:0 4px 14px rgba(37,211,102,.35);}
.reg-btn-submit:hover{opacity:.88;transform:translateY(-1px);}

@media(max-width:580px){
  .reg-body{padding:1rem 1rem;}
  .reg-header{padding:1.1rem 1.1rem;}
  .reg-row{grid-template-columns:1fr;}
  .reg-footer{padding:.8rem 1rem;}
}

/* ══════════════════════════════════════════════
   RESPONSIVE – COMPREHENSIVE OVERRIDES
   ══════════════════════════════════════════════ */

/* ── 1024 px ── */
@media(max-width:1024px){
  .contact-wrap{grid-template-columns:1fr;}
  .globe-cta-content{padding:5rem 5%;}
  .leon-mascot{display:none;}
  /* 5-stat grid: 3 cols (rows: 3 + 2) */
  .stats-grid{grid-template-columns:repeat(3,1fr);}
  /* 5-benefit grid: 3 cols (rows: 2 + 3) */
  .quick-grid{grid-template-columns:repeat(3,1fr);}
}

/* ── 860 px ── */
@media(max-width:860px){
  .vs-section{padding:3rem 5%;}
  .vs-wrap{border-radius:14px;}
  .form-card{padding:2rem 1.5rem;}
  .programs{padding:4rem 5%;}
}

/* ── 768 px ── */
@media(max-width:768px){
  /* top bar: keep badge only */
  .top-bar{height:32px;}
  .top-bar-badge{font-size:10px;}
  #navbar{top:40px;width:calc(100% - 2rem);height:58px;}
  .mobile-menu{top:110px;bottom:0;}
  .hero{padding:100px 5% 60px;}

  /* Programs section */
  .programs{padding:3rem 5%;}
  .tabs{gap:6px;margin-bottom:.8rem;}
  .subtabs{gap:5px;margin-bottom:1.5rem;}
  .tab{padding:8px 16px;font-size:12px;}
  .subtab{padding:6px 14px;font-size:11px;}

  /* Carousel cards on tablet */
  .cs-track .prog-card{width:220px;}

  /* Contact */
  .contact{padding:3rem 5%;}
  .form-card{padding:1.75rem 1.25rem;}

  /* Globe CTA */
  .globe-cta{min-height:380px;}
  .globe-cta-content{padding:4rem 5%;}
  .globe-cta-content h2{font-size:clamp(1.6rem,4vw,2.4rem);}

  /* Video showcase */
  .vs-section{padding:3rem 5%;}

  /* Why section – hide orbit canvas on 768 and below */
  .why-orbit-canvas{display:none;}
  .why-orbit-side .wo-stats{gap:1.5rem;}

  /* DV body padding */
  .dv-body{padding:2rem 5%;}

  /* CV info */
  .cv-info-inner{gap:3rem;}

  /* Footer */
  .footer-top{gap:2rem;}

  /* Social icons in mobile navbar */
  .nav-social-mobile{
    display:flex;
    align-items:center;
    gap:7px;
    margin-left:auto;
    margin-right:10px;
  }
  .nav-social-mobile a{
    width:28px;height:28px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    text-decoration:none;
    transition:color .2s, transform .2s;
  }
  .nav-social-mobile a[aria-label="Facebook"]{color:#1877F2;}
  .nav-social-mobile a[aria-label="Instagram"]{color:#E1306C;}
  .nav-social-mobile a[aria-label="LinkedIn"]{color:#0A66C2;}
  .nav-social-mobile a[aria-label="TikTok"]{color:#69C9D0;}
  .nav-social-mobile a:hover{transform:scale(1.2);filter:brightness(1.25);}
  .hamburger{display:flex;}
}

/* ── 600 px ── */
@media(max-width:600px){
  /* Make tabs horizontally scrollable */
  .tabs{
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding-bottom:4px;
    gap:6px;
  }
  .tabs::-webkit-scrollbar{display:none;}
  .subtabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px;}
  .subtabs::-webkit-scrollbar{display:none;}
  .tab{
    flex-shrink:0;
    padding:8px 14px;
    font-size:12px;
  }
  .subtab{flex-shrink:0;}
  /* Prox panel: slightly wider on tablet */
  .prox-panel{width:min(350px,88vw);}

  /* Quick access */
  .quick-access{padding:2.5rem 5%;}
  .quick-item{padding:1.5rem 1.25rem;}

  /* Stats band */
  .stats-band{padding:3rem 5%;}
  .stat-big .n{font-size:2.2rem;}

  /* Programs */
  .programs{padding:3rem 4%;}

  /* Carousel cards on mobile */
  .cs-track .prog-card{width:200px;}
  .cs-track{gap:16px;}
  .cs-phrase{font-size:clamp(1rem,3vw,1.35rem);}

  /* Video showcase */
  .vs-section{padding:2.5rem 4%;}
  .vs-title{font-size:clamp(1.5rem,5vw,2.2rem);}
  .vs-sub{font-size:.9rem;}

  /* Globe CTA */
  .globe-cta-content{padding:3rem 5%;}
  .globe-cta-content>p{font-size:14px;}

  /* Contact form */
  .form-card{padding:1.5rem 1rem;}
  .form-card h3{font-size:1rem;margin-bottom:1.25rem;}

  /* Why section */
  .why{padding:3rem 5%;}
  .why-header{margin-bottom:2.5rem;}
  .wf-num{font-size:2rem;min-width:48px;}
  .wf-body h3{font-size:14px;}

  /* Campus cards */
  .campus-accordion{gap:.6rem;}
  .ca-item{height:160px;}
  .ca-title{font-size:.7rem;}

  /* Testimonials */
  .tiktok-circle{width:120px;height:120px;}
  .tiktok-label{font-size:11px;max-width:120px;}

  /* Privacy modal */
  .priv-box{border-radius:14px;}

  /* Registration modal */
  .reg-box{border-radius:14px;}
  .reg-title{font-size:1.1rem;}
  .reg-section{padding:1rem 1.1rem;}

  /* Cookie banner */
  .cookie-inner{padding:1rem 1.2rem;}
}

/* ── 480 px ── */
@media(max-width:480px){
  /* Top bar: hide completely on very small screens */
  .top-bar{display:none;}
  #navbar{top:8px;width:calc(100% - 1.5rem);}
  .mobile-menu{top:82px;bottom:0;}
  .hero{padding:88px 5% 60px;}

  /* Nav logo smaller */
  .nav-logo img{height:34px;}

  /* Carousel cards */
  .cs-track .prog-card{width:180px;}
  .cs-track{gap:12px;}

  /* Video section */
  .vs-section{padding:2rem 4%;}
  .vs-play-ring{width:72px;height:72px;}
  .vs-play-btn{width:54px;height:54px;}
  .vs-play-btn svg{width:20px;height:20px;}

  /* Hero stats smaller */
  .hero-stats .num{font-size:1.6rem;}
  .hero-stats{gap:16px;}
  .hero-logo img{height:110px;}

  /* Programs */
  .programs{padding:2.5rem 4%;}
  .section-title{font-size:clamp(1.5rem,5vw,2rem);}

  /* Prog card text */
  .prog-card h3{font-size:13.5px;}
  .prog-card p{font-size:12px;}
  .prog-icon{font-size:2rem;}

  /* Quick grid */
  .quick-grid{grid-template-columns:1fr 1fr;}
  .quick-item{padding:1.25rem 1rem;}
  .qi-icon{font-size:1.6rem;}
  .quick-item h4{font-size:14px;}
  .quick-item p{font-size:12px;}

  /* Stats band */
  .stat-big .n{font-size:1.9rem;}
  .stat-big .l{font-size:11px;}
  .stats-band{padding:2.5rem 4%;}

  /* CTA strip */
  .cta-strip{padding:1rem 5%;}
  .cta-strip-text strong{font-size:1rem;}
  .cta-strip-actions{width:100%;}
  .cta-strip-btn{width:100%;justify-content:center;}
  .cta-strip-link{display:none;}

  /* Globe CTA */
  .globe-cta{min-height:320px;}
  .globe-cta-content{padding:2.5rem 5%;}
  .globe-cta-content h2{font-size:clamp(1.4rem,5vw,2rem);}

  /* Contact */
  .contact{padding:2.5rem 4%;}
  .form-card{padding:1.25rem .9rem;}
  .submit-btn{font-size:13px;padding:12px;}

  /* Why features */
  .wf-item{padding:1.2rem 0 1.2rem .8rem;}
  .wf-num{font-size:1.6rem;min-width:40px;}

  /* Footer */
  .footer-top{gap:1.5rem;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.6rem;}

  /* Acred */
  .acred{padding:2rem 4%;}
  .acred-inner{gap:.75rem;}
  .acred-badge{padding:8px 12px;}
  .ab-text{font-size:12px;}

  /* CV info */
  .cv-info-inner{gap:2.5rem;padding:0 4%;}
  .cv-info-stats{gap:1rem;}
  .cv-stat{padding:.6rem .8rem;min-width:56px;}
  .cv-stat-n{font-size:1.1rem;}
  .cv-why-grid{grid-template-columns:1fr;}

  /* Campus section */
  .campus{padding:2.5rem 4%;}
  .campus-accordion{gap:.5rem;}
  .ca-item{height:150px;}

  /* Privacy modal */
  .priv-modal{padding:8px;}
  .priv-box{border-radius:12px;max-height:95vh;}
  .priv-header{padding:1rem .9rem .8rem;}
  .priv-body{padding:.85rem .9rem;}
  .priv-footer{padding:.75rem .9rem;}
  .priv-title{font-size:1rem;}

  /* Registration modal */
  .reg-modal{padding:8px;}
  .reg-box{border-radius:12px;max-height:95vh;}
  .reg-header{padding:.9rem 1rem;}
  .reg-title{font-size:1rem;letter-spacing:.02em;}
  .reg-body{padding:.85rem .9rem;gap:1rem;}
  .reg-section{padding:.9rem 1rem;}
  .reg-footer{padding:.75rem .9rem;gap:.5rem;}
  .reg-btn-cancel{padding:.5rem 1rem;font-size:12px;}
  .reg-btn-submit{padding:.5rem 1.1rem;font-size:12px;}

  /* Cookie banner */
  .cookie-inner{padding:.9rem 1rem;gap:.7rem;}
  .cookie-icon{font-size:1.5rem;}
  .cookie-text strong{font-size:13px;}
  .cookie-text p{font-size:11px;}
  .cookie-btn-info,.cookie-btn-accept{font-size:11px;padding:.45rem .9rem;}

  /* Mobile bar safe area */
  body{padding-bottom:72px;}
}

/* ── 380 px ── */
@media(max-width:380px){
  .nav-logo img{height:30px;}
  .hamburger span{width:20px;}
  .tab{padding:7px 12px;font-size:11px;}
  .hero-content h1{font-size:clamp(1.8rem,7vw,2.8rem);}
  .hero-content p{font-size:.95rem;}
  .cs-track .prog-card{width:165px;}
  .stat-big .n{font-size:1.6rem;}
  .prog-card h3{font-size:13px;}
  .globe-cta-content h2{font-size:clamp(1.3rem,6vw,1.8rem);}
  .reg-title{font-size:.95rem;}
  .reg-badge{font-size:10px;}
  .priv-title{font-size:.95rem;}
  .footer-col h4{font-size:11px;}
  .footer-col li a{font-size:12px;}
  .subtab{padding:5px 10px;font-size:10px;}
  .prox-tab-label{font-size:9px;}
  .prox-panel-head h3{font-size:11px;}
}
@media(max-width:360px){
  /* ── Navbar ── */
  .nav-logo img{height:26px;}
  #navbar{padding:0 .5rem;}
  .hamburger span{width:18px;}

  /* ── Hero (landing) ── */
  .hero{padding:76px 4% 38px;min-height:auto;}
  .hero-content h1{font-size:clamp(1.5rem,8vw,1.95rem);}
  .hero-content p{font-size:.86rem;line-height:1.6;margin-bottom:1.5rem;}
  .hero-badge{font-size:10px;padding:5px 10px;}
  .hero-btns{gap:8px;}
  .btn-primary,.btn-outline{padding:11px 16px;font-size:13px;}
  .hero-stats{gap:8px;flex-wrap:wrap;row-gap:10px;}
  .hero-stats .num{font-size:1.28rem;}
  .hero-stats .lbl{font-size:9px;}
  .hero-logo img{height:80px;}

  /* ── Secciones generales ── */
  .section-title{font-size:clamp(1.25rem,7vw,1.65rem);}
  .section-sub{font-size:.84rem;}

  /* ── Stats band ── */
  .stat-big .n{font-size:1.3rem;}
  .stat-big .l{font-size:9.5px;}
  .stats-grid{grid-template-columns:1fr 1fr;gap:.65rem;}
  .stats-band{padding:2rem 4%;}

  /* ── Cards de programas ── */
  .cs-track .prog-card{width:152px;}
  .prog-card{padding:.8rem;}
  .prog-card h3{font-size:12px;}
  .prog-card p{font-size:10.5px;}
  .prog-tag{font-size:9px;padding:2px 6px;}

  /* ── Mini cards ── */
  .mini-cards-grid{grid-template-columns:1fr;}

  /* ── Quick items ── */
  .quick-grid{grid-template-columns:1fr;}
  .quick-item{padding:.9rem .8rem;}
  .quick-item h4{font-size:12.5px;}
  .quick-item p{font-size:11px;}

  /* ── Detail hero (dv-hero) ── */
  .dv-hero{padding:82px 4% 1.5rem;}
  .dv-hero h1{font-size:clamp(1.3rem,7vw,1.8rem);margin-bottom:.75rem;}
  .dv-hero p{font-size:.85rem;margin-bottom:1.25rem;}
  .dv-badge{font-size:10.5px;padding:3px 10px;margin-bottom:.65rem;}
  .breadcrumb{font-size:11.5px;margin-bottom:.85rem;gap:5px;}
  .dv-hero-body{gap:1.25rem;}
  .btn-back{padding:9px 14px;font-size:12.5px;}
  /* Botones del hero: apilar verticalmente */
  .dv-btns{flex-direction:column;align-items:stretch;gap:8px;}
  .dv-btns .btn-back,.dv-btns .btn-primary{width:100%;justify-content:center;}

  /* ── Tarjeta info general ── */
  .dv-meta{padding:12px 13px;border-radius:12px;}
  .dv-meta-header{font-size:7.5px;margin-bottom:8px;padding-bottom:7px;}
  .meta-chip .mc-icon{width:22px;height:22px;font-size:.74rem;}
  .mc-label{font-size:9px;}
  .mc-val{font-size:11px;}
  .meta-chip{padding:7px 0;gap:9px;}

  /* ── Cuerpo detalle ── */
  .dv-body{padding:1.5rem 4%;}
  .dv-card{padding:1.1rem 1rem;margin-bottom:.9rem;border-radius:14px;}
  .dv-card h2{font-size:14px;margin-bottom:.85rem;}
  .dv-card p{font-size:13px;}
  .dv-card ul li{font-size:13px;}
  .dv-card ul{gap:.45rem;}

  /* ── Side CTA ── */
  .side-cta{padding:1rem 1.1rem;}
  .side-cta h3{font-size:13px;}
  .side-cta p{font-size:12px;margin-bottom:1rem;}
  .side-cta button{font-size:12px;padding:11px;}

  /* ── Módulos (acordeón) ── */
  .mod-accordion{grid-template-columns:1fr;}
  .mod-acc-header{padding:.65rem .75rem;gap:.55rem;}
  .mod-acc-badge{width:38px;height:38px;border-radius:8px;}
  .mod-acc-title{font-size:12.5px;}

  /* ── Proceso de inscripción ── */
  .ins-step{gap:.65rem;padding:.7rem 0;}
  .ins-num{width:30px;height:30px;font-size:9.5px;}
  .ins-step:not(.ins-step-last)::after{left:15px;top:44px;}
  .ins-body strong{font-size:13px;}
  .ins-body p{font-size:11.5px;}

  /* ── Tabs ── */
  .tab{padding:5px 9px;font-size:10px;}
  .subtab{padding:4px 8px;font-size:9px;}

  /* ── Menú móvil ── */
  .mobile-menu{padding:1.2rem 4% 2rem;}
  .mobile-menu a{font-size:13.5px;padding:10px 11px;}
  .mobile-menu .mm-label{font-size:9px;padding:8px 11px 2px;}

  /* ── Barra inferior móvil ── */
  .mobile-bar a{padding:5px 10px;font-size:9.5px;}
  .bar-icon{font-size:17px;}

  /* ── Inputs: ≥16px para evitar zoom en iOS ── */
  input,select,textarea{font-size:16px !important;}

  /* ── CTA strip ── */
  .cta-strip{padding:.8rem 4%;}
  .cta-strip-text strong{font-size:.88rem;}

  /* ── Globe CTA ── */
  .globe-cta{min-height:265px;}
  .globe-cta-content h2{font-size:clamp(1.15rem,7vw,1.55rem);}
  .globe-cta-content{padding:2rem 4%;}

  /* ── Footer ── */
  .footer-top{gap:1.25rem;}
  .footer-brand p{font-size:.81rem;}
  .footer-col h4{font-size:10.5px;}
  .footer-col li a{font-size:11.5px;}
  .footer-bottom{font-size:10.5px;gap:.4rem;}
  .footer-bottom p{font-size:10.5px;}

  /* ── Modales y formularios ── */
  .reg-title{font-size:.86rem;}
  .reg-form-inner{padding:.85rem .9rem;}
  .priv-title{font-size:.9rem;}
  .priv-body{padding:.8rem .9rem;}

  /* ── Animación reveal más rápida en móvil ── */
  .reveal{transition-duration:.3s;}

  /* ── Campus Virtual / Chamilo section ── */
  .cv-info-section{padding:3rem 0;}
  .cv-info-inner{gap:3rem;padding:0 4%;}
  .cv-info-hero{gap:1.5rem;}
  .cv-info-title{font-size:clamp(1.2rem,6.5vw,1.6rem);margin-bottom:.75rem;}
  .cv-info-desc p{font-size:13px;}
  .cv-info-stats{gap:.75rem;margin-top:1rem;}
  .cv-stat{padding:.6rem .8rem;min-width:56px;}
  .cv-stat-n{font-size:1.05rem;}
  .cv-stat-l{font-size:9px;}
  .cv-why-title{font-size:clamp(1.1rem,6vw,1.5rem);margin-bottom:1.5rem;}
  .cv-why-card{padding:1.1rem;}
  .cv-why-icon{font-size:1.5rem;}
  .cv-why-card h3{font-size:13px;}
  .cv-why-card p{font-size:12px;}
  .cv-diff-title{font-size:clamp(1.1rem,6vw,1.5rem);}
  .cv-diff-sub{font-size:13px;}
  .cv-badge-card{padding:1.2rem 1rem;}
  .cv-badge-star{font-size:2.2rem;}
  .cv-badge-card h3{font-size:13px;}
  .cv-badge-card>p{font-size:12px;}
  .chm-title{font-size:clamp(1.1rem,6vw,1.5rem);}
  .chm-tabs{flex-wrap:wrap;justify-content:center;gap:.5rem;}
  .chm-tab{flex:1 1 calc(50% - .3rem);min-width:0;max-width:calc(50% - .3rem);padding:.75rem .6rem;}
  .chm-tab-icon{font-size:1.2rem;}
  .chm-tab-lbl{font-size:10px;}
  .chm-panel{padding:1rem .85rem;gap:1.25rem;}
  .chm-panel-title{font-size:1.15rem;}
  .chm-panel p{font-size:13px;}
  .chm-list li{font-size:12.5px;}
  .chm-feat{padding:.65rem .75rem;}
  .chm-feat-lbl{font-size:11.5px;}
  .chm-access-btn{font-size:13px;padding:.75rem 1.5rem;}
  .cv-chamilo-cta{padding:1.2rem 1rem;gap:1rem;}
  .cv-chamilo-body h3{font-size:14px;}
  .cv-chamilo-body p{font-size:12px;}
}

/* ===== PRÓXIMOS INICIOS TAB ===== */
.prox-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:900;background:linear-gradient(180deg,#1A6EBF 0%,#0d4f99 100%);color:#fff;border-radius:10px 0 0 10px;padding:18px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:-3px 0 20px rgba(0,0,0,.35);transition:right .35s cubic-bezier(.4,0,.2,1),box-shadow .25s;}
.prox-tab.prox-hidden{right:-56px;}
.prox-tab:hover{box-shadow:-5px 0 28px rgba(26,110,191,.55);}
.prox-tab-label{writing-mode:vertical-rl;transform:rotate(180deg);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;line-height:1;white-space:nowrap;}
.prox-tab-icon{font-size:18px;line-height:1;}
.prox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:910;opacity:0;pointer-events:none;transition:opacity .3s;}
.prox-overlay.prox-open{opacity:1;pointer-events:all;}
.prox-panel{position:fixed;right:-360px;top:50%;transform:translateY(-50%);z-index:920;width:320px;max-height:82vh;overflow-y:auto;background:#0e1622;border:1px solid rgba(87,185,255,.22);border-radius:14px 0 0 14px;box-shadow:-8px 0 40px rgba(0,0,0,.55);transition:right .35s cubic-bezier(.4,0,.2,1);}
.prox-panel.prox-open{right:0;}
.prox-panel-head{background:linear-gradient(135deg,#1A6EBF,#0d4f99);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1;}
.prox-panel-head h3{margin:0;color:#fff;font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;}
.prox-panel-close{background:none;border:none;color:rgba(255,255,255,.8);font-size:20px;cursor:pointer;line-height:1;padding:0 2px;transition:color .2s;}
.prox-panel-close:hover{color:#fff;}
.prox-panel-body{padding:10px 14px 14px;}
.prox-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(87,185,255,.1);}
.prox-item:last-of-type{border-bottom:none;}
.prox-item-num{min-width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#1A6EBF,#57B9FF);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;margin-top:2px;}
.prox-item-info{flex:1;}
.prox-item-name{font-size:12px;font-weight:700;color:#dde6f4;line-height:1.35;margin-bottom:3px;}
.prox-item-meta{font-size:10px;color:#57B9FF;font-weight:600;margin-bottom:3px;}
.prox-item-link{font-size:10px;color:rgba(87,185,255,.8);text-decoration:none;transition:color .2s;}
.prox-item-link:hover{color:#8dd4ff;text-decoration:underline;}
.prox-ver-todos{display:block;margin-top:12px;background:linear-gradient(135deg,#1A6EBF,#0d4f99);color:#fff !important;text-align:center;padding:10px;border-radius:8px;font-size:11px;font-weight:800;letter-spacing:.06em;text-decoration:none;text-transform:uppercase;transition:opacity .2s;}
.prox-ver-todos:hover{opacity:.85;}
.prox-section-head{display:flex;align-items:center;gap:7px;margin:10px 0 4px;padding-top:9px;border-top:1px solid rgba(87,185,255,.12);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:rgba(170,200,230,.5);}
.prox-section-first{border-top:none !important;margin-top:2px !important;padding-top:0 !important;}
.prox-city-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0;}
@media(max-width:480px){
  /* Tab: pill flotante en esquina inferior izquierda */
  .prox-tab{
    top:auto;
    bottom:76px;
    right:auto;
    left:0;
    transform:none;
    flex-direction:row;
    border-radius:0 20px 20px 0;
    padding:9px 13px;
    gap:7px;
    transition:bottom .35s cubic-bezier(.4,0,.2,1),box-shadow .25s;
  }
  .prox-tab.prox-hidden{left:0;bottom:-72px;}
  .prox-tab-label{writing-mode:horizontal-tb;transform:none;font-size:10px;letter-spacing:.1em;}
  .prox-tab-icon{font-size:16px;}
  /* Panel: bottom sheet que sube desde abajo */
  .prox-panel{
    width:100%;
    right:0;
    left:0;
    top:auto;
    bottom:-100vh;
    transform:none;
    border-radius:20px 20px 0 0;
    max-height:72vh;
    transition:bottom .35s cubic-bezier(.4,0,.2,1);
  }
  .prox-panel.prox-open{right:0;bottom:0;}
  .prox-panel-head{border-radius:20px 20px 0 0;padding:14px 16px;}
  .prox-panel-head h3{font-size:12px;}
  .prox-panel-body{padding:8px 14px 14px;}
  .prox-item-name{font-size:11px;}
  .prox-ver-todos{font-size:10px;padding:9px;}
}


/* ══ PROMO HERO POPUP ══ */
@keyframes phbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes phbGlowPulse{0%,100%{opacity:1}50%{opacity:.7}}
#promoHeroBadge{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:none;background:rgba(6,6,12,.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:2px solid #fff;border-radius:20px;padding:1.1rem 1.5rem;text-align:center;min-width:185px;max-width:240px;animation:phbFloat 3s ease-in-out infinite;cursor:default;}
#promoHeroBadge .phb-fire{font-size:1.9rem;display:block;line-height:1;margin-bottom:.2rem;}
#promoHeroBadge .phb-top{display:block;font-size:.72rem;font-weight:700;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.1em;}
#promoHeroBadge .phb-mid{display:block;font-size:.98rem;font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:.03em;line-height:1.2;margin-top:.1rem;}
#promoHeroBadge .phb-date{display:inline-flex;align-items:center;gap:.3rem;border-radius:999px;padding:.22rem .85rem;font-size:.76rem;font-weight:800;margin-top:.6rem;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,.93);color:#111;}
#promoHeroBadge .phb-sub{display:block;font-size:.68rem;color:rgba(255,255,255,.52);margin-top:.35rem;font-style:italic;}
@media(max-width:768px){#promoHeroBadge{bottom:1rem;right:1rem;min-width:155px;max-width:195px;padding:.85rem 1rem;border-radius:16px;}#promoHeroBadge .phb-fire{font-size:1.5rem;}#promoHeroBadge .phb-mid{font-size:.85rem;}#promoHeroBadge .phb-date{font-size:.68rem;}}
@media(max-width:480px){#promoHeroBadge{display:none!important;}}
