/* Colores principales */
:root {
  --color1: #9c4392;
  --color11: #af639f;
  --color2: #308da1;
  --color22: #51aabe;
  --color3: #71b6e5;
  --color33: #98d6f6;
}
/********************************************/
/* Font Face  *******************************/
/********************************************/
* {
  font-family: "Lato", sans-serif;
}
h1 {
  font-weight: 900;
  font-size: 2em;
}
div.g-recaptcha {
  margin: 0 auto;
  width: 304px;
}
.ancla:before {
  display: block;
  content: " ";
  margin-top: -110px;
  height: 150px;
  visibility: hidden;
}
.redondeado {
  border-radius: 20px;
}
/* PARA CAMBIAR LA FORMA DE PASAR LOS SLIDES */
.carousel-indicators li {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #ce2172;
  border: 2px solid #fff;
}
a {
  text-decoration: none;
}

/********************************************/
/* Menú *************************************/
/********************************************/
.navbar {
  box-shadow: 0px 2px 8px 0px rgba(50, 50, 50, 0.08);
  background-color: white;
  transition: all 0.5s;
}
.nav-link {
  font-size: 1rem;
  font-weight: 900;
  color: var(--color1);
}
.nav-item a {
  position: relative;
  padding: 10px;
  transition: all 0.5s;
  color: white;
}
.nav-item a:hover {
  text-decoration: none;
  color: var(--color33);
}

.botonblanco {
  border: 2px solid white;
  color: white;
  border-radius: 10px 10px 0px 10px;
  transition: all 0.5s;
}

.botonblanco:hover {
  background-color: var(--color1);
  color: white;
}
.botoncolor {
  border: 2px solid var(--color1);
  color: var(--color1);
  background-color: white;
  border-radius: 10px 10px 0px 10px;
  transition: all 0.5s;
  padding: 10px 15px;
}

.botoncolor:hover {
  background-color: var(--color3);
  color: white;
}
.botoncolorForm {
  border: 2px solid var(--color2);
  color: var(--color2);
  background-color: white;
  border-radius: 10px 10px 0px 10px;
  transition: all 0.5s;
  padding: 10px 15px;
}

.botoncolorForm:hover {
  background-color: var(--color3);
  color: white;
}

.dropdown-menu .nav-link {
  font-size: 0.8rem;
  font-weight: 700;
}
.dropdown-menu {
  min-width: 250px;
  /*border-top: 0px solid var(--color1);
  border-bottom: 2px solid var(--color1);
  border-left: 2px solid var(--color1);
  border-right: 2px solid var(--color1);*/
  border: 0px;
  padding: 10px 10px;
  border-radius: 0px 0px 0px 10px;
  margin-left: 0px;
  margin-top: 0px;
  box-shadow: 0px 12px 8px 0px rgba(50, 50, 50, 0.08);
  background-color: white;
  width: auto;
}

.dropdown-menu a {
  padding: 8px 20px;
  line-height: 20px;
  font-weight: 800;
  color: var(--color2);
  transition: all 0.3s;
  text-transform: uppercase;
}
.dropdown-menu a:hover {
  color: var(--color2);
  margin-left: 10px;
}
.dropdown-menu a:hover:after {
  width: 0px;
}
.dropdown:hover > .dropdown-menu {
  display: block;
}

.footerLink {
  font-size: 14px;
  color: white;
}
.footerLink:hover {
  font-size: 14px;
  color: white;
}

ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.bi-square-fill {
  font-size: 0.5em;
  color: var(--color2);
  vertical-align: 0.4em;
}
.nav-link .bi-square-fill {
  font-size: 0.5em;
  color: var(--color1);
  vertical-align: 0.4em;
}
.footerLink .bi-square-fill {
  font-size: 0.5em;
  color: var(--color33);
  vertical-align: 0.4em;
}

/********************************************/
/* Texto y colores **************************/
/********************************************/
.text-300 {
  font-weight: 300;
} /*Light*/
.text-400 {
  font-weight: 400;
} /*Normal*/
.text-700 {
  font-weight: 700;
} /*Bold*/
.text-900 {
  font-weight: 900;
} /*Black*/
.color1 {
  color: var(--color1);
}
.fcolor1 {
  background-color: var(--color1);
}
.color11 {
  color: var(--color11);
}
.fcolor11 {
  background-color: var(--color11);
}
.color2 {
  color: var(--color2);
}
.fcolor2 {
  background-color: var(--color2);
}
.color22 {
  color: var(--color22);
}
.fcolor22 {
  background-color: var(--color22);
}
.color3 {
  color: var(--color3);
}
.fcolor3 {
  background-color: var(--color3);
}
.color33 {
  color: var(--color33);
}
.fcolor33 {
  background-color: var(--color33);
}

/********************************************/
/* VARIOS ***********************************/
/*******************************************/
.sticky {
  position: sticky;
  top: 0;
  z-index: 10;
}

.recuadro {
  border: 5px solid var(--color2);
  border-radius: 10px 10px 0px 10px;
  padding: 15px 40px;
}

.recuadro3 {
  border: 5px solid var(--color3);
  border-radius: 20px 20px 0px 20px;
  padding: 15px 40px;
}

.fotito {
  border-radius: 40px 40px 0px 40px;
  border: 5px solid var(--color22);
  width: 220px;
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.5) !important;
}

.bordes {
  border-radius: 10px 10px 0px 10px;
}

.bordesFoto {
  border-radius: 10px 10px 0px 0px;
}

.bordes1 {
  border-radius: 0px 0px 0px 10px;
}

h6 {
  line-height: 1.5;
}
.bi-square-fill {
  font-size: 0.5em;
  color: var(--color1);
  vertical-align: 0.2em;
}

/*laptop*/
@media screen and (min-width: 1280px) {
  h1 {
    font-size: 60px;
  }
  h3 {
    font-size: 30px;
  }
  h5 {
    font-size: 20px;
  }
}

/********************************************/
/* Ajustes celular **************************/
/********************************************/

@media only screen and (max-width: 992px) {
  /*celular*/
  .ancla:before {
    height: 120px;
  }

  .navbar-nav {
    /*height: 370px;*/
    overflow: auto;
  }
  .nav-link {
    font-size: 1rem;
    font-weight: 900;
    color: var(--color1);
  }
  .nav-item a {
    position: relative;
    padding: 10px 10px;
  }
  .botonMembresia {
    float: none;
    position: relative;
    padding: 10px;
    right: 0px;
    transform: translateY(0%);
  }
  .dropdown-menu .nav-link {
    text-align: center;
    padding: 4px 10px;
  }
  .tituloBanner {
    color: white;
    font-size: 1.5em;
    text-shadow: 0px 0px 0px;
    position: relative;
    top: 0px;
    padding: 0px;
  }
  .fondo {
    height: 250px;
  }
  .fondo img {
    transform: translateY(100%);
  }
  tbody tr th:nth-child(1) {
    width: 50px;
  }
}

@media only screen and (min-width: 992px) {
  /*laptop*/
  tbody tr th:nth-child(1) {
    width: 80px;
  }
}

/********************************************/
/* Video Youtube ****************************/
/********************************************/
.videoWrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  padding-top: 25px;
  height: 0;
  margin-bottom: 15px;
}

.videoWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/********************************************/
/* Efecto para foto**************************/
/********************************************/
figure {
  border-radius: 50%;
  margin: 0;
  padding: 0;
  background: #fff;
  overflow: hidden;
}
/* Zoom In #1 */
.hoverzoom figure img {
  -webkit-transform: scale(1);
  transform: scale(1);
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.hoverzoom figure:hover img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}
/* Gray Scale */
.hovercolor img {
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
  -webkit-transition: 0.1s ease-in-out;
  transition: 0.1s ease-in-out;
}
.hovercolor:hover img {
  -webkit-filter: grayscale(0);
  filter: grayscale(0);
}
/********************************************/
/* Campos Formulario ************************/
/********************************************/
#error_nombre,
#error_email,
#error_email1,
#error_mensaje {
  color: red;
  font-size: 16px;
  line-height: 30px;
}
.errorForm {
  border: 2px solid red;
}
/********************************************/
/* Custom Checkbox **************************/
/********************************************/
.pre {
  display: block;
  position: relative;
  padding-left: 30px;
  margin-bottom: -10px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.pre input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
.checkmark {
  position: absolute;
  top: 5px;
  left: 0;
  height: 15px;
  width: 15px;
  background-color: #eee;
  border-radius: 50%;
}
.checkmarkcuadrado {
  position: absolute;
  top: 5px;
  left: 0;
  height: 15px;
  width: 15px;
  background-color: #eee;
}
.pre:hover input ~ .checkmark,
.pre:hover input ~ .checkmarkcuadrado {
  background-color: #ccc;
}
.pre input:checked ~ .checkmark,
.pre input:checked ~ .checkmarkcuadrado {
  background-color: var(--color1);
}
.custom-select {
  width: auto;
  background-color: #00ffff;
  color: #081e3f;
}

/********************************************/
/* boton top ********************************/
/********************************************/
#boton_top {
  display: none; /* Hidden by default */
  opacity: 0;
  position: fixed; /* Fixed/sticky position */
  bottom: 40px; /* Place the button at the bottom of the page */
  right: 23px; /* Place the button 30px from the right */
  width: 50px;
  height: 50px;
  z-index: 99; /* Make sure it does not overlap */
  border: none; /* Remove borders */
  outline: none; /* Remove outline */
  background-color: var(--color1); /* Set a background color */
  color: white; /* Text color */
  padding: 0;
  animation-name: btn_animado;
  animation-duration: 2s;
  animation-fill-mode: both;
  cursor: pointer; /* Add a mouse pointer on hover */
  border-radius: 50%; /* Rounded corners */
  font-size: 25px; /* Increase font size */
  vertical-align: middle;
}
#boton_top:hover {
  background-color: var(--color1);
}
@keyframes btn_animado {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/********************************************/
/* popup ************************************/
/********************************************/
.popup-form-process,
.popup-form-error,
.popup-form-success,
.popup-cv {
  position: fixed;
  display: none;
  z-index: 1000;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(94, 110, 141, 0.9);
}
.popup-cv .popup-container {
  position: relative;
  font-size: 16px;
  width: 90%;
  max-width: 600px;
  top: 150px;
  margin: 0 auto;
  background: #fff;
  border-radius: 1em 1em 0em 1em;
  text-align: left;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  animation-name: popup_animatetop;
  animation-duration: 0.4s;
  border: 8px solid var(--color2);
}
.popup-container {
  position: relative;
  font-size: 16px;
  width: 90%;
  max-width: 400px;
  top: 150px;
  margin: 0 auto;
  background: #fff;
  border-radius: 1em;
  text-align: center;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  animation-name: popup_animatetop;
  animation-duration: 0.4s;
  border: 4px solid var(--color1);
}
@keyframes popup_animatetop {
  from {
    top: -300px;
    opacity: 0;
  }
  to {
    top: 150px;
    opacity: 1;
  }
}
.popup-container p {
  padding: 0.5em 1em 0em 1em;
}
.popup-cabecera {
  border-radius: 0.5em 0.5em 0 0;
  background: linear-gradient(90deg, var(--color1), var(--color11));
  padding: 20px 0px;
  text-align: center;
  color: white;
  position: relative;
}
.cerrar {
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  position: absolute;
  top: -25px;
  right: -25px;
  border-radius: 50%;
  font-size: 35px;
  background-color: var(--color22);
  border: 4px solid var(--color2);
  width: 50px;
  height: 50px;
}
.popup-close {
  color: white;
}

@media only screen and (max-width: 992px) {
  /*celular*/
  .popup-cv .popup-container {
    font-size: 12px;
  }
  .cerrar {
    right: -15px;
  }
}

/* ─ FOOTER ─ */
footer {
  background: var(--color1);
  color: white;
  text-align: center;
  padding: 38px 40px 28px;
}
footer p {
  font-size: 12.5px;
  line-height: 0.5;
}
footer a {
  color: var(--color33);
  text-decoration: none;
}

/* Centered text */
.centered {
  z-index: 10;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1200px;
}

@media only screen and (max-width: 992px) {
  .centered {
    width: 300px;
  }
}

.sec-line {
  width: 70px;
  height: 4px;
  background: var(--color33);
  border-radius: 2px;
  margin: 0 auto;
}

/* ─ INSCRIPTION BAND ─ */
.insc-opts {
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 800px;
  margin: 0 auto;
}
.insc-opt {
  flex: 1;
  min-width: 240px;
  max-width: 310px;
  background: rgba(255, 255, 255, 0.09);
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 16px;
  padding: 32px 26px;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
  color: white;
  display: block;
}
.insc-opt:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: var(--color22);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}
.insc-opt h3 {
  font-size: 18px;
  font-weight: 900;
  margin-bottom: 8px;
}
.insc-opt p {
  font-size: 13px;
  line-height: 1.5;
}
.insc-opt .cta, .cta-form {
  display: inline-block;
  margin-top: 16px;
  background: var(--color22);
  color: white;
  padding: 9px 20px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}
/* RESPONSIVE */
@media (max-width: 820px) {
  .insc-opts {
    flex-direction: column;
    align-items: center;
  }
}
/* SPEAKERS */
.cta-speaker {
  display: inline-block;
  margin-top: 16px;
  background: var(--color1);
  color: white;
  padding: 9px 20px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.kn-card{background:white;border-radius: 40px 40px 0px 40px;overflow:hidden;border:2px solid var(--color3);transition:all 0.3s;cursor:pointer;}
.kn-card:hover{border-color:var(--color22);box-shadow:0 12px 32px rgba(123,63,160,0.15);transform:translateY(-4px);}
.kn-top{background:var(--color3);padding:20px;text-align:center;color:white;}
.kn-body{padding:20px 20px;background:var(--color33);}
.speaker-fotito {
  border-radius: 50%;
  border: 2px solid white;
  width: 220px;
}

/* ─ AGENDA ─ */
.a-izquierda{border-radius: 10px 0px 0px 10px;box-shadow:0 1px 8px rgba(0,0,0,0.06);}
.a-derecha{border-radius: 0px 10px 10px 0px;box-shadow:0 1px 8px rgba(0,0,0,0.06);padding:0px 22px;}
.a-body{padding:18px 0px;}
.a-topic{font-size:15px;font-weight:700;color:var(--color1);margin-bottom:5px;}
.a-mod{font-size:13px;color:var(--color2);font-style:italic;margin-bottom:7px;}
.a-talks{list-style:none;}
.a-talks li{font-size:13.5px;padding:3.5px 0;border-bottom:1px solid #f0e8f8;display:flex;gap:7px;}
.a-talks li:last-child{border-bottom:none;}
.a-talks li::before{content:'›';color:var(--color2);font-weight:700;flex-shrink:0;}
.a-sp{font-style:italic;color:var(--color1);font-size:12.5px;}
/* RESPONSIVE */
@media (max-width: 820px) {
  .a-izquierda {
    border-radius: 10px 10px 0px 0px;
  }
  .a-derecha {
    border-radius: 0px 0px 10px 10px;
  }
}