/* Scss Document */
body {
  font-family: Century Gothic,CenturyGothic,AppleGothic,sans-serif;
  scroll-behavior: smooth; }

h2 {
  font-weight: 700;
  color: #1B1748;
  padding: 1.5rem 0 1.5rem 1.4rem;
  border-left: 8px solid #FFD040; }
  @media (min-width: 992px) {
    h2 {
      padding: 1.5rem 0 1.5rem 2rem; } }

.h3, h3 {
  color: #1B1748;
  font-weight: 700;
  font-size: 1.3rem; }

@media (min-width: 1200px) {
  .h3, h3 {
    font-size: 1.5rem; } }
.co-contacto {
  position: fixed;
  top: 4rem;
  right: 15px;
  z-index: 99;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1B1748;
  width: 50px;
  height: 50px;
  border-top-left-radius: calc(20px + .5vw);
  border-bottom-right-radius: calc(20px + .5vw); }
  @media (min-width: 768px) {
    .co-contacto {
      width: 66px;
      height: 66px;
      border-top-left-radius: calc(20px + .5vw);
      border-bottom-right-radius: calc(20px + .5vw); } }

.custom-tooltip {
  --bs-tooltip-color: $azul1;
  --bs-tooltip-bg: white;
  --bs-tooltip-margin: 0 4rem 0 0; }

.co-listado-amarillo li {
  display: block;
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: .8rem; }
  .co-listado-amarillo li::before {
    content: '';
    display: block;
    width: 16px;
    height: 16px;
    background: url(../images/bullet-amarillo.svg);
    position: absolute;
    left: 0;
    top: .2rem; }

.co-listado-azul {
  padding: 0; }
  .co-listado-azul li {
    display: block;
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: .8rem; }
    .co-listado-azul li::before {
      content: '';
      display: block;
      width: 16px;
      height: 16px;
      background: url(../images/bullet-azul-1.svg);
      position: absolute;
      left: 0;
      top: .2rem; }

.co-listado-azul-claro {
  padding: 0; }
  .co-listado-azul-claro li {
    display: block;
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: .8rem; }
    .co-listado-azul-claro li::before {
      content: '';
      display: block;
      width: 16px;
      height: 16px;
      background: url(../images/bullet-azul-2.svg);
      position: absolute;
      left: 0;
      top: .2rem; }

.bl-intro {
  display: block;
  color: white;
  background: linear-gradient(263deg, #776FCD 0%, #363386 100%);
  padding: 3rem 0; }
  .bl-intro img {
    margin-left: auto; }
  .bl-intro--inner {
    padding-left: 1.4rem;
    border-left: 8px solid #FFD040; }
    @media (min-width: 992px) {
      .bl-intro--inner {
        padding-left: 2rem; } }
    .bl-intro--inner p {
      font-size: 1.2rem;
      line-height: 1.8; }
      .bl-intro--inner p:last-child {
        margin-bottom: 0; }

header {
  position: absolute;
  z-index: 2;
  width: 100%; }
  header .co-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px; }
  header .el-logo {
    width: calc( 120px + (10vw/2) );
    max-width: 100%; }
  header .co-lang ul {
    display: flex;
    gap: 8px;
    margin: 0; }
  header .co-lang li {
    display: block;
    font-weight: bold; }
    header .co-lang li a {
      font-size: .7rem;
      display: flex;
      width: 34px;
      height: 34px;
      border-radius: 50%;
      background: #FFE193;
      color: #1B1748;
      overflow: hidden;
      text-decoration: none;
      justify-content: center;
      align-items: center;
      transition: all .3s ease-out; }
      @media (min-width: 1200px) {
        header .co-lang li a {
          font-size: .8rem;
          width: 42px;
          height: 42px; } }
      header .co-lang li a:hover {
        background: #372E95 !important;
        color: white !important; }
    header .co-lang li.active a {
      background: #FFD040; }

/***********************
HERO
***********************/
.bl-hero {
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  height: 60vh; }
  @media (min-width: 1200px) {
    .bl-hero {
      min-height: 600px;
      max-height: 832px; } }
  .bl-hero .co-hero {
    width: 100%;
    margin: 0;
    position: absolute; }
    .bl-hero .co-hero--text {
      color: white;
      display: inline-block;
      position: relative;
      z-index: 0;
      background-image: url(../images/fd-title.png);
      background-blend-mode: multiply;
      background-repeat: repeat;
      border-top-left-radius: 2rem;
      border-bottom-right-radius: 2rem;
      padding: 2rem 2rem;
      /*&::after {
      	content: '';
      	
      	background: $azul2;
      	height: calc(100% + 4rem);
      	width: 100%;
      	position: absolute;
      	left: 0;
      	top: 0;
      	z-index: -1;
      	mix-blend-mode: multiply;
      }*/ }
      .bl-hero .co-hero--text h1 {
        font-size: calc(1rem + 1.5vw);
        padding-left: 1.4rem;
        border-left: 8px solid #FFD040; }
        @media (min-width: 992px) {
          .bl-hero .co-hero--text h1 {
            font-size: calc(1rem + 1.5vw);
            padding-left: 2rem; } }
      @media (min-width: 992px) {
        .bl-hero .co-hero--text {
          border-top-left-radius: 4rem;
          border-bottom-right-radius: 4rem;
          padding: 4rem 2rem; } }
  .bl-hero video {
    display: block;
    opacity: 1;
    object-fit: cover;
    width: 100%;
    min-height: 100%;
    height: auto; }

/***********************
ACORDEONES
***********************/
.bl-acordeones {
  padding: 2rem 0 0;
  /***AMARILLO***/
  /***AZUL***/ }
  .bl-acordeones .container {
    background: url(../images/gotas2.svg) no-repeat 92% 0; }
    @media (min-width: 992px) {
      .bl-acordeones .container {
        background: url(../images/gotas2.svg) no-repeat top right; } }
  .bl-acordeones h2 {
    margin-bottom: 2rem; }
    @media (min-width: 992px) {
      .bl-acordeones h2 {
        margin-bottom: 3rem; } }
  @media (min-width: 992px) {
    .bl-acordeones {
      padding: 4rem 0 0; } }
  .bl-acordeones .accordion-amarillo .accordion-item {
    border: 1px solid #FFD040;
    background: linear-gradient(265deg, #FFF4DA 0.04%, rgba(255, 244, 218, 0.5) 99.72%);
    border-top-left-radius: 25px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 25px !important;
    border-bottom-left-radius: 0 !important; }
    .bl-acordeones .accordion-amarillo .accordion-item .accordion-body {
      background: transparent !important; }
  .bl-acordeones .accordion-amarillo .accordion-body p {
    padding-inline-start: 32px; }
  .bl-acordeones .accordion-amarillo .accordion-body li {
    display: block;
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: .4rem; }
    .bl-acordeones .accordion-amarillo .accordion-body li::before {
      content: '';
      display: block;
      width: 16px;
      height: 16px;
      background: url(../images/bullet-amarillo.svg);
      position: absolute;
      left: 0;
      top: .2rem; }
  .bl-acordeones .accordion-amarillo .accordion-header button {
    color: #1B1748;
    font-size: 1.5rem;
    font-weight: 700;
    padding: 2.5rem var(--bs-accordion-btn-padding-x) 2.5rem 7rem;
    position: relative; }
    .bl-acordeones .accordion-amarillo .accordion-header button::before {
      content: attr(data-content);
      display: block;
      width: 104px;
      height: 104px;
      background: #FFD040;
      color: #372E95;
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 2.8rem;
      position: absolute;
      left: -15px;
      top: -15px;
      border-top-left-radius: 25px !important;
      border-bottom-right-radius: 25px !important; }
  .bl-acordeones .accordion-amarillo .accordion-button,
  .bl-acordeones .accordion-amarillo .accordion-button:not(.collapsed) {
    background-color: transparent !important;
    box-shadow: none; }
    .bl-acordeones .accordion-amarillo .accordion-button:focus,
    .bl-acordeones .accordion-amarillo .accordion-button:not(.collapsed):focus {
      box-shadow: none; }
  .bl-acordeones .accordion-amarillo .accordion-button:not(.collapsed) {
    background-color: transparent !important; }
  .bl-acordeones .accordion-amarillo .accordion-button::after {
    background: #FFE193 url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%231B1748'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
    background-size: 55%;
    background-repeat: no-repeat;
    background-position: 9px 10px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    position: absolute;
    bottom: 1rem;
    right: 1rem; }
  .bl-acordeones .accordion-azul .accordion-item {
    border: 1px solid #776FCD;
    background: linear-gradient(269deg, #DFDEE9 -0.98%, rgba(223, 222, 233, 0.5) 102.34%);
    border-top-left-radius: 25px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 25px !important;
    border-bottom-left-radius: 0 !important; }
    .bl-acordeones .accordion-azul .accordion-item .accordion-body {
      background: transparent !important; }
  .bl-acordeones .accordion-azul .accordion-body p {
    padding-inline-start: 32px; }
  .bl-acordeones .accordion-azul .accordion-body li {
    display: block;
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: .4rem; }
    .bl-acordeones .accordion-azul .accordion-body li::before {
      content: '';
      display: block;
      width: 16px;
      height: 16px;
      background: url(../images/bullet-azul-2.svg);
      position: absolute;
      left: 0;
      top: .2rem; }
  .bl-acordeones .accordion-azul .accordion-header button {
    color: #1B1748;
    font-size: 1.5rem;
    font-weight: 700;
    padding: 4rem var(--bs-accordion-btn-padding-x) 4rem 7rem;
    position: relative; }
    .bl-acordeones .accordion-azul .accordion-header button::before {
      content: attr(data-content);
      display: block;
      width: 104px;
      height: 104px;
      background: #776FCD;
      color: white;
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 2.8rem;
      position: absolute;
      left: -15px;
      top: -15px;
      border-top-left-radius: 25px !important;
      border-bottom-right-radius: 25px !important; }
  .bl-acordeones .accordion-azul .accordion-button,
  .bl-acordeones .accordion-azul .accordion-button:not(.collapsed) {
    background-color: transparent !important;
    box-shadow: none; }
    .bl-acordeones .accordion-azul .accordion-button:focus,
    .bl-acordeones .accordion-azul .accordion-button:not(.collapsed):focus {
      box-shadow: none; }
  .bl-acordeones .accordion-azul .accordion-button:not(.collapsed) {
    background-color: transparent !important; }
  .bl-acordeones .accordion-azul .accordion-button::after {
    background: #D1CDEC url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%231B1748'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
    background-size: 55%;
    background-repeat: no-repeat;
    background-position: 9px 10px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    position: absolute;
    bottom: 1rem;
    right: 1rem; }

/***********************
SERVICIO OPCIONAL
***********************/
.bl-opcional {
  margin: 4rem 0; }
  .bl-opcional .container {
    background: url(../images/gotas2.svg) no-repeat 92% 0; }
    @media (min-width: 992px) {
      .bl-opcional .container {
        background: url(../images/gotas2.svg) no-repeat bottom left; } }
  .bl-opcional h2 {
    margin-bottom: 2.5rem; }
  .bl-opcional-bis {
    background: linear-gradient(251deg, #DDDBEA 0%, rgba(221, 219, 234, 0.5) 94.9%);
    padding: 4rem 0;
    margin: 0; }
    .bl-opcional-bis .container {
      padding-bottom: 12rem;
      background: url(../images/gotas3.svg) no-repeat 92% 0; }
      .bl-opcional-bis .container h2 {
        border-left: 8px solid #372E95 !important; }
      @media (min-width: 992px) {
        .bl-opcional-bis .container {
          background: url(../images/gotas3.svg) no-repeat bottom left; } }

/***********************
PASO A PASO
***********************/
.bl-paso-paso {
  background: linear-gradient(251deg, #FFF5DE 0%, rgba(255, 245, 222, 0.3) 94.9%);
  padding: 4rem 0 6rem 0;
  margin-bottom: 4rem;
  position: relative; }
  .bl-paso-paso .co-paso-mobile {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 10px; }
    .bl-paso-paso .co-paso-mobile img {
      width: 80px !important; }
  .bl-paso-paso .btn-cta {
    background: #FFD040;
    border: none;
    color: black;
    font-size: 1.2rem;
    font-weight: 700;
    text-decoration: none;
    text-transform: uppercase;
    display: block;
    padding: 1rem 0;
    text-align: center;
    min-width: 180px;
    border-top-left-radius: calc(8px + 0.5vw);
    border-bottom-right-radius: calc(8px + 0.5vw);
    position: relative;
    transition: all .5s ease-out;
    width: 100%;
    max-width: 280px;
    /* margin: 0 auto; */
    position: absolute;
    left: calc(50vw - 140px);
    bottom: -24px; }
    .bl-paso-paso .btn-cta:hover {
      background: black;
      color: #FFD040; }
  .bl-paso-paso .container {
    background: url(../images/gotas4.svg) no-repeat 92% 0; }
    @media (min-width: 992px) {
      .bl-paso-paso .container {
        background: url(../images/gotas4.svg) no-repeat top right; } }
  .bl-paso-paso h2 {
    margin-bottom: 4rem; }
  .bl-paso-paso .co-pasos {
    display: flex;
    flex-direction: column; }
    @media (min-width: 992px) {
      .bl-paso-paso .co-pasos {
        flex-direction: row; } }
  .bl-paso-paso .co-bloque1,
  .bl-paso-paso .co-bloque2 {
    width: 100%; }
    .bl-paso-paso .co-bloque1 img,
    .bl-paso-paso .co-bloque2 img {
      width: 100%;
      height: auto; }
    @media (min-width: 992px) {
      .bl-paso-paso .co-bloque1,
      .bl-paso-paso .co-bloque2 {
        width: 37.5%; } }
  .bl-paso-paso .co-bloque3 {
    width: 100%; }
    .bl-paso-paso .co-bloque3 img {
      width: 66%;
      height: auto; }
    @media (min-width: 992px) {
      .bl-paso-paso .co-bloque3 {
        width: 24.5%; }
        .bl-paso-paso .co-bloque3 img {
          width: 100%; } }

/***********************
FORM
***********************/
.bl-form {
  background: #FFF4DA;
  border: 1px solid #FFD040;
  padding: 3rem 1.5rem;
  border-top-left-radius: calc(40px + 1vw);
  border-bottom-right-radius: calc(40px + 1vw);
  position: relative;
  top: 4rem; }
  @media (min-width: 768px) {
    .bl-form {
      padding: 4rem 4rem; } }
  .bl-form .form-control {
    border: 1px solid #FFD040;
    border-radius: 0; }
    .bl-form .form-control:focus {
      box-shadow: 0 0 0 0.25rem #FFE193; }
  .bl-form a {
    color: #372E95;
    font-weight: 700;
    text-decoration: none; }
  .bl-form .btn-submit {
    background: #1B1748;
    border: none;
    color: white;
    display: block;
    padding: 1rem 0;
    text-align: center;
    min-width: 180px;
    font-weight: 700;
    text-transform: uppercase;
    border-top-left-radius: calc(8px + 0.5vw);
    border-bottom-right-radius: calc(8px + 0.5vw);
    position: relative;
    transition: all .5s ease-out; }
    .bl-form .btn-submit:hover {
      background: #372E95;
      letter-spacing: .32rem; }

.form-check-input:checked {
  background-color: #372E95;
  border-color: #372E95; }
.form-check-input:focus {
  border-color: #FFD040;
  outline: 0;
  box-shadow: 0 0 0 0.25rem #FFE193; }

/***********************
FOOTER
***********************/
footer {
  color: white; }
  footer a {
    color: white; }
  footer .bl-footer {
    background: #372E95;
    padding: 10rem 0 5rem; }
    footer .bl-footer p {
      font-size: .8rem;
      text-align: center; }
  footer .bl-fooer--legal {
    background: #1B1748;
    padding: 1.5rem 0; }
    footer .bl-fooer--legal .el-site {
      font-weight: 700; }
    footer .bl-fooer--legal nav ul {
      display: flex;
      gap: 3px;
      margin: 0;
      padding: 0; }
      @media (min-width: 768px) {
        footer .bl-fooer--legal nav ul {
          gap: 5px; } }
      footer .bl-fooer--legal nav ul a {
        margin: 0;
        padding: 0; }
      footer .bl-fooer--legal nav ul li {
        display: block; }
        footer .bl-fooer--legal nav ul li a {
          opacity: 1;
          transition: all .3s ease-out;
          margin: 0; }
          footer .bl-fooer--legal nav ul li a:hover {
            opacity: .6; }
          footer .bl-fooer--legal nav ul li a img {
            width: 30px;
            height: auto; }
            @media (min-width: 768px) {
              footer .bl-fooer--legal nav ul li a img {
                width: 37px;
                height: auto; } }

/*********************
MODAL
**********************/
.modal-dialog .modal-title {
  color: #1B1748;
  font-weight: 700 !important; }
.modal-dialog .btn-secondary {
  background: #1B1748;
  border-top-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: calc(8px + .5vw);
  border-bottom-right-radius: calc(8px + .5vw);
  width: 140px;
  text-align: center;
  font-weight: 700; }
@media (min-width: 992px) {
  .modal-dialog {
    max-width: 970px; } }
