:root{
  --colorPrimary900:#0B2B5C;
  --colorPrimary700:#264D86;
  --colorPrimary500:#1657B9;
  --colorPrimary400:#1E78FD;
  --colorPrimary200:#88A9DB;
  --colorPrimary100:#C9DEFF;

  --colorSecondary900:#5C410B;
  --colorSecondary500:#B19050;
  --colorSecondary100:#FFEDC9;

  --colorNeutral900:#161616;
  --colorNeutral700:#4A4A4A;
  --colorNeutral100:#F2F2F2;
  
  --navy:#061629;
  --navy2:#071f3a;
  --gold:#D9B65F;
  --gold2:#F3D17A;

  --container:1240px;
  --colorNeutral000:#FFFFFF;
}

/* =========================================================
   OFERTA ACADÉMICA — ESTILOS GENERALES
========================================================= */

.oaAcademic{
  position:relative;
  overflow:hidden;
  background:var(--colorNeutral100);
}

/* =========================================================
   01. HERO
========================================================= */

.oaHero{
  position:relative;
  padding:190px 0 80px;
  background:var(#071A3D);
}

.oaHero_bg{
  position:absolute;
  inset:0;

  background:
    radial-gradient(
      circle at 80% 20%,
      rgba(217,182,95,.22),
      transparent 25%
    ),
    radial-gradient(
      circle at 15% 20%,
      rgba(30,120,253,.12),
      transparent 35%
    ),
    linear-gradient(
      135deg,
      var(--navy) 0%,
      var(--navy2) 55%,
      #0B2B5C 100%
    );
}

.oaContainer{
  position:relative;
  z-index:2;

  width:min(var(--container),calc(100% - 64px));
  max-width:var(--container);
  margin-inline:auto;

  padding-left:0;
  padding-right:0;
}

.oaHero_content{
  max-width:620px;
}

.oaHero_eyebrow{
  display:inline-flex;

  margin-bottom:28px;

  color:var(--gold2);

  font-size:13px;
  font-weight:600;
  letter-spacing:.24em;

  text-transform:uppercase;
}

.oaHero_title{
  margin-bottom:32px;

  color:var(--colorNeutral000);

  font-family:var(--fontSecondary);

  font-size:clamp(58px,7vw,100px);

  line-height:.92;
}

.oaHero_divider{
  width:120px;
  height:2px;

  margin-bottom:32px;

  background:var(--gold);
}

.oaHero_text{
  max-width:560px;

  color:rgba(255,255,255,.74);

  font-size:17px;

  line-height:1.9;
}

/* =========================================================
   02. ESTADÍSTICAS DEL HERO
========================================================= */

.oaStats{
  border-left:1px solid rgba(255,255,255,.08);
}

.oaStatCard{
  height:100%;

  padding:34px;

  border-right:1px solid rgba(255,255,255,.08);
}

.oaStatCard--borderless{
  border-right:none;
}

.oaStatCard i{
  margin-bottom:28px;

  color:var(--gold2);

  font-size:20px;
}

.oaStatCard h3{
  margin-bottom:8px;

  color:var(--colorNeutral000);

  font-family:var(--fontSecondary);

  font-size:34px;

  line-height:1;
}

.oaStatCard span{
  display:block;

  margin-bottom:18px;

  color:rgba(255,255,255,.52);

  font-size:12px;

  letter-spacing:.18em;

  text-transform:uppercase;
}

.oaStatCard p{
  margin:0;

  color:rgba(255,255,255,.72);

  font-size:14px;

  line-height:1.8;
}

/* =========================================================
   03. CONTENIDO PRINCIPAL
========================================================= */

.oaContent{
  position:relative;

  margin-top:-50px;

  padding-bottom:100px;
}

/* =========================================================
   04. BARRA DE BÚSQUEDA Y FILTROS
========================================================= */

.oaToolbar{
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:24px;

  margin-bottom:40px;
  padding:36px 42px;

  background:var(--colorNeutral000);

  box-shadow:0 20px 60px rgba(0,0,0,.06);
  border-radius:18px;
border:1px solid rgba(7,31,58,.08);
}

.oaSearch{
  position:relative;

  width:100%;
  max-width:420px;

  flex:1;
}

.oaSearch i{
  position:absolute;
  top:50%;
  left:20px;

  transform:translateY(-50%);

  color:var(--colorNeutral700);

  font-size:14px;
}

.oaSearch input{
  width:100%;
  height:56px;

  padding:0 20px 0 52px;

  border:none;
  border-radius:999px;

  background:var(--colorNeutral100);

  outline:none;

  font-size:14px;
}

.oaFilterControls{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:14px;

  flex-wrap:wrap;
}

/* =========================================================
   05. SELECT PERSONALIZADO
========================================================= */

.oaCustomSelect{
  position:relative;
  min-width:220px;
}

.oaCustomSelect_trigger{
  width:100%;
  height:56px;

  padding:0 20px;

  display:flex;
  align-items:center;
  gap:12px;

  border:none;
  border-radius:999px;

  background:var(--colorNeutral100);

  color:var(--colorNeutral900);

  font-size:14px;
  font-weight:600;

  cursor:pointer;

  transition:.3s ease;
}

.oaCustomSelect_trigger:hover,
.oaCustomSelect.is-open .oaCustomSelect_trigger{
  background:var(--colorPrimary100);
}

.oaCustomSelect_icon{
  color:var(--colorPrimary900);
  font-size:13px;
}

.oaCustomSelect_text{
  flex:1;

  text-align:left;

  white-space:nowrap;
}

.oaCustomSelect_arrow{
  width:9px;
  height:9px;

  border-right:2px solid var(--colorPrimary900);
  border-bottom:2px solid var(--colorPrimary900);

  transform:rotate(45deg) translateY(-2px);

  transition:.3s ease;
}

.oaCustomSelect.is-open .oaCustomSelect_arrow{
  transform:rotate(-135deg) translateY(-2px);
}

.oaCustomSelect_menu{
  position:absolute;
  top:calc(100% + 12px);
  left:0;
  z-index:20;

  width:100%;

  margin:0;
  padding:8px;

  list-style:none;

  border:1px solid rgba(20,20,20,.06);

  background:var(--colorNeutral000);

  box-shadow:0 20px 50px rgba(0,0,0,.10);

  opacity:0;
  visibility:hidden;

  transform:translateY(8px);

  transition:.25s ease;
}

.oaCustomSelect.is-open .oaCustomSelect_menu{
  opacity:1;
  visibility:visible;

  transform:translateY(0);
}

.oaCustomSelect_menu li{
  padding:13px 14px;

  color:var(--colorNeutral700);

  font-size:14px;
  font-weight:600;

  cursor:pointer;

  transition:.25s ease;
}

.oaCustomSelect_menu li:hover,
.oaCustomSelect_menu li.is-active{
  background:var(--colorNeutral100);

  color:var(--colorPrimary900);
}

/* =========================================================
   06. BOTÓN LIMPIAR FILTROS
========================================================= */

.oaClearFilter{
  height:56px;

  padding:0 22px;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;

  border:1px solid rgba(11,43,92,.14);
  border-radius:999px;

  background:var(--colorNeutral000);

  color:var(--colorPrimary900);

  font-size:14px;
  font-weight:700;

  cursor:pointer;

  transition:.3s ease;
}

.oaClearFilter:hover{
  transform:translateY(-2px);

  background:var(--colorNeutral100);
}

/* =========================================================
   07. RESUMEN DE RESULTADOS
========================================================= */

.oaSummary{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;

  margin:-12px 0 28px;
}

.oaSummary_kicker{
  display:block;

  margin-bottom:8px;

  color:var(--gold);

  font-size:11px;
  font-weight:700;

  letter-spacing:.18em;

  text-transform:uppercase;
}

.oaSummary h2{
  margin:0;

  color:var(--colorPrimary900);

  font-family:var(--fontSecondary);

  font-size:34px;

  line-height:1;

  letter-spacing:-.04em;
}

.oaSummary p{
  max-width:440px;

  margin:0;

  color:var(--colorNeutral700);

  font-size:14px;

  line-height:1.7;

  text-align:right;
}

/* =========================================================
   08. GRID DE PROGRAMAS
========================================================= */

.oaProgramsGrid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:32px;
  align-items:stretch;
}

.oaProgramItem{
  height:100%;
}

.oaProgramItem[hidden]{
  display:none !important;
}

/* =========================================================
   09. CARD DE PROGRAMA
========================================================= */

.oaProgramCard{
  height:100%;

  display:flex;

  overflow:hidden;

  background:var(--colorNeutral000);

  box-shadow:0 18px 40px rgba(0,0,0,.05);

  transition:.35s ease;
}

.oaProgramCard:hover{
  transform:translateY(-6px);

  box-shadow:0 30px 60px rgba(0,0,0,.08);
}

.oaProgramCard_image{
  width:38%;

  min-height:280px;

  overflow:hidden;

  flex-shrink:0;
}

.oaProgramCard_image img{
  width:100%;
  height:100%;

  object-fit:cover;

  transition:.5s ease;
}

.oaProgramCard:hover .oaProgramCard_image img{
  transform:scale(1.04);
}

.oaProgramCard_content{
  flex:1;

  display:flex;
  flex-direction:column;

  padding:34px;
}

.oaProgramCard_tag{
  display:inline-flex;
  margin-bottom:18px;
  font-size:11px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  padding: 5px 10px;
  max-width: fit-content;
}

.oaProgramCard_title{
  margin-bottom:22px;
  color:var(--colorNeutral900);
  font-family:var(--fontSecondary);
  font-size:32px;
  line-height:.96;
  letter-spacing:-.04em;
}

.oaProgramCard_meta{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;

  margin-bottom:26px;
}

.oaProgramCard_meta span{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--colorNeutral700);
  font-size:14px;
}

.oaProgramCard_meta i{
  color:var(--colorPrimary900);

  font-size:13px;
}

.oaProgramCard_footer{
  margin-top:auto;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.oaProgramCard_footer a{
  display:inline-flex;
  align-items:center;
  gap:10px;

  color:var(--colorPrimary900);

  font-size:14px;
  font-weight:600;
}

.oaProgramCard_footer i{
  font-size:11px;
}

.oaProgramCard_coordinator {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: var(--colorPrimary900);
  font-size: 14px;
  line-height: 1.4;
}

.oaProgramCard_coordinator i {
  margin-top: 3px;
  color: var(--colorSecondary500);
}
/* =========================================================
   10. COLORES POR NIVEL ACADÉMICO
========================================================= */

.oaProgramCard_tag--licenciatura,
.oaProgramCard_tag--licenciaturas{
  background:var(--colorPrimary900) ;
  color:var(--colorNeutral000);
}

.oaProgramCard_tag--especialidad,
.oaProgramCard_tag--especialidades{
  background:var(--colorSecondary900) ;
  color:var(--colorNeutral000);
}

.oaProgramCard_tag--maestria,
.oaProgramCard_tag--maestrias{
  background:var(--colorSecondary100) ;
  color:var(--colorSecondary900);
}

.oaProgramCard_tag--doctorado,
.oaProgramCard_tag--doctorados{
  background:var(--colorSecondary500) ;
  color:var(--colorNeutral000);
}


/* =========================================================
   11. BADGE DESTACADO
========================================================= */

.oaProgramCard_featured{
  width:max-content;

  margin-bottom:14px;
  padding:7px 12px;

  display:inline-flex;
  align-items:center;
  gap:8px;

  background:var(--colorSecondary100);

  color:var(--colorSecondary900);

  font-size:11px;
  font-weight:800;

  letter-spacing:.12em;

  text-transform:uppercase;
}

.oaProgramCard_featured i{
  color:var(--colorSecondary500);

  font-size:11px;
}

/* =========================================================
   12. ESTADO VACÍO
========================================================= */

.oaEmptyState{
  margin-bottom:30px;

  padding:44px 28px;

  text-align:center;

  background:var(--colorNeutral000);

  box-shadow:0 18px 40px rgba(0,0,0,.05);
}

.oaEmptyState i{
  margin-bottom:14px;

  color:var(--colorPrimary900);

  font-size:34px;
}

.oaEmptyState h3{
  margin-bottom:8px;

  color:var(--colorNeutral900);

  font-family:var(--fontSecondary);

  font-size:30px;
}

.oaEmptyState p{
  margin:0;

  color:var(--colorNeutral700);
}

/* =========================================================
   CTA FINAL COMPARTIDO
========================================================= */

.final-cta{
  width:100%;
  margin-top:40px;
  min-height:160px;
  position:relative;
  overflow:hidden;

  display:grid;
  grid-template-columns:1fr 300px;
  gap:28px;
  align-items:center;

  padding:28px 34px 28px 320px;

  color:#fff;
  border-radius:24px;
  background:#04173f;
  box-shadow:0 24px 45px rgba(7,31,58,.16);
}

.final-cta::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;

  background-image:
    linear-gradient(
      90deg,
      rgba(4,23,63,.10) 0%,
      rgba(4,23,63,.70) 15%,
      rgba(4,23,63,.95) 25%,
      rgba(4,23,63,1) 35%
    ),
    url("/img/ofertaAcademica/banner-contacto-ofertaAcademica.png");

  background-size:cover;
  background-position:left center;
  background-repeat:no-repeat;
}

.final-cta_image{
  display:none;
}

.final-cta_content,
.final-cta_actions{
  position:relative;
  z-index:1;
}

.final-cta_content h2{
  margin:0 0 8px;
  color:#fff;
  font-size:27px;
  line-height:1.12;
  font-weight:800;
}

.final-cta_content h2 span{
  color:var(--gold2);
}

.final-cta_content p{
  margin:0 0 22px;
  color:var(--gold2);
  font-weight:700;
}

.cta-badges{
  display:flex;
  flex-wrap:wrap;
  gap:22px;
  color:rgba(255,255,255,.82);
  font-size:13px;
}

.cta-badges span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.cta-badges i{
  color:var(--gold2);
}

.final-cta_actions{
  display:grid;
  gap:14px;
}

.final-cta_actions .btn-program{
  width:100%;
  min-height:48px;
}

.btn-program{
  min-height:54px;
  padding:0 28px;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:14px;

  border-radius:8px;
  border:1px solid transparent;

  font-size:14px;
  font-weight:800;

  text-decoration:none;

  transition:
    transform .25s ease,
    box-shadow .25s ease,
    border-color .25s ease;

  cursor:pointer;
}

.btn-program:hover{
  transform:translateY(-2px);
}

.btn-program--gold{
  color:#061629;
  background:linear-gradient(
    135deg,
    #F8DA88,
    #C99D3C
  );

  box-shadow:0 12px 26px rgba(217,182,95,.22);
}

.btn-program--gold:hover{
  color:#061629;
}

.btn-program--ghost{
  color:#fff;

  background:rgba(255,255,255,.04);

  border:1px solid rgba(255,255,255,.45);
}

.btn-program--ghost:hover{
  color:#fff;
  border-color:var(--gold2);
}


@media(max-width:1100px){

  .final-cta{
    grid-template-columns:1fr;
    padding:28px;
  }

}

@media(max-width:760px){

  .final-cta{
    padding:24px;
  }

  .cta-badges{
    display:grid;
    gap:12px;
  }

}

/* =========================================================
   14. AJUSTES DE ALTURA EN CARDS
========================================================= */

#programGrid{
  align-items:stretch;
}

#programGrid .oaProgramItem{
  display:flex;
}

#programGrid .oaProgramCard{
  width:100%;
  min-height:360px;
}

.oaProgramCard_content{
  min-height:100%;
}

.oaProgramCard_title{
  min-height:92px;
}

.oaProgramCard_meta{
  flex:1;
}

.oaProgramCard_footer{
  margin-top:auto;
}

/* =========================================================
   15. PAGINACIÓN
========================================================= */

.oaPagination{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-top:46px;
  flex-wrap:wrap;
}

.oaPagination button{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(11,43,92,.12);
  border-radius:999px;
  background:var(--colorNeutral000);
  color:var(--colorPrimary900);
  font-size:14px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 12px 28px rgba(0,0,0,.06);
  transition:.3s ease;
}

.oaPagination button:hover:not(:disabled){
  transform:translateY(-3px);
  background:var(--colorNeutral100);
  color: var(--colorPrimary900);
}

.oaPagination button.is-active{
  background:var(--colorPrimary900);
  color:var(--colorNeutral000);
  border-color:var(--colorPrimary900);
  box-shadow:0 14px 30px rgba(11,43,92,.18);
}

.oaPagination button:disabled{
  opacity:.35;
  cursor:not-allowed;
  box-shadow:none;
}

@media(max-width:767px){
  .oaPagination{
    margin-top:34px;
    gap:8px;
  }

  .oaPagination button{
    width:40px;
    height:40px;
    font-size:13px;
  }
}

/* =========================================================
   16. RESPONSIVE
========================================================= */

@media(max-width:1199px){

  .oaContainer{
    width:min(var(--container),calc(100% - 64px));
    padding-left:0;
    padding-right:0;
  }

  .oaHero_content{
    margin-bottom:80px;
  }

  .oaStats{
    border-top:1px solid rgba(255,255,255,.08);
  }

  .oaStatCard{
    border-bottom:1px solid rgba(255,255,255,.08);
  }

  .oaToolbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .oaSearch{
    max-width:100%;
  }

  .oaFilterControls{
    width:100%;
    justify-content:flex-start;
  }

  .oaCustomSelect,
  .oaClearFilter{
    flex:1;
  }

  .oaProgramsGrid{
    grid-template-columns:1fr;
  }


}

@media(max-width:991px){

  .oaProgramCard{
    flex-direction:column;
  }

  .oaProgramCard_image{
    width:100%;
    height:240px;
  }

}

@media(max-width:767px){

  .oaHero{
    padding:100px 0 90px;
  }

  .oaContainer{
    width:min(100% - 36px,var(--container));
    padding-left:0;
    padding-right:0;
  }

  .oaHero_title{
    font-size:58px;
  }

  .oaHero_text{
    font-size:15px;
  }

  .oaToolbar{
    padding:24px;
  }

  .oaFilterControls{
    flex-direction:column;
    align-items:stretch;
  }

  .oaCustomSelect,
  .oaClearFilter,
  .oaSearch{
    width:100%;
    max-width:100%;
  }

  .oaProgramCard_content{
    padding:28px;
  }

  .oaProgramCard_title{
    font-size:28px;
  }

  .oaSummary{
    align-items:flex-start;
    flex-direction:column;
  }

  .oaSummary h2{
    font-size:28px;
  }

  .oaSummary p{
    text-align:left;
  }


}

/* =========================================================
   RESPONSIVE — AJUSTES MÓVIL
   Corrige tarjetas del hero y flechas de filtros
========================================================= */

@media(max-width:767px){

  .oaStats{
    margin-top:34px;
  }

  .oaStatCard{
    min-height:155px;
    padding:24px 18px;
  }

  .oaStatCard i{
    margin-bottom:18px;
    font-size:18px;
  }

  .oaStatCard h3{
    font-size:clamp(24px,7vw,30px);
    line-height:1.05;
    letter-spacing:-.04em;
    overflow-wrap:normal;
    word-break:normal;
  }

  .oaStatCard span{
    margin-bottom:14px;
    font-size:11px;
    letter-spacing:.16em;
  }

  .oaStatCard p{
    font-size:13px;
    line-height:1.65;
  }

  .oaCustomSelect_trigger{
    padding:0 18px;
    gap:12px;
  }

  .oaCustomSelect_text{
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .oaCustomSelect_arrow{
    flex:0 0 9px;
    margin-left:auto;
    transform:rotate(45deg);
    transform-origin:center;
  }

  .oaCustomSelect.is-open .oaCustomSelect_arrow{
    transform:rotate(225deg);
  }

}
