/* Estilos generales plantilla de programas */
:root {
  --paragraph-default-size: 18px;
  --color-princ-programa: #006d77;
  --oscuro-princ-programa: #002d31;
  --ligth-princ-programa: #00C4D5;
  --rojo-principal: #DA1B21;
  --gris-claro: #EDEDED;
  --gris-medio: #707070;
  --gris-oscuro: #5A5A5A;
  --gris-negro: #323232;
  --negro: #111;
  --gris-textos: #323232;
  --header-bg: #fff;
  --header-height: 64px;
  --header-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  --nav-link-hover: ;
  --nav-bg: #fff;
  --nav-overlay-bg: rgba(0, 0, 0, 0.5);
  --focus-outline: 2px solid var(--color-princ-programa);
  --transition: 0.2s cubic-bezier(.4, .2, .2, 1);
}

.main-fluid:has(#hero_banner_programas) {
  .main-content {
    .btn-primary {
      color: var(--color-block-programs);
      line-height: 1.2;
      background-color: white;
      border: 2px solid var(--color-block-programs);
      border-radius: 2rem;
      &:hover {
        color: white;
        background-color: var(--color-block-programs);
        &::after {content: none;}
      }
    }
    .btn-primary-solid {
      color: white;
      line-height: 1.2;
      background-color: var(--color-block-programs);
      border: 2px solid var(--color-block-programs);
      border-radius: 2rem;
      &:hover {
        color: var(--color-block-programs);
        background-color: white;
        &::after {content: none;}
      }
    }
    .c-programs {color: var(--color-block-programs);}
    .bg-programs {background: var(--color-block-programs);}
    .bg-gray-light {background-color: var(--c-gray-01);}
    ul.list-checked {
      padding-left: 0;
      list-style: none;
      li {
        list-style: none;
        position: relative;
        margin-bottom: 1rem;
        padding-left: 1.5rem;
        &::before {
          content: '\f00c';
          font-family: "Font Awesome 5 Free";
          font-weight: 900;
          color: var(--color-block-programs);
          background-image: none;
          width: auto;
          height: auto;
          position: absolute;
          top: 3px;
          left: 0;
        }
      }
    }
    .modal {
      .modal-content {
        background: white;
        width: 90%;
        max-width: 800px;
        border-radius: 0.75rem;
        overflow: hidden;
        transition: all 300ms ease;
        box-shadow: 0 20px 40px rgba(0, 0, 0, .3);
      }
      .modal-close {
        font-size: 2rem;
        color: white;
        background: none;
        border: none;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        padding: 0;
        border-radius: 50%;
        transition: background-color 200ms ease;
        position: absolute;
        top: 50%;
        right: 1.5rem;
        transform: translateY(-50%);
        &:hover {background-color: rgba(255, 255, 255, .2);}
      }
      .modal-btn-close {
        font-size: 1rem;
        font-weight: 500;
        color: white;
        background: var(--color-block-programs, #006d77);
        border: none;
        padding: .8rem 1.5rem;
        border-radius: 6px;
        cursor: pointer;
        transition: background-color 200ms ease;
        &:hover {background: color-mix(in srgb, var(--color-block-programs, #006d77) 80%, black);}
      }
      .modal-header, .modal-body, .modal-footer {padding: 1.5rem 2rem;}
      .modal-header {
        color: white;
        background: var(--color-block-programs, #006d77);
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: relative;
      }
      .modal-footer {
        padding-top: 0;
        border-top: none;
      }
    }
    p.degree-options__cta-wrapper strong.degree-options__cta {
      font-weight: 400;
      color: white;
      &::after {
        content: '\f105';
        color: currentColor;
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
        line-height: 1;
        width: 16px;
        height: 16px;
      }
      &:hover {color: var(--color-block-programs);}
    }
  }
}

.main-fluid:has(#hero_banner_programas) {
  .our-team {
    .section__title, .section__title-lg, .why-choose-us__title, .profile-list__title {
       strong {color: inherit;}
    }
  }
  .section__title, .section__title-lg, .why-choose-us__title, .profile-list__title {
    font-weight: 400;
    strong {
      color: var(--color-block-programs);
      font-weight: bold;
    }
  }
  .section__title {
    font-size: clamp(1.5rem, 5vw, 1.8rem);
    margin-bottom: 1rem;
    padding-bottom: 0;
  }
  .section__subtitle {
    font-size: clamp(1.1rem, 5vw, 1.3rem);
    font-weight: normal;
    display: block;
  }
  .section__title-lg, .why-choose-us__title, .profile-list__title {font-size: 1.75rem;}
  .why-choose-us__title {padding: 0 3%;}
}

.banner-financiacion {
  display: flex;
  justify-content: center;
  align-items: center;
}
.banner-financiacion a > picture, .banner-financiacion a > img {transition: 0.3s;}
.banner-financiacion a:hover > picture, .banner-financiacion a:hover > img {
  transform: scale(0.95);
  box-shadow: 3px 3px 10px #e3e3e3;
}
.rich-text-video, .why-choose-us__header, .section-planes, .degree-options__header, .profile-list__header,  .related-videos__title, .images-slider__title {
  h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
    strong, b {
      font-weight: 700;
      color: var(--color-block-programs);
    }
  }
}
.images-slider__title {padding-bottom: 0;}

/* Menu interno */
body:has(#site-header-plantilla-programas) header.header__sticky,
body:has(#site-header-plantilla-programas) .header__top,
body:has(#site-header-plantilla-programas) .main,
body:has(#site-header-plantilla-programas) .main-fluid {
  width: 100%;
  margin-top: 0;
  position: relative;
  top: 0;
}
body:has(#site-header-plantilla-programas) .header__mobile {
  background: #fff;
  position: fixed;
  top: 0px;
  height: 60px;
  width: 100vw;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  z-index: 6;
  max-width: 100vw;
}
body:has(#site-header-plantilla-programas) .header__bar {width: 100%;}
#site-header-plantilla-programas #btn_inscribirse_movil.site-header__link {display: none;}
#plantilla-programas-main .contenedor-banner-programas .etiqueta-header {
  font-size: 1.7rem;
  line-height: 1.5rem;
  background-color: var(--color-princ-programa);
  color: white;
  padding: 5px 10px;
  border-radius: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  height: fit-content;
}
#site-header-plantilla-programas.site-header {
  position: fixed;
  top: 60px;
  z-index: 5;
  background: var(--gris-negro);
  box-shadow: none;
  width: 100vw;
  transition: box-shadow var(--transition);
  background: var(--gris-negro);
  margin: 0;
}
#site-header-plantilla-programas.site-header--sticky {box-shadow: var(--header-shadow);}
#site-header-plantilla-programas .site-header__container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--header-height);
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}
#site-header-plantilla-programas .site-header__brand {
  display: flex;
  align-items: center;
  gap: 0.5em;
  text-decoration: none;
}
#site-header-plantilla-programas .site-header__brand-text {
  font-weight: bold;
  font-size: 1.25rem;
  color: var(--color-princ-programa);
  letter-spacing: 1px;
}
#site-header-plantilla-programas .site-header__nav {
  width: fit-content;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
#site-header-plantilla-programas .site-header__menu {
  display: flex;
  gap: 1.5em;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;

}
#site-header-plantilla-programas .site-header__link {
  display: inline-block;
  padding: 2px 8px;
  color: lightgray;
  text-decoration: none;
  font-size: 16px;
  border: none;
  background: none;
  transition: color var(--transition);
  position: relative;
  background: transparent;
  transition: all 100ms ease-in-out;
  text-align: center;
}
#site-header-plantilla-programas .site-header__link:hover,
#site-header-plantilla-programas .site-header__link:focus-visible {color: white;}
#site-header-plantilla-programas .site-header__link--active {
  background: var(--color-princ-programa);
  color: white;
  font-weight: bold;
  border-radius: 15px;
}
#site-header-plantilla-programas .site-header__link:hover::after,
#site-header-plantilla-programas .site-header__link:focus-visible::after {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0px;
  display: block;
  margin: 0 auto;
  width: 60%;
  height: 2px;
  background: white;
  border-radius: 2px;
  margin-top: 2px;
}
#site-header-plantilla-programas .site-header__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  padding: 0.5em;
  margin-left: 1em;
  border-radius: 4px;
  transition: background var(--transition);
}
#site-header-plantilla-programas .site-header__toggle:focus-visible {
  outline: var(--focus-outline);
  background: #f3f3f3;
}

#site-header-plantilla-programas .site-header__overlay {
  display: none;
}
#site-header-plantilla-programas #btn_inscribirse.site-header__link {
  background: var(--color-block-programs, var(--banner-2025-accent));
  color: white;
  font-weight: bold;
  border-radius: 15px;
  border: 2px solid white;
}
#site-header-plantilla-programas #btn_inscribirse.site-header__link::after {display: none;}
#site-header-plantilla-programas #btn_inscribirse.site-header__link--active {
  background: var(--color-princ-programa);
  color: white;
  font-weight: bold;
  border-radius: 15px;
}
#site-header-plantilla-programas.site-header {top: 50px; /* Default when at top */}
#site-header-plantilla-programas.site-header.site-header--scrolled {top: 60px; /* When scrolled */}

/* Estilos específicos para el banner de 2025 */
.text-black {color: var(--c-text);}
.container-default, .content-container-default {max-width: 1200px;}
.img-round img {border-radius: 0.5rem;}
#hero_banner_programas .banner-2025__image {
  object-position: center top;
  top: 0;
  left: 0;
  transform: none;
}
#hero_banner_programas .banner-2025__central {
  max-width: 1280px;
  #hero-banner-program, h2#hero-banner-program {
    font-size: 1.75rem;
    max-width: 100%;
  }
}
#hero_banner_programas .SeccionFormul .title-form {
  font-size: 120%;
  font-weight: 500;
  text-align: center;
  margin-bottom: 0.5rem;
}
#hero_banner_programas .SeccionFormul .form-item {margin-bottom: .25em;}
#hero_banner_programas .SeccionFormul .form-item__label {padding: 0;}
#hero_banner_programas .SeccionFormul .js-form-item-habeas-data {margin-top: 0 !important;}
#hero_banner_programas .form-card .SeccionFormul .form-actions .webform-button--submit {border: 2px solid var(--color-block-programs);}
#hero_banner_programas .form-card .SeccionFormul .form-actions {margin: 1rem 0 0;}
#hero_banner_programas .form-card .SeccionFormul .form-actions .webform-button--submit:hover {
  color: var(--color-block-programs);
  background-color: transparent;
  border-color: var(--color-block-programs);
}
.sec-info-legal__list > small {
  text-align: center;
  width: 100%;
}
.why-choose-us .why-choose-us__card-title {
  transition: all 150ms ease-in-out;
  margin: 0;
}
.why-choose-us .why-choose-us__card:hover .why-choose-us__card-title {transition-delay: 100ms;}
#sec-internacionalizacion .profile-list {padding: 20px 0;}
#sec-internacionalizacion .our-team__content {align-items: center;}
#sec-internacionalizacion .our-team {
  background: none;
  color: #323232;
}
#sec-internacionalizacion .our-team .text-long {
  font-size: 18px;
  color: var(--gris-textos);
}
#sec-internacionalizacion .boton-principal {
  display: flex;
  padding: 2px 8px;
  gap: 10px;
  background-color: var(--color-block-programs, #52c4b0);
  color: white;
  width: fit-content;
  border-radius: 100px;
  align-items: center;
  height: fit-content;
}
#sec-internacionalizacion .boton-principal:hover {
  background-color: white;
  color: var(--color-block-programs, #52c4b0);
  box-shadow: var(--color-block-programs, #52c4b0) 0px 1px 4px, var(--color-block-programs, #52c4b0) 0px 0px 0px 3px;
}
#sec-internacionalizacion .boton-principal i {color: white;}
#sec-internacionalizacion .boton-principal:hover i {color: var(--color-block-programs, #52c4b0);}
.rich-text-video {padding: 60px 2rem;}

.rich-text-video.rich-text-video__top, .rich-text-video__top .rich-text-video {padding-bottom: 1.25rem;}
.rich-text-video.rich-text-video__bottom, .rich-text-video__bottom .rich-text-video {padding-top: 0;}

.rich-text-video h2 {color: var(--c-text);}
.rich-text-video__text ul li, .rich-text-video__text ol li {
  font-size: 1.125rem;
  color: var(--c-text);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

.rich-text-video__text a:not(.btn) {color: var(--color-block-programs);}
.rich-text-video__text a:not(.btn):hover {
  color: var(--color-block-programs);
  filter: brightness(0.7);
}
.rich-text-video__text a::after {
  background: var(--color-block-programs);
}
.rich-text-video__text a:hover::after {
  filter: brightness(0.7);
}
.rich-text-video__text em, .rich-text-video__text i {color: var(--color-block-programs, #006d77);}
.why-choose-us {
  --why-choose-us-accent: var(--color-block-programs, #006d77);
  padding: 60px 0;
  background: var(--c-gray-01);
}
.sec-beneficios-secundarios {padding: 60px 0;}
.section-planes {
  padding: 30px 0;
  overflow: hidden;
}
.degree-options__top .degree-options__header {margin-bottom: 0;}
.degree-options__top .container-default, .degree-options__top .content-container-default {max-width: 1240px;}
.degree-options__bottom .degree-options, .degree-options__bottom .degree-options__inner {padding-top: 0;}
.degree-options__inner {padding: 30px 2.75rem;}
.degree-options__panel {
  border-radius: 0.5rem;
  overflow: hidden;
}
.our-team {
  background-color: #323232;
  padding: 60px 0;
  margin: 30px 0 0;
}
.our-team__image {box-shadow: none;}
.profile-modal__image-container {
  max-width: 500px;
  max-height: 300px;
}
.profile-modal__image {object-position: top;}
.profile-list {
  padding: 30px 0;
  background-color: #fff;
}
.profile-modal__body img {border-radius: 20px;}
.card-publicaciones {background: var(--c-gray-01);}
.card-publicaciones .grid__item {
  background: white;
  border-radius: 0.5rem;
  overflow: hidden;
}
.card-publicaciones .card-logo {
  width: 100%;
  max-width: none;
  padding: 0;
}
.card-publicaciones .card-logo .embed-container {
  width: 100%;
  height: clamp(145px, 50vw + 70px, 483px);
  padding: 0;
}
.card-publicaciones .card-logo__heading {
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: #333;
  text-align: left;
  padding-right: 1rem;
  padding-left: 1rem;
}
.card-publicaciones .card-logo__heading-link {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}
.main-fluid:has(#hero_banner_programas) a.card-logo__heading-link {font-family: inherit;}
.card-publicaciones .card-logo__link {
  font-weight: normal;
  color: var(--color-block-programs);
  float: initial;
  border: 2px solid var(--color-block-programs);
  border-radius: 3rem;
  right: auto;
  bottom: 1rem;
  left: 1rem;
}
.card-publicaciones .card-logo__link::after {
  color: var(--color-block-programs);
  content: '\f054';
}
.card-publicaciones .card-logo__link:hover {
  color: white;
  background-color: var(--color-block-programs);
}
.card-publicaciones .card-logo__link:hover::after {color: white;}
.plan-de-estudios-menores .footnote {font-size: 80%;}
.plan-de-estudios-menores .accordion-item {
  background-color: initial;
  border: none;
  margin-bottom: 0.5rem;
}
.plan-de-estudios-menores .accordion-item__content .accordion-header .accordion-button {
  color: var(--plan-color, var(--color-block-programs, green));
  background-color: white;
  margin-bottom: 0;
  border: 2px solid var(--plan-color, var(--color-block-programs, green));
  border-radius: 0.5rem;
}
.plan-de-estudios-menores .accordion-item__content .accordion-header .accordion-button h2 {font-size: 1.2rem;}
.plan-de-estudios-menores .accordion-item__content .accordion-header .accordion-button .fa-angle-down:before {
  display: block;
  transition: 0.5s;
  transform: rotate(-90deg);
}
.plan-de-estudios-menores .accordion-item__content .accordion-header .accordion-button:not(.collapsed) {
  color: white;
  background-color: var(--plan-color, var(--color-block-programs, green));
}
.plan-de-estudios-menores .accordion-item__content .accordion-header .accordion-button:not(.collapsed) .fa-angle-down:before {transform: rotate(0deg);}
.plan-de-estudios-menores .accordion-body {background-color: white;}
.plan-de-estudios-menores .planes-semestre {box-shadow: 0 0 5px #00000030;}
.plan-de-estudios-menores .planes-semestre .planes-semestre__row {background-color: #FFF;}
.plan-de-estudios-menores .planes-semestre .planes-semestre__row:hover {
  background-color: var(--plan-color, var(--color-block-programs, green));
  cursor: initial;
}
.plan-de-estudios-menores .planes-semestre__group-inner {
  background-color: #EFEFEF;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--c-gray-03);
  border-radius: 0.5rem;
}
.plan-de-estudios-menores .planes-semestre__group-inner p {
  width: 100%;
  margin-bottom:0;
}

@media screen and (max-width: 1200px) {
  #plantilla-programas-main #site-header-plantilla-programas.site-header {
    position: fixed;
    background: var(--gris-negro);
    display: flex;
    width: fit-content;
    right: 0;
    padding: 0;
  }
  #plantilla-programas-main #site-header-plantilla-programas .site-header__container {
    padding: 0;
    max-width: 0;
  }
  #plantilla-programas-main #site-header-plantilla-programas .site-header__toggle {margin: 0;}
  #site-header-plantilla-programas #btn_inscribirse_movil.site-header__link {display: none;}
  #site-header-plantilla-programas.site-header {background: transparent;}
  #site-header-plantilla-programas .site-header__toggle {background: var(--gris-negro);}
  body:has(#site-header-plantilla-programas) .header__mobile {position: relative;}
  #plantilla-programas-main .contenedor-banner-programas .etiqueta-header {
    font-size: 1rem;
    line-height: 1rem;
    background-color: white;
    color: var(--color-princ-programa);
    padding: 3px 8px;
    border-radius: 100px;
    margin-bottom: 15px;
  }
  #site-header-plantilla-programas.site-header {top: 40px;}
  #site-header-plantilla-programas .site-header__menu {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 15px;
    position: fixed;
    top: var(--header-height);
    right: 0;
    background: var(--nav-bg);
    box-shadow: var(--header-shadow);
    transform: translateX(100%);
    opacity: 1;
    visibility: hidden;
    padding: 1.5em 1rem;
    z-index: 101;
    width: 80%;
    height: 100vh;
    max-height: 100vh;
  }
  #site-header-plantilla-programas .site-header__link {
    color: var(--gris-textos);
    font-size: 1rem;
  }
  #site-header-plantilla-programas .site-header__link--active {color: white;}
  #site-header-plantilla-programas .site-header__nav[aria-expanded="true"] .site-header__menu {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
    top: 0;
  }

  #site-header-plantilla-programas .site-header__toggle {display: inline-flex;}
  #site-header-plantilla-programas .site-header__nav {position: static;}
  #site-header-plantilla-programas .site-header__overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: var(--nav-overlay-bg);
    opacity: 0;
    visibility: hidden;
    z-index: 100;
    transition: opacity var(--transition);
  }
  #site-header-plantilla-programas .site-header__nav[aria-expanded="true"]~.site-header__overlay {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    cursor: pointer;
  }
  #site-header-plantilla-programas .site-header__container {
    margin: 0;
    padding: 0;
    width: fit-content;
  }
  #site-header-plantilla-programas.site-header {
    width: fit-content;
    right: 25px;
  }
  #site-header-plantilla-programas .site-header__link:hover {color: var(--color-block-programs, var(--banner-2025-accent));}
}
@media screen and (max-width: 768px) {
  .section-planes {overflow-x: hidden;}
  .section-planes__left {
    min-width: 0;
    margin: 0 auto;
    width: 100%;
  }
}

@media (min-width: 576px) {
  .main-fluid:has(#hero_banner_programas) .section__title {font-size: clamp(1.8rem, 4vw, 2.2rem);}
  .main-fluid:has(#hero_banner_programas) .section__subtitle {font-size: 1.4rem;}
}
@media (min-width: 768px) {
  .main-fluid:has(#hero_banner_programas) .section__title-lg, .why-choose-us__title, .profile-list__title {font-size: 2.25rem;}
  #hero_banner_programas .banner-2025__central {
    #hero-banner-program, h2#hero-banner-program {
      font-size: 2.5rem;
      max-width: 66%;
    }
  } 
  .card-publicaciones .card-logo .embed-container {height: clamp(147px, 10vw + 60px, 252px);}
}
@media (min-width: 1200px) {
  .main-fluid:has(#hero_banner_programas) {
    .section__title-lg, .why-choose-us__title, .profile-list__title {font-size: 2.5rem;}
    .why-choose-us__title {padding: 0;}
  }
  #hero_banner_programas .banner-2025__central {
    #hero-banner-program, h2#hero-banner-program {font-size: 3rem;}
  } 
  #site-header-plantilla-programas .site-header__menu {
    flex-direction: row;
    position: static;
    background: none;
    box-shadow: none;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    padding: 0;
  }
  #site-header-plantilla-programas .site-header__toggle,
  #site-header-plantilla-programas .site-header__overlay {display: none !important;}
}
@media (min-width: 1400px) {
  .card-publicaciones .card-logo .embed-container {height: 252px;}
}
@media (prefers-reduced-motion: reduce) {
  #site-header-plantilla-programas.site-header,
  #site-header-plantilla-programas .site-header__menu,
  #site-header-plantilla-programas .site-header__overlay {transition: none !important;}
}