/* ═══════════════════════════════════════════════════════
   UNIVIM · univim-base.css v2.0
   CSS compartido — editar aquí afecta TODO el sitio
   Tipografía: Gibson (local) · Paleta: Guinda + Dorado
═══════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════
   UNIVIM v4 — Paleta oficial exacta
   Guinda #911A3A · Dorado #BD9868 · Rosa #C83182 · Gris #ADADAD
   Dirección: editorial de lujo latinoamericano
   ══════════════════════════════════════════════ */
:root{
  /* Paleta oficial UNIVIM */
  --G:  #911A3A; /* Guinda  PANTONE 1955C */
  --G2: #6e132c; /* Guinda oscuro */
  --G3: #b5203f; /* Guinda claro */
  --Gl: #f7eaee; /* Guinda tint */
  --D:  #BD9868; /* Dorado  PANTONE 4655C */
  --D2: #9a7a50; /* Dorado oscuro */
  --Dl: #f5ede0; /* Dorado tint */
  --R:  #C83182; /* Rosa    PANTONE 233C */
  --Rl: #fce8f3; /* Rosa tint */
  --Gr: #ADADAD; /* Gris    Cool Gray 5U */
  --Grd:#7a7a7a; /* Gris oscuro */
  /* Neutros */
  --ink: #1a0a10;
  --ink2:#3d1a22;
  --mist:#f9f5f6;
  --wh:  #ffffff;
  --bd:  #ede3e6;
  /* Tipo */
  /* Gibson = fuente oficial UNIVIM (Canada Type/Adobe Fonts)
     Nunito = fallback visual más cercano */
  --serif: 'Gibson','Helvetica Neue',sans-serif;
  --sans:  'Gibson','Helvetica Neue',sans-serif;
  --mono:  'Gibson','Nunito',sans-serif;
  /* Radios */
  --r4:4px; --r8:8px; --r16:16px; --r24:24px; --r9:9999px;
  /* Sombras */
  --s1:0 2px 12px rgba(26,10,16,.08);
  --s2:0 8px 32px rgba(26,10,16,.13);
  --s3:0 20px 60px rgba(26,10,16,.2);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);color:var(--ink);background:var(--wh);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}

/* ── TOPBAR ── */
.topbar{
  background:var(--ink);
  padding:9px 0;
  font-size:11.5px;
  font-family:var(--sans);
  letter-spacing:.02em;
  color:rgba(255,255,255,.85);
  position:relative;
  overflow:hidden;
}
.topbar::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,rgba(189,152,104,.06) 0,rgba(189,152,104,.06) 1px,transparent 1px,transparent 80px);
  pointer-events:none;
}
.tb-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.tb-l,.tb-r{display:flex;align-items:center;gap:18px}
.tb-item{display:flex;align-items:center;gap:6px}
.tb-item i{color:var(--D);font-size:11px}
.tb-soc{display:flex;gap:6px}
.tb-soc a{
  width:22px;height:22px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;color:rgba(255,255,255,.7);transition:.2s;
}
.tb-soc a:hover{background:var(--G);border-color:var(--G);color:var(--wh)}
.tb-divider{width:1px;height:14px;background:rgba(255,255,255,.25)}
.tb-tel{color:var(--D);font-weight:400;letter-spacing:.03em;display:flex;align-items:center;gap:6px}
.topbar a:hover{color:var(--D)}

/* ── HEADER ── */

/* ══ PAGE HERO (shared) ══ */
.page-hero{
  background:linear-gradient(135deg,var(--G2) 0%,var(--G) 55%,#7a1430 100%);
  padding:60px 0 68px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100'%3E%3Cpath d='M28 2 L54 17 L54 47 L28 62 L2 47 L2 17 Z' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3C/svg%3E");
  background-size:56px 100px;pointer-events:none;
}
.page-hero::after{
  content:'';position:absolute;right:-80px;bottom:-80px;width:360px;height:360px;
  border-radius:50%;background:radial-gradient(circle,rgba(189,152,104,.15) 0%,transparent 65%);
  pointer-events:none;
}
.ph-inner{position:relative;z-index:1}

.hdr{
  background:var(--wh);
  position:sticky;top:0;z-index:900;
  border-bottom:1px solid var(--bd);
  transition:box-shadow .3s,border-color .3s;
}
.hdr.scrolled{box-shadow:0 4px 30px rgba(26,10,16,.1);border-color:transparent}
.hdr-row{height:76px;display:flex;align-items:center;justify-content:space-between;gap:12px;overflow:visible}
.hdr-brand{display:flex;align-items:center;gap:4px;flex-shrink:0}
.logo-link{display:flex;align-items:center;flex-shrink:0;gap:0;min-width:0}
.logo-link img{height:48px;width:auto}
.logo-fb{display:none;align-items:center;gap:10px}
.l-mark{
  width:46px;height:46px;
  background:linear-gradient(135deg,var(--G),var(--G3));
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:400;font-size:22px;color:var(--wh);
  box-shadow:0 4px 16px rgba(145,26,58,.3);
}
.l-text strong{font-family:var(--sans);font-size:20px;font-weight:400;color:var(--G);display:block;line-height:1;letter-spacing:-.01em}
.l-text small{font-size:9.5px;color:var(--Gr);letter-spacing:.1em;text-transform:uppercase;display:block;margin-top:3px}

/* NAV */
.nav-main{display:flex;align-items:center;gap:0;flex-shrink:1;min-width:0}
.ni{
  position:relative;
  font-size:14.5px;font-weight:400;color:#2a0f18;
  padding:8px 16px;border-radius:0;
  cursor:pointer;display:flex;align-items:center;gap:6px;
  transition:.2s;white-space:nowrap;user-select:none;
  font-family:var(--sans);letter-spacing:.01em;
  /* Línea inferior animada */
  border-bottom:2px solid transparent;
}
.ni::before{
  content:'';position:absolute;
  bottom:-1px;left:50%;right:50%;height:2px;
  background:var(--G);border-radius:2px;
  transition:.25s ease;
}
.ni:hover::before{left:12px;right:12px}
.ni:hover{color:var(--G);background:transparent}
.ni .cv{font-size:10px;opacity:.5;transition:.28s}
.ni:hover .cv{opacity:1;transform:rotate(180deg);color:var(--G)}
.drop{
  position:absolute;top:calc(100% + 2px);left:0;
  background:var(--wh);border:1px solid var(--bd);
  border-radius:var(--r16);box-shadow:var(--s3);
  min-width:248px;z-index:800;
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:all .2s ease;pointer-events:none;
  overflow:hidden;
}
/* Puente invisible que cubre el gap para no perder el hover */
.ni::after{
  content:'';position:absolute;
  top:100%;left:0;right:0;height:10px;
}
.ni:hover .drop{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.drop-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;font-size:13px;font-weight:400;
  color:#374151;border-bottom:1px solid var(--bd);
  transition:.15s;
}
.drop-item:last-child{border-bottom:none}
.drop-item:hover{background:var(--Gl);color:var(--G);padding-left:20px}
.d-dot{
  width:28px;height:28px;border-radius:8px;
  background:var(--Gl);display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--G);flex-shrink:0;transition:.15s;
}
.drop-item:hover .d-dot{background:var(--G);color:var(--wh)}

.hdr-r{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-search{
  width:38px;height:38px;border-radius:var(--r8);
  border:1.5px solid var(--bd);display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--Gr);cursor:pointer;transition:.2s;
}
.btn-search:hover{border-color:var(--G);color:var(--G);background:var(--Gl)}

.btn-campus i{
  font-size:13px;flex-shrink:0;
  transition:transform .65s cubic-bezier(.34,1.56,.64,1);
}
.btn-campus .bc-txt{
  transition:transform .65s cubic-bezier(.34,1.56,.64,1);
  display:inline-block;
}

.btn-campus:hover i{transform:translateX(18px) scale(1.15)}
.btn-campus:hover .bc-txt{transform:translateX(-6px)}
.btn-campus:active{transform:translateY(-1px) scale(.98)}
@keyframes campus-gradient{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes campus-pulse{
  0%,100%{box-shadow:0 3px 12px rgba(145,26,58,.35),inset 0 0 0 1px rgba(255,255,255,.12)}
  50%{box-shadow:0 6px 20px rgba(145,26,58,.5),inset 0 0 0 1px rgba(255,255,255,.2)}
}

/* ══ HERO ══ */
.hero{position:relative;overflow:hidden;background:var(--ink)}
.hero-swiper{width:100%;height:680px}
.slide{position:relative;overflow:hidden}
.s-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* Overlay editorial con gradiente diagonal */
.slide-ov{position:absolute;inset:0}
.sl-a .slide-ov{background:linear-gradient(118deg,rgba(26,10,16,.97) 0%,rgba(145,26,58,.82) 42%,rgba(145,26,58,.15) 72%,rgba(26,10,16,.05) 100%)}
.sl-b .slide-ov{background:linear-gradient(118deg,rgba(26,10,16,.97) 0%,rgba(26,10,16,.85) 40%,rgba(26,10,16,.3) 72%,transparent 100%)}
.sl-c .slide-ov{background:linear-gradient(118deg,rgba(10,5,32,.97) 0%,rgba(20,10,50,.85) 40%,rgba(20,10,50,.3) 72%,transparent 100%)}

/* Grain texture overlay */
.slide-grain{
  position:absolute;inset:0;opacity:.04;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}

/* Línea decorativa vertical guinda */
.slide-accent{
  position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(to bottom,var(--D),var(--G),var(--D));
  z-index:3;
}

.s-content{
  position:relative;z-index:5;height:100%;
  display:flex;align-items:center;
}
.s-text{max-width:640px}

/* Número de slide como decoración */
.s-num{
  font-family:var(--sans);font-size:11px;font-weight:400;
  color:rgba(255,255,255,.55);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:20px;
  display:flex;align-items:center;gap:10px;
}
.s-num::before{content:'';width:36px;height:1px;background:var(--D);opacity:.6}

.s-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(189,152,104,.12);
  border:1px solid rgba(189,152,104,.3);
  border-radius:var(--r9);padding:5px 18px;
  margin-bottom:20px;
  font-family:var(--sans);font-size:11px;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;color:var(--D);
}
.s-tag i{font-size:10px}

/* Titular grande serif con mezcla italic/normal */
.s-h{
  font-family:var(--sans);
  font-size:clamp(38px,5vw,70px);
  font-weight:400;color:var(--wh);
  line-height:1.04;margin-bottom:20px;
  letter-spacing:-.025em;
}
.s-h .ln1{display:block}
.s-h .gold{color:var(--D);font-style:italic}
.s-h .rose{color:#f09fd4}
.s-h .grn{color:#7ee8a2}
.s-h .sky{color:#93c5fd}

.s-p{
  font-size:15.5px;color:rgba(255,255,255,.62);
  line-height:1.82;max-width:480px;margin-bottom:34px;
  font-weight:300;
}
.s-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}

/* Botones héroe */
.hbtn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-weight:400;font-size:14px;
  padding:13px 32px;border-radius:var(--r9);
  border:2px solid transparent;cursor:pointer;transition:.28s;
  letter-spacing:.01em;
}
.hbtn-fill{
  background:var(--D);color:var(--ink);border-color:var(--D);
  box-shadow:0 6px 20px rgba(189,152,104,.35);
}
.hbtn-fill:hover{background:var(--wh);border-color:var(--wh);transform:translateY(-2px);box-shadow:0 12px 30px rgba(189,152,104,.4)}
.hbtn-ghost{
  background:transparent;color:var(--wh);
  border-color:rgba(255,255,255,.3);
}
.hbtn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}

/* Stats */
.s-stats{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.08);padding-top:28px}
.sst{padding:0 32px 0 0;margin-right:32px;border-right:1px solid rgba(255,255,255,.1)}
.sst:last-child{border-right:none;margin-right:0}
.sst .n{
  font-family:var(--sans);font-size:38px;font-weight:400;
  color:var(--D);line-height:1;letter-spacing:-.02em;
}
.sst .l{font-size:11.5px;color:rgba(255,255,255,.4);margin-top:5px;line-height:1.45;font-weight:400}

/* Float card */
.s-card{
  position:absolute;bottom:50px;right:52px;z-index:10;
  background:var(--wh);border-radius:var(--r16);
  padding:20px 24px;width:234px;
  box-shadow:var(--s3);
  animation:flt 4s ease-in-out infinite;
  border-top:3px solid var(--G);
}
.sc-eyebrow{
  font-family:var(--sans);font-size:9.5px;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--G);margin-bottom:8px;
}
.sc-title{
  font-family:var(--sans);font-size:15.5px;font-weight:400;
  color:var(--ink);line-height:1.35;margin-bottom:10px;
}
.sc-sub{font-size:11.5px;color:var(--Gr);display:flex;align-items:center;gap:5px;margin-bottom:10px}
.sc-pill{
  display:inline-block;border-radius:var(--r4);
  padding:4px 12px;font-size:10.5px;font-weight:400;
  font-family:var(--sans);color:var(--wh);
}
.pill-g{background:var(--G)} .pill-d{background:var(--D);color:var(--ink)} .pill-b{background:#1e4db5}

/* Side photo panel */
.s-photo{
  position:absolute;right:0;top:0;bottom:0;width:44%;
  overflow:hidden;z-index:2;
}
.s-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
/* Máscara diagonal que une con el overlay */
.s-photo::before{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(to right,var(--ink) 0%,rgba(26,10,16,.9) 12%,rgba(26,10,16,.4) 40%,transparent 70%);
}
.sl-a .s-photo::before{background:linear-gradient(to right,rgba(145,26,58,.97) 0%,rgba(145,26,58,.7) 15%,rgba(145,26,58,.2) 45%,transparent 70%)}
.sl-c .s-photo::before{background:linear-gradient(to right,rgba(10,5,32,.97) 0%,rgba(20,10,50,.7) 15%,rgba(20,10,50,.2) 45%,transparent 70%)}

/* Swiper controles */
.swiper-button-next,.swiper-button-prev{
  width:48px;height:48px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,.18);
  border-radius:50%;transition:.25s;
}
.swiper-button-next:hover,.swiper-button-prev:hover{background:var(--G);border-color:var(--G)}
.swiper-button-next::after,.swiper-button-prev::after{font-size:14px;color:var(--wh);font-weight:400}
.swiper-pagination-bullet{width:32px;height:3px;border-radius:2px;background:rgba(255,255,255,.25);opacity:1;transition:.3s}
.swiper-pagination-bullet-active{background:var(--D);width:54px}
.swiper-pagination{bottom:24px!important}
.hprog{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,var(--G),var(--D));z-index:20;width:0}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ══ QUICKBAR ══ */
/* qbar styles now defined per-page; base just provides fallback */
.qbar{background:#120810;border-bottom:1px solid rgba(255,255,255,.07)}
.qbar-grid{display:grid;grid-template-columns:repeat(5,1fr)}
.qb{display:flex;align-items:center;gap:15px;padding:20px 22px;border-right:1px solid rgba(255,255,255,.05);text-decoration:none;position:relative;overflow:hidden;transition:background .2s}
.qb:focus-visible{outline:2px solid #BD9868;outline-offset:-2px;z-index:3}
.qb:last-child{border-right:none}
.qb-ico{width:50px;height:50px;border-radius:15px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);display:flex;align-items:center;justify-content:center;font-size:19px;color:rgba(255,255,255,.65);flex-shrink:0;transition:all .26s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:1}
.qb-ico--conecta{background:linear-gradient(135deg,#911A3A 0%,#C83182 45%,#BD9868 90%,#911A3A 100%);background-size:300% 300%;border-color:rgba(255,255,255,.18);color:#fff;animation:conecta-pulse 10s ease infinite}
@keyframes conecta-pulse{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.qb:hover .qb-ico{background:rgba(145,26,58,.55);border-color:rgba(145,26,58,.8);color:#fff;transform:scale(1.1) rotate(-5deg);box-shadow:0 8px 24px rgba(145,26,58,.4)}
.qb:hover .qb-ico--conecta{background:linear-gradient(135deg,#BD9868,#D4B070);animation:none}
.qb-txt{flex:1;position:relative;z-index:1;min-width:0;overflow:hidden}
.qb-txt span{font-family:var(--sans);font-size:13px;font-weight:400;color:rgba(255,255,255,.88);display:block;line-height:1.3;letter-spacing:.008em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}
.qb-txt small{font-family:var(--sans);font-size:11px;font-weight:300;color:rgba(255,255,255,.36);display:block;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}
.qb:hover .qb-txt span{color:#fff}.qb:hover .qb-txt small{color:rgba(255,255,255,.58)}
.qb-arrow{position:relative;z-index:1;color:rgba(255,255,255,.18);font-size:10px;flex-shrink:0;transition:transform .22s,color .2s,opacity .2s;opacity:0;transform:translateX(-6px)}
.qb:hover .qb-arrow{opacity:1;transform:translateX(0);color:rgba(255,255,255,.5)}
.qb-line{position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#911A3A,#BD9868);transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:2}
.qb:hover .qb-line{transform:scaleX(1)}

/* ══ ANNOUNCE ══ */

/* ══ OFERTA EDUCATIVA · NIVELES ══ */
.programs{
  padding:100px 0 108px;
  background:var(--ink);
  position:relative;overflow:hidden;
}
/* Malla de puntos */
.programs::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
/* Resplandor guinda lateral izquierdo */
.programs .glow-l{
  position:absolute;left:-240px;top:50%;transform:translateY(-50%);
  width:680px;height:680px;border-radius:50%;
  background:radial-gradient(circle,rgba(145,26,58,.35) 0%,transparent 68%);
  pointer-events:none;
}
/* Resplandor dorado lateral derecho */
.programs .glow-r{
  position:absolute;right:-200px;bottom:-100px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(189,152,104,.15) 0%,transparent 68%);
  pointer-events:none;
}
.sec-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;color:var(--G);
  margin-bottom:12px;
}
.sec-eyebrow::before{content:'';width:24px;height:2px;background:var(--G);border-radius:2px}
.sec-h{
  font-family:var(--sans);
  font-size:clamp(30px,3.5vw,48px);
  font-weight:400;color:var(--ink);
  line-height:1.08;margin-bottom:14px;
  letter-spacing:-.025em;
}
.sec-h em{color:var(--G);font-style:italic}
.sec-sub{font-size:15px;color:var(--Grd);line-height:1.75;max-width:500px;font-weight:300}
/* Override solo para sección oscura de programas */
.programs .sec-eyebrow{color:var(--D)}
.programs .sec-eyebrow::before{background:var(--D)}
.programs .sec-h{color:var(--wh)}
.programs .sec-h em{color:var(--D)}
.programs .sec-sub{color:rgba(255,255,255,.45)}
.prog-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:52px;position:relative;z-index:1}
.btn-outline-g{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:400;font-size:14px;
  padding:13px 28px;border-radius:var(--r9);
  border:1.5px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.75);transition:.25s;
}
.btn-outline-g:hover{background:var(--D);border-color:var(--D);color:var(--ink)}

/* ── NIV GRID hexagonal-ish 3+2+1 layout ── */
.niv-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:16px;
  position:relative;z-index:1;
}
/* Segunda fila: 3 cards centradas */
.ncard:nth-child(4){grid-column:1}
.ncard:nth-child(5){grid-column:2}
.ncard:nth-child(6){grid-column:3}

/* ── NCARD ── */
.ncard{
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.09);
  border-radius:22px;
  padding:36px 26px 26px;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  position:relative;overflow:hidden;
  transition:.38s cubic-bezier(.34,1.56,.64,1);
  text-decoration:none;
}
/* Móvil: 1 sola columna, 6 filas — un mosaico por fila */
@media(max-width:900px){
  .niv-grid{
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
  }
  .ncard{
    width:100% !important;
    flex-direction:column;align-items:center;
    text-align:center;padding:28px 20px 20px;
    border-radius:16px;
  }
  .ncard .n-ico{width:64px;height:64px;font-size:26px;margin-bottom:16px}
  .ncard .n-badge{margin-bottom:8px}
  .ncard .n-title{font-size:19px;margin-bottom:6px}
  .ncard .n-cnt{justify-content:center;margin-bottom:20px}
  .ncard .n-foot{width:100%;padding-top:14px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}
  .ncard .n-dur{display:flex}
  .ncard .n-num{display:none}
}
/* Número decorativo gigante en fondo */
.ncard .n-num{
  position:absolute;right:10px;bottom:-10px;
  font-size:96px;font-weight:400;line-height:1;
  color:rgba(255,255,255,.025);letter-spacing:-.04em;
  pointer-events:none;user-select:none;z-index:0;
}
/* Barra inferior de acento */
.ncard::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:3px;
  transition:.38s;transform:scaleX(0);transform-origin:left;
}
.ncard:hover{
  transform:translateY(-10px) scale(1.02);
  border-color:rgba(255,255,255,.18);
}
.ncard:hover::after{transform:scaleX(1)}

/* Glow interior en hover */
.ncard::before{
  content:'';position:absolute;inset:0;
  opacity:0;transition:.38s;border-radius:22px;
  pointer-events:none;
}
.ncard:hover::before{opacity:1}

/* Per-level colors */
.nlv-lic::after{background:linear-gradient(90deg,var(--G),var(--G3))}
.nlv-lic:hover::before{background:linear-gradient(145deg,rgba(145,26,58,.22),transparent 60%)}
.nlv-lic:hover{box-shadow:0 28px 60px rgba(145,26,58,.45)}

.nlv-mae::after{background:linear-gradient(90deg,var(--R),#e060a0)}
.nlv-mae:hover::before{background:linear-gradient(145deg,rgba(200,49,130,.22),transparent 60%)}
.nlv-mae:hover{box-shadow:0 28px 60px rgba(200,49,130,.4)}

.nlv-doc::after{background:linear-gradient(90deg,var(--D),var(--D2))}
.nlv-doc:hover::before{background:linear-gradient(145deg,rgba(189,152,104,.2),transparent 60%)}
.nlv-doc:hover{box-shadow:0 28px 60px rgba(189,152,104,.35)}

.nlv-esp::after{background:linear-gradient(90deg,#6b2fa0,#9b59d0)}
.nlv-esp:hover::before{background:linear-gradient(145deg,rgba(107,47,160,.22),transparent 60%)}
.nlv-esp:hover{box-shadow:0 28px 60px rgba(107,47,160,.4)}

.nlv-dip::after{background:linear-gradient(90deg,#0e7a6e,#14a898)}
.nlv-dip:hover::before{background:linear-gradient(145deg,rgba(14,122,110,.22),transparent 60%)}
.nlv-dip:hover{box-shadow:0 28px 60px rgba(14,122,110,.38)}

.nlv-cur::after{background:linear-gradient(90deg,#1d6eb5,#2e8fd4)}
.nlv-cur:hover::before{background:linear-gradient(145deg,rgba(29,110,181,.22),transparent 60%)}
.nlv-cur:hover{box-shadow:0 28px 60px rgba(29,110,181,.38)}

/* ── ICON ── */
.n-ico{
  width:80px;height:80px;border-radius:22px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;margin-bottom:20px;
  position:relative;z-index:1;flex-shrink:0;
  transition:.38s cubic-bezier(.34,1.56,.64,1);
}
.nlv-lic .n-ico{background:rgba(145,26,58,.3);color:#e06080;border:1px solid rgba(145,26,58,.4)}
.nlv-mae .n-ico{background:rgba(200,49,130,.25);color:#e878b8;border:1px solid rgba(200,49,130,.35)}
.nlv-doc .n-ico{background:rgba(189,152,104,.2);color:var(--D);border:1px solid rgba(189,152,104,.35)}
.nlv-esp .n-ico{background:rgba(107,47,160,.25);color:#a06ee0;border:1px solid rgba(107,47,160,.35)}
.nlv-dip .n-ico{background:rgba(14,122,110,.22);color:#16c4b4;border:1px solid rgba(14,122,110,.35)}
.nlv-cur .n-ico{background:rgba(29,110,181,.22);color:#4eaaee;border:1px solid rgba(29,110,181,.35)}

.ncard:hover .n-ico{transform:scale(1.14) rotate(-10deg)}
.nlv-lic:hover .n-ico{background:var(--G);color:var(--wh);border-color:var(--G);box-shadow:0 8px 28px rgba(145,26,58,.55)}
.nlv-mae:hover .n-ico{background:var(--R);color:var(--wh);border-color:var(--R);box-shadow:0 8px 28px rgba(200,49,130,.55)}
.nlv-doc:hover .n-ico{background:var(--D2);color:var(--wh);border-color:var(--D2);box-shadow:0 8px 28px rgba(155,122,80,.55)}
.nlv-esp:hover .n-ico{background:#6b2fa0;color:var(--wh);border-color:#6b2fa0;box-shadow:0 8px 28px rgba(107,47,160,.55)}
.nlv-dip:hover .n-ico{background:#0e7a6e;color:var(--wh);border-color:#0e7a6e;box-shadow:0 8px 28px rgba(14,122,110,.55)}
.nlv-cur:hover .n-ico{background:#1d6eb5;color:var(--wh);border-color:#1d6eb5;box-shadow:0 8px 28px rgba(29,110,181,.55)}

/* ── BADGE ── */
.n-badge{
  font-size:9.5px;font-weight:400;letter-spacing:.13em;text-transform:uppercase;
  padding:3px 13px;border-radius:var(--r9);display:inline-block;
  margin-bottom:11px;position:relative;z-index:1;
}
.nlv-lic .n-badge{background:rgba(145,26,58,.28);color:#e06080;border:1px solid rgba(145,26,58,.25)}
.nlv-mae .n-badge{background:rgba(200,49,130,.22);color:#e878b8;border:1px solid rgba(200,49,130,.2)}
.nlv-doc .n-badge{background:rgba(189,152,104,.18);color:var(--D);border:1px solid rgba(189,152,104,.25)}
.nlv-esp .n-badge{background:rgba(107,47,160,.22);color:#a06ee0;border:1px solid rgba(107,47,160,.2)}
.nlv-dip .n-badge{background:rgba(14,122,110,.2);color:#16c4b4;border:1px solid rgba(14,122,110,.2)}
.nlv-cur .n-badge{background:rgba(29,110,181,.2);color:#4eaaee;border:1px solid rgba(29,110,181,.2)}

/* ── TITLE + COUNT ── */
.n-title{
  font-size:21px;font-weight:400;color:var(--wh);
  line-height:1.12;margin-bottom:7px;letter-spacing:-.015em;
  position:relative;z-index:1;
}
.n-cnt{
  font-size:12px;font-weight:400;color:rgba(255,255,255,.55);
  display:flex;align-items:center;justify-content:center;gap:5px;
  position:relative;z-index:1;margin-bottom:24px;
}
.n-cnt i{font-size:10px;opacity:.5}

/* ── FOOTER ── */
.n-foot{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  position:relative;z-index:1;margin-top:auto;
}
.n-dur{font-size:11px;color:rgba(255,255,255,.52);font-weight:400;display:flex;align-items:center;gap:4px}
.n-dur i{font-size:10px}
.n-cta{
  display:flex;align-items:center;gap:6px;
  font-size:12px;font-weight:400;padding:7px 16px;border-radius:var(--r9);
  transition:.28s;color:rgba(255,255,255,.6);
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
}
.nlv-lic:hover .n-cta{background:var(--G);border-color:var(--G);color:var(--wh)}
.nlv-mae:hover .n-cta{background:var(--R);border-color:var(--R);color:var(--wh)}
.nlv-doc:hover .n-cta{background:var(--D2);border-color:var(--D2);color:var(--wh)}
.nlv-esp:hover .n-cta{background:#6b2fa0;border-color:#6b2fa0;color:var(--wh)}
.nlv-dip:hover .n-cta{background:#0e7a6e;border-color:#0e7a6e;color:var(--wh)}
.nlv-cur:hover .n-cta{background:#1d6eb5;border-color:#1d6eb5;color:var(--wh)}

/* ── RESPONSIVE ── */
@media(max-width:960px){.niv-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.niv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.niv-grid{grid-template-columns:1fr}}

/* WAVE separador */

/* ══ COUNTERS ══ */
.counts{
  background:var(--G);padding:80px 0;
  position:relative;overflow:hidden;
}
.counts::before{
  content:'';position:absolute;
  right:-100px;top:-100px;width:500px;height:500px;
  border-radius:50%;border:2px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.counts::after{
  content:'';position:absolute;
  left:-60px;bottom:-80px;width:320px;height:320px;
  border-radius:50%;border:1px solid rgba(189,152,104,.12);
  pointer-events:none;
}
.cnt-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  position:relative;z-index:1;
}
.cnt-i{
  padding:40px 30px;text-align:center;
  border-right:1px solid rgba(255,255,255,.12);
  transition:.3s;
}
.cnt-i:last-child{border-right:none}
.cnt-i:hover{background:rgba(255,255,255,.06)}
.cnt-ico{
  width:60px;height:60px;border-radius:50%;
  background:rgba(255,255,255,.1);border:2px solid rgba(189,152,104,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:var(--D);margin:0 auto 18px;
}
.cnt-n{
  font-family:var(--sans);font-size:56px;font-weight:400;
  color:var(--D);line-height:1;margin-bottom:8px;
  letter-spacing:-.03em;
}
.cnt-sup{font-size:28px;vertical-align:super}
.cnt-lb{font-size:13px;color:rgba(255,255,255,.55);line-height:1.55;font-weight:300}

/* ══ WHY ══ */
.why{padding:100px 0;background:var(--wh)}
.why-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-vis{position:relative}
.why-main{
  border-radius:var(--r24);overflow:hidden;
  height:520px;position:relative;
}
.why-main img{width:100%;height:100%;object-fit:cover}
/* Marco decorativo dorado */
.why-main::after{
  content:'';position:absolute;
  bottom:-16px;left:-16px;right:16px;top:16px;
  border:2px solid var(--D);border-radius:var(--r24);
  z-index:-1;opacity:.4;
}
.why-mini{
  position:absolute;bottom:-28px;right:-28px;
  width:168px;height:168px;
  border-radius:var(--r16);overflow:hidden;
  border:5px solid var(--wh);box-shadow:var(--s3);
}
.why-mini img{width:100%;height:100%;object-fit:cover}
.why-badge{
  position:absolute;top:24px;left:-32px;
  background:var(--G);color:var(--wh);
  border-radius:var(--r16);padding:22px 24px;
  text-align:center;box-shadow:var(--s3);
  min-width:128px;
}
.wb-n{font-family:var(--sans);font-size:46px;font-weight:400;line-height:1;display:block;color:var(--D)}
.wb-l{font-size:11px;opacity:.85;line-height:1.4;display:block;margin-top:4px}

.feat-list{display:flex;flex-direction:column;gap:14px;margin:28px 0 32px}
.feat{
  display:flex;gap:14px;align-items:flex-start;
  padding:18px;background:var(--mist);
  border-radius:var(--r8);border:1px solid var(--bd);
  transition:.25s;
}
.feat:hover{border-color:var(--G);background:var(--Gl);transform:translateX(5px)}
.feat-ic{
  width:46px;height:46px;border-radius:12px;
  background:var(--Gl);display:flex;align-items:center;justify-content:center;
  font-size:19px;color:var(--G);flex-shrink:0;transition:.2s;
}
.feat:hover .feat-ic{background:var(--G);color:var(--wh)}
.feat h4{font-family:var(--sans);font-size:15px;font-weight:400;color:var(--ink);margin-bottom:4px}
.feat p{font-size:13px;color:var(--Grd);line-height:1.65;font-weight:300}
.why-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-g{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:400;font-size:14px;
  padding:13px 30px;border-radius:var(--r9);
  background:var(--G);color:var(--wh);
  border:2px solid var(--G);transition:.25s;
  box-shadow:0 4px 16px rgba(145,26,58,.28);
}
.btn-g:hover{background:var(--G2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(145,26,58,.4)}
.btn-d{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:400;font-size:14px;
  padding:13px 30px;border-radius:var(--r9);
  background:transparent;color:var(--G);
  border:2px solid var(--G);transition:.25s;
}
.btn-d:hover{background:var(--G);color:var(--wh)}

/* ══ TESTIMONIOS ══ */
.testi{padding:96px 0;background:var(--ink);position:relative;overflow:hidden}
.testi::before{
  content:'"';
  font-family:var(--sans);font-size:420px;font-weight:400;
  color:rgba(145,26,58,.08);
  position:absolute;top:-60px;left:-40px;
  line-height:1;pointer-events:none;z-index:0;
}
.testi .sec-eyebrow{color:var(--D)}
.testi .sec-eyebrow::before{background:var(--D)}
.testi .sec-h{color:var(--wh)}
.t-sw{margin-top:48px;padding-bottom:56px;position:relative;z-index:1}
.t-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r16);padding:30px;
  transition:.3s;
}
.t-card:hover{background:rgba(145,26,58,.15);border-color:rgba(145,26,58,.4);transform:translateY(-4px)}
.t-stars{color:var(--D);font-size:13px;letter-spacing:4px;margin-bottom:14px}
.t-txt{
  font-family:var(--sans);font-size:15.5px;font-style:italic;
  color:rgba(255,255,255,.72);line-height:1.82;margin-bottom:24px;
  font-weight:400;
}
.t-auth{display:flex;align-items:center;gap:12px}
.t-ava{width:46px;height:46px;border-radius:50%;overflow:hidden;border:2px solid var(--G);flex-shrink:0}
.t-ava img{width:100%;height:100%;object-fit:cover}
.t-name{font-family:var(--sans);font-size:13.5px;font-weight:400;color:var(--wh)}
.t-prog{font-size:11.5px;color:rgba(255,255,255,.68);margin-top:2px}
.t-sw .swiper-pagination-bullet{background:rgba(255,255,255,.2)}
.t-sw .swiper-pagination-bullet-active{background:var(--D)}

/* ══ NOTICIAS ══ */
.news{padding:96px 0;background:var(--mist)}
.n-layout{display:grid;grid-template-columns:7fr 4fr;gap:28px;align-items:start}
.n-feat{
  border-radius:var(--r16);overflow:hidden;
  border:1px solid var(--bd);background:var(--wh);
  transition:.3s;display:block;
}
.n-feat:hover{box-shadow:var(--s3);transform:translateY(-4px);border-color:transparent}
.n-fi{position:relative;height:280px;overflow:hidden}
.n-fi img{width:100%;height:100%;object-fit:cover;transition:.4s}
.n-feat:hover .n-fi img{transform:scale(1.04)}
.n-cat{
  position:absolute;top:16px;left:16px;
  background:var(--G);color:var(--wh);
  border-radius:var(--r4);padding:4px 14px;
  font-family:var(--sans);font-size:10px;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;
}
.n-body{padding:28px 30px}
.n-date{
  font-family:var(--sans);font-size:11px;font-weight:400;
  color:var(--Gr);margin-bottom:12px;display:flex;align-items:center;gap:6px;
  letter-spacing:.05em;
}
.n-tit{
  font-family:var(--sans);font-size:22px;font-weight:400;
  color:var(--ink);line-height:1.3;margin-bottom:12px;
}
.n-exc{font-size:14px;color:var(--Grd);line-height:1.76;margin-bottom:18px;font-weight:300}
.n-more{
  font-family:var(--sans);font-size:13px;font-weight:400;
  color:var(--G);display:inline-flex;align-items:center;gap:6px;transition:.2s;
}
.n-more:hover{gap:10px}
.n-side{display:flex;flex-direction:column;gap:14px}
.n-mini{
  display:flex;gap:14px;padding:14px;
  border-radius:var(--r8);border:1px solid var(--bd);
  background:var(--wh);transition:.25s;text-decoration:none;
  align-items:flex-start;
}
.n-mini:hover{border-color:var(--G);box-shadow:var(--s1);transform:translateX(3px)}
.nm-img{width:68px;height:68px;border-radius:var(--r8);overflow:hidden;flex-shrink:0}
.nm-img img{width:100%;height:100%;object-fit:cover}
.nm-d{font-family:var(--sans);font-size:10px;color:var(--Gr);margin-bottom:5px;letter-spacing:.05em}
.nm-t{font-family:var(--sans);font-size:13.5px;font-weight:400;color:var(--ink);line-height:1.38}
.nm-t:hover{color:var(--G)}

/* ══ APP ══ */
.app-s{
  padding:0;
  background:linear-gradient(150deg,var(--G2) 0%,var(--G) 45%,#7a1430 100%);
  position:relative;overflow:hidden;
}
/* Patrón hexagonal */
.app-s::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100'%3E%3Cpath d='M28 2 L54 17 L54 47 L28 62 L2 47 L2 17 Z' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3Cpath d='M28 62 L54 77 L54 100' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3Cpath d='M28 62 L2 77 L2 100' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3C/svg%3E");
  background-size:56px 100px;pointer-events:none;
}
/* Resplandor dorado detrás del teléfono */
.app-s::after{
  content:'';position:absolute;
  right:0;top:50%;transform:translateY(-50%);
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(189,152,104,.18) 0%,transparent 60%);
  pointer-events:none;
}
.app-in{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;gap:52px;align-items:end;padding-top:80px;padding-bottom:72px}
.app-eyebrow{color:rgba(255,255,255,.6)}
.app-eyebrow::before{background:rgba(255,255,255,.5)}
.app-h{
  font-family:var(--sans);font-size:clamp(28px,3.5vw,44px);
  font-weight:400;color:var(--wh);line-height:1.15;
  margin-bottom:14px;letter-spacing:-.02em;
}
.app-h em{color:var(--D);font-style:italic}
.app-p{font-size:15px;color:rgba(255,255,255,.7);line-height:1.78;max-width:440px;font-weight:300}
.app-stores{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.store{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.1);
  border:1.5px solid rgba(255,255,255,.22);
  border-radius:var(--r16);padding:13px 24px;
  color:var(--wh);transition:.3s;
  backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.15);
}
.store:hover{
  background:rgba(255,255,255,.22);
  border-color:rgba(255,255,255,.55);
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.2);
}
.s-ico{font-size:28px}
.s-inf small{font-size:9.5px;opacity:.75;display:block;letter-spacing:.04em}
.s-inf strong{font-family:var(--sans);font-size:15px;font-weight:400;display:block;margin-top:1px}
/* Mockup telefono decorativo */
.ph-mock{
  width:320px;
  display:flex;align-items:flex-end;justify-content:center;
  position:relative;flex-shrink:0;align-self:flex-end;
  margin-bottom:0;
}
.ph-mock img{
  width:100%;height:auto;display:block;
  filter:drop-shadow(0 32px 56px rgba(0,0,0,.55));
  transition:.45s cubic-bezier(.34,1.56,.64,1);
}
.ph-mock:hover img{transform:translateY(-10px) scale(1.03);filter:drop-shadow(0 44px 64px rgba(0,0,0,.65))}
.ph-ic{display:none}
.ph-lbl{display:none}

/* ══ PARTNERS ══ */
.partners{padding:60px 0;background:var(--wh);border-top:1px solid var(--bd)}
.tick-wrap{overflow:hidden;position:relative;margin-top:36px}
.tick-wrap::before,.tick-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;
}
.tick-wrap::before{left:0;background:linear-gradient(to right,var(--wh),transparent)}
.tick-wrap::after{right:0;background:linear-gradient(to left,var(--wh),transparent)}
.tick-track{display:flex;gap:16px;animation:tick 32s linear infinite;width:max-content;align-items:center}
.tick-track:hover{animation-play-state:paused}
.p-chip{
  min-width:154px;height:72px;
  background:var(--mist);border:1px solid var(--bd);
  border-radius:var(--r8);display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:12px;font-weight:400;
  color:var(--ink2);text-align:center;padding:12px;
  transition:.2s;flex-shrink:0;
}
.p-chip:hover{border-color:var(--G);color:var(--G);background:var(--Gl)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ FOOTER ══ */
footer{
  background:linear-gradient(170deg,#110510 0%,#1a0a10 40%,#0f0818 100%);
  color:rgba(255,255,255,.78);padding:0;
  position:relative;overflow:hidden;
}
footer::before{
  content:'';position:absolute;
  right:-120px;top:-120px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(145,26,58,.18) 0%,transparent 70%);
  pointer-events:none;
}
footer::after{
  content:'';position:absolute;
  left:-80px;bottom:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(189,152,104,.1) 0%,transparent 70%);
  pointer-events:none;
}
.f-top-bar{
  background:var(--G);
  padding:20px 0;
  display:flex;align-items:center;justify-content:center;
  gap:16px;flex-wrap:wrap;
  position:relative;z-index:1;
}
.f-top-bar .ftb-item{
  display:flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:12.5px;font-weight:400;
  color:rgba(255,255,255,.88);letter-spacing:.02em;
  padding:0 20px;border-right:1px solid rgba(255,255,255,.2);
}
.f-top-bar .ftb-item:last-child{border-right:none}
.f-top-bar .ftb-item i{color:var(--D);font-size:14px}
.f-main{padding:72px 0 0;position:relative;z-index:1}
.f-grid{display:grid;grid-template-columns:2.6fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px}
.f-logo img{height:42px;width:auto;opacity:.85}
.f-logo-fb{display:none;font-family:var(--sans);font-size:26px;font-weight:400;color:var(--wh)}
.f-desc{
  font-size:13px;color:rgba(255,255,255,.68);
  line-height:1.85;max-width:270px;
  margin:16px 0 22px;font-weight:300;
}
.f-contacts li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:12.5px;margin-bottom:12px;
}
.f-ci{font-size:13px;flex-shrink:0;margin-top:2px;color:var(--D)}
.f-contacts a:hover{color:var(--D)}
.f-col h5{
  font-family:var(--sans);font-size:10.5px;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--wh);margin-bottom:20px;padding-bottom:10px;
  border-bottom:1px solid var(--G);display:inline-block;
}
.f-col li{margin-bottom:10px}
.f-col li a{
  font-size:12.5px;color:rgba(255,255,255,.85);
  transition:.2s;display:flex;align-items:center;gap:6px;font-weight:300;
}
.f-col li a::before{content:'›';color:var(--G);font-size:16px}
.f-col li a:hover{color:var(--D);padding-left:4px}
.f-soc{display:flex;gap:8px;margin-top:18px}
.fs{
  width:34px;height:34px;border-radius:var(--r8);
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;
  font-size:12.5px;color:rgba(255,255,255,.72);transition:.2s;
}
.fs:hover{background:var(--G);color:var(--wh);border-color:var(--G)}
.f-bot{
  border-top:1px solid rgba(255,255,255,.06);
  padding:22px 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:12px;
}
.f-copy{font-family:var(--sans);font-size:11px;color:rgba(255,255,255,.58);letter-spacing:.04em}
.f-chips{display:flex;gap:8px;flex-wrap:wrap}
.f-chip{
  font-family:var(--sans);font-size:10px;font-weight:400;
  border-radius:var(--r9);padding:4px 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  color:rgba(255,255,255,.55);letter-spacing:.04em;
}
.f-chip.gold{color:var(--D);border-color:rgba(189,152,104,.25);background:rgba(189,152,104,.06)}

/* ══ REVEAL ══ */
/* rv reveal — CSS fallback ensures content always shows after 1s even if JS fails */
.rv{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease;animation:rv-fallback 0s 1.2s forwards}
.rv.vis{opacity:1;transform:translateY(0);animation:none}
@keyframes rv-fallback{to{opacity:1;transform:translateY(0)}}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}

/* ══ RESPONSIVE ══ */

/* ── Hamburger (mobile nav) ── */
.ham{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  width:40px;height:40px;gap:5px;cursor:pointer;
  border:1.5px solid var(--bd);border-radius:var(--r8);
  background:transparent;flex-shrink:0;
}
.ham span{
  display:block;width:20px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:.3s;transform-origin:center;
}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer móvil */
.mob-nav{
  display:none;
  position:fixed;top:0;left:0;right:0;bottom:0;
  z-index:800;
  pointer-events:none;
}
.mob-nav.open{display:block;pointer-events:auto}
.mob-backdrop{
  position:absolute;inset:0;
  background:rgba(26,10,16,.45);
  backdrop-filter:blur(2px);
}
.mob-drawer{
  position:absolute;
  /* Se posiciona justo debajo del header en JS — ver toggleMob */
  top:60px;right:0;bottom:0;
  width:min(300px,92vw);
  background:var(--wh);
  box-shadow:-6px 0 32px rgba(26,10,16,.18);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:.32s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
  border-top:2px solid var(--G);
}
.mob-nav.open .mob-drawer{transform:translateX(0)}
.mob-drawer-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 12px;border-bottom:1px solid var(--bd);
  background:var(--wh);
}
.mob-close{
  width:34px;height:34px;border-radius:var(--r8);
  border:1.5px solid var(--bd);display:flex;align-items:center;
  justify-content:center;font-size:13px;color:var(--Grd);cursor:pointer;
  background:transparent;
}
.mob-links{padding:8px 0 32px;flex:1;overflow-y:auto}

/* Acordeón primer nivel */
.mob-acc{border-bottom:1px solid var(--bd)}
.mob-acc-btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;background:transparent;border:none;cursor:pointer;
  font-family:var(--f);font-size:15px;font-weight:400;color:var(--ink);
  text-decoration:none;
}
.mob-acc-btn span{display:flex;align-items:center;gap:10px}
.mob-acc-btn span i{font-size:14px;color:var(--G);width:18px;text-align:center}
.mob-acc-btn.direct{justify-content:flex-start}
.mob-acc-ico{font-size:11px;color:var(--Gr);transition:.25s}
.mob-acc.open .mob-acc-ico{transform:rotate(180deg)}
.mob-acc-btn:hover{background:var(--Gll);color:var(--G)}

/* Subnivel: oculto por defecto */
.mob-acc-body{
  display:none;
  background:#faf5f7;
  border-top:1px solid var(--bd);
}
.mob-acc.open .mob-acc-body{display:block}
.mob-link.sub{
  display:block;
  padding:11px 20px 11px 48px;
  font-size:13.5px;font-weight:400;color:#444;
  border-left:3px solid transparent;
  transition:.15s;
}
.mob-link.sub:hover{color:var(--G);background:var(--Gl);border-left-color:var(--G)}

@media(max-width:1200px){
  .ni{font-size:13px;padding:8px 11px}
  
}
@media(max-width:1024px){
  .hero-swiper{height:580px}
  .s-photo{width:42%}
  .why-inner{grid-template-columns:1fr;gap:56px}
  .n-layout{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr 1fr}
  .cnt-grid{grid-template-columns:1fr 1fr}
  .app-in{grid-template-columns:1fr;padding-bottom:0}
  .ph-mock{width:260px;margin:0 auto;display:flex}
}

@media(max-width:960px){
  /* Topbar */
  .f-top-bar{display:none}
  .tb-l{display:none}
  /* Header — logo pequeño, campus compacto, ham visible */
  .nav-main{display:none}
  .btn-search{display:none}
  .ham{display:flex}
  .logo-link img{height:32px}
  .hdr-row{height:60px;gap:10px}
  
  .btn-campus i{font-size:11px}
  .hdr-r{gap:8px}
  /* Hero */
  .hero-swiper{height:auto;min-height:480px}
  .s-photo{display:none}
  .s-content{padding:48px 20px 60px}
  .s-stats{flex-wrap:wrap;gap:16px}
  .sst{border-right:none;padding-right:0;margin-right:0}
  /* App: teléfono abajo en móvil */
  .app-in{grid-template-columns:1fr;flex-direction:column;padding-bottom:0}
  .app-s .wrap{padding-bottom:0}
  /* Quickbar: 1 columna apilada */
  .qbar-grid{grid-template-columns:1fr}
  .qb{padding:13px 20px;border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}
  .qb:last-child{border-bottom:none}
  .qb-ico{width:42px;height:42px;font-size:17px}
  .qb-txt span{font-size:13px}
  .qb-txt small{font-size:10.5px}
  /* Oferta educativa: 1 columna (apilado como numeralia) */
  .prog-head{flex-direction:column;align-items:flex-start}
  .programs{padding:64px 0 72px}
  /* Counters */
  .cnt-grid{grid-template-columns:1fr 1fr}
  .cnt-i:nth-child(2){border-right:none}
  .cnt-i:nth-child(n+3){border-top:1px solid rgba(255,255,255,.1)}
  /* Why */
  .why-badge{display:none}
  .why-mini{display:none}
  .s-card{display:none}
  /* Footer */
  .f-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .wrap{padding:0 16px}
  /* Header más compacto */
  .hdr-row{height:64px}
  .logo-link img{height:38px}
  /* Quickbar: 1 columna */
  .qbar-grid{grid-template-columns:repeat(2,1fr)}
  /* Counters: 1 columna */
  .cnt-grid{grid-template-columns:1fr}
  .cnt-i{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  /* Noticias */
  .n-grid{grid-template-columns:1fr}
}

/* ── Tabletim mascota – desktop visible, móvil oculto ── */
.univim-mascot-wrap{
  display:flex;align-items:center;justify-content:center;
  margin:0 4px;flex-shrink:0;
}
.hdr-brand .univim-mascot-wrap{margin:0 0 0 2px;}
.univim-mascot-wrap img{
  height:44px;width:auto;object-fit:contain;
  filter:drop-shadow(0 2px 8px rgba(145,26,58,.18));
}
@media(max-width:900px){
  .univim-mascot-wrap{display:none!important;}
}

/* ── Logo Michoacán en footer ── */
.f-mich{margin-top:18px;}

/* ── Logo header image ── */
.hdr-logo-img{
  height:52px;width:auto;display:block;
}

/* ── Tabletim float animation ── */
@keyframes tabletim-float{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-8px) rotate(1deg)}
}
.tabletim-float{
  animation:tabletim-float 3.5s ease-in-out infinite;
}

/* ── Logo Michoacán en footer – más grande ── */
.f-mich-logo{
  height:52px!important;width:auto;opacity:.9;
  filter:brightness(0) invert(1);
  transition:opacity .2s,transform .2s;
}
.f-mich-logo:hover{opacity:1;transform:scale(1.04);}

/* ── Tipografía prose: <strong> más delgado en contenido ── */
p strong, li strong, .tit-panel-nota strong,
.dl-card-info strong, .step-desc strong,
.ss-foraneo p strong, .cost-note strong,
section p strong, main p strong, main li strong {
  font-weight:500;
}

/* ══ Botón Conecta UNIVIM (ast-custom-button) ══════════════════════════════ */
.ast-custom-button,.btn-campus{
  position:relative!important;overflow:visible!important;
  border-radius:50px!important;padding:6px 14px!important;
  color:white!important;font-weight:400!important;letter-spacing:.25px!important;
  font-size:13.5px!important;font-family:inherit!important;text-transform:none!important;
  display:inline-flex!important;align-items:center!important;justify-content:center!important;
  white-space:nowrap!important;min-width:135px!important;height:38px!important;line-height:1!important;
  background:linear-gradient(135deg,#911A3A 0%,#C83182 35%,#BD9868 65%,#911A3A 100%)!important;
  background-size:250% 250%!important;
  border:2px solid rgba(255,255,255,.4)!important;
  box-shadow:0 3px 10px rgba(145,26,58,.3),0 1px 4px rgba(0,0,0,.1),inset 0 0 0 1px rgba(255,255,255,.15)!important;
  animation:campus-gradient 15s infinite linear,campus-pulse 4s infinite ease-in-out!important;
  cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;
  text-decoration:none!important;
}
.ast-custom-button::before,.btn-campus::before{
  content:''!important;display:inline-block!important;
  width:18px!important;height:18px!important;
  background-image:url('https://univim.edu.mx/wp-content/uploads/2024/02/cropped-logo-univim-768x209-1.png')!important;
  background-size:contain!important;background-repeat:no-repeat!important;background-position:center!important;
  filter:brightness(0) invert(1) drop-shadow(0 0 3px rgba(255,255,255,.9)) drop-shadow(0 0 2px rgba(255,255,255,.7)) contrast(1.5)!important;
  opacity:1!important;transition:all .7s cubic-bezier(.34,1.56,.64,1)!important;
  margin-right:4px!important;margin-left:0!important;flex-shrink:0!important;
}
.ast-custom-button .bc-txt,.btn-campus .bc-txt{
  transition:transform .7s cubic-bezier(.34,1.56,.64,1)!important;
  position:relative!important;z-index:4!important;display:inline-block!important;
}
.ast-custom-button:hover,.btn-campus:hover{
  background:linear-gradient(135deg,#BD9868 0%,#D4B588 50%,#BD9868 100%)!important;
  transform:translateY(-3px) scale(1.05)!important;
  border-color:rgba(255,255,255,.95)!important;border-width:3px!important;
  box-shadow:0 8px 25px rgba(189,152,104,.6),0 3px 10px rgba(0,0,0,.2)!important;
  animation:none!important;
}
.ast-custom-button:hover::before,.btn-campus:hover::before{
  order:1!important;margin-right:0!important;margin-left:4px!important;
  transform:translateX(3px) scale(1.1)!important;
}
.ast-custom-button:hover .bc-txt,.btn-campus:hover .bc-txt{
  transform:translateX(-12px)!important;
}
.ast-custom-button i,.btn-campus i{
  font-size:13px;margin-right:7px;flex-shrink:0;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.ast-custom-button:hover i,.btn-campus:hover i{
  transform:translateX(3px) scale(1.1);
}
@keyframes campus-pulse{0%,100%{transform:scale(1) translateY(0)}50%{transform:scale(1.03) translateY(-2px)}}

/* ── Malla Curricular — Responsive Grid ─────────────────── */
.lic-malla-grid {
  display: grid !important;
  gap: 14px !important;
  align-items: stretch !important;
}
/* Override inline repeat(N,1fr) with responsive columns */
.lic-malla-grid[style*="repeat(1,"] { grid-template-columns: 1fr !important; }
.lic-malla-grid[style*="repeat(2,"] { grid-template-columns: repeat(2,1fr) !important; }
.lic-malla-grid[style*="repeat(3,"] { grid-template-columns: repeat(3,1fr) !important; }
.lic-malla-grid[style*="repeat(4,"] { grid-template-columns: repeat(4,1fr) !important; }
.lic-malla-grid[style*="repeat(5,"] { grid-template-columns: repeat(5,1fr) !important; }
.lic-malla-grid[style*="repeat(6,"] { grid-template-columns: repeat(6,1fr) !important; }

@media (max-width: 900px) {
  .lic-malla-grid[style*="repeat(5,"],
  .lic-malla-grid[style*="repeat(6,"] { grid-template-columns: repeat(3,1fr) !important; }
  .lic-malla-grid[style*="repeat(4,"] { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 640px) {
  .lic-malla-grid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 400px) {
  .lic-malla-grid { grid-template-columns: 1fr !important; }
}

/* Malla table (Tec Emergentes style) */
.tec-malla-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tec-malla-table { min-width: 600px; }

/* Líneas de generación responsive */
@media (max-width: 640px) {
  .tec-lineas-grid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 400px) {
  .tec-lineas-grid { grid-template-columns: 1fr !important; }
}

/* Responsive malla label */
@media (max-width: 640px) {
  .mp-label, .mp-esp-label { font-size: 9px !important; }
  .lic-cuatri-roman { font-size: 14px !important; }
  .lic-cuatri-num { display: none !important; }
  .lic-table td { font-size: 11px !important; padding: 5px 7px !important; }
}



/* ── Formación Continua submenu (JS-positioned) ── */
.drop-has-sub-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;font-size:13px;font-weight:400;
  color:#374151;
  border-top:none;border-left:none;border-right:none;
  border-bottom:1px solid var(--bd);
  border-radius:0;
  outline:none;
  -webkit-appearance:none;appearance:none;
  transition:.15s;cursor:pointer;width:100%;
  background:transparent;font-family:var(--sans);text-align:left;
  box-shadow:none;
  margin:0;line-height:inherit;
}
.drop-has-sub-btn:hover,.drop-has-sub-btn:focus{background:var(--Gl);color:var(--G);padding-left:20px;outline:none}
.drop-has-sub-btn:hover .d-dot{background:var(--G);color:var(--wh)}
.drop-has-sub-btn .sub-chev{font-size:9px;color:var(--Gr);margin-left:auto;flex-shrink:0;transition:.15s}
.drop-has-sub-btn:hover .sub-chev{color:var(--G)}
#fc-submenu{
  position:fixed;
  background:var(--wh,#fff);border:1px solid #ede3e6;
  border-radius:16px;box-shadow:0 20px 60px rgba(26,10,16,.2);
  min-width:190px;z-index:9999;
  opacity:0;visibility:hidden;transform:translateX(4px);
  transition:opacity .15s ease,transform .15s ease,visibility .15s;
  pointer-events:none;overflow:hidden;
}
#fc-submenu.show{opacity:1;visibility:visible;transform:translateX(0);pointer-events:auto}
.fc-sub-link{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;font-size:13px;color:#374151;
  border-bottom:1px solid #ede3e6;text-decoration:none;transition:.15s;
}
.fc-sub-link:last-child{border-bottom:none}
.fc-sub-link:hover{background:#f7eaee;color:#911A3A;padding-left:20px}
.fc-sub-link:hover .d-dot{background:#911A3A;color:#fff}

/* ══ MICRO-INTERACTIONS ═══════════════════════════════════════════ */

/* Smooth image hover zoom on all cards */
.ncard img, .n-feat img, .n-mini img, .not-card img {
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.ncard:hover img, .n-feat:hover img { transform: scale(1.05); }

/* Drop shadow depth on hover for all cards */
.ncard { transition: transform .38s cubic-bezier(.34,1.56,.64,1), box-shadow .38s, border-color .38s; }

/* Button press feel */
.btn-g:active, .btn-d:active, .btn-campus:active,
.hbtn:active, .btn-outline-g:active {
  transform: scale(.97) !important;
}

/* Nav underline smooth grow */
.ni::before { transition: left .28s cubic-bezier(.4,0,.2,1), right .28s cubic-bezier(.4,0,.2,1); }

/* Feature card left slide on hover */
.feat { transition: border-color .22s, background .22s, transform .22s; }
.feat:hover { transform: translateX(6px); }

/* Counter section number pulse */
.cnt-n { transition: color .3s; }

/* Partner logo cards */
.p-logo-card { transition: box-shadow .25s, border-color .25s, transform .25s; }
.p-logo-card:hover { transform: translateY(-5px) scale(1.02); }

/* Scroll reveal — smoother */
.rv {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .65s cubic-bezier(.25,.46,.45,.94), transform .65s cubic-bezier(.25,.46,.45,.94);
}
.rv.vis { opacity: 1; transform: translateY(0); }
.rv.d1 { transition-delay: .12s }
.rv.d2 { transition-delay: .24s }
.rv.d3 { transition-delay: .36s }
.rv.d4 { transition-delay: .48s }

/* ── Accessibility ── */
:focus-visible {
  outline: 3px solid var(--G);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── Selection color ── */
::selection { background: var(--G); color: #fff; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--mist); }
::-webkit-scrollbar-thumb { background: var(--G); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--G2); }

/* ── Skip to content (accessibility) ── */
.skip-link {
  position: absolute; top: -60px; left: 50%; transform: translateX(-50%);
  z-index: 10000; background: var(--G); color: #fff;
  padding: 12px 28px; border-radius: 0 0 12px 12px;
  font-size: 14px; font-weight: 500; text-decoration: none;
  transition: top .2s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 4px 20px rgba(145,26,58,.5);
  white-space: nowrap;
}
.skip-link:focus,.skip-link:focus-visible { top: 0; outline: 3px solid #BD9868; outline-offset: 2px; }


/* ══ FOCUS VISIBLE — Accesibilidad de teclado ══ */
*:focus { outline: none; }
*:focus-visible {
  outline: 2px solid #BD9868;
  outline-offset: 3px;
  border-radius: 3px;
}
a:focus-visible, button:focus-visible {
  outline: 2px solid #BD9868;
  outline-offset: 3px;
}

/* ══ REDUCED MOTION ══ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ══ HIGH CONTRAST MODE ══ */
@media (forced-colors: active) {
  .btn-primary, .btn-outline-g, .lic-sb-btn {
    border: 2px solid ButtonText;
  }
}

/* ══ ENHANCED TYPOGRAPHY ═════════════════════════════════════════ */
.sec-h {
  letter-spacing: -.03em;
  font-weight: 500;
}
.sec-h em { 
  font-style: italic;
  position: relative;
}

/* ══ FOOTER LINK HOVER BAR ═══════════════════════════════════════ */
.f-col li a {
  position: relative;
  overflow: hidden;
}
.f-col li a::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 1px;
  background: var(--D);
  transition: width .25s ease;
}
.f-col li a:hover::after { width: 100%; }

/* ═══════════════════════════════════════════════════════════════
   UNIVIM VISUAL UPGRADE v2 — Sorprende al rector
   ═══════════════════════════════════════════════════════════════ */

/* ── Animated gradient hero background ── */
@keyframes heroShift {
  0%   { background-position: 0% 50% }
  50%  { background-position: 100% 50% }
  100% { background-position: 0% 50% }
}
@keyframes floatY {
  0%,100% { transform: translateY(0px) }
  50%      { transform: translateY(-12px) }
}
@keyframes glowPulse {
  0%,100% { opacity:.18; transform:scale(1) }
  50%      { opacity:.32; transform:scale(1.08) }
}
@keyframes slideInLeft  { from { opacity:0; transform:translateX(-30px) } to { opacity:1; transform:none } }
@keyframes slideInRight { from { opacity:0; transform:translateX(30px)  } to { opacity:1; transform:none } }
@keyframes slideInUp    { from { opacity:0; transform:translateY(24px)   } to { opacity:1; transform:none } }
@keyframes countUp      { from { opacity:0; transform:translateY(16px) scale(.9) } to { opacity:1; transform:none } }
@keyframes shimmer      { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes borderGlow   { 0%,100%{box-shadow:0 0 0 0 rgba(145,26,58,0)} 50%{box-shadow:0 0 0 6px rgba(145,26,58,.12)} }

/* ── Hero upgrade: animated gradient + glow orbs ── */
.lc-hero, .mc-hero, .esp-hero {
  background-size: 300% 300% !important;
  animation: heroShift 14s ease infinite;
  min-height: 360px;
}
.lc-hero::after, .mc-hero::after {
  content: '' !important;
  position: absolute !important;
  width: 600px !important; height: 600px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(189,152,104,.2) 0%, transparent 65%) !important;
  right: -140px !important; top: -140px !important;
  animation: glowPulse 6s ease-in-out infinite !important;
  pointer-events: none !important;
}
/* Animated badge number */
.lc-hero-badge-n, .mc-hero-badge-n {
  animation: countUp .8s .4s both;
  background: linear-gradient(135deg,#BD9868,#e8c98a);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* Hero chip animation */
.lc-chips .lc-chip, .mc-chips .mc-chip { animation: slideInUp .6s both; }
.lc-chips .lc-chip:nth-child(2) { animation-delay: .1s }
.lc-chips .lc-chip:nth-child(3) { animation-delay: .2s }

/* ── CARD REDESIGN — richer hover states ── */
.lc-card {
  border-radius: 18px !important;
  border: 1.5px solid var(--bd) !important;
  overflow: hidden;
  position: relative;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1),
              box-shadow .35s ease,
              border-color .35s ease !important;
}
.lc-card::before {
  content: '';
  position: absolute;
  inset: 0; z-index: 0;
  background: linear-gradient(135deg, rgba(145,26,58,.04), transparent 60%);
  opacity: 0;
  transition: opacity .35s;
}
.lc-card:hover {
  transform: translateY(-8px) scale(1.02) !important;
  box-shadow: 0 24px 55px rgba(145,26,58,.18), 0 8px 20px rgba(0,0,0,.08) !important;
  border-color: rgba(145,26,58,.3) !important;
}
.lc-card:hover::before { opacity: 1; }
.lc-card:hover .lc-img { transform: scale(1.08) !important; }
.lc-img { transition: transform .55s cubic-bezier(.25,.46,.45,.94) !important; }

/* Arrow button upgrade */
.lc-arr {
  background: var(--Gl) !important;
  color: var(--G) !important;
  transition: background .2s, color .2s, transform .3s cubic-bezier(.34,1.56,.64,1) !important;
}
.lc-card:hover .lc-arr {
  background: var(--G) !important;
  color: #fff !important;
  transform: translateX(4px) rotate(-45deg) !important;
}

/* ── MAESTRIAS / MC CARDS ── */
.mc-card {
  border-radius: 18px !important;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1),
              box-shadow .35s, border-color .35s !important;
  position: relative; overflow: hidden;
}
.mc-card:hover {
  transform: translateY(-8px) scale(1.015) !important;
  box-shadow: 0 24px 55px rgba(145,26,58,.2) !important;
}
.mc-card:hover .mc-img { transform: scale(1.08); }
.mc-img { transition: transform .55s cubic-bezier(.25,.46,.45,.94); }

/* ── ESPECIALIDADES CARDS ── */
.esp-card {
  border-radius: 18px !important;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1), box-shadow .35s !important;
}
.esp-card:hover { transform: translateY(-8px) scale(1.015) !important; box-shadow: 0 24px 55px rgba(145,26,58,.18) !important; }

/* ── Shimmer loading effect on card images ── */
.lc-img-wrap, .mc-img-wrap { background: linear-gradient(90deg,#f0e8ec 25%,#f7eaee 50%,#f0e8ec 75%); background-size:200% 100%; }
.lc-img[src], .mc-img[src] { background: none; }

/* ── Toolbar / search upgrade ── */
.lc-srch-wrap, .mc-srch-wrap {
  border-radius: 12px !important;
  border: 1.5px solid var(--bd) !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.lc-srch-wrap:focus-within, .mc-srch-wrap:focus-within {
  border-color: var(--G) !important;
  box-shadow: 0 0 0 4px rgba(145,26,58,.1) !important;
}

/* ── Filter chips ── */
.lc-flt, .mc-flt {
  transition: background .18s, color .18s, border-color .18s, transform .18s !important;
}
.lc-flt:hover, .mc-flt:hover { transform: translateY(-2px); }
.lc-flt.on, .mc-flt.on { animation: borderGlow 2s ease-in-out; }

/* ── NOTICIAS GRID UPGRADE ── */
.not-card {
  border-radius: 18px !important;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1),
              box-shadow .35s, border-color .35s !important;
  position: relative;
}
.not-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--G), var(--D));
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s ease;
}
.not-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 24px 50px rgba(145,26,58,.16) !important;
  border-color: rgba(145,26,58,.25) !important;
}
.not-card:hover::after { transform: scaleX(1); }
.not-card img { transition: transform .55s cubic-bezier(.25,.46,.45,.94) !important; }
.not-card:hover img { transform: scale(1.06) !important; }

/* ── Individual program pages — hero stats animated ── */
.lic-stat {
  cursor: default;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1) !important;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
}
.lic-stat:hover { transform: translateY(-4px) !important; background: rgba(255,255,255,.12) !important; }
.lic-stat-n {
  background: linear-gradient(135deg,#fff,rgba(255,255,255,.8));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Sidebar on program pages ── */
.lic-sb-item {
  transition: background .18s, color .18s, border-color .18s, padding-left .18s !important;
}
.lic-sb-item:hover { padding-left: 26px !important; }
.lic-sb-item.on { padding-left: 26px; }

/* ── CTA section on individual programs ── */
.lic-cta {
  position: relative; overflow: hidden;
}
.lic-cta::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(189,152,104,.08) 0%, transparent 60%);
  pointer-events: none;
}

/* ── Malla curricular cards ── */
.lic-cuatri {
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s !important;
}
.lic-cuatri:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 12px 35px rgba(145,26,58,.18) !important;
}

/* ── Profile cards (ingreso/egreso) ── */
.lic-list-item {
  transition: border-color .2s, background .2s, transform .22s, padding-left .22s !important;
}
.lic-list-item:hover {
  transform: translateX(6px) !important;
  border-color: var(--lc-text) !important;
  background: var(--Gl) !important;
}

/* ── Back-to-top button ── */
#btt {
  position: fixed; bottom: 28px; right: 28px; z-index: 888;
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--G); color: #fff;
  border: none; cursor: pointer; font-size: 16px;
  box-shadow: 0 6px 22px rgba(145,26,58,.35);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s, background .2s;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
}
#btt.show { opacity: 1; pointer-events: auto; }
#btt:hover { transform: translateY(-4px) scale(1.12); background: var(--G2); }
#btt:active { transform: scale(.95); }

/* ── Floating gradient text for key numbers ── */
.grad-text {
  background: linear-gradient(135deg, var(--G), var(--D));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Program card stagger reveal ── */
.lc-card.rv { opacity: 0; transform: translateY(20px); }
.lc-card.rv.vis { opacity: 1; transform: translateY(0); }
.lc-card:nth-child(3n+2).rv { transition-delay: .08s }
.lc-card:nth-child(3n+3).rv { transition-delay: .16s }

/* ── Image meta overlay on cards ── */
.lc-img-meta {
  background: linear-gradient(to top, rgba(26,10,16,.9) 0%, transparent 100%) !important;
  padding: 20px 10px 8px !important;
}

/* ══ RESPONSIVE UPGRADES ══════════════════════════════════════ */
@media (max-width: 768px) {
  .lc-card:hover { transform: translateY(-4px) scale(1) !important; }
  .mc-card:hover { transform: translateY(-4px) !important; }
}

/* ── Page load fade-in ── */
@keyframes pageIn { from { opacity: 0; } to { opacity: 1; } }
body { animation: pageIn .4s ease; }

/* ── Link transition clicks ── */
a { transition: color .18s, opacity .18s; }

/* ── Focus ring ── */
button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible {
  outline: 3px solid var(--G);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ══ FORM ACCESSIBILITY ══ */
.form-group input:invalid:not(:placeholder-shown),
.form-group textarea:invalid:not(:placeholder-shown) {
  border-color: #c62828;
  box-shadow: 0 0 0 3px rgba(198,40,40,.1);
}
.form-group input:valid:not(:placeholder-shown) {
  border-color: #388e3c;
}
.field-error {
  color: #c62828; font-size: 12px; margin-top: 4px;
  display: flex; align-items: center; gap: 4px;
}
.field-error::before { content: "⚠"; }
.form-group label {
  display: flex; align-items: center; gap: 4px;
}
.req { color: #c62828; font-size: 14px; line-height: 1; }

/* ══ LOADING STATES ══ */
.skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,.06) 25%, rgba(255,255,255,.12) 50%, rgba(255,255,255,.06) 75%);
  background-size: 200% 100%;
  animation: skeleton-wave 1.5s infinite;
  border-radius: 8px;
}
.skeleton-light {
  background: linear-gradient(90deg, #f0e8ea 25%, #faf0f2 50%, #f0e8ea 75%);
  background-size: 200% 100%;
  animation: skeleton-wave 1.5s infinite;
  border-radius: 8px;
}
@keyframes skeleton-wave { 0%{background-position:200% 0} 100%{background-position:-200% 0} }


/* ════════════════════════════════════════════════════════════════
   SISTEMA DE DISEÑO UNIVIM — Revisión visual completa
   ════════════════════════════════════════════════════════════════ */

/* ── Tipografía refinada con Gibson ── */
:root {
  --fw-thin:   100;
  --fw-light:  300;
  --fw-book:   350;   /* Gibson Book — peso editorial preferido */
  --fw-reg:    400;   /* Gibson Regular */
  --fw-med:    500;   /* Gibson Medium — encabezados */
  --fw-semi:   600;   /* Gibson SemiBold — CTA, badges */
  --space-1: 4px; --space-2: 8px; --space-3: 12px;
  --space-4: 16px; --space-5: 24px; --space-6: 32px;
  --space-7: 48px; --space-8: 64px; --space-9: 96px;
}

/* ── Body: Gibson Book como base ── */
body {
  font-weight: var(--fw-book);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ── Encabezados de sección — más refinados ── */
.sec-eyebrow {
  font-size: 10.5px;
  font-weight: var(--fw-semi);
  letter-spacing: .22em;
  margin-bottom: var(--space-4);
}
.sec-eyebrow::before {
  width: 20px; height: 1.5px;
}

.sec-h {
  font-size: clamp(28px, 3.2vw, 46px);
  font-weight: var(--fw-med);
  letter-spacing: -.03em;
  line-height: 1.06;
  margin-bottom: var(--space-4);
}
.sec-h em {
  font-weight: var(--fw-light);
  font-style: italic;
  letter-spacing: -.01em;
}

.sec-sub {
  font-size: 15px;
  font-weight: var(--fw-book);
  line-height: 1.8;
  color: var(--Grd);
  max-width: 480px;
}

/* ════ SECCIÓN PROGRAMAS — rediseño completo ════ */
.programs {
  padding: var(--space-9) 0 calc(var(--space-9) + 8px);
  background: linear-gradient(170deg, #1a0a10 0%, #120810 60%, #0f0618 100%);
}
.programs::before {
  background-image: 
    radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    radial-gradient(rgba(189,152,104,.04) 1px, transparent 1px);
  background-size: 40px 40px, 80px 80px;
  background-position: 0 0, 20px 20px;
}
.prog-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

/* ── Grid de niveles — 3+3 con proporciones áureas ── */
.niv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: 14px;
}

/* ── NCARD — rediseño editorial ── */
.ncard {
  background: rgba(255,255,255,.028);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px;
  padding: 32px 24px 24px;
  display: flex; flex-direction: column; align-items: flex-start;
  text-align: left;
  position: relative; overflow: hidden;
  text-decoration: none;
  transition: transform .32s cubic-bezier(.34,1.4,.64,1),
              box-shadow .32s ease,
              border-color .25s ease,
              background .25s ease;
  min-height: 200px;
}

/* Número decorativo — más sutil, esquina superior derecha */
.ncard .n-num {
  position: absolute; right: 16px; top: 12px;
  font-size: 72px; font-weight: var(--fw-med); line-height: 1;
  color: rgba(255,255,255,.04); letter-spacing: -.04em;
  pointer-events: none; user-select: none; z-index: 0;
  font-variant-numeric: tabular-nums;
}

/* Ícono — más compacto y elegante */
.n-ico {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; margin-bottom: 20px;
  position: relative; z-index: 1;
  flex-shrink: 0;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.ncard:hover .n-ico { transform: scale(1.12) rotate(-6deg); }

/* Badge de nivel */
.n-badge {
  font-size: 9.5px; font-weight: var(--fw-semi);
  letter-spacing: .16em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: var(--space-2);
  position: relative; z-index: 1;
}

/* Título del nivel */
.n-title {
  font-size: 22px; font-weight: var(--fw-med);
  color: #fff; line-height: 1.1;
  margin-bottom: var(--space-3);
  position: relative; z-index: 1;
  letter-spacing: -.02em;
}

/* Contador de programas */
.n-cnt {
  font-size: 12px; font-weight: var(--fw-book);
  color: rgba(255,255,255,.42);
  display: flex; align-items: center; gap: 6px;
  margin-bottom: auto;
  padding-bottom: var(--space-4);
  position: relative; z-index: 1;
}
.n-cnt i { font-size: 10px; opacity: .6; }

/* Footer de la card */
.n-foot {
  display: flex; align-items: center;
  justify-content: space-between;
  width: 100%; padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.07);
  position: relative; z-index: 1;
  margin-top: auto;
}
.n-dur {
  font-size: 11px; font-weight: var(--fw-book);
  color: rgba(255,255,255,.35);
  display: flex; align-items: center; gap: 5px;
}
.n-dur i { font-size: 10px; }
.n-cta {
  font-size: 11.5px; font-weight: var(--fw-semi);
  color: rgba(255,255,255,.55);
  display: flex; align-items: center; gap: 5px;
  letter-spacing: .02em;
  transition: color .2s, gap .2s;
}
.ncard:hover .n-cta { color: #fff; gap: 8px; }
.n-cta i { font-size: 9px; transition: transform .2s; }
.ncard:hover .n-cta i { transform: translateX(2px); }

/* Glow de fondo en hover — más suave */
.ncard::before {
  content:''; position: absolute; inset: 0;
  opacity: 0; transition: opacity .35s;
  border-radius: 20px; pointer-events: none;
}
.ncard:hover::before { opacity: 1; }

/* Borde luminoso inferior */
.ncard::after {
  content:''; position: absolute;
  bottom: 0; left: 0; right: 0; height: 2px;
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  transform: scaleX(0); transform-origin: left;
}
.ncard:hover { 
  transform: translateY(-8px) scale(1.015);
  border-color: rgba(255,255,255,.14);
}
.ncard:hover::after { transform: scaleX(1); }

/* ── Colores por nivel ── */
.nlv-lic .n-ico { background: rgba(145,26,58,.25); color: #f4a0b5; border: 1px solid rgba(145,26,58,.4); }
.nlv-lic::after { background: linear-gradient(90deg, var(--G), #c4254e); }
.nlv-lic:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(145,26,58,.2) 0%, transparent 65%); }
.nlv-lic:hover { box-shadow: 0 24px 50px rgba(145,26,58,.35); }

.nlv-mae .n-ico { background: rgba(200,49,130,.2); color: #f4a0d0; border: 1px solid rgba(200,49,130,.35); }
.nlv-mae::after { background: linear-gradient(90deg, var(--R), #e060a8); }
.nlv-mae:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(200,49,130,.18) 0%, transparent 65%); }
.nlv-mae:hover { box-shadow: 0 24px 50px rgba(200,49,130,.32); }

.nlv-doc .n-ico { background: rgba(189,152,104,.2); color: #e8c88a; border: 1px solid rgba(189,152,104,.35); }
.nlv-doc::after { background: linear-gradient(90deg, var(--D), #d4aa6a); }
.nlv-doc:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(189,152,104,.18) 0%, transparent 65%); }
.nlv-doc:hover { box-shadow: 0 24px 50px rgba(189,152,104,.28); }

.nlv-esp .n-ico { background: rgba(80,120,200,.2); color: #aac0f0; border: 1px solid rgba(80,120,200,.35); }
.nlv-esp::after { background: linear-gradient(90deg, #5078c8, #6090e0); }
.nlv-esp:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(80,120,200,.18) 0%, transparent 65%); }
.nlv-esp:hover { box-shadow: 0 24px 50px rgba(80,120,200,.28); }

.nlv-dip .n-ico { background: rgba(50,160,120,.2); color: #90e0c0; border: 1px solid rgba(50,160,120,.35); }
.nlv-dip::after { background: linear-gradient(90deg, #32a078, #50c090); }
.nlv-dip:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(50,160,120,.18) 0%, transparent 65%); }
.nlv-dip:hover { box-shadow: 0 24px 50px rgba(50,160,120,.25); }

.nlv-cur .n-ico { background: rgba(160,80,200,.2); color: #d0a0f0; border: 1px solid rgba(160,80,200,.35); }
.nlv-cur::after { background: linear-gradient(90deg, #a050c8, #c070e0); }
.nlv-cur:hover::before { background: radial-gradient(ellipse at 20% 50%, rgba(160,80,200,.18) 0%, transparent 65%); }
.nlv-cur:hover { box-shadow: 0 24px 50px rgba(160,80,200,.25); }

/* ── Responsive ncards ── */
@media(max-width:960px){
  .niv-grid { grid-template-columns: repeat(3,1fr); gap:12px; }
}
@media(max-width:700px){
  .niv-grid { grid-template-columns: repeat(2,1fr); }
  .ncard { min-height: 180px; padding: 24px 18px 18px; }
  .n-title { font-size: 18px; }
}
@media(max-width:460px){
  .niv-grid { grid-template-columns: 1fr; gap:10px; }
  .ncard { 
    flex-direction: row; align-items: center; 
    padding: 18px 20px; min-height: auto; gap: 16px;
    text-align: left;
  }
  .n-ico { margin-bottom: 0; flex-shrink: 0; width: 40px; height: 40px; }
  .n-badge { display: none; }
  .n-num { display: none; }
  .n-title { font-size: 16px; margin-bottom: var(--space-1); }
  .n-cnt { font-size: 11px; padding-bottom: 0; }
  .n-foot { display: none; }
  .ncard > * { z-index: 1; }
}

/* ════ COUNTERS — más impacto visual ════ */
.counts {
  padding: var(--space-9) 0;
  background: linear-gradient(135deg, var(--G2) 0%, var(--G) 50%, #a02040 100%);
  position: relative; overflow: hidden;
}
.counts::before {
  content:''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 2 L58 17 L58 43 L30 58 L2 43 L2 17 Z' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3C/svg%3E");
  background-size: 60px 60px;
  pointer-events: none;
}
.cnt-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 2px;
  position: relative; z-index: 1;
}
.cnt-i {
  text-align: center;
  padding: var(--space-7) var(--space-5);
  position: relative;
}
.cnt-i + .cnt-i::before {
  content: '';
  position: absolute; left: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: rgba(255,255,255,.12);
}
.cnt-ico {
  width: 52px; height: 52px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--space-5);
  font-size: 20px; color: rgba(255,255,255,.85);
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
}
.cnt-i:hover .cnt-ico {
  background: rgba(255,255,255,.22);
  transform: scale(1.1) rotate(-5deg);
}
.cnt-n {
  font-size: clamp(40px,5vw,60px);
  font-weight: var(--fw-light);
  color: #fff;
  line-height: 1;
  margin-bottom: var(--space-3);
  letter-spacing: -.04em;
  display: flex; align-items: baseline; justify-content: center; gap: 3px;
}
.cnt-sup {
  font-size: .45em;
  font-weight: var(--fw-book);
  color: var(--D);
  line-height: 1;
  align-self: flex-start;
  margin-top: 6px;
}
.cnt-lb {
  font-size: 12px; font-weight: var(--fw-book);
  color: rgba(255,255,255,.6);
  line-height: 1.55; letter-spacing: .01em;
}

@media(max-width:700px){
  .cnt-grid { grid-template-columns: repeat(2,1fr); gap: 1px; }
  .cnt-i + .cnt-i::before { display: none; }
  .cnt-i { border-bottom: 1px solid rgba(255,255,255,.08); }
}
@media(max-width:400px){
  .cnt-grid { grid-template-columns: 1fr; }
}

/* ════ NOTICIAS — cards más limpias ════ */
.n-card {
  border-radius: 18px;
  overflow: hidden;
  transition: transform .28s cubic-bezier(.34,1.4,.64,1), box-shadow .28s ease;
  position: relative;
}
.n-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,.12);
}
.n-img-wrap { overflow: hidden; }
.n-img { transition: transform .5s ease; }
.n-card:hover .n-img { transform: scale(1.04); }
.n-meta { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }
.n-cat {
  font-size: 10px; font-weight: var(--fw-semi);
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--G); padding: 3px 10px;
  background: var(--Gl); border-radius: 40px;
}
.n-date { font-size: 11.5px; color: var(--Grd); font-weight: var(--fw-book); }
.n-t {
  font-size: 15px; font-weight: var(--fw-med);
  line-height: 1.4; color: var(--ink);
  margin-bottom: var(--space-3);
  letter-spacing: -.01em;
}
.n-exc {
  font-size: 13.5px; font-weight: var(--fw-book);
  line-height: 1.7; color: var(--Grd);
}

/* ════ SECCIÓN WHY/PORQUE — espaciado ════ */
.why { padding: var(--space-9) 0; }
.why-inner { gap: 72px; }

/* ════ TESTIMONIOS ════ */
.testi { padding: var(--space-9) 0; }
.t-card {
  border-radius: 20px;
  padding: 32px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.1);
}
.t-q {
  font-size: 14.5px; font-weight: var(--fw-book);
  line-height: 1.8; color: rgba(255,255,255,.82);
  font-style: italic;
}
.t-q::before { 
  content: '"';
  font-size: 48px; line-height: .8;
  color: var(--D); opacity: .5;
  display: block; margin-bottom: 8px;
  font-weight: var(--fw-light);
}
.t-name { font-size: 13px; font-weight: var(--fw-med); color: #fff; }
.t-role { font-size: 11.5px; font-weight: var(--fw-book); color: rgba(255,255,255,.4); }

/* ════ NOTICIAS DESTACADAS section ════ */
.news { padding: var(--space-9) 0; }

/* ════ BOTONES — refinamiento ════ */
.btn-primary-g, .hbtn-fill {
  font-weight: var(--fw-semi);
  letter-spacing: .02em;
  border-radius: 40px;
}
.btn-outline-g {
  font-weight: var(--fw-semi);
  letter-spacing: .02em;
}

/* ════ HERO — mejoras de tipografía ════ */
.s-h {
  font-weight: var(--fw-light);
  letter-spacing: -.035em;
  line-height: 1.02;
}
.s-h .gold {
  font-weight: var(--fw-book);
  font-style: italic;
}
.s-tag {
  font-size: 11px; font-weight: var(--fw-semi);
  letter-spacing: .14em;
}
.s-card .sc-title {
  font-weight: var(--fw-med);
  letter-spacing: -.02em;
}

/* ════ MICROCREDENCIALES — rediseño portafolio ════ */

/* Override portafolio-container para más premium */
.portafolio-container {
  max-width: 1080px;
  margin: 48px auto 64px;
  padding: 0 20px;
}
.portafolio-card {
  border-radius: 24px;
  box-shadow: 0 2px 4px rgba(0,0,0,.04), 
              0 8px 24px rgba(0,0,0,.08), 
              0 32px 80px rgba(145,26,58,.08);
  border: 1px solid rgba(145,26,58,.08);
  overflow: hidden;
}

/* Header del portafolio — más dramático */
.portafolio-header {
  background: linear-gradient(155deg, #1a0408 0%, #6e132c 40%, #911A3A 75%, #a02040 100%);
  padding: 56px 48px 44px;
  position: relative; overflow: hidden;
}
.portafolio-header::before {
  content: '';
  position: absolute; inset: 0;
  background: 
    radial-gradient(ellipse 60% 80% at 80% 20%, rgba(189,152,104,.15) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(200,49,130,.1) 0%, transparent 60%);
  pointer-events: none;
}
.portafolio-header::after {
  content: '';
  position: absolute; bottom: -1px; left: 0; right: 0; height: 48px;
  background: var(--card, #fff);
  border-radius: 50% 50% 0 0 / 36px 36px 0 0;
}
.portafolio-header h1 {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 300;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}
.portafolio-header > p {
  font-size: 14px;
  font-weight: 350;
  opacity: .75;
}

/* Sello inferior del header */
.portafolio-sello {
  gap: 0;
  background: rgba(0,0,0,.2);
  border-color: rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  max-width: 680px;
  border-radius: 40px;
}
.portafolio-sello span {
  font-size: 11px;
  font-weight: 350;
  padding: 0 18px;
  opacity: .8;
}
.portafolio-sello span::before {
  width: 4px; height: 4px;
  background: var(--d, #BD9868);
}

/* Body del portafolio */
.portafolio-body { padding: 40px 40px 36px; }

/* Tabs de secciones */
.perfil-tabs {
  background: #f4eff1;
  padding: 4px;
  border-radius: 40px;
  margin-bottom: 32px;
  gap: 2px;
}
.perfil-tab {
  padding: 9px 22px;
  font-size: 13px;
  font-weight: 350;
  border-radius: 36px;
  letter-spacing: .005em;
}
.perfil-tab.active {
  font-weight: 500;
  box-shadow: 0 2px 8px rgba(145,26,58,.15);
}

/* Cards de insignias */
.insignia-card {
  border-radius: 18px;
  border-color: rgba(145,26,58,.08);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  padding: 22px 16px 18px;
  transition: transform .28s cubic-bezier(.34,1.4,.64,1), 
              box-shadow .28s ease;
}
.insignia-card:hover {
  transform: translateY(-6px) scale(1.01);
  box-shadow: 0 16px 40px rgba(145,26,58,.12);
  border-color: rgba(145,26,58,.2);
}
.insignia-card::before { height: 2px; }
.insignia-imagen {
  border-radius: 12px;
  width: 80px; height: 80px;
  background: #f9f5f6;
}
.insignia-card h3 {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -.01em;
  line-height: 1.35;
}
.insignia-card p { font-size: 12px; font-weight: 350; }
.fecha-tag {
  font-size: 10.5px;
  font-weight: 350;
  letter-spacing: .02em;
}

/* Bienvenida */
.welcome-msg { 
  border-radius: 16px;
  padding: 16px 20px;
  gap: 14px;
}
.welcome-info strong { 
  font-size: 17px; 
  font-weight: 500;
  letter-spacing: -.01em;
}

/* Tipo selector */
.tipo-card {
  border-radius: 18px;
  padding: 28px 20px 22px;
  transition: transform .25s cubic-bezier(.34,1.4,.64,1), 
              box-shadow .25s ease, border-color .2s;
}
.tipo-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(145,26,58,.12);
}
.tipo-card h3 { font-size: 15px; font-weight: 500; }
.tipo-card p { font-size: 13px; font-weight: 350; line-height: 1.65; }

/* Formularios de microcredenciales */
.formulario { border-radius: 16px; }
.form-group label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #5a1a2a;
}
.form-group input, .form-group textarea {
  font-size: 14px;
  font-weight: 350;
  padding: 11px 14px;
  border-radius: 10px;
  border-width: 1.5px;
}
.btn-primary {
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: .04em;
  padding: 13px;
  border-radius: 40px;
}

/* ════ FOOTER — refinamiento tipografía ════ */
.f-col-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .16em;
}
.f-link, .f-meta-link {
  font-size: 13px;
  font-weight: 350;
}

/* ════ MOBILE — espaciados consistentes ════ */
@media(max-width:768px){
  .portafolio-header { padding: 40px 24px 32px; }
  .portafolio-body { padding: 28px 20px 24px; }
  .perfil-tab { padding: 8px 14px; font-size: 12px; }
  .prog-head { flex-direction: column; align-items: flex-start; gap: var(--space-5); }
}
@media(max-width:500px){
  .portafolio-container { margin: 24px auto 48px; padding: 0 12px; }
  .portafolio-card { border-radius: 18px; }
  .insignias-grid { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════════════════════════════
   SISTEMA DE ACCESIBILIDAD UNIVIM + WHATSAPP — v3
   © 2026 Universidad Virtual del Estado de Michoacán
   ══════════════════════════════════════════════════════════ */

/* ── Barra de lectura ── */
#reading-bar {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: linear-gradient(90deg, #911A3A, #BD9868);
  z-index: 9999;
  width: 0%;
  transition: width .1s linear;
}

/* ── WhatsApp — inferior izquierda ── */
#fab-whatsapp {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 9000;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 4px 18px rgba(37,211,102,.4);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;
  -webkit-tap-highlight-color: transparent;
}
#fab-whatsapp:hover { transform: translateY(-4px) scale(1.08); box-shadow: 0 8px 28px rgba(37,211,102,.5); }
#fab-whatsapp:active { transform: scale(.94); }
#fab-whatsapp svg { width: 30px; height: 30px; fill: #fff; }

/* ── Botón principal de accesibilidad — superior izquierda ── */
#accesibilidad-btn {
  position: fixed !important;
  top: 120px !important;
  left: 20px !important;
  z-index: 99999 !important;
  background: linear-gradient(135deg, #4A001F 0%, #6A001F 100%) !important;
  color: white !important;
  border: none !important;
  border-radius: 50% !important;
  width: 70px !important;
  height: 70px !important;
  cursor: pointer !important;
  box-shadow: 0 6px 25px rgba(74,0,31,.4) !important;
  transition: all .3s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  animation: pulseAttentionUNIVIM 2s ease-in-out infinite !important;
}
@keyframes pulseAttentionUNIVIM {
  0%,100% { transform: scale(1); box-shadow: 0 6px 25px rgba(74,0,31,.4), 0 0 0 0 rgba(106,0,31,.7); }
  50%      { transform: scale(1.05); box-shadow: 0 8px 30px rgba(74,0,31,.5), 0 0 0 15px rgba(106,0,31,0); }
}
#accesibilidad-btn:hover,
#accesibilidad-btn.activo {
  transform: scale(1.1) !important;
  box-shadow: 0 8px 35px rgba(74,0,31,.6) !important;
  background: linear-gradient(135deg, #6A001F 0%, #4A001F 100%) !important;
  animation: none !important;
}
.icono-accesibilidad {
  width: 46px !important; height: 46px !important;
  object-fit: contain !important;
  filter: brightness(0) invert(1) !important;
  animation: iconoBounce 2s ease-in-out infinite !important;
}
.icono-accesibilidad-svg {
  width: 46px !important; height: 46px !important;
  fill: white !important;
}
@keyframes iconoBounce {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}

/* ── Menú de accesibilidad — abre a la derecha del botón ── */
#accesibilidad-menu {
  position: fixed !important;
  top: 120px !important;
  left: 100px !important;
  z-index: 99998 !important;
  background: white !important;
  border: 2px solid #6A001F !important;
  border-radius: 15px !important;
  padding: 0 !important;
  box-shadow: 0 8px 30px rgba(74,0,31,.2) !important;
  display: none !important;
  flex-direction: column !important;
  width: 300px !important;
  max-height: 70vh !important;
  overflow: hidden !important;
  font-family: Arial, sans-serif !important;
}
#accesibilidad-menu.visible {
  display: flex !important;
  animation: slideInLeft .25s ease !important;
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-16px); }
  to   { opacity: 1; transform: translateX(0); }
}

.acc-menu-header {
  background: linear-gradient(135deg, #4A001F, #6A001F) !important;
  color: white !important;
  padding: 14px 18px !important;
  font-size: 14px !important;
  font-weight: bold !important;
  text-align: center !important;
  border-radius: 13px 13px 0 0 !important;
  position: sticky !important; top: 0 !important; z-index: 10 !important;
}
.acc-menu-content {
  overflow-y: auto !important;
  padding: 12px 0 !important;
  max-height: calc(70vh - 110px) !important;
}
.acc-menu-content::-webkit-scrollbar { width: 5px !important; }
.acc-menu-content::-webkit-scrollbar-track { background: #f1f1f1 !important; }
.acc-menu-content::-webkit-scrollbar-thumb { background: #6A001F !important; border-radius: 10px !important; }

.acc-category { margin: 8px 0 !important; padding: 0 8px !important; }
.acc-category-title {
  padding: 8px 12px !important; font-size: 11px !important;
  font-weight: bold !important; color: #7f8c8d !important;
  text-transform: uppercase !important; letter-spacing: 1px !important;
  background: #f8f9fa !important; border-radius: 5px !important; margin: 4px 0 !important;
}
#accesibilidad-menu button {
  background: transparent !important; border: none !important;
  padding: 10px 18px !important; cursor: pointer !important;
  text-align: left !important; transition: all .18s ease !important;
  font-size: 13px !important; font-weight: 600 !important; color: #2c3e50 !important;
  display: flex !important; align-items: center !important; gap: 10px !important;
  border-left: 3px solid transparent !important; margin: 1px 0 !important;
  border-radius: 0 8px 8px 0 !important; width: 100% !important; font-family: Arial, sans-serif !important;
}
#accesibilidad-menu button:hover {
  background: #f8f9fa !important; border-left-color: #6A001F !important;
  color: #4A001F !important; transform: translateX(3px) !important;
}
#accesibilidad-menu button.activo {
  background: #f9f0f5 !important; border-left-color: #4A001F !important; color: #4A001F !important;
}
#accesibilidad-menu button .icon {
  font-size: 15px !important; min-width: 22px !important; text-align: center !important;
}

.acc-menu-footer {
  background: #f8f9fa !important; padding: 10px !important;
  border-top: 2px solid #e9ecef !important;
  position: sticky !important; bottom: 0 !important; z-index: 10 !important;
}
#reset-todo {
  width: 100% !important; background: #6A001F !important; color: white !important;
  padding: 11px !important; border-radius: 8px !important; font-weight: bold !important;
  border: none !important; text-transform: uppercase !important;
  letter-spacing: 1px !important; justify-content: center !important;
}
#reset-todo:hover { background: #4A001F !important; transform: none !important; }

.acc-developer-info {
  text-align: center !important; padding: 7px 10px 6px !important;
  font-size: 10px !important; color: #7f8c8d !important;
  background: #f8f9fa !important; border-top: 1px solid #e9ecef !important;
  font-style: italic !important; line-height: 1.4 !important;
}
.acc-developer-info strong { color: #4A001F !important; }

/* ── Elementos auxiliares de lectura ── */
#guia-lectura-line {
  position: fixed !important; left: 0 !important; right: 0 !important;
  height: 2px !important; background: #6A001F !important;
  box-shadow: 0 0 10px rgba(106,0,31,.8) !important;
  pointer-events: none !important; z-index: 99997 !important; display: none !important;
}
body.guiaLectura #guia-lectura-line { display: block !important; }

#mascara-lectura-window {
  position: fixed !important; left: 0 !important; right: 0 !important;
  height: 150px !important; background: transparent !important;
  box-shadow: 0 0 0 9999px rgba(0,0,0,.7) !important;
  pointer-events: none !important; z-index: 99997 !important; display: none !important;
}
body.mascaraLectura #mascara-lectura-window { display: block !important; }

/* ── Efectos de accesibilidad ── */
body.modoOscuro { background-color: #1a1a1a !important; color: #ffffff !important; }
body.modoOscuro div:not(#accesibilidad-menu):not(.acc-menu-content):not(.acc-category):not(#accesibilidad-btn),
body.modoOscuro section, body.modoOscuro article, body.modoOscuro main {
  background-color: #1a1a1a !important; color: #ffffff !important;
}
body.textoResaltado p, body.textoResaltado span:not(.icon), body.textoResaltado li {
  background-color: #ffff00 !important; color: #000 !important; padding: 2px 4px !important;
}
body.altoContraste   { filter: contrast(200%) !important; }
body.escalaGrises    { filter: grayscale(100%) !important; }
body.saturacion      { filter: saturate(200%) !important; }
body.invertirColores { filter: invert(100%) hue-rotate(180deg) !important; }
body.invertirColores img, body.invertirColores video { filter: invert(100%) hue-rotate(180deg) !important; }
body.modoSepia       { filter: sepia(80%) !important; }
body.linksSubrayados a { text-decoration: underline !important; text-decoration-thickness: 2px !important; text-decoration-color: #6A001F !important; }
body.resaltarEnlaces a { background-color: #f9f0f5 !important; padding: 2px 6px !important; border-radius: 3px !important; border: 2px solid #6A001F !important; }
body.resaltarTitulos h1 { background: #4A001F !important; color: white !important; padding: 10px !important; }
body.resaltarTitulos h2 { background: #6A001F !important; color: white !important; padding: 8px !important; }
body.resaltarTitulos h3 { background: #8B4513 !important; color: white !important; padding: 6px !important; }
body.resaltarTitulos h4 { background: #A0522D !important; color: white !important; padding: 5px !important; }
body.fuenteDislexica * { font-family: "Comic Sans MS","Open Dyslexic",Arial,sans-serif !important; letter-spacing: .5px !important; }
body.espaciadoTexto * { line-height: 2 !important; letter-spacing: 1px !important; word-spacing: .3em !important; }
body.alineacionTexto p, body.alineacionTexto div:not(#accesibilidad-menu):not(.acc-menu-content):not(.acc-category) {
  text-align: left !important; max-width: 800px !important;
}
body.cursorGrande, body.cursorGrande * {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Ccircle cx='20' cy='20' r='18' fill='%234A001F' stroke='%23fff' stroke-width='2'/%3E%3C/svg%3E") 20 20, auto !important;
}
body.ocultarImagenes img:not(.icono-accesibilidad):not(.icono-accesibilidad-svg) {
  opacity: .1 !important; filter: blur(5px) !important;
}
body.tecladoMejorado *:focus { outline: 4px solid #6A001F !important; outline-offset: 2px !important; box-shadow: 0 0 10px rgba(106,0,31,.5) !important; }
body.pausarAnimaciones *, body.pausarAnimaciones *::before, body.pausarAnimaciones *::after {
  animation-play-state: paused !important; transition: none !important;
}
body.modoConcentracion header, body.modoConcentracion footer,
body.modoConcentracion aside, body.modoConcentracion .sidebar,
body.modoConcentracion nav:not(#accesibilidad-menu) {
  opacity: .1 !important; pointer-events: none !important;
}

/* ── Back-to-top — no choca con WA (está en derecha) ── */
#btt {
  position: fixed !important;
  bottom: 28px !important;
  right: 28px !important;
  z-index: 8998 !important;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  #fab-whatsapp { bottom: 16px; left: 16px; width: 50px; height: 50px; }
  #fab-whatsapp svg { width: 26px; height: 26px; }
  #accesibilidad-btn { width: 58px !important; height: 58px !important; top: 100px !important; }
  .icono-accesibilidad { width: 36px !important; height: 36px !important; }
  #accesibilidad-menu { left: 80px !important; width: calc(100vw - 96px) !important; }
}
@media (max-width: 380px) {
  #accesibilidad-menu { left: 8px !important; top: 180px !important; width: calc(100vw - 16px) !important; }
}

/* ── Slider video background (full-cover) ── */
.s-video-wrap{position:absolute;inset:0;overflow:hidden;z-index:0;background:#000}
/* YouTube iframe: scale-to-cover using vmax for reliable full coverage */
.s-video-wrap iframe,.s-iframe-bg{
  position:absolute;
  top:50%;left:50%;
  /* Scale both dims to cover: use the larger of viewport dimensions */
  width:max(100%, 177.78vh, 177.78vmax);
  height:max(100%, 56.25vw, 56.25vmax);
  /* Fallback for browsers without max() */
  min-width:100%;
  min-height:100%;
  transform:translate(-50%,-50%);
  pointer-events:none;border:none;
  object-fit:cover;
}
.s-video,.s-img{position:absolute!important;inset:0;width:100%!important;height:100%!important;object-fit:cover;z-index:0}
.slide{position:relative;overflow:hidden}
.s-img{object-position:center}

/* ── Tercer nivel de menú — CSS puro (has-sub / sub-drop) ── */
.drop-item.has-sub{cursor:default;position:relative;padding-right:12px}
.drop-item.has-sub .sub-arrow{font-size:9px;color:#ADADAD;margin-left:auto;flex-shrink:0;transition:color .15s}
.drop-item.has-sub:hover .sub-arrow{color:var(--G,#911A3A)}
.drop-item.has-sub:hover{background:var(--Gl,#f7eaee);color:var(--G,#911A3A);padding-left:20px}
.sub-drop{
  position:absolute;top:0;left:100%;
  background:#fff;border:1px solid #ede3e6;
  border-radius:16px;box-shadow:0 8px 32px rgba(26,10,16,.18);
  min-width:220px;z-index:801;
  opacity:0;visibility:hidden;transform:translateX(6px);
  transition:all .18s ease;pointer-events:none;overflow:hidden;
}
.drop-item.has-sub:hover .sub-drop{opacity:1;visibility:visible;transform:translateX(2px);pointer-events:auto}
.drop-item.has-sub::after{content:'';position:absolute;top:0;right:-8px;width:8px;height:100%}
/* .drop must be overflow:visible for sub-drop to show outside */
.ni:hover .drop,.drop{overflow:visible!important}

/* ── CMS Gallery & Lightbox ─────────────────────────────────── */
.cms-gallery{display:grid;gap:10px;margin:20px 0}
.cms-gallery a.cms-lb{display:block;aspect-ratio:4/3;overflow:hidden;border-radius:8px;position:relative}
.cms-gallery a.cms-lb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.cms-gallery a.cms-lb:hover img{transform:scale(1.04)}
.cms-gallery a.cms-lb::after{
  content:'\f00e';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.4rem;background:rgba(145,26,58,.0);
  transition:background .2s;pointer-events:none;
}
.cms-gallery a.cms-lb:hover::after{background:rgba(145,26,58,.35)}

/* Lightbox overlay */
#cms-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:99999;align-items:center;justify-content:center;flex-direction:column}
