.warning-content {
  box-sizing: border-box;
  position: absolute;
  top: 25%;
  width: 100%;
  height: 300px;
  text-align: center;
  margin: 0;
}

[v-cloak] {
  display: none;
}

html {
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-size: 1.25rem;
  font-family: "text-family", canada-type-gibson, sans-serif;
  color: #3d3d3d;
  min-height: 100vh;
}

a {
  color: #3d3d3d;
}

.opacity-75 {
  opacity: 0.75;
}

.op {
  opacity: 0;
}

.d-none {
  display: none !important;
}

.d-block {
  display: block !important;
}

.d-flex {
  display: flex !important;
}

.d-table {
  display: table !important;
}


.round {
  border-radius: 50%;
  width: 18.25rem;
  height: 18.25rem;
  overflow: hidden;
}

.img-resp {
  width: 100%;
}

.menu-icon {
  display: none;
  position: relative;
  font-size: 2.25rem;
  z-index: 11;
  color: var(--site-header-bg-contrast);
  transition: background 0.25s linear;
}

/* .menu-icon:before {
  bottom: 0;
  transform: translateY(-0.5rem);
}
.menu-icon:after {
  top: 0;
  transform: translateY(0.5rem);
}
.menu-icon:after,
.menu-icon:before {
  position: absolute;
  content: "";
  left: 0;
  height: 100%;
  width: 100%;
  background: var(--site-header-bg-contrast);
  transition: transform 0.25s linear;
} */

.menu-icon.show {
  background: transparent;
  position: fixed;
  right: 5%;
}

.menu-icon.show::before {
  transform: rotate(-45deg);
}

.menu-icon.show::after {
  transform: rotate(45deg);
}

/* FONT */

.p-0 {
  padding: 0;
}

.mt-0 {
  margin-top: 0rem !important;
}

.mt-05 {
  margin-top: 0.5rem;
}

.mt-1 {
  margin-top: 1rem;
}

.mt-2 {
  margin-top: 2rem !important;
}

.m-3 {
  margin: 3rem !important;
}

.mt-3 {
  margin-top: 3rem !important;
}

.mb-1 {
  margin-bottom: 1rem !important;
}

.mb-2 {
  margin-bottom: 2rem !important;
}

.mb-3 {
  margin-bottom: 3rem !important;
}

.mb-4 {
  margin-bottom: 4rem !important;
}

.mt-5 {
  margin-top: 5rem;
}

.mb-5 {
  margin-bottom: 5rem;
}

.ml-1 {
  margin-left: 1rem;
}

.mr-1 {
  margin-right: 1rem;
}

.mx-1 {
  margin: 1rem 0;
}

.my-3 {
  margin: 0 3rem;
}

.my-5 {
  margin: 5rem 0rem;
}

.mx-3 {
  margin: 3rem 0;
}

.py-3 {
  padding: 0 3rem;
}

.py-5 {
  padding: 5rem 0rem;
}

.continue {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, -100%);
}

.round {
  background: #e1e1e1;
}

#welcome video {
  height: 100vh;
  object-fit: cover;
  filter: grayscale(1);
  -webkit-filter: grayscale(1);
}

.card-event {
  background: #fff;
}

.lesson-item {
  cursor: pointer;
}

/* LIBRARY */
.card-course {
  background: #e1e1e1;
}

.alert-window {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}

.alert-container {
  padding: 1rem;
  background: #fff;
  border-radius: 1rem;
  min-width: 25rem;
}

/* BADGES */

/* PRIZE SHOP */

/* UNITS */

#lessons-section {
  background: #f5f5f5;
}

/* LESSON */
#lesson-material {
  background: #fff;
}

/* EVALUATION */
#question {
  /* background: #4a4a4a; */
  color: #fff;
}

#answers-certification {
  background: rgba(0, 0, 0, 0.75);
}

#certification-app .plyr {
  border-radius: 0;
}

#answers-certification .progress {
  width: 100%;
}

/* NO LOGIN INDEX */
#introduction-section {
  position: relative;
  z-index: 0;

  background-image: url("images/mother-with-children-choosing-shoes-in-kids-store-RZBA4M2.jpg");
  background-size: cover;
  background-position-y: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
  justify-content: center;
  /*Esto es necesaria si quieres un header con esquinas de abajo redondas*/
  min-height: calc(100vh - 56px);
  width: 100%;
  margin-top: -30px;

}

#introduction-section::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  /*background: rgba(31, 156, 175, 0.75);*/
  background: transparent;
}

#introduction-section .row {
  align-items: flex-end;
}

#introduction-section .col-4 .round {
  margin: 0 auto 1rem auto;
}

#introduction-section .col-4 p {
  margin: 1rem 0;
}

#introduction-section .col-4 .btn {
  margin: 1rem auto 0 auto;
}

.full-section {
  min-height: calc(100vh - 171px);
  width: 100%;
}

#full-section {
  position: relative;
  z-index: 0;

  display: flex;
  align-items: center;
  justify-content: center;
  /*Esto es necesaria si quieres un header con esquinas de abajo redondas*/
  min-height: calc(100vh - 171px);
  width: 100%;
}

#full-section::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  /*background: rgba(31, 156, 175, 0.75);*/
  background: transparent;
}

#full-section .row {
  align-items: flex-end;
}

#full-section .col-4 .round {
  margin: 0 auto 1rem auto;
}

#full-section .col-4 p {
  margin: 1rem 0;
}

#full-section .col-4 .btn {
  margin: 1rem auto 0 auto;
}

#second-section {
  padding: 3rem 0;
}

#second-section .col-7 {
  min-height: 60vh;
  display: flex;
  align-items: center;
}

#second-section .col-4 p {
  margin: 0 auto 2rem auto;
}

#third-section {
  padding: 3rem 0;
  position: relative;
  z-index: 0;
}

#third-section ul {
  position: relative;
  margin: 5rem 0 10rem 0;
}

#third-section .shield {
  width: 15rem;
  height: 15rem;
  /* background: rgba(255, 255, 255, 0.5); */
}

#third-section .shield.center {
  /* background: rgba(255, 255, 255, 1); */
  margin: 0 auto;
  z-index: 2;
  position: relative;
}

#third-section .shield.left,
#third-section .shield.right {
  position: absolute;
  top: 50%;
  transform: translateY(-25%);
  z-index: 1;
}

#third-section .shield.right {
  right: 0;
}

#third-section .shield.left {
  left: 0;
}

#fourth-section .shield {
  width: 18rem;
  height: 12rem;
  background: rgba(0, 0, 0, 0.5);
}

#fourth-section .shield img {
  height: 100%;
  object-fit: cover;
}

#fourth-section p {
  margin: 2rem 0;
}

#fourth-section ul {
  position: relative;
  margin: 5rem 0 10rem 0;
}

#fourth-section .shield.center {
  width: 25rem;
  height: 15rem;

  background: rgba(0, 0, 0, 0.5);
  margin: 0 auto;
  z-index: 1;
}

#fourth-section .shield.left,
#fourth-section .shield.right {
  background: rgba(0, 0, 0, 1);
  position: absolute;
  top: 50%;
  transform: translateY(0%);
  z-index: 2;
}

#fourth-section .shield.right {
  right: 0;
}

#fourth-section .shield.left {
  left: 0;
}

#fifth-section {
  padding: 2rem 0;
  margin-bottom: 0;
}

/* END NO LOGIN INDEX */

/* MODAL LOGIN */
#modal-indicaciones,
#modal-login,
#modal-info,
#modal-congrats,
#modal-lesson,
#modal-registro,
#modal-resultados,
#modal-imagen,
#modal-sugerencia,
#modal-create-account,
#modal-recovery-password {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 100vh;
  max-height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  justify-content: center;
  align-items: center;
  overflow-y: auto;
  overflow-x: hidden;
  /* opacity: 0; */
  /* border-radius: 50%; */
  display: none;
  /* transition: all 0.5s; */
  overflow: hidden;
}

#modal-login .modal-container {
  height: fit-content;
  max-height: 100vh;
}

#modal-registro .modal-container {
  width: 80%;
}

#modal-info .modal-container, #modal-congrats .modal-container {
  height: fit-content;
  max-height: 100vh;
  width: 25% !important;
}

@media screen and (max-width: 768px) {
  #modal-info .modal-container, #modal-congrats .modal-container {
    width: 80% !important;
  }

  #modal-registro .img-side, #modal-registro .content-form {
    width: 100% !important;
  }
}

#modal-lesson .modal-container {
  max-height: 90vh;
}

#modal-registro .modal-container, #modal-resultados .modal-container {
  max-height: 90vh;
}

#modal-registro .modal-container img {
  width: 100%;
}

#modal-registro .modal-container form {
  display: block;
  max-height: 100%;
}

#modal-registro .modal-container .content-form {
  overflow: auto;
}

#modal-indicaciones.show,
#modal-login.show,
#modal-info.show,
#modal-congrats.show,
#modal-lesson.show,
#modal-registro.show,
#modal-resultados.show,
#modal-imagen.show,
#modal-sugerencia.show,
#modal-create-account.show,
#modal-recovery-password.show {
  /* opacity: 1;
  width: 100%;
  height: 100%;
  border-radius: 0%; */
  display: flex !important;
}

#modal-indicaciones .modal-container {
  padding: 2rem 1rem;
}

#modal-indicaciones .modal-container .fa-times,
#modal-login .modal-container .fa-times,
#modal-lesson .modal-container .fa-times,
#modal-registro .modal-container .fa-times,
#modal-imagen .modal-container .fa-times,
#modal-sugerencia .modal-container .fa-times,
#modal-create-account .modal-container .fa-times,
#modal-recovery-password .modal-container .fa-times {
  position: absolute;
  margin: 1rem;
  top: 0;
  right: 0;
  cursor: pointer;
  z-index: 10;
}

#modal-resultados .modal-container .btn-close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: white;
  color: black;
  border: 0;
  cursor: pointer;
}

#modal-sugerencia textarea {
  height: 25vh;
}

#modal-login .modal-container,
#modal-login .modal-registro {
  min-height: 70%;
}

.clickable {
  cursor: pointer;
}


.modal-container {
  position: relative;
  border-radius: 0.625rem;
  overflow: hidden;
  background: #fff;
  width: 50%;
  /* height: 60vh; */
  box-shadow: 0.1875rem 0.1875rem 0.5rem rgba(0, 0, 0, 0.25);
  top: -100%;
  transition: all 0.5s;
}

.modal-container.show {
  top: 0;
}

.modal-container form {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  /* align-items: center; */
  justify-content: center;
}

.modal-container form>p {
  margin-bottom: 2rem;
}

.modal-container .row .col-6 {
  padding: 0;
}

.modal-container .row {
  margin-top: 1rem;
}

.modal-container .img-side {
  padding: 0;
  height: auto;
  position: relative;
  z-index: 1;
  background: linear-gradient(180deg, var(--site-primary), 65%, var(--site-secondary));
  display: flex;
  justify-content: center;
  align-items: center;
}

/* .modal-container .img-side::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background: linear-gradient(to bottom, rgba(177, 31, 36, 0.75), rgb(69, 19, 15, 0.75));
} */
.modal-container .img-side img {
  height: auto;
  width: 100%;
}

.modal-container .img-side .logo-login {
  position: relative;
  z-index: 2;
  padding: 30px;
}

/* END MODAL LOGIN */

/* HOME PAGE */

#lessons-preview-section {
  margin: 0;
  position: relative;
  color: #fff;
  /*height: 60vh;*/
  overflow: hidden;
  /*Esto es necesaria si quieres un header con esquinas de abajo redondas*/
  /*top: -30px;*/
  padding-top: 30px;
}

#lessons-preview-section .row {
  height: 100%;
}

#lessons-preview-section .preview-video {
  height: 100%;
  object-fit: cover;
  filter: blur(0.15rem);
  -webkit-filter: blur(0.15rem);
  -ms-filter: blur(0.15rem);
}

#lessons-preview-section .lesson-preview-info {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

#lessons-preview-section .lesson-preview-info::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: linear-gradient(to right, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0) 100%);
}

#lessons-preview-section .lesson-preview-info .col-6,
#lessons-preview-section .lesson-preview-info .col-10 {
  padding: 0;
}

#lessons-preview-section .lesson-preview-info .row .col-10 {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 5rem;
}

#lessons-preview-section .lesson-preview-info p {
  margin-bottom: 1rem;
}

#lessons-preview-section #progress {
  margin-top: 5rem;
}

#lessons-preview-section #continue .col-6 {
  padding: 0;
}

#lessons-preview-section .btn {
  margin-top: 2rem;
}

#badges-events-section {
  margin: 0;
}

#badges-events-section .shield {
  width: 9.375rem;
  height: 9.375rem;
  background: rgba(0, 0, 0, 0.5);
  margin: 0 auto;
  margin-bottom: 1rem;
}

#badges-events-section ul {
  margin: 3rem 0;
}

#badges-events-section #events p.text-bold-34~p.text-reg-16 {
  margin-top: 1rem;
}

#badges-events-section #events .card-event {
  margin-top: 5rem;
}

/* .card-event {
  border-radius: 1.25rem;
  border: 1px solid #e1e1e1;
  padding: 1rem;
}
.card-event .col-6 {
  padding: 0;
}
.card-event p.text-bold-34 ~ p.text-bold-20 {
  margin: 1rem 0;
} */

#questions-section {
  padding: 2rem 0;
  /*border-bottom: 1px solid #f49c00;*/
}

#library-section {
  padding: 3rem 0;
  background: #fff;
  min-height: calc(100dvh - 334px);
}

.locked {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
}

.locked i {
  font-size: 3.5rem;
  color: #fff;
}

/* END LIBRARY PAGE */

/* BADGES */
#badges-section>.wrap>.row>.col-9 .col-12:not(:last-child) {
  margin-bottom: 2rem;
}

.lock {
  width: 2.75rem;
  height: 2.75rem;
}

/* END BADGES */

/* PRIZE SHOP */
#badges-section {
  padding: 3rem 0;
  min-height: 80vh;
}

#badges-section>.wrap>.row>.col-3 .shield {
  width: 3.125rem;
  height: 3.125rem;
  background: #e1e1e1;
  margin-right: 1rem;
}

/* END PRIZE SHOP */

/* UNIT */
#slider-units-section {
  padding: 2rem 0;
}

.text-loading {
  width: 80%;
  height: 0.75rem;
  margin: 0 auto;
}

.text-loading-big {
  width: 50%;
  height: 1.75rem;
}



.dot.loading {
  border-radius: 50px;
  width: 5rem;
  height: 0.75rem;
  margin-right: 2rem;
}

.loading {
  background: linear-gradient(323deg, #d1d1d1, #e7e7e7, #d1d1d1);
  background-size: 400% 100%;
  overflow: hidden;

  -webkit-animation: shine-walking 1.5s ease infinite;
  -moz-animation: shine-walking 1.5s ease infinite;
  -o-animation: shine-walking 1.5s ease infinite;
  animation: shine-walking 1.5s ease infinite;
}

.card-loading {
  border-radius: 0.625rem;
  margin-bottom: 1.5rem;
  min-height: 445px;
}

.card-loading-long {
  border-radius: 0.625rem;
  margin-bottom: 1.5rem;
  min-height: 7rem;
}

.card-details p i {
  margin-right: 1rem;
}

/* SLIDER */

#introduction-section .slick-arrow {
  color: #fff;
}

#questions .slick-prev {
  left: 25%;
}

#questions .slick-next {
  right: 25%;
}

#questions .slick-arrow {
  top: 25%;
}

#lessons-section .slick-arrow {
  color: #fff;
}

#introduction-section .slick-dots li button {
  border-radius: 50%;
  border: 2px solid #fff;
  background: transparent;
  width: 20px;
  height: 20px;
  color: transparent;
  cursor: pointer;
}

#introduction-section .slick-dots {
  top: unset;
  bottom: 5%;
  position: relative;
}

#introduction-section .slick-dots li.slick-active button {
  background: #fff;
}

#units .slick-dots {
  top: unset;
  /* bottom: 0; */
}

#questions .slick-dots li button {
  border-radius: 50%;
  border: 1px solid var(--site-secondary);
  background: #fff;
  width: 1.75rem;
  color: transparent;
  height: 1.75rem;
  cursor: pointer;
}

#questions .slick-dots li.slick-active button {
  background: var(--site-secondary);
}

/* END SLIDER */
#other-units-section {
  padding: 3rem 0;
}

#other-units-section .wrap>.row {
  margin-top: 1rem;
}

#other-units-section .col-3:first-of-type {
  padding-left: 0;
}

#other-units-section .col-3:last-of-type {
  padding-right: 0;
}

/* #lesson-section {
  padding: 3rem 0;
} */

#lessons-section {
  position: relative;
  /*background: rgba(4, 77, 124, 1);*/
  background: var(--site-footer-bg);
}

#lessons,
.lessons {
  padding: 3rem 0rem;
}

.lesson-item {
  width: 25%;
  display: inline-block;
  position: relative;
}

.lock-lesson {
  opacity: 0.5 !important;
  cursor: not-allowed;
}

.lesson-item .round i {
  color: var(--site-secondary);
  font-size: 2rem;
  margin-bottom: 0rem;
}

.lesson-item .round,
.lesson-item.completed .round {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 2.75rem;
  height: 2.75rem;
  margin: 0 auto 1rem auto;
  background: transparent;
  border: 0.5rem solid #fff;
}

.lesson-item .round.done {
  background: var(--site-footer-bg-contrast);
}

.lesson-item.current .round i {
  color: rgba(31, 156, 175, 1);
}

.lesson-item .round.loading {
  background: transparent;
  border: 0.5rem solid #e1e1e1;
}

.lesson-item.current .round {
  background: #fff;
  border-color: #fff;
}

.lesson-item img {
  margin: 1rem auto 0 auto;
  height: 2.5rem;
}

.lesson-item.current .shield {
  background: #fff;
}

/* END UNIT */

/* LESSON */

#lesson-material {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0.1875rem 0.1875rem 0.5rem rgba(0, 0, 0, 0.25);

  transition: transform 0.5s;
}

#lesson-material.open {
  transform: translate(0%, -40%);
}

#material {
  box-shadow: 0.1875rem 0.1875rem 0.5rem rgba(0, 0, 0, 0.25);
  background: #fff;
  padding: 1.25rem;
  height: 100%;
  box-sizing: border-box;
}

#material a {
  display: block;
}


.transcript::before {
  font-family: "Font Awesome 5 Free";
  content: "\f036";
  margin-right: 1rem;
}

.document::before {
  font-family: "Font Awesome 5 Free";
  content: "\f15c";
  margin-right: 1rem;
}

/* #article,#video {
  height: 50vh;
} */

#article p {
  margin: 0.5rem;
}

/* END LESSON */

/* EVALUATION */
#slider-evaluation-section {
  padding: 2rem 0;
}

#questions {
  padding: 2rem 0;
  position: relative;
}

#questions .slick-dots {
  bottom: 0;
  top: unset;
  transform: translate(-50%, 100%);
}

#question p {
  padding: 1rem 0;
}

/* .question-item {
  margin: 0 5rem;
} */

/* END EVALUATION */

/* CERTIFICATION */

#certification {
  margin: 0;
  position: relative;
  overflow: hidden;
}

#certification .plyr {
  height: calc(100vh);
  border-radius: 0;
}

#answers-certification {
  transition: all 1s;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  padding: 3rem 0;
  margin: 0;
  transform: translateY(100%);
}

#answers-certification.response {
  transform: translateY(0);
}

#answers-certification .col-6 a {
  display: block;
  padding: 2rem 0;
  color: #fff;
  margin: 0 auto;
  position: relative;
  transition: all 0.5s;
}

#answers-certification .col-6 a:hover {
  color: #fff;
}

#answers-certification .col-6 a::after {
  content: "";
  position: absolute;
  transform: translate(0, -100%);
  bottom: 0;
  left: 50%;
  width: 0;
  transition: all 0.5s;
  height: 0.25rem;
  background: #f49c00;
}

#answers-certification .col-6 a:hover::after {
  left: 0;
  width: 100%;
}

#answers-certification .col-1 {
  color: #fff;
}

#answers-certification .col-1 i {
  margin-right: 1rem;
}

/* END CERTIFICATION */

/* RESULTS */
#results-section {
  padding: 3rem 0;
}

#results-section .results-details {
  margin-bottom: 1rem;
  padding: 2rem;
  box-shadow: 0.1875rem 0.1875rem 0.5rem rgba(0, 0, 0, 0.25);
  background: #fff;
}

#results-section .results-details>p:first-child {
  margin-bottom: 1rem;
}

#results-section .results-details .shield {
  width: 12.1875rem;
  height: 12.1875rem;
  margin: 3rem 0;
  background: #3d3d3d;
}

#results-section .results-details .col-10 {
  padding: 0;
}

#results-section .results-details .col-10 .btn {
  margin-top: 5rem;
}

canvas {
  width: 100%;
  height: 100%;
}

/* END RESULTS */

@-webkit-keyframes shine-walking {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

@-moz-keyframes shine-walking {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

@-o-keyframes shine-walking {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

@keyframes shine-walking {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

.parsley-errors-list li {
  font-size: 0.625rem;
  color: #9f200d;
  padding: 0.5rem;
  /* color: #fff; */
}

.parsley-error {
  border: 1px solid #9f200d;
  border-radius: 0.625rem;
}

#modal-login .container,
#modal-info .container,
#modal-congrats .container,
#modal-lesson .container,
#modal-registro .container,
#modal-resultados .container,
#modal-create-account .container {
  display: block;
  position: relative;
  padding-left: 2rem;
  margin: 1rem 0;
  font-size: 1rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

#modal-login .container input,
#modal-lesson .container input,
#modal-registro .container input,
#modal-create-account .container input,
#modal-recovery-password .container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

#modal-login .checkmark,
#modal-lesson .checkmark,
#modal-registro .checkmark,
#modal-create-account .checkmark {
  border: 1px solid #ccc;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
  height: 1rem;
  width: 1rem;
  background-color: #eee;
}

#modal-login .container:hover input~.checkmark,
#modal-lesson .container:hover input~.checkmark,
#modal-registro .container:hover input~.checkmark,
#modal-create-account .container:hover input~.checkmark {
  background-color: #ccc;
}

#modal-registro .container input:checked~.checkmark,
#modal-login .container input:checked~.checkmark,
#modal-lesson .container input:checked~.checkmark {
  background-color: var(--site-primary);
}

iframe {
  width: 100%;
  height: 80vh;
}

ul.no-login .login {
  /* width: 10rem; */
  margin-left: 2rem;
  text-align: center;
}

ul.no-login {
  justify-content: flex-end;
}

.area-lesson,
.area-material {
  height: 60vh;
  box-sizing: border-box;
}

.area-lesson {
  margin: 0 1rem;
}

.area-material {
  width: 33.33%;
  margin: 0 1rem;
}

.timer {
  position: fixed;
  min-width: 10vw;
  background: #fff;
  box-shadow: 0rem 0rem 1rem rgba(0, 0, 0, 0.25);
  top: 21%;
  right: -100%;
  z-index: 6;
  transition: all 0.5s;
  overflow: hidden;
}

.timer.show {
  right: 1%;
  width: auto;
  height: auto;
  background: #fff;
  color: #000;
  border-radius: 1rem 1rem 0 0;
}

.timer .colors>* {
  height: 0.5rem;
}

.timer-container {
  text-align: center;
  font-size: 3rem;
  border-radius: 0.5rem;
}

.timer-container p:not(.text-reg-16) {
  padding: 0.75rem;
}

.timer-container p.text-reg-16 {
  padding: 0.75rem 0.75rem 0 0.75rem;
}

#welcome {
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 50;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.5s;
}

#welcome.bye {
  transform: translateY(-100%);
}

#welcome::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  background: rgba(31, 156, 175, 0.75);
}

#welcome .text-content {
  position: absolute;
  text-align: center;
  width: 45%;
  z-index: 51;
}

#welcome .text-content>* {
  margin-bottom: 1rem;
}

.point {
  width: 0rem;
  height: 0rem;
}

.circle {
  border-radius: 50%;
  width: calc(100% - 3rem);
  padding-top: calc(100% - 3rem);
  margin: 0 auto;
  position: relative;
  background: #1e719a;
}

.circle img {
  position: absolute;
}

.circle .big {
  top: 0;
  left: 50%;
  width: 80%;
  transform: translate(-35%, -15%);
}

.circle .middle {
  width: 55%;
  left: 0;
  top: 50%;
  transform: translate(-15%, -25%);
}

.circle .short {
  width: 40%;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 25%);
}

.toogle-side {
  border-radius: 50%;
  height: 4rem;
  width: 4rem;
  z-index: 0;
  position: absolute;
  background: #fff;
  top: 50%;
  right: 0;
  transform: translate(50%, -50%);
  transition: transform, box-shadow 0.5s;
  cursor: pointer;
}

.toogle-side i {
  position: absolute;
  top: 50%;
  left: 50%;
  color: rgba(4, 77, 124, 1);
  font-size: 1.5rem;
  transform: translate(0, -50%);
}

#course-breadcrumb .wrap>.row {
  border-bottom: 1px solid #DEDEDE;
  padding: 2rem 0 2rem 0;
}

.notification {
  border-radius: 0.625rem;
  position: fixed;
  bottom: 0;
  right: 2rem;
  transform: translate(0, 100%);
  z-index: 10;
  background: var(--site-primary);
  min-width: 5rem;
  min-height: 5rem;
  max-width: 20rem;
  box-shadow: 0 3px 30px rgba(0, 0, 0, 0.25);
  transition: all 0.5s;
}

.notification.notificate {
  bottom: 2rem;
  transform: translate(0, 0);
}

.notification-container {
  padding: 1rem;
}

.empty-diamond {
  border: 3px solid #e1e1e1;
  width: 2rem;
  height: 2rem;
  transform: rotate(45deg);
  margin: 0 auto;
}

video {
  width: 100%;
}

.animation-rank {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.5s;
}

.animation-rank .overlay-radial {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20rem;
  height: 20rem;
  border-radius: 50%;
  z-index: 0;
  background: radial-gradient(#fff, transparent);
  transform: translate(-50%, -50%);
  filter: blur(1.5rem);
  -webkit-filter: blur(1.5rem);
  -ms-filter: blur(1.5rem);
  transition: all 0.5s;
  animation-delay: 0.5s;
}

.animation-rank img {
  width: 15rem;
  filter: drop-shadow(0px 0px 1rem rgba(0, 0, 0, 0.75));
  -webkit-filter: drop-shadow(0px 0px 1rem rgba(0, 0, 0, 0.75));
  -ms-filter: drop-shadow(0px 0px 1rem rgba(0, 0, 0, 0.75));
  animation-delay: 0.75s;
  position: relative;
}

.animation-rank p {
  filter: drop-shadow(0px 0px 0.25rem rgba(0, 0, 0, 0.75));
  -webkit-filter: drop-shadow(0px 0px 0.25rem rgba(0, 0, 0, 0.75));
  -ms-filter: drop-shadow(0px 0px 0.25rem rgba(0, 0, 0, 0.75));
  animation-delay: 1s;
  position: relative;
}

@keyframes slide {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(100%);
    opacity: 0;
  }
}

.animation-rank p::after {
  content: "";
  top: 0;
  transform: translateX(100%);
  width: 100%;
  height: 2.125rem;
  position: absolute;
  z-index: 1;
  -webkit-animation: slide 1.5s;
  -moz-animation: slide 1.5s;
  -o-animation: slide 1.5s;
  animation: slide 1.5s 1.5s;
  filter: blur(1.5rem);
  -webkit-filter: blur(1.5rem);
  -ms-filter: blur(1.5rem);

  background: -moz-linear-gradient(left,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.8) 50%,
      rgba(128, 186, 232, 0) 99%,
      rgba(125, 185, 232, 0) 100%);
  /* FF3.6+ */
  background: -webkit-gradient(linear,
      left top,
      right top,
      color-stop(0%, rgba(255, 255, 255, 0)),
      color-stop(50%, rgba(255, 255, 255, 0.8)),
      color-stop(99%, rgba(128, 186, 232, 0)),
      color-stop(100%, rgba(125, 185, 232, 0)));
  /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(left,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.8) 50%,
      rgba(128, 186, 232, 0) 99%,
      rgba(125, 185, 232, 0) 100%);
  /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(left,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.8) 50%,
      rgba(128, 186, 232, 0) 99%,
      rgba(125, 185, 232, 0) 100%);
  /* Opera 11.10+ */
  background: -ms-linear-gradient(left,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.8) 50%,
      rgba(128, 186, 232, 0) 99%,
      rgba(125, 185, 232, 0) 100%);
  /* IE10+ */
  background: linear-gradient(to right,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.8) 50%,
      rgba(128, 186, 232, 0) 99%,
      rgba(125, 185, 232, 0) 100%);
  /* W3C */
}

.loading.answer {
  height: 200px;
  margin: 0 0.5rem;
}

.question.loading {
  height: 250px;
  width: 45%;
  margin: 1rem auto;
}

#certification-app:not(.full-screen) .plyr__video-wrapper {
  height: calc(100vh - 86px);
}

#certification-app.full-screen .plyr__video-wrapper {
  height: calc(100vh);
}

#certification-app video {
  position: absolute;
  top: 0;
  left: 0;
}

.animation-rank i {
  font-size: 2rem;
  position: absolute;
  top: 1rem;
  right: 1rem;
  color: #fff;
  cursor: pointer;
}

.progress-ranking {
  position: relative;
  width: 100%;
}

.progress-ranking>div {
  position: absolute;
  top: 1.5rem;
  width: 2rem;
  transform: translate(-50%);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.card-info .progress-ranking>div {
  flex-direction: column;
}

.card-lesson .card-info.ranking {
  padding: 1.5rem 2rem 5.5rem 2rem;
}

.progress-ranking>div::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  height: 0.75rem;
  width: 1px;
  background: #000;
  transform: translate(-50%, -100%);
}

.progress-ranking>div>img {
  width: 100%;
}

.card-ranking {
  padding: 3rem 1.5rem;
}

.border-bottom {
  border-bottom: 1px solid rgb(31, 156, 175);
}

.lenguage-item {
  padding: 1rem;
  border-bottom: 1px solid rgba(4, 77, 124, 1);
  cursor: pointer;
}

.lenguage-item:hover {
  background: rgba(4, 77, 124, 0.25);
}

.lenguage-item img {
  width: 100%;
}

.lenguages-list {
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-height: 75vh;
  height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  box-shadow: 0.5rem 0.25rem 0.5rem rgba(0, 0, 0, 0.5);
  transition: height 0.5s ease-in-out;
}

.lenguages-list .close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  border-radius: 50%;
  height: 1.5rem;
  width: 1.5rem;
}

.lenguages-list.open {
  height: 75vh;
  border-top: 2px solid rgba(4, 77, 124, 1);
  border-bottom: 2px solid rgba(4, 77, 124, 0.5);
}

li.list-group-item {
  padding: 1rem;
  text-align: center;
  border: 1px solid #c6c6c6;
  border-radius: 0.25rem;
  /* cursor: move; */

  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.badge {
  background: #89200d;
  color: #fff;
  padding: 0.25rem 0.5rem;
  border-radius: 50px;
  margin-right: 1rem;
}

ul.list-group .list-group-item:not(:last-of-type) {
  margin-bottom: 0.5rem;
}

li.list-group-item {
  padding: 0 1rem;
  /* text-align: center; */
  border: 1px solid #c6c6c6;
  border-radius: 0.25rem;
  /* cursor: move; */
  display: flex;
  justify-content: flex-start;
  align-items: center;
  min-height: 65px;
}

li.list-question-item>input {
  width: 15%;
  min-height: 65px;
  /* border-left: 2px solid #c6c6c6; */
  text-align: center;
  text-transform: uppercase;
  /* box-shadow: inset 0px 0px 10px rgba(0,0,0,0.25); */
}

li.list-question-item>div {
  width: 85%;
  padding: 0 1rem;
}

li.list-question-item:not(:last-of-type) {
  margin-bottom: 0.5rem;
}

li.list-question-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid #c6c6c6;
  border-radius: 0.5rem;
  overflow: hidden;
  min-height: 65px;
}

ul.list-group>div {
  height: 100%;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}

ul.list-group {
  margin-bottom: 3rem;
  height: 100%;
}

.active-tab {
  border-bottom: 1px solid rgba(4, 77, 124, 1);
  color: rgba(4, 77, 124, 1);
}

footer {
  position: fixed;
  bottom: 0;
  padding: 15px;
  right: 0;
  z-index: 100;
}

footer a {
  text-decoration: underline;
}

.whatsapp {
  position: fixed;
  width: 45px;
  height: 45px;
  bottom: 95px;
  right: 20px;
  background-color: #25d366;
  color: #FFF;
  border-radius: 50px;
  text-align: center;
  font-size: 30px;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
}

.whatsapp::before {
  content: '';
  position: absolute;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  bottom: -5px;
  right: -5px;
  border: 2px white solid;
}

.whatsapp.inactive::before {
  background: var(--site-danger);
}

.whatsapp.active::before {
  background: var(--site-success);
}

.whatsapp-enter-active,
.whatsapp-leave-active {
  transition: all 1s;
  transform: translateY(0px);
}

.whatsapp-enter,
.whatsapp-leave-to {
  transform: translateY(100px);
}

.whatsapp .tooltip {
  font-size: 12px;
  position: absolute;
  transform-origin: bottom;
  margin-bottom: 200%;
  background: var(--site-primary);
  border-radius: 15px;
  padding: 10px 15px;
  width: fit-content;
  right: 0;
  white-space: nowrap;
}

.whatsapp .tooltip-enter-active,
.whatsapp .tooltip-leave-active {
  transition: all .3s cubic-bezier(0.64, 0.57, 0.67, 1.53);
  opacity: .7;
  transform: translateX(0px);
}

.whatsapp .tooltip-enter,
.whatsapp .tooltip-leave-to {
  opacity: 0;
  transform: translateX(10px);
}

/*Transitions*/
.fade-enter-active,
.fade-leave-active {
  opacity: 1;
  transition: opacity .2s;
}

.fade-enter,
.fade-leave-to {
  opacity: 0;
}


.jump-enter-active,
.fade-leave-active {
  opacity: 1;
  transform: scale(1);
  transition: all 1.5s;
}

.jump-enter,
.jump-leave-to {
  opacity: 0;
  transform: scale(1.4);
}

.logout-sm {
  display: none;
}

.logout {
  display: block;
}

/* Nuevos estilos */
.img-logo-left {
  margin-right: 30px;
}

.header-no-login-left {
  width: 60% !important;
}

.header-no-login-right {
  width: 40% !important;
}

ul.header-no-login-left a {
  width: 10rem;
  margin-left: 1rem;
  text-align: center;
}

.bg-warning {
  background-color: var(--site-warning) !important;
  color: inherit;
}

.bg-primary {
  background-color: var(--site-primary) !important;
  color: inherit;
}

.bg-primary-accent {
  background-color: #9e0048 !important;
  color: inherit;
}

.text-primary-accent {
  color: #9e0048;
}

.text-white {
  color: white !important;
}

.btn-circle {
  width: 25px;
  height: 25px;
  border-radius: 100%;
}

.btn-flat {
  display: flex;
  background: transparent;
  color: #000;
  border: none;
  cursor: pointer;
  align-items: center;
  text-align: center;
  justify-content: center;
}

.btn-flat:hover {
  background: lightgray;
}

.btn-primary {
  background: var(--site-primary) !important;
  color: white !important;
}

.btn-warning {
  background: var(--site-warning) !important;
  color: white !important;
}

.items-center {
  align-items: center;
}

.justify-content-center {
  justify-content: center;
}

.btn-signup {
  background-color: var(--site-warning) !important;
  padding: 25px 35px;
  color: white;
  border-radius: 15px;
  border: 0px;
  cursor: pointer;
  font-size: 35px !important;
  margin-top: 50px;
}

.btn-show-more {
  background-color: #f0f0f0 !important;
  padding: 10px 25px;
  color: var(--site-primary);
  border-radius: 15px;
  border: 0px;
  cursor: pointer;
}

.btn-header {
  padding: 5px 15px;
  background-color: var(--site-warning);
  border-radius: 25px;
  border: 0px;
  cursor: pointer;
}

.btn-header.outline {
  background-color: transparent;
  outline: 1px solid var(--site-header-bg-contrast);
}

.vertical-content .middle {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.card-white {
  background: white !important;
}

.shadow-1 {
  box-shadow: 0 1px 3px #0003, 0 1px 1px #00000024, 0 2px 1px -1px #0000001f !important;
}

.shadow-up-1 {
  box-shadow: 0 -1px 3px #0003, 0 -1px 1px #00000024, 0 -2px 1px -1px #0000001f !important;
}

.shadow-2 {
  box-shadow: 0 1px 5px #0003, 0 2px 2px #00000024, 0 3px 1px -2px #0000001f !important;
}

.shadow-up-2 {
  box-shadow: 0 -1px 5px #0003, 0 -2px 2px #00000024, 0 -3px 1px -2px #0000001f !important;
}

.shadow-3 {
  box-shadow: 0 1px 8px #0003, 0 3px 4px #00000024, 0 3px 3px -2px #0000001f !important;
}

.shadow-up-3 {
  box-shadow: 0 -1px 8px #0003, 0 -3px 4px #00000024, 0 -3px 3px -2px #0000001f !important;
}

.shadow-4 {
  box-shadow: 0 2px 4px -1px #0003, 0 4px 5px #00000024, 0 1px 10px #0000001f !important;
}

.shadow-up-4 {
  box-shadow: 0 -2px 4px -1px #0003, 0 -4px 5px #00000024, 0 -1px 10px #0000001f !important;
}

.shadow-5 {
  box-shadow: 0 3px 5px -1px #0003, 0 5px 8px #00000024, 0 1px 14px #0000001f !important;
}

.shadow-up-5 {
  box-shadow: 0 -3px 5px -1px #0003, 0 -5px 8px #00000024, 0 -1px 14px #0000001f !important;
}

.shadow-6 {
  box-shadow: 0 3px 5px -1px #0003, 0 6px 10px #00000024, 0 1px 18px #0000001f !important;
}

.shadow-up-6 {
  box-shadow: 0 -3px 5px -1px #0003, 0 -6px 10px #00000024, 0 -1px 18px #0000001f !important;
}

.shadow-7 {
  box-shadow: 0 4px 5px -2px #0003, 0 7px 10px 1px #00000024, 0 2px 16px 1px #0000001f !important;
}

.shadow-up-7 {
  box-shadow: 0 -4px 5px -2px #0003, 0 -7px 10px 1px #00000024, 0 -2px 16px 1px #0000001f !important;
}

.shadow-8 {
  box-shadow: 0 5px 5px -3px #0003, 0 8px 10px 1px #00000024, 0 3px 14px 2px #0000001f !important;
}

.shadow-up-8 {
  box-shadow: 0 -5px 5px -3px #0003, 0 -8px 10px 1px #00000024, 0 -3px 14px 2px #0000001f !important;
}

.shadow-9 {
  box-shadow: 0 5px 6px -3px #0003, 0 9px 12px 1px #00000024, 0 3px 16px 2px #0000001f !important;
}

.shadow-up-9 {
  box-shadow: 0 -5px 6px -3px #0003, 0 -9px 12px 1px #00000024, 0 -3px 16px 2px #0000001f !important;
}

.shadow-10 {
  box-shadow: 0 6px 6px -3px #0003, 0 10px 14px 1px #00000024, 0 4px 18px 3px #0000001f !important;
}

.shadow-up-10 {
  box-shadow: 0 -6px 6px -3px #0003, 0 -10px 14px 1px #00000024, 0 -4px 18px 3px #0000001f !important;
}

.shadow-11 {
  box-shadow: 0 6px 7px -4px #0003, 0 11px 15px 1px #00000024, 0 4px 20px 3px #0000001f !important;
}

.shadow-up-11 {
  box-shadow: 0 -6px 7px -4px #0003, 0 -11px 15px 1px #00000024, 0 -4px 20px 3px #0000001f !important;
}

.shadow-12 {
  box-shadow: 0 7px 8px -4px #0003, 0 12px 17px 2px #00000024, 0 5px 22px 4px #0000001f !important;
}

.shadow-up-12 {
  box-shadow: 0 -7px 8px -4px #0003, 0 -12px 17px 2px #00000024, 0 -5px 22px 4px #0000001f !important;
}

.shadow-13 {
  box-shadow: 0 7px 8px -4px #0003, 0 13px 19px 2px #00000024, 0 5px 24px 4px #0000001f !important;
}

.shadow-up-13 {
  box-shadow: 0 -7px 8px -4px #0003, 0 -13px 19px 2px #00000024, 0 -5px 24px 4px #0000001f !important;
}

.shadow-14 {
  box-shadow: 0 7px 9px -4px #0003, 0 14px 21px 2px #00000024, 0 5px 26px 4px #0000001f !important;
}

.shadow-up-14 {
  box-shadow: 0 -7px 9px -4px #0003, 0 -14px 21px 2px #00000024, 0 -5px 26px 4px #0000001f !important;
}

.shadow-15 {
  box-shadow: 0 8px 9px -5px #0003, 0 15px 22px 2px #00000024, 0 6px 28px 5px #0000001f !important;
}

.shadow-up-15 {
  box-shadow: 0 -8px 9px -5px #0003, 0 -15px 22px 2px #00000024, 0 -6px 28px 5px #0000001f !important;
}

.shadow-16 {
  box-shadow: 0 8px 10px -5px #0003, 0 16px 24px 2px #00000024, 0 6px 30px 5px #0000001f !important;
}

.shadow-up-16 {
  box-shadow: 0 -8px 10px -5px #0003, 0 -16px 24px 2px #00000024, 0 -6px 30px 5px #0000001f !important;
}

.shadow-17 {
  box-shadow: 0 8px 11px -5px #0003, 0 17px 26px 2px #00000024, 0 6px 32px 5px #0000001f !important;
}

.shadow-up-17 {
  box-shadow: 0 -8px 11px -5px #0003, 0 -17px 26px 2px #00000024, 0 -6px 32px 5px #0000001f !important;
}

.shadow-18 {
  box-shadow: 0 9px 11px -5px #0003, 0 18px 28px 2px #00000024, 0 7px 34px 6px #0000001f !important;
}

.shadow-up-18 {
  box-shadow: 0 -9px 11px -5px #0003, 0 -18px 28px 2px #00000024, 0 -7px 34px 6px #0000001f !important;
}

.shadow-19 {
  box-shadow: 0 9px 12px -6px #0003, 0 19px 29px 2px #00000024, 0 7px 36px 6px #0000001f !important;
}

.shadow-up-19 {
  box-shadow: 0 -9px 12px -6px #0003, 0 -19px 29px 2px #00000024, 0 -7px 36px 6px #0000001f !important;
}

.shadow-20 {
  box-shadow: 0 10px 13px -6px #0003, 0 20px 31px 3px #00000024, 0 8px 38px 7px #0000001f !important;
}

.shadow-up-20 {
  box-shadow: 0 -10px 13px -6px #0003, 0 -20px 31px 3px #00000024, 0 -8px 38px 7px #0000001f !important;
}

.shadow-21 {
  box-shadow: 0 10px 13px -6px #0003, 0 21px 33px 3px #00000024, 0 8px 40px 7px #0000001f !important;
}

.shadow-up-21 {
  box-shadow: 0 -10px 13px -6px #0003, 0 -21px 33px 3px #00000024, 0 -8px 40px 7px #0000001f !important;
}

.shadow-22 {
  box-shadow: 0 10px 14px -6px #0003, 0 22px 35px 3px #00000024, 0 8px 42px 7px #0000001f !important;
}

.shadow-up-22 {
  box-shadow: 0 -10px 14px -6px #0003, 0 -22px 35px 3px #00000024, 0 -8px 42px 7px #0000001f !important;
}

.shadow-23 {
  box-shadow: 0 11px 14px -7px #0003, 0 23px 36px 3px #00000024, 0 9px 44px 8px #0000001f !important;
}

.shadow-up-23 {
  box-shadow: 0 -11px 14px -7px #0003, 0 -23px 36px 3px #00000024, 0 -9px 44px 8px #0000001f !important;
}

.shadow-24 {
  box-shadow: 0 11px 15px -7px #0003, 0 24px 38px 3px #00000024, 0 9px 46px 8px #0000001f !important;
}

.shadow-up-24 {
  box-shadow: 0 -11px 15px -7px #0003, 0 -24px 38px 3px #00000024, 0 -9px 46px 8px #0000001f !important;
}

.full-width {
  width: 100% !important;
}

.text-h1 {
  font-size: 6rem;
  font-weight: 300;
  line-height: 6rem;
  letter-spacing: -.01562em
}

.text-h2 {
  font-size: 3.75rem;
  font-weight: 300;
  line-height: 3.75rem;
  letter-spacing: -.00833em
}

.text-h3 {
  font-size: 3rem;
  font-weight: 400;
  line-height: 3.125rem;
  letter-spacing: normal
}

.text-h4 {
  font-size: 2.125rem;
  font-weight: 400;
  line-height: 2.5rem;
  letter-spacing: .00735em
}

.text-h5 {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 2rem;
  letter-spacing: normal
}

.text-h6 {
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2rem;
  letter-spacing: .0125em
}

.text-bold {
  font-weight: bold !important;
}

.paragraph-text {
  font-size: 20px;
  line-height: 1.5;
}

.introduction-side-left {
  height: 100vh;
}

.introduction-side-left img {
  position: absolute;
  top: 15%;
  right: 55%;
  -webkit-transform: scaleX(-1);
  -moz-transform: scaleX(-1);
  -o-transform: scaleX(-1);
  transform: scaleX(-1);
}

.introduction-side-right {
  background: var(--site-primary);
  height: 100vh;
  padding-left: 5% !important;
}

.introduction-side-right .middle h2 {
  font-size: 40px;
  color: white !important;
  margin-bottom: 15px;
  font-weight: bold;
}

.introduction-side-right .isr-container {
  padding-left: 25%;
  padding-right: 5%;
}

.video-introduction {
  border-radius: 16px;
}

.que-aprendere-img-bg {
  position: absolute;
  width: 100%;
  max-height: 70%;
  opacity: 0.3;
}

.que-aprendere-img-col {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .introduction-side-right {
    padding: 5px !important;
  }

  .introduction-side-right .middle h2 {
    font-size: 30px !important;
    text-align: center !important;
  }

  .introduction-side-right .isr-container {
    padding-left: 0% !important;
    padding-right: 0% !important;
  }

  .introduction-side-right .btn-signup {
    padding: 10px 20px !important;
    font-size: 25px !important;
  }

  .hide-on-sm {
    display: none;
  }

  .link-menu {
    font-size: 1.5rem !important;
  }

  .que-aprendere-img-col {
    width: 50% !important;
  }

  .text-center-on-sm {
    text-align: center !important;
  }
}

@media screen and (min-width: 768px) {
  .hide-on-md {
    display: none;
  }
}

.pa-none {
  padding: 0 !important
}

.pl-none {
  padding-left: 0 !important
}

.pr-none {
  padding-right: 0 !important
}

.pt-none {
  padding-top: 0 !important
}

.pb-none {
  padding-bottom: 0 !important
}

.px-none {
  padding-left: 0 !important;
  padding-right: 0 !important
}

.py-none {
  padding-top: 0 !important;
  padding-bottom: 0 !important
}

.ma-none {
  margin: 0 !important
}

.ml-none {
  margin-left: 0 !important
}

.mr-none {
  margin-right: 0 !important
}

.mt-none {
  margin-top: 0 !important
}

.mb-none {
  margin-bottom: 0 !important
}

.mx-none {
  margin-left: 0 !important;
  margin-right: 0 !important
}

.my-none {
  margin-top: 0 !important;
  margin-bottom: 0 !important
}

.pa-xs {
  padding: 4px !important
}

.pl-xs {
  padding-left: 4px !important
}

.pr-xs {
  padding-right: 4px !important
}

.pt-xs {
  padding-top: 4px !important
}

.pb-xs {
  padding-bottom: 4px !important
}

.px-xs {
  padding-left: 4px !important;
  padding-right: 4px !important
}

.py-xs {
  padding-top: 4px !important;
  padding-bottom: 4px !important
}

.ma-xs {
  margin: 4px !important
}

.ml-xs {
  margin-left: 4px !important
}

.mr-xs {
  margin-right: 4px !important
}

.mt-xs {
  margin-top: 4px !important
}

.mb-xs {
  margin-bottom: 4px !important
}

.mx-xs {
  margin-left: 4px !important;
  margin-right: 4px !important
}

.my-xs {
  margin-top: 4px !important;
  margin-bottom: 4px !important
}

.pa-sm {
  padding: 8px !important
}

.pl-sm {
  padding-left: 8px !important
}

.pr-sm {
  padding-right: 8px !important
}

.pt-sm {
  padding-top: 8px !important
}

.pb-sm {
  padding-bottom: 8px !important
}

.px-sm {
  padding-left: 8px !important;
  padding-right: 8px !important
}

.py-sm {
  padding-top: 8px !important;
  padding-bottom: 8px !important
}

.ma-sm {
  margin: 8px !important
}

.ml-sm {
  margin-left: 8px !important
}

.mr-sm {
  margin-right: 8px !important
}

.mt-sm {
  margin-top: 8px !important
}

.mb-sm {
  margin-bottom: 8px !important
}

.mx-sm {
  margin-left: 8px !important;
  margin-right: 8px !important
}

.my-sm {
  margin-top: 8px !important;
  margin-bottom: 8px !important
}

.pa-md {
  padding: 16px !important
}

.pl-md {
  padding-left: 16px !important
}

.pr-md {
  padding-right: 16px !important
}

.pt-md {
  padding-top: 16px !important
}

.pb-md {
  padding-bottom: 16px !important
}

.px-md {
  padding-left: 16px !important;
  padding-right: 16px !important
}

.py-md {
  padding-top: 16px !important;
  padding-bottom: 16px !important
}

.ma-md {
  margin: 16px !important
}

.ml-md {
  margin-left: 16px !important
}

.mr-md {
  margin-right: 16px !important
}

.mt-md {
  margin-top: 16px !important
}

.mb-md {
  margin-bottom: 16px !important
}

.mx-md {
  margin-left: 16px !important;
  margin-right: 16px !important
}

.my-md {
  margin-top: 16px !important;
  margin-bottom: 16px !important
}

.pa-lg {
  padding: 24px !important
}

.pl-lg {
  padding-left: 24px !important
}

.pr-lg {
  padding-right: 24px !important
}

.pt-lg {
  padding-top: 24px !important
}

.pb-lg {
  padding-bottom: 24px !important
}

.px-lg {
  padding-left: 24px !important;
  padding-right: 24px !important
}

.py-lg {
  padding-top: 24px !important;
  padding-bottom: 24px !important
}

.ma-lg {
  margin: 24px !important
}

.ml-lg {
  margin-left: 24px !important
}

.mr-lg {
  margin-right: 24px !important
}

.mt-lg {
  margin-top: 24px !important
}

.mb-lg {
  margin-bottom: 24px !important
}

.mx-lg {
  margin-left: 24px !important;
  margin-right: 24px !important
}

.my-lg {
  margin-top: 24px !important;
  margin-bottom: 24px !important
}

.pa-xl {
  padding: 48px !important
}

.pl-xl {
  padding-left: 48px !important
}

.pr-xl {
  padding-right: 48px !important
}

.pt-xl {
  padding-top: 48px !important
}

.pb-xl {
  padding-bottom: 48px !important
}

.px-xl {
  padding-left: 48px !important;
  padding-right: 48px !important
}

.py-xl {
  padding-top: 48px !important;
  padding-bottom: 48px !important
}

.ma-xl {
  margin: 48px !important
}

.ml-xl {
  margin-left: 48px !important
}

.mr-xl {
  margin-right: 48px !important
}

.mt-xl {
  margin-top: 48px !important
}

.mb-xl {
  margin-bottom: 48px !important
}

.mx-xl {
  margin-left: 48px !important;
  margin-right: 48px !important
}

.my-xl {
  margin-top: 48px !important;
  margin-bottom: 48px !important
}

.mt-auto,
.my-auto {
  margin-top: auto !important
}

.ml-auto {
  margin-left: auto !important
}

.mb-auto,
.my-auto {
  margin-bottom: auto !important
}

.mr-auto {
  margin-right: auto !important
}

.mx-auto {
  margin-left: auto !important;
  margin-right: auto !important
}

.subtitle-family {
  font-family: "subtitle-family";
}

.section-home {
  padding: 2rem;
}

.section-home .questions {
  display: grid;
  grid-template-columns: 1fr;
  max-width: 1080px;
  margin: 0 auto;
  row-gap: 2rem;
}

.section-home .questions .question {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  line-height: 34px;
  font-size: 26px;
}

.section-home .questions:is(:last-child) {
  margin-top: 2rem;
}

@media (min-width: 768px) {
  .section-home .questions .question {
    line-height: 24px;
    font-size: 20px;
  }
}

/* Accordion styles */
.tabs {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 4px -2px rgba(0, 0, 0, 0.5);
}

.tabs input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}

.tab {
  width: 100%;
  color: white;
  overflow: hidden;
}

.tab-label {
  display: flex;
  justify-content: space-between;
  padding: 1em;
  background: lightgray;
  color: black;
  font-weight: bold;
  cursor: pointer;
  /* Icon */
}

.tab-label::after {
  content: "❯";
  width: 1em;
  height: 1em;
  text-align: center;
  transition: all 0.35s;
}

.tab-content {
  max-height: 0;
  padding: 0 1em;
  color: #2c3e50;
  background: white;
  transition: all 0.35s;
}

.tab-close {
  display: flex;
  justify-content: flex-end;
  padding: 1em;
  font-size: 0.75em;
  background: #2c3e50;
  cursor: pointer;
}

.tab-close:hover {
  background: #1a252f;
}

input:checked+.tab-label {
  background: var(--site-primary);
  color: white;
}

input:checked+.tab-label::after {
  transform: rotate(90deg);
}

input:checked~.tab-content {
  max-height: 125vh;
  padding: 1em;
}

.required:after {
  content: "*";
  color: var(--danger);
  font-size: 18px;
  margin-left: 2px;
}

.title-pink {
  color: #960048 !important;
}