body{
	/*line-height: 1.5;*/
	font-family: 'Poppins', sans-serif;
	font-weight: 400;
	overflow-x: hidden;
	height: 100vh;
	background: var(--color-fondo);
	text-align: justify !important;
}
:root{
	--color-blanco: #fff;
	--color-hover: #c29e50;
	--color-letras: #000;
	--color-letras-blanco: #fff;
  --color-letras-contenido: #fff;
  --color-principal: #335a96;
	--color-secundario: #202c56;
	--color-terciario: #c29e50;
  --color-cuarto: #1885c2;
	--color-fondo: #f3f3f3;
	--letras-menu: 1rem;
	--letras-contenido: 1rem;
	--letras-titulos: 2rem;
  --color-exito: #00ff62;
  --color-fail: #ff0000;
  --color-ipn: #78003c;
  --color-unam: #1E264E;
  --color-uam: #195707;
}

/* Lo agregue para que se acomodaran los menus en todas las pantallas*/
ol, ul {
  list-style: none;
  padding: 0 !important;
}

p{
  line-height: 1.5rem;
}
/* Container de registro **/
.p-5 {
  position: relative;
  z-index: -99;
  color: transparent;
}

/* Prelaoder */
#preloader {
	position: fixed;
	left: 0;
	top: 0;
	z-index: 999;
	width: 100%;
	height: 100%;
	overflow: visible;
	background: #fff url("../img/preloader/preload.svg") no-repeat center center;
  }


.logo {
	width: 90px;
	height: 80px;
  padding: .5rem;
  /*object-fit: cover;*/
}


/** 05.01 Header */
ol,
ul {
  list-style: none;
/*   padding: 0 !important; */
}
.header-main {
  padding: 0px 0;
  transition: all 0.4s;
  background-color: #fff;
  box-shadow: -1px 0px 15px 0px rgba(0,0,0,0.75);
  -webkit-box-shadow: -1px 0px 15px 0px rgba(0,0,0,0.75);
  -moz-box-shadow: -1px 0px 15px 0px rgba(0,0,0,0.75);
  position: fixed;
  z-index: 99;
  width: 100%;
  top: 0;
}

.is-transparent .header-main,
.has-fixed .header-main {
  width: 100%;
  z-index: 999;
}

.is-transparent .header-main {
  position: absolute !important;
}

.has-fixed .header-main {
  position: fixed !important;
  box-shadow: 0 0 20px 0 rgba(18, 24, 58, 0.08);
}

.has-fixed:not(.is-dark) .header-main {
  background: #fff;
}

.has-fixed.is-dark .header-main {
  background: #08103b;
}

.has-fixed.is-shrink .header-main {
  padding: 8px 0;
}

.header-container:not(.container) {
  width: 100%;
  padding: 0 40px;
}

.header-wrap {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}



.header-navbar {
  position: fixed;
  left: -280px;
  top: 0;
  width: 260px;
  height: 100vh;
}

.header-navbar.menu-mobile {
  transition: all 0.4s;
}

.header-navbar::before,
.header-navbar-overlay {
  position: absolute;
  height: 100%;
  width: 100%;
  content: "";
  top: 0;
}

.header-navbar::before {
  background: #fff;
  left: 50%;
  transform: translateX(-50%);
  transition: all 0.4s;
}

.is-dark .header-navbar::before {
  background: #0f1f71;
}

.header-navbar-overlay {
  background: rgba(12, 25, 90, 0.7);
  left: 100%;
  width: 0;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s;
  transition-delay: 0.2s;
}

.header-navbar.menu-shown {
  left: 0 !important;
  z-index: 10;
}

.header-navbar.menu-shown .header-navbar-overlay {
  width: 100vw;
  opacity: 1;
  visibility: visible;
}

.header-navbar-classic {
  position: absolute;
  top: 99%;
  right: 0;
  left: 0;
  width: 100%;
  height: auto;
  background: transparent;
  margin-top: 12px;
  z-index: auto;
  flex-grow: 1;
  transition: all 0.4s;
  padding: 0 20px;
}

.has-fixed .header-navbar-classic {
  margin-top: -6px;
  padding: 0;
}

.header-navbar-classic:before {
  border-radius: 4px;
}

.has-fixed .header-navbar-classic:before {
  width: 100vw;
  border-radius: 0;
}

.header-navbar-s1 {
  flex-grow: 1;
}

.header-menu {
  justify-content: flex-end;
  padding: 30px 25px;
}

.header-navbar-classic .header-menu {
  padding: 0;
}

.header-banner {
  min-height: 72px;
}

.overlay-menu-shown {
  overflow: hidden;
}

.overlay-menu-shown .has-fixed > .header-main {
  z-index: 6;
}

@media (min-width: 375px) {
  .header-navbar:not(.header-navbar-classic) {
    left: -310px;
    width: 290px;
    /* top para alinear el menu */
    /*top: 7px;*/
  }
}

@media (min-width: 576px) {
  .header-navbar:not(.header-navbar-classic) {
    left: -360px;
    width: 340px;
  }
}



@media (min-width: 992px) {
  .header-navbar:not(.header-navbar-classic) {
    height: auto;
    width: auto;
    left: 0;
  }
  .header-main {
    padding: 0rem 0 0 0;
  }
  .header-nav-toggle {
    display: none;
  }
  .header-container:not(.container) {
    padding: 0 120px;
  }
  .header-container-s1:not(.container) {
    padding: 0 120px;
  }
  .header-banner {
    min-height: 98px;
  }
}

@media (min-width: 1200px) {
  .header-container:not(.container) {
    padding: 0 120px;
  }
  .header-container-s1:not(.container) {
    padding: 0 120px;
  }
}

.header-menu {
  max-height: 100vh;
  overflow: hidden;
  overflow-y: auto;
  height: 100%;
}

.header-navbar-classic .header-menu {
  display: none;
  max-height: 65vh;
}


.header-navbar-classic .header-menu.menu-shown {
  display: block;
}


.header-nav-toggle {
  height: 44px;
}

.language-switcher .toggle-tigger,
.header-menu .btn-outline:not(:hover) {
  color: #415076;
}

.is-light .language-switcher .toggle-tigger,
.language-switcher .toggle-tigger .is-transparent:not(.is-dark),
.is-light .header-menu .btn-outline:not(:hover),
.header-menu .btn-outline:not(:hover) .is-transparent:not(.is-dark) {
  color: #415076;
}

.tc-light .language-switcher .toggle-tigger,
.tc-light .btn-outline:not(:hover),
.is-dark .language-switcher .toggle-tigger,
.is-dark .btn-outline:not(:hover) {
  color: #fff;
}

@media (min-width: 992px) {
  .tc-light .header-menu .language-switcher .toggle-tigger,
  .tc-light .header-menu .btn-outline:not(:hover),
  .is-transparent .header-menu .language-switcher .toggle-tigger,
  .is-transparent .header-menu .btn-outline:not(:hover),
  .is-transparent:not(.has-fixed):not(.is-light)
    .header-menu
    .language-switcher
    .toggle-tigger,
  .is-transparent:not(.has-fixed):not(.is-light)
    .header-menu
    .btn-outline:not(:hover),
  .is-dark .header-menu .language-switcher .toggle-tigger,
  .is-dark .header-menu .btn-outline:not(:hover) {
    color: #fff;
  }
  .is-split:not(.has-fixed):not(.is-light)
    .header-menu
    .btn-outline:not(:hover) {
    color: #415076;
  }
  .has-fixed:not(.is-dark)
    .header-menu
    .language-switcher
    .toggle-tigger:not(.btn),
  .has-fixed:not(.is-dark) .header-menu .btn-outline:not(:hover),
  .is-light .header-menu .language-switcher .toggle-tigger:not(.btn),
  .is-light .header-menu .btn-outline:not(:hover) {
    color: #415076;
  }
  .is-transparent:not(.has-fixed):not(.is-light)
    .header-menu
    .btn-outline:not(:hover):not(.no-change) {
    border-color: rgba(255, 255, 255, 0.4);
  }
  .is-transparent:not(.has-fixed):not(.is-light)
    .header-menu
    .btn:not(:hover):not(.no-change):not(.btn-outline) {
    border-color: #fff;
    background: #fff;
    color: #415076;
  }
  .is-transparent:not(.has-fixed):not(.is-light)
    .header-menu
    .btn-outline:not([class*="btn-grad"]):not(.no-change):hover {
    color: #16a3fe !important;
    border-color: #fff;
    background-color: #fff;
  }
}

@media (max-width: 991px) {
  .header-menu .language-switcher-s1,
  .header-menu .language-switcher-s4 {
    width: 100%;
  }
    /* Imagen despues de letras  en responsive*/
    
    .menu-icon {
      display: none;
      max-width: 25px;
    }
    .menu-icono {
      cursor: pointer;
    }
  .header-menu .language-switcher .toggle-tigger:not(.btn) {
    padding-left: 0;
  }
  .has-rtl .header-menu .language-switcher .toggle-tigger:not(.btn) {
    padding-left: 15px;
    padding-right: 0;
  }
  .header-menu .btn {
    line-height: 24px;
    padding: 6px 14px;
    min-width: 100px;
  }
  .header-menu .btn-transparent {
    padding: 6px 0;
  }
}

/** 05.02 Menu */
.menu {
  padding: 12px 0;
}



.menu-item {
  position: relative;
  border-bottom: 1px solid rgba(219, 228, 247, 0.75);
}

.is-dark .menu-item {
  border-color: rgba(219, 228, 247, 0.1);
}

.menu-item:last-child {
  border-bottom: 0;
}

.menu-item > ul,
.menu-item .menu-sub {
  display: none;
}

/*** ES aqui ***/
.menu-item a {
  font-size: 1rem;
  line-height: 18px;
  color: var(--color-letras);
  padding: 12px 0;
  display: block;
  position: relative;
  z-index: 999;
  cursor: pointer;
}

.header-menu-s2 .menu-item a {
  font-size: 1rem;
}

.menu-item a .badge {
  margin-left: 5px;
  position: relative;
  top: -1px;
}

.menu-item a .badge-dot {
  top: 0;
}

.menu-item a .active,
.menu-item a:hover {
  color: #16a3fe !important;
}

.is-dark .menu-item a .active,
.is-dark .menu-item a:hover {
  color: #16a3fe;
}

.menu-s2 > .menu-item > a {
  font-size: 1rem;
  text-transform: uppercase;
  font-weight: 500;
}

.menu-sub {
  padding-left: 12px;
}

.menu-sub .menu-item:first-child {
  border-top: 1px solid rgba(219, 228, 247, 0.75);
}

.is-dark .menu-sub .menu-item:first-child {
  border-color: rgba(219, 228, 247, 0.1);
}

.menu-sub .menu-sub {
  margin-top: 0;
  margin-bottom: 15px;
}

.menu-sub .menu-sub .menu-item {
  border-bottom: none;
}

.menu-sub .menu-sub .menu-item:first-child {
  border-top: none;
}

.menu-sub .menu-sub .menu-item a {
  padding-top: 6px;
  padding-bottom: 6px;
}

.menu-sub a {
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  color: #415076;
}

.menu-mega a {
  font-family: "Roboto", sans-serif;
  font-size: 1rem;
  color: #415076;
}

.is-dark .menu-item a {
  color: #fff;
}

.menu-item > a.active {
  color: #1ec500;
}

.has-sub > a {
  position: relative;
}

.has-sub > a:after {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
content: "\e64b";
  font-family: "themify"; 
    content: "\f107";
      font-family: "Font Awesome 5 Free"; 
  font-weight: 900; 
  font-size: 8px;
  font-weight: 700;
  transition: transform 0.4s;
}

.has-sub.open-nav > a:after {
  transform: translateY(-50%) rotate(-180deg);
}

.navbar-toggle {
  width: 44px;
  height: 44px;
  text-align: center;
  display: inline-block;
  border-radius: 50%;
  padding: 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}

.navbar-toggle.navbar-active {
  color: #16a3fe;
  position: relative;
  z-index: 49;
}

.navbar-toggle:hover,
.navbar-toggle.navbar-active {
  background: rgba(246, 250, 253, 0.2);
}

.is-transparent:not(.has-fixed) .navbar-toggle {
  color: #321f1f;
}

.is-transparent:not(.has-fixed) .navbar-toggle:hover,
.is-transparent:not(.has-fixed) .navbar-toggle.navbar-active {
  background: rgba(246, 250, 253, 0.2);
}

.toggle-line {
  position: relative;
  width: 32px;
  height: 32px;
  /*display: block;*/
  color: #415076;
}

.toggle-line:hover {
  color: #415076;
}

.is-transparent:not(.has-fixed):not(.is-light) .toggle-line {
  color: #fff;
}

.is-dark.has-fixed .toggle-line {
  color: #fff;
}

.toggle-line::after,
.toggle-line::before,
.toggle-line > span {
  content: "";
  position: absolute;
  background: currentColor;
  transition: all 0.2s;
  width: 24px;
  height: 2px;
  left: 4px;
  border-radius: 3px;
}

.toggle-line::before {
  top: 8px;
}

.toggle-line::after {
  bottom: 8px;
}

.toggle-line > span {
  top: 50%;
  margin-top: -1px;
  width: 20px;
}

.navbar-active .toggle-line {
  color: #fff;
}

.navbar-active .toggle-line::before,
.navbar-active .toggle-line::after {
  width: 28px;
  left: 2px;
}

.navbar-active .toggle-line::before {
  transform: rotate(45deg);
  top: 15px;
}

.navbar-active .toggle-line::after {
  transform: rotate(-45deg);
  bottom: 15px;
}

.navbar-active .toggle-line > span {
  opacity: 0;
  visibility: hidden;
}

.secondary-navbar {
  box-shadow: 0px 5px 40px rgba(65, 80, 118, 0.1);
  padding: 15px 0;
}

.secondary-menu-list {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-wrap: wrap;
}

.secondary-menu-item {
  width: 50%;
}

.secondary-menu-link {
  padding: 5px 16px;
  display: inline-block;
  color: #415076;
  font-weight: 400;
  position: relative;
}

.secondary-menu-link:after {
  position: absolute;
  content: "";
  left: 50%;
  bottom: 0;
  width: 0;
  height: 3px;
  background: #23c99d;
  transform: translateX(-50%);
  transition: 0.3s;
  transform-origin: left;
  border-radius: 50%;
}

.secondary-menu-link:hover {
  color: currentColor;
}

.secondary-menu-link:hover:after {
  width: 3px;
}

.secondary-menu-item.active .secondary-menu-link {
  color: currentColor;
}

.secondary-menu-item.active .secondary-menu-link:after {
  width: 3px;
}

@media (min-width: 425px) {
  .secondary-menu-item {
    width: auto;
  }
  .secondary-menu-link {
    padding: 20px 16px;
    width: auto;
  }
  .secondary-navbar {
    padding: 0;
    display: block;
  }
  .secondary-menu-list {
    flex-wrap: nowrap;
  }
  .secondary-menu-link:after {
    border-radius: 0;
  }
  .secondary-menu-link:hover {
    color: currentColor;
  }
  .secondary-menu-link:hover:after {
    width: 25px;
  }
  .secondary-menu-item.active .secondary-menu-link {
    color: currentColor;
  }
  .secondary-menu-item.active .secondary-menu-link:after {
    width: 25px;
  }
}

@media (min-width: 576px) {
  .secondary-menu-item {
    width: auto;
  }
  .secondary-menu-link {
    padding: 20px 28px;
    width: auto;
  }
}

@media (min-width: 992px) {
  .header-menu {
    display: flex !important;
    width: auto;
    align-items: center;
    position: static;
    background: transparent;
    padding: 0;
    margin: 0;
    border-radius: 0;
    overflow: visible;
  }
  .header-navbar {
    padding: 0 0 0 15px;
    margin-top: 0;
    position: relative;
  }
  .header-navbar:before {
    display: none;
  }
  .has-fixed .header-navbar {
    margin-top: 0;
  }
  .menu {
    display: flex;
    align-items: center;
    padding: 0;
  }
  .menu-item {
    border-bottom: none;
  }
  .menu-item > a {
    font-weight: 400;
    padding: 20px 10px;
  }
  .menu-drop .menu-item > a {
    font-weight: 300;
  }
  .menu-item:hover {
    z-index: 99;
  }
  .menu-sub {
    position: absolute;
    min-width: 215px;
    max-width: 215px;
    background: #fff;
    padding: 15px 10px;
    top: 100%;
    left: 0;
    display: block !important;
    z-index: 99;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s;
    border-radius: 4px;
    transform: translateX(0) translateY(-8px);
    box-shadow: 0 3px 12px 0 rgba(18, 24, 58, 0.08);
  }
  .menu-sub a {
    width: 100%;
    display: block;
    padding: 10px 10px;
  }
  .menu-sub .menu-item:first-child {
    border-top: none;
  }
  .menu-sub .menu-item:hover > a {
    color: #16a3fe;
  }
  .menu-item:hover > .menu-sub {
    opacity: 1;
    visibility: visible;
    transform: translateX(0) translateY(0);
  }
  .menu-sub .menu-sub {
    left: calc(100% - 25px);
    top: 15px;
    margin: 0;
  }
  .menu-sub .menu-sub .menu-item a {
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .is-dark .menu-sub {
    background-color: #1d4bcf;
  }

  /* Aqui se cambian las opciones del menu despegable*/
  .menu-mega {
    /* Ancho del menu despegable*/
    width: 290px;
    position: absolute;
    left: 50%;
    background: #fff;
    padding: 15px 10px;
    top: 100%;
    display: block !important;
    z-index: 99;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s;
    border-radius: 4px;
    box-shadow: 0 3px 12px 0 rgba(18, 24, 58, 0.08);
    transform: translateX(-50%) translateY(-8px);
  }

  /* Imagen despues de letras */
  .menu-icon {
    max-width: 25px;
    vertical-align: middle;
    right: 0 !important;
  }

  /* Imagen despues de letras */
  .menu-icono {
    max-width: 25px;
    vertical-align: middle;
    right: 0 !important;
  }

  .menu-item:hover > .menu-mega {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
  }
  .menu-mega .menu-item a {
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .menu-mega-innr {
    display: flex;
  }
  .menu-mega-innr > div,
  .menu-mega-innr ul {
    flex-grow: 1;
  }
  .menu-mega-2clmn .menu-mega-innr > div,
  .menu-mega-2clmn .menu-mega-innr ul {
    width: 50%;
  }
  .menu-mega-1clmn {
    min-width: 200px;
    max-width: 300px;
  }
  .menu-mega-2clmn {
    min-width: 370px;
    max-width: 370px;
  }
  .is-dark .menu-mega {
    background-color: #1d4bcf;
  }
  .menu-btns {
    display: flex;
    margin-bottom: -10px;
    margin-left: 10px;
  }
  .menu-btns-s3 {
    margin-left: 0;
  }
  .has-sub > a {
    padding-right: 24px !important;
    position: relative;
  }
  .has-sub > a:after {
    right: 8px;
  }
  .menu-sub .has-sub > a {
    padding-right: 35px;
  }
  .menu-sub .has-sub > a:after {
    transform: translateY(-50%) rotate(-90deg);
    right: 15px;
  }
   .has-sub.menu-item:last-child .menu-sub:not(.menu-mega) .menu-item > a {
    padding-right: 20px !important;
    padding-left: 35px;
  }
   .has-sub.menu-item:last-child
    .menu-sub:not(.menu-mega)
    .menu-item
    > a:after {
    transform: translateY(-50%) rotate(90deg);
    left: 15px;
    right: auto;
  }
   .has-sub.menu-item:last-child .menu-mega {
    left: auto;
    right: 0;
    transform: translateX(0) translateY(-8px);
  }
   .has-sub.menu-item:last-child:hover .menu-mega {
    transform: translateX(0) translateY(0);
  }
  .is-transparent:not(.has-fixed):not(.is-light) .menu > .menu-item > a {
    color: #fff;
  }
  .is-transparent:not(.has-fixed):not(.is-light) .menu > .menu-item:hover > a {
    color: #16a3fe;
  }
  .secondary-navbar {
    padding: 0;
    display: block;
  }
  .secondary-menu-link {
    padding: 20px 38px;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .header-navbar-s1 .menu > .menu-item > a {
    padding: 20px 4px;
    font-size: 12px;
    font-weight: 500;
  }
  .menu-btns > li {
    padding: 6px;
  }
  .menu-btns .btn {
    font-size: 13px;
    line-height: 20px;
    padding: 10px 15px;
    min-width: 0;
  }
  .menu-btns .btn.btn-grad {
    padding: 12px 15px;
  }
  .menu-btns .btn-md {
    font-size: 11px;
    line-height: 19px;
    padding: 8px 16px;
  }
  .menu-btns .btn-md.btn-grad {
    padding: 10px 16px;
  }
}

@media (min-width: 1200px) {
  .menu > .menu-item > a {
    padding: auto 15px;
    z-index: 99;
  }
  
  .header-navbar-s1 .menu > .menu-item > a {
    padding: 20px 8.5px;
    font-size: 12px;
    font-weight: 500;
  }
  .menu-s2 > .menu-item > a {
    padding-left: 7.5px;
    padding-right: 7.5px;
  }
  .menu-item.has-sub > a {
    padding-right: 23px !important;
  }
  .menu-item.has-sub > a:after {
    right: 8px;
  }
  .menu-sub a {
    padding: 10px 15px;
  }
  .secondary-menu-link {
    padding: 20px 45px;
  }
  
}

@media (min-width: 1600px) {
  .header-navbar-s1 .menu > .menu-item > a {
    font-size: 14px;
  }
  .header-menu-s2 .menu > .menu-item > a {
    padding: 20px 30px;
  }
  
}

.menu-btns {
/*     margin-bottom: 26px; */
  margin-bottom: 8px;
    margin-left: -10px;
    margin-right: -10px;
    margin-top: -10px;
    display: flex;
    flex-wrap: wrap;
}
@media (min-width: 992px) {
.menu-btns {
    display: flex;
/*     margin-bottom: -10px;
    margin-left: 10px; */
}
}
.menu-btns > li {
    padding: 10px;
    padding: 10px;
}
@media (min-width: 992px) and (max-width: 1199px) {
.menu-btns > li {
    padding: 6px;
}
  }
.btn-grad {
    border: none;
    background-image: linear-gradient(to right, #16a3fe 0%, #23c99d 100%);
}
.btn {
    position: relative;
    font-size: 12px;
    line-height: 24px;
    font-weight: 500;
    padding: 8px 15px;
    text-align: center;
    text-transform: uppercase;
    color: #fff !important;
    min-width: 120px;
    max-width: 100%;
    /*border: 2px solid #16a3fe;*/
    box-sizing: border-box;
    transition: all 0.5s;
    position: relative;
    border-radius: 5px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    cursor: pointer !important;
}

.btn:hover{
transform: scale(1.08);
cursor: pointer;
}

.btn-md {
    font-size: 12px;
    line-height: 24px;
    padding: 10px 26px;
}
.btn-auto {
    min-width: 44px !important;
}
@media (min-width: 576px) {
.btn {
    font-size: 13px;
    line-height: 25px;
    padding: 12px 30px;
    letter-spacing: 0.1em;
    min-width: 120px;
}
}
@media (min-width: 576px) {
.btn-md {
    font-size: 12px;
    line-height: 24px;
    padding: 8px 20px;
    min-width: 160px;
}
}
a:link, a:visited {
    text-decoration: none;
}
.btn-grad:before {
    position: absolute;
    left: 0;
    top: 0;
    content: "";
    width: 100%;
    height: 100%;
    z-index: -2;
    border-radius: 5px;
    opacity: 0;
    transition: all .5s;
    background-image: linear-gradient(to right, #23c99d 0%, #16a3fe 100%);
}
.btn span {
    position: relative;
    z-index: 999999;
    display: block;
}
.btn-grad:hover, .btn-grad:focus {
    color: #fff !important;
}


li {
    color: #000 !important;
}







.banner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
  max-width: 1100px;
  width: 90%;
  height: 35vh;
  margin: 6.5rem auto 0 auto;
  border-radius: 15px;
  overflow: hidden;
  /*background: linear-gradient(to bottom, #041ba09b , #343434e5);*/
}

.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.7; 
}
/*
.border {
  width: 50%;
  margin: 0 auto;
  height: 5px;
  border: 5px solid #fff;
  border-bottom: 0;
  z-index: 99;
}*/
.banner h2 {

  margin: 1rem;
  font-size: 2rem;
  color: #FFFFFF;
  font-weight: 300;
  text-align: center;
  z-index: 7;
  letter-spacing: 0.5em;
  padding: 0.5em 0 0 0;
}

.banner p {
color: #FFFFFF;
font-size: 1rem;
font-weight: bold;
margin: 1em 0 0 0;
line-height: 2em;
letter-spacing: 2px;
padding: 0 0 2em 0;
margin-top: 1rem;
z-index: 7;
}
/*
.border-bottom {
  border-top: 0;
  border-bottom: 2px solid #fff !important;
  z-index: 99;
}*/



/*** Tarjetas ****/
.col-md-4{
  cursor: pointer;
  transition: ease-in .2s;
  }
  
.col-md-4:hover{
  cursor: pointer;
  transition: ease-in .2s;
  /*transform: translateY(-10px);*/
  }
    





  

/*** Footer ***/

.site-footer
{
  background-color:var(--color-principal);
  padding:45px 0 20px;
  font-size:15px;
  line-height:24px;
  color: var(--color-blanco) !important;
}
.site-footer hr
{
  border-top-color:#bbb;
  opacity:0.5
}
.site-footer hr.small
{
  margin:20px 0
}
.site-footer h6
{
  color:var(--color-terciario);
  font-size:1.2rem;
  /*text-transform:uppercase;*/
  margin-top:5px;
  font-weight: 700;
}
.site-footer a
{
  color:var(--color-hover);
}
.site-footer a:hover
{
  color:#3366cc;
  text-decoration:none;
}
.footer-links
{
  padding-left:0;
  list-style:none
}
.footer-links li
{
  display:block
}
.footer-links a
{
  color:var(--color-letras-blanco);
  transition: ease-in .2s;
}
.footer-links a:active,.footer-links a:focus,.footer-links a:hover
{
  color:var(--color-hover);
  text-decoration:none;
  transition: ease-in .2s;
}
.footer-links.inline li
{
  display:inline-block
}

/*
.site-footer .social-icons
{
  text-align:right
}

*/
.site-footer .social-icons a{
  width:40px;
  height:40px;
  line-height:40px;
  margin-left:6px;
  margin-right:0;
  border-radius:100%;
  background-color:#33353d;
}



.copyright-text
{
  margin:0;
  color: var(--color-blanco) !important;
}
@media (max-width:991px)
{
  .site-footer [class^=col-]
  {
    margin-bottom:30px
  }
}
@media (max-width:767px)
{
  .site-footer
  {
    padding-bottom:0
  }
  .site-footer .copyright-text,.site-footer .social-icons
  {
    text-align:center
  }
}
.social-icons
{
  padding-left:0;
  margin-bottom:0;
  list-style:none
}

.social-icons li{
  display:inline-block;
  margin-bottom:4px
}

.social-icons li.title
{
  margin-right:15px;
  text-transform:uppercase;
  color:var(--color-blanco);
  font-weight:700;
  font-size:13px
}
.social-icons a{
  background-color:#eceeef;
  color:#818a91;
  font-size:1.2rem;
  display:inline-block;
  line-height:44px;
  width:44px;
  height:44px;
  text-align:center;
  margin-right:8px;
  border-radius:100%;
  -webkit-transition:all .2s linear;
  -o-transition:all .2s linear;
  transition:all .2s linear
}
.social-icons a:active,.social-icons a:focus,.social-icons a:hover
{
  color:#fff;
  background-color:#29aafe
}
.social-icons.size-sm a
{
  line-height:34px;
  height:34px;
  width:34px;
  font-size:14px
}
.social-icons a.facebook:hover
{
  background-color:#3b5998
}
.social-icons a.whatsapp:hover
{
  background-color:#00ed9a
}
.social-icons a.tiktok:hover
{
  background-color:#0a0a0a
}
.social-icons a.dribbble:hover
{
  background-color:#ea4c89
}
@media (max-width:767px)
{
  .social-icons li.title
  {
    display:block;
    margin-right:0;
    font-weight:600
  }
}


/* <!-- About Section Start --> */
@media only screen and (min-width: 992px) and (max-width: 1199px) {
.section-padding {
  padding-top: 100px;
  padding-bottom: 100px;
}
.section-padding {
  padding-top: 100px;
  padding-bottom: 100px;
}
}
.section,
.main-wrapper {
  float: left;
  width: 100%;
}
.learts-mb-n30 {
  margin-bottom: -30px;
}
.learts-mb-30 {
  margin-bottom: 30px;
}
.about-us3 .sub-title {
  font-size: 18px;
  font-weight: 500;
  display: block;
  margin-bottom: 20px;
  color: #333;
}
.about-us3 .title {
  font-size: 40px;
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 20px;
}
/*
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 600;
  line-height: 1.2;
  margin-top: 0;
  color: #333;
}*/
.about-us3 .desc {
  margin-bottom: 35px;
  font-size: 18px;
  font-weight: 300;
  font-style: normal;
  line-height: 1.75;
  position: relative;
  visibility: visible;
  overflow-x: hidden;
  color: #696969;
}
.about-us3 .link {
  font-weight: 500;
  line-height: 1.25;
  position: relative;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  color: #333;
}
.about-us3 .link::before {
  width: 60px;
  height: 2px;
  margin-right: 10px;
  content: "";
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
  background-color: #333;
}
.about-us3 .link:hover {
  color: #f8796c;
  text-decoration: none;
}
.about-us3 .link:hover::before {
  width: 70px;
}

/* ekvivalent je bootstrap klasa img-fluid! */
/* .responsive-img {
max-width: 100%;
    height: auto;
} */


svg {
  max-width: 25px;
  height: auto;
}


.whats-float{
	position:fixed;
	width:60px;
	height:60px;
	bottom:40px;
	right:30px;
	background-color:#25d366;
	color:#FFF;
	border-radius:50px;
	text-align:center;
  font-size:30px;
	box-shadow: 2px 2px 3px #999;
  z-index:100;
  transition: ease-in .2s;
}

.whats-float:hover{
	transform: scale(1.07);
  transition: ease-in .2s;
  color: var(--color-blanco);
}

.my-float{
	margin-top:16px;
}




/**** Boton *****/
/* Botón CSS con imagen */
.boton__animado {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 19px 34px;
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, #1e264e, #335a96);
  border: none;
  border-radius: 25px;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  margin: 1rem 0rem;
  align-items: center;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.boton__animado::after {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 100%;
  height: 100%;
  color: #080808 !important;
  background: rgba(255, 255, 255, 0.084);
  transition: left 0.4s ease;

}

.boton__animado:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.3);
  color: var(--color-cuarto);
}

.boton__animado:hover::after {
  left: 0;
}

.btn-icon {
  width: 30px !important;
  height: 30px !important;
  object-fit: cover;
}



/* MODAL */

.grid-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px;
  padding: 20px 20px;
  max-width: 1080px;
  margin: 0 auto;
  margin-top: 2rem;
}

.grid-item {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  text-align: center;
  padding: 20px;
  cursor: pointer;
  transition: transform 0.3s ease;
}
.grid-item:hover {
  transform: translateY(-5px);
}

.grid-item img {
  width: 70px;
  height: 70px;
  margin-bottom: 10px;
}

.grid-item h3 {
  margin: 0;
  font-size: 1.2rem;
  color: #0078D7;
}

/* Modal styles */
.modal {
  
  /*display: none;
  position: fixed;
  z-index: 1000;
  left: 0; top: 0;*/
  width: 100%; height: 100%;
  background-color: rgba(0,0,0,0.6);
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.modal-content {
  background: #fff;
  padding: 30px;
  border-radius: 10px;
  max-width: 500px;
  width: 100%;
  text-align: center;
  position: relative;
  animation: fadeIn 0.3s ease;
}

.modal-content h2 {
  margin-top: 0;
  color: #0078D7;
  font-size: 1.5rem;
}

.modal-content img {
  width: 100%;
  max-height: 200px;
  object-fit: cover;
  border-radius: 8px;
  margin: 20px 0;
}

.close-btn {
  position: absolute;
  top: 10px; right: 15px;
  font-size: 1.5rem;
  color: #333;
  cursor: pointer;
}

@keyframes fadeIn {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}

/** Imagenes blog */
.img-fluid {
  max-width: 100%;
  height: auto;
  margin: .5rem;
  border-radius: 20px;
}




/**** Acordeon ***/



/* Acordeon Grid */

.contenedor__acordeon{
  padding: 2rem;
  margin-top: 3rem;
}
.acordeon-tabs {
  text-decoration: none; 
}
/* Acordeon Core */
.acordeon {
  max-width: 1100px;
  margin: 0 auto;
    position: relative;
    width: 100%;
    color: #fff;
    overflow: hidden;
    border-bottom: solid 1px #3a4366;
}
/* Acordeon Title Section */
.acordeon label {
    position: relative;
    display: block;
    padding: 0 0 0 1em;
    background: linear-gradient(135deg, #1e264e, #335a96);
    font-weight: bold;
    line-height: 3;
    cursor: pointer;
}
/* Acordeon Content For Anything */
.acordeon-content {
    max-height: 0;
    overflow: hidden;
    background: var(--color-blanco);
    -webkit-transition: max-height .35s;
    transition: max-height .35s;
    color: #000;
    transition: ease-in .5s;
}
/* Acordeon Content P Text */
.acordeon-content p {
    margin: 20px;
    line-height: 15px;
}
/* Acordeon Check Box Hidden */
.acordeon input {
	display:none;
    position: absolute;
    opacity: 0;
    z-index: -1;
}
/* :checked */
input:checked ~ .acordeon-content {
    max-height: 10em;
}
/* Acordeon Icon*/
label::after {
    position: absolute;
    right: 0;
    top: 0;
    display: block;
    width: 3em;
    height: 3em;
    line-height: 3;
    text-align: center;
    -webkit-transition: all .35s;
    transition: all .35s;
}
/* Acordeon Icon Content*/
input[type=checkbox] + label::after {
    content: "+";
}
/* Acordeon Icon Content Animation*/
input[type=checkbox]:checked + label::after {
    -webkit-transform: rotate(315deg);
    transform: rotate(315deg);
}



/*** Video slider ***/
.carousel-heading{
 text-decoration: none;
}
.page-width {
  max-width: 900px;
  margin: 2rem auto;
}
.page-width h2 {
  margin: 1rem;
  text-align: center;
  font-size: 2rem;
  color: var(--color-terciario);
}
.splide {
  max-width: 800px;
  width: 80%;
  margin: 0 auto;
}
.splide__slide img {
  max-width: 100%;
}
.splide__arrow--prev {
  margin-left: -50px;
}
.splide__arrow--next {
  margin-right: -50px;
}
.splide__pagination {
  margin-bottom: -35px;
}
.splide__pagination__page.is-active {
  background: var(--color-principal);
}



  /*** Testimonials ***/
  .heading {
    position: relative;
}
.testimonials {
    background: url("https://images.unsplash.com/photo-1632616427546-a471c1cff36a?ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&q=80&w=1740") center center no-repeat;
    background-size: cover;
    background-attachment: fixed;
    padding: 100px 0 100px;
    color: #ffffff;
    position: relative;
    width: 90%;
    margin: 0 auto;
    border-radius: 20px;
    max-width: 1100px;
}
.testimonials:before {
    content: "";
    background: rgba(0, 0, 0, 0.5);
    width: 100%;
    height: 100%;
    top: 0;
    position: absolute;
    left: 0;
    border-radius: 20px;
}
.testimonials .heading h2 {
    font-size: 25px;
    font-weight: 700;
    color: #ffffff;
}

.testimonials .heading h2 span {
    color:  var(--color-terciario);
}

.testimonials p {
    font-size: 15px;
    font-weight: 400;
    line-height: 1.7;
    color: #d1e5e7;
    margin: 20px 0;
    padding: 0;
}

/* Image */
.testimonials .carousel-inner .carousel-item .team {
    width: 100px;
    height: 100px;
    border: 2px solid  var(--color-terciario);
    border-radius: 100%;
    padding: 5px;
    margin: 50px 0 15px;
}

.testimonials .carousel-inner .carousel-item h3 {
    font-size: 20px;
    color: #ffffff;
    font-weight: 600;
}

.testimonials .carousel-inner .carousel-item h4 {
    font-size: 14px;
    font-weight: 300;
    color: #e2e1e1;
    margin-bottom: 20px;
}

.testimonials .carousel-indicators {
    bottom: -30px;
}

.testimonials .carousel-indicators li {
    background-color: #b8b7b7;
    border-radius: 50px !important;
    height: 18px;
    width: 18px;
}

.testimonials .carousel-indicators .active {
    background-color: var(--color-terciario);
}

.testimonials .control span {
    cursor: pointer;
}

.testimonials .icon {
    height: 60px;
    width: 60px;
    background-size: 100%, 100%;
    border-radius: 50%;
    font-size: 30px;
    background-image: none;
    color: #ffffff;
}



/*** Redes Sociales GRID*/
.social-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  padding: 20px;
}

.social-item {
  flex: 1 1 150px;
  max-width: 100px;
  text-align: center;
}

.social-item img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  transition: transform 0.3s ease;
}

.social-item img:hover {
  transform: scale(1.05);
}

/* Responsive adjustment */
@media (max-width: 600px) {
  .social-item {
    flex: 1 1 100%;
  }
}


  /*======== TEXTO E IMAGEN ===========*/
  .seccion__cursos {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0rem;
    padding: 1rem;

  }
  
  .block {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  
  .block.reverse {
    flex-direction: row-reverse;
  }
  
  .text{
    /*background: url("../img/inicio/contenido/shape.png") center center no-repeat;*/
    border-radius: 20px;
  }
  .image, .text {
    flex: 1 1 100px;
    padding: 1rem;
  }
  
  .image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    /*background-color: var(--color-blanco);*/
    transition: ease-in .2s;
  }

  .image:hover{
    transform: scale(1.01);
    transition: ease-in .3s;
  }
  
  h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    justify-content:flex-end
  }
  
  h2 .texto__unam {
    color: var(--color-principal);
    font-size: 2rem;
  }
  
  h2 .texto__ipn {
    color: var(--color-ipn);
    font-size: 2rem;
  }
  
  h2 .texto__uam {
    color: #ff8c00;
    font-size: 2rem;
  }
  
  .subtitulo__inicio {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-cuarto);
    margin-bottom: 1rem;
  }
  
  @media (max-width: 768px) {
    .block,
    .block.reverse {
      flex-direction: column;
    }
    .image img {
      width: 100%;
      height: auto;
      border-radius: 8px;
    }
  }
  
  
  
  /*===== TERMINA TEXTO E IMAGEN =======*/


  

/* === BANER   el baner es min width ojo cuando lo edites ===*/

.page {
  /*height: 100%;*/
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 3rem 0;
}

.page a{
  text-decoration: none;
}

.page h1{
font-size: 1.5rem;
color: #d2ab67;
}

.page h2{
  font-size: 1rem;
}

  .component {
    margin: 0 1rem;
    background: #fff;
    box-shadow: 0 0 0.25rem rgba(black, 0.3);
    border-radius: 10px;
    padding: 1rem;
    width: 30rem;
    font-size: 1rem;
    color: #747474;
   }
  .avatar {
    background-color: darken(white, 10%);
    background-image: url('../img/benito.png');
    background-size: cover;
    border-radius: 0%;
    width: 10em;
    height: 10em;
    margin: 0 auto;
    /*border: 0.125rem solid #ccc;*/
  }
  .user_info {
    text-align: center;
    margin: 0.5rem 0 1.25rem;
  }

    /*
      h2:before {
        content: 'Last Updated: ';
      }
      */
    
  .btn2 {
    padding: 1rem;
    font-size: 1rem;
    text-align: center;
    background: var(--color-secundario);
    color: #fff;
    border-radius: 10px;
    box-shadow: 0 0 2px rgba(grey, 0.5);
    transition: all 0.2s;
  }
    .btn2:hover {
      cursor: pointer;
      background: #d2ab67;
    }
  

@media (min-width: 768px) {
  .page {
    height: 10%;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 5rem auto;
  }
    .component {
      display: flex;
      align-items: center;
      padding: 1rem ;
      width: 1070px;
      font-size: 10px;
    }
    .avatar, .user_info, .btn {
      flex: 1;
    }
    .avatar {
      max-width: 10em;
      height: 10em;
      margin: 0;
      border-radius: 0;
      border: 0;
    }
    .user_info {
      text-align: left;
      margin: 0 1rem 0 1rem;

    }
    .btn2 {
      padding: 1rem;
      font-size: 1rem;
      max-width: 10rem;
    }
  }
  
/* === TERMINA BANNER ===*/




/* === Infromación Inicio ===*/
/* styles.css */

.info__general{
  max-width: 1100px;
  margin: 0 auto;
  width: 90%;
}
.hero {
  padding: 2rem;
  text-align: center;
  border-radius: 20px;
  width: 100%;
  margin: 3rem auto;
  background: url('https://images.unsplash.com/photo-1687042277317-7f0738d801bd?ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&q=80&w=1740') center / cover no-repeat fixed;
  background-color: #fff; /* Fallback */
  color: #1a1a1a;
}

.hero h1 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
  color: var(--color-letras-blanco);
  font-weight: 700;
  
}

.intro {
  font-size: 1.2rem;
  /*font-weight: bold;*/
  color: var(--color-letras-blanco);
}

.subtext {
  font-size: .9rem;
  margin-top: 0.5rem;
}

.features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2.5rem;
  padding: 1rem;
}


.feature-box h2 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
  color: var(--color-cuarto);
}

.feature-box p {
  font-size: 1rem;
}
.feature-box {
  position: relative;
  background-color: #ffffff;
  border-radius: 8px;
  padding: 1.5rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  /* Elimina overflow para permitir que el ícono sobresalga */
  overflow: visible;
  transition: ease-in .3s;
  cursor: pointer;
}
.feature-box:hover{
transform: scale(1.03);
transition: ease-in .2s;
background-color: var(--color-secundario);
color: var(--color-letras-blanco);
}

.floating-icon {
  position: absolute;
  top: -3rem;
  right: -1rem;
  width: 100px;
  height: 100px;
  object-fit: contain;
  z-index: 10; /* Asegura que esté por encima del contenido */
  pointer-events: none; /* Opcional: evita que interfiera con clics */
}

/*
.floating-icon {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s ease;
}
.feature-box:hover .floating-icon {
  transform: scale(1.05);
*/
@media (max-width: 600px) {
  .floating-icon {
    width: 80px;
    height: 80px;
    top: -2rem;
    right: -1rem;
  }
}


/* Responsive tweaks */
@media (max-width: 600px) {
  .hero h1 {
    font-size: 1.5rem;
  }

  .intro {
    font-size: 1rem;
  }

  .feature-box {
    padding: 1rem;
  }
}


.rating {
  display: flex;
  gap: 0.5rem;
  font-size: 2rem;
  color: #ffc107; /* Amarillo dorado */
  justify-content: center;
  align-items: center;
  padding: 1rem;
}

.star {
  transition: transform 0.3s ease;
}

.star:hover {
  transform: scale(1.2);
  cursor: pointer;
}


/* Bñog card */
.container__blog{
  max-width: 1100px;
  margin: 0 auto;
  width: 90%;
  margin: 1rem;
}

.blog-section {
  padding: 2rem 1rem;
  background-color: transparent;
}

.section-header {
  text-align: center;
  margin-bottom: 2rem;
}

.section-header h2 {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  color: var(--color-cuarto);
}

.section-header p {
  font-size: 1.2rem;
  color: #666;
}

.blog-link {
  display: inline-block;
  margin-top: 0.5rem;
  color: #6a1b9a;
  text-decoration: underline;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
}

.tarjeta__curso {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  transition: transform 0.3s ease;
}

.tarjeta__curso:hover {
  transform: translateY(-5px);
}

.blog-image {
  position: relative;
}

.blog-image img {
  width: 100%;
  height: auto;
  display: block;
}

.blog-date {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 70px;
  height: 70px;
  background-color: var(--color-cuarto);
  color: var(--color-blanco);
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

/* Imagen de la escuela*/
.blog-date img {
  width: 70%;
  height: auto;
  object-fit: contain;
}


.blog-category {
  position: absolute;
  top: 1rem;
  right: 10px;
  background: var(--color-cuarto);
  color: #fff;
  padding: 12px 8px;
  font-size: 0.8rem;
  border-radius: 4px;
}

.blog-content {
  padding: 1rem;
}

.blog-content h3 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}

.blog-content p {
  font-size: 0.95rem;
  color: #444;
  /*margin-bottom: 1rem;*/
}

.blog-meta {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
  color: #888;
}









/**** Blog Section ***/
#blog-section h2 {
  color: var(--color-cuarto);
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
}
#blog-section h3 {
  color: var(--color-cuarto);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.2;
  margin-top: 0;
  margin-bottom: 10px;
}

#blog-section p {
  color: #76787a;
  font-size: 16px;
  font-weight: normal;
  line-height: 1.625;
}

#blog-section a,
a:visited {
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

#blog-section a.button {
  position: relative;
  z-index: 1;
  display: inline-block;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.625em;
  color: #1c1c45 !important;
  text-align: center;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  border-radius: 0;
  border: 1px solid;
  border-color: #fff;
  text-decoration: none;
  text-transform: none;
  text-shadow: none;
  letter-spacing: 1px;
  padding: 10px 30px 10px;
  background-color: #fff;
  background: #fff; /* Old browsers
  -webkit-appearance: none;
  -moz-appearance: none;

  vertical-align: middle;
  -webkit-backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;*/
  overflow: hidden;
}

#blog-section a.button:hover {
  color: #fff !important;
  background: #1c1c45;
  border-color: #1c1c45;
  text-decoration: none !important;
}

#blog-section {
  padding: 100px 0 200px;
  background-image: url(https://static.pexels.com/photos/3164/sea-black-and-white-water-ocean-large.jpg);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  -webkit-background-size: cover;
}

#blog-section .container {
  width: 1255px;
}

@media only screen and (max-width: 1254px) {
  #blog-section .container {
    width: 100%;
  }
}

#blog-section .container .row > div {
  padding-right: 30px;
  padding-left: 30px;
}



.blog-section-intro h2 {
  font-size: 2rem;
  line-height: 40px;
  font-weight: 900;
}

.blog-section-intro p {
  font-size: 18px;
}

.blog-item {
  position: relative;
  display: block;
  text-decoration: none;
  margin: 0 0 35px 0;
}

#blog-section .blog-item {
  padding-top: 200px;
}

.blog-item:hover {
  text-decoration: none !important;
}

#blog-section .button {
  position: relative;
  top: 160px;
}

@media only screen and (min-width: 992px) {
  .blog-item.second,
  .blog-item.fourth {
    top: 120px;
  }

  #blog-section .button {
    position: relative;
    top: 260px;
  }
}

.blog-item-img {
  position: relative;
  width: 100%;
  height: 230px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  -webkit-background-size: cover;
  -moz-box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.blog-item-img.smaller {
  height: 210px;
}
.blog-item-img.larger {
  height: 250px;
}


.blog-item-img.video::before {
  content: "\f04b";
  position: absolute;
  left: 50%;
  top: 50%;
  display: inline-block;
  color: #fff;
  font-size: 50px;
  line-height: 19px;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.blog-item:hover .blog-item-img.video::before {
  color: #e2002b;
}

#blog-section .blog-item-img {
  position: absolute;
  left: 5px;
  top: 0;
  height: 240px;
}

#blog-section .blog-item.first .blog-item-img {
  left: -10px;
}

.blog-item-content {
  position: relative;
  padding: 35px 20px 30px 65px;
  background-color: #fff;
  -moz-box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 6px 24px 0 rgba(0, 0, 0, 0.1);
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

#blog-section .blog-item-content {
  left: -5px;
}

#blog-section .blog-item.first .blog-item-content {
  left: 10px;
}

#blog-section .blog-item:hover .blog-item-img,
#blog-section .blog-item:hover .blog-item-content {
  left: 0;
}

.blog-item-label {
  position: absolute;
  left: 20px;
  top: -15px;
  display: inline-block;
  padding: 3px 10px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #fff;
  text-transform: uppercase;
  background-color: var(--color-cuarto);
}

.blog-item-date {
  position: absolute;
  left: 20px;
  top: 35px;
  display: inline-block;
  color: #c8cace;
  text-align: center;
}
.blog-item-date-day {
  display: block;
  font-size: 28px;
  line-height: 28px;
}

.blog-item-date-month {
  display: block;
  font-size: 14px;
  font-weight: 700;
  line-height: 14px;
}

.blog-item h3 {
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

.blog-item:hover h3 {
  color: #272c42;
}

.blog-item-content p {
  margin-bottom: 0;
}

.buttonContainer {
  position: relative;
  width: 100%;
  float: left;
  clear: both;
  text-align: center;
  margin-bottom: 35px;
}

/* =========================================
   ESTILOS MEJORADOS PARA EL HEADER (PROFESIONAL)
   ========================================= */

/* 1. Contenedor del Header y Sombra */
.header-main {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05) !important; /* Sombra más suave y difusa */
  background-color: #fff !important; /* Ligeramente translúcido */
  backdrop-filter: blur(10px); /* Efecto de desenfoque (glassmorphism) */
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

/* 2. Tipografía y Espaciado del Menú (Desktop) */
@media (min-width: 992px) {
  .menu > .menu-item > a {
      font-family: 'Poppins', sans-serif;
      font-weight: 600;
      font-size: 0.9rem;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      padding: 24px 12px !important; /* Espacio vertical reducido */
      transition: color 0.3s ease;
      color: var(--color-secundario);
  }

  /* Ajuste específico para ítems con submenú (flecha) */
  .menu > .menu-item.has-sub > a {
      padding-right: 25px !important;
  }

  /* Efecto Hover: Subrayado animado desde el centro */
  .menu > .menu-item > a::before {
      content: '';
      position: absolute;
      bottom: 10px; /* Ajustar según el padding */
      left: 50%;
      width: 0;
      height: 3px;
      background-color: var(--color-terciario); /* Color dorado/acento */
      transition: width 0.3s ease, left 0.3s ease;
      border-radius: 2px;
  }

  .menu > .menu-item > a:hover::before,
  .menu > .menu-item > a.active::before {
      width: 70%;
      left: 15%;
  }
  
  .menu > .menu-item > a:hover {
      color: var(--color-principal) !important; /* Color azul principal */
  }
}

/* 3. Botón "Ingresar / Registrarse" Estilizado */
@media (min-width: 992px) {
  .menu-item.logged-out {
      display: flex;
      align-items: center;
  }

  .menu-item.logged-out > a {
      background: transparent;
      color: var(--color-terciario) !important; /* Color café/dorado */
      padding: 8px 20px !important;
      border-radius: 50px;
      margin-left: 20px;
      border: 1px solid var(--color-terciario);
      box-shadow: none;
      transition: all 0.3s ease;
      text-transform: none; /* Texto normal para el botón */
      font-weight: 500;
      font-size: 0.9rem;
      line-height: 1.2;
  }

  .menu-item.logged-out > a:hover {
      transform: translateY(-1px);
      box-shadow: 0 2px 10px rgba(194, 158, 80, 0.2);
      background: var(--color-terciario);
      color: #fff !important;
      border-color: var(--color-terciario);
  }

  .menu-item.logged-out > a::before {
      display: none; /* Quitar el efecto de subrayado del botón */
  }
  
  .menu-item.logged-out > a i {
      margin-right: 8px;
  }
}

/* 4. Estilos para Usuario Logueado */
.menu-item.logged-in > a {
  color: var(--color-secundario);
  font-weight: 600;
}

.menu-item.logged-in > a span#menu-user-name {
  color: var(--color-terciario);
  font-weight: 700;
}

/* 5. Mejoras en los Menús Desplegables (Dropdowns) */
.menu-sub, .menu-mega {
  border-top: 4px solid var(--color-terciario); /* Línea de acento superior */
  box-shadow: 0 15px 35px rgba(0,0,0,0.1);
  border-radius: 0 0 8px 8px;
  padding-top: 5px;
  padding-bottom: 5px;
}

.menu-sub a, .menu-mega a {
  transition: all 0.2s ease;
  border-radius: 4px;
  margin: 0px 5px;
  padding: 6px 10px !important;
  font-size: 0.95rem;
  font-weight: 500 !important;
  color: #555 !important;
  text-transform: none !important; /* Normal case para submenús */
}

.menu-sub a:hover, .menu-mega a:hover {
  background-color: rgba(24, 133, 194, 0.08); /* Fondo azul muy claro */
  color: var(--color-principal) !important;
  padding-left: 15px !important; /* Efecto de desplazamiento */
  font-weight: 600 !important;
}

/* 6. Animación del Logo */
.logo {
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.logo:hover {
  transform: scale(1.08);
}

/* Ajuste para móviles */
@media (max-width: 991px) {
  .menu-item.logged-out > a {
      background-color: var(--color-principal);
      color: white !important;
      margin: 10px 20px;
      text-align: center;
      border-radius: 5px;
  }
}
