body * {
    font-family: 'Poppins', sans-serif;
    color: #27326a;
    font-weight: 400;
}

#modal_lang {
    text-align: center;
}

#modal_lang .modal-body{
    padding: 2rem;
}

#modal_lang img {
    width: 100%;
    max-width: 120px;
}
#modal_lang h3 {
    font-size: 1.5rem;
    font-weight: 400;
    text-align: center;
    margin-top: 2rem;
}
#modal_lang .langs {
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-top: 2rem;
}

#modal_lang .langs .btn {
    padding: .5rem 2rem;
    color: #ffffff;
    background-color: #010658;
    transition: all .4s ease;
}

#modal_lang .langs .btn:hover {
    background-color: #fd9d01;
}

#header-lp {
    background-color: #ffffff;
}

#header-lp img{
    height: 50px;
}

#banner {
    padding-top: 4rem;
    padding-bottom: 2rem;
    background: linear-gradient(0deg, #FFFFFF 34.54%, #EAEAEA 67.52%, #C8CDFF 100%);
    background-position: center bottom 100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#banner-content {
    width: 80%;
    max-width: 550px;
    margin: 0 auto;
    text-align: center;
}

#banner-content img {
    width: 100%;
}

#banner-content .btn-cta {
    background-color: #27326a;
    color: #ffffff;
    padding: .8rem 2rem;
    border-radius: 30px;
    font-size: 1rem;
    font-weight: 700;
    margin-top: -1rem;
    transition: all .5 ease;
}

#descripcion {
    padding: 2rem 0;
    text-align: center;
}

#descripcion h1 {
    margin: 1rem auto 3rem;
    font-size: 2.5rem;
    line-height: 3.5rem;
    font-weight: 700;
    width: 100%;
    max-width: 900px;
}

#descripcion h1 span{
    font-weight: 700;
    color: #fd9d01;
}

.card-paso {
    display: flex;
    flex-direction: column;
    gap: 30px;
    width: 80%;
    max-width: 400px;
    padding: 2rem;
    background-color: #ffffff;
    align-items: center;
    border-radius: 20px;
    box-shadow: 5px 10px 18px #888888;
    margin-bottom: 3rem;
}

.card-paso > .fila {
    display: flex;
    justify-content: space-between;
}

.card-paso .titulo h3 {
    font-weight: 700;
    font-size: 1.6rem;
}

.card-paso .texto p {
    font-size: 1.1rem;
    line-height: 1.5rem;
}

#beneficios {
    padding: 2rem 0;
}

#beneficios .title{
    min-width: 300px;
    margin: 0 auto;
}

#beneficios .title h1{
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: 2rem;
    text-align: center;
    line-height: 3.5rem;
}

#beneficios .title h1 span{
    font-weight: 700;
    background-color: #fd9d01;
    padding: 0 1rem;
    margin: 0 -1rem;
}

.beneficios {
    margin: 2rem auto;
    gap: 20px;
}

.beneficios .item {
    text-align: left;
    max-width: 300px;
    padding: 10px 15px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0 auto;
}

.beneficios .item h3 {
    margin-top: 5px;
    margin-bottom: 5px;
    font-weight: 700;
    font-size: 1.6rem;
    position: relative;
}

.beneficios .item h3 i {
    color: #fd9d01;
    font-size: 1.7rem;
    position: absolute;
    left: -38px;
}

.beneficios p {
    line-height: 1.2rem;
    font-size: 1.2rem;
    margin: 0;
}

.beneficios p strong{
    font-weight: 700;
}

#contacto {
    padding: 3rem 0;
}

#contacto .title {
    text-align: center;
    margin-bottom: 2.5rem;
}

#contacto .title h1 {
    font-size: 2.5rem;
    font-weight: 700;
}

#contacto .title h1 span {
    background-color: #fd9d01;
    font-weight: 700;
    padding: 0 1rem;
}

#contacto .title p {
    font-size: 1.2rem;
    line-height: 1.5rem;
}

strong {
    font-weight: 700;
}

#formulario {
    background: #F2F2F2;
    box-shadow: -6px 6px 20px 5px rgba(0, 0, 0, 0.25);
    border-radius: 20px;
    padding: 2rem 3rem;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
}

#formulario input, #formulario select, #formulario::placeholder, .select2-selection, #country_cod {
    color: #27326a !important;
    border-color: #27326a !important;
}

#formulario #amount {
    display: flex;
    align-items: center;
    gap: 15px;
    justify-content: space-between;
    width: 100%;
    max-width: 250px;
    margin: 0 auto;
}
#formulario #amount input {
    width: 90%;
    padding-top: .65rem;
    padding-bottom: .65rem;
    text-align: center;
}
#formulario #amount .btn{
    padding: 0;
    border: none;
}

#formulario #amount .btn i {
    color: #fd9d01;
    font-size: 1.5rem;
}

#formulario .btn-send {
    background-color: #fd9d01;
    color: #ffffff;
    padding: .5rem 1rem;
    text-align: center;
    transition: all .5 ease;
}

#footer {
    background-color: #010658;
    text-align: center;
}

#footer *{
    color: #ffffff;
    font-weight: 300;
}

#footer .descripcion img{
    max-width: 150px;
    width: 100%;
}

#footer .descripcion p {
    margin-top: 2rem;
    font-size: 1rem;
    line-height: 1.2rem;
}

#footer h2 {
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 2rem;
    margin-bottom: 1rem;
}

#footer ul {
    list-style: none;
    padding-left: 0;
}

#footer .redes ul{
    width: 30%;
    max-width: 150px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

#footer .redes ul li a{
    font-size: 1.5rem;
}

#footer .row > div{
    margin-bottom: 3rem;
}

#footer .contacto li{
    justify-content: center;
    font-size: 1.2rem;
    gap: 10px;
}

#footer .contacto {
    margin-bottom: 3rem;
}

#footer .asociados .imagen {
    margin-top: 2rem;
}

.btn-cta:hover {
    background-color: transparent !important;
    
}
.btn-cta {
    border-radius: 50px;
    background-color: #010658 !important;
    color:white;
}

.btn-send:hover {
    background-color: #010658 !important;
}

@media (min-width: 768px) {
    #header-lp img{
        height: 60px;
    }

    #banner-content .btn-cta {
        padding: .8rem 2rem;
        font-size: 4.5rem;
    }

    #descripcion {
        padding: 1.5rem 0;
    }
    
    #descripcion h1 {
        font-size: 2.3rem;
        line-height: 3.4rem;
    }

    .card-paso {
        gap: 20px;
        padding: 2rem 1rem;
        margin-bottom: 2rem;
        width: 100%;
    }
    
    .card-paso .titulo h3 {
        font-size: 1.1rem;
    }
    
    .card-paso .texto p {
        font-size: .8rem;
        line-height: 1rem;
    }

    #beneficios .title h1 {
        font-size: 2.3rem;
        line-height: 2.8rem;
        margin-bottom: 0;
    }

    #beneficios .row{
        align-items: center;
    }

    #beneficios * {
        text-align: left !important;
    }

    .beneficios p {
        font-size: .9rem;
        line-height: 1.1rem;
    }

    .beneficios {
        flex-wrap: wrap;
        flex-direction: row !important;
        margin: 0 !important;
        padding-bottom: 0;
        gap: 0;
    }
    
    .beneficios .item {
        width: 50% !important;
    }
    
    .beneficios .item h3 {
        font-size: 1.3rem;
    }
    
    .beneficios .item h3 i {
        font-size: 1.2rem;
        left: -25px;
    }

    #contacto .title {
        text-align: left;
        padding: 1rem;
        margin-bottom: 0;
    }
    
    #contacto .title h1 {
        font-size: 2.2rem;
    }
    
    #contacto .title p {
        font-size: 1rem;
        line-height: 1.2rem;
    }

    #contacto .row {
        align-items: center;
    }

    #footer .descripcion p {
        font-size: .8rem;
        line-height: 1rem;
    }

    #footer h2 {
        font-size: 1.3rem;
        line-height: 1.5rem;
    }

    #footer .redes ul{
        width: 60%;
        max-width: 100px;
    }

    #footer .contacto, #footer .reclamaciones {
        text-align: left;
    }

    #footer .contacto li{
        font-size: .8rem;
        line-height: 1rem;
        margin-bottom: .7rem;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
    
    #footer .contacto li i {
        margin-right: 0 !important;
        width: 5%;
    }

    #footer .contacto li span {
        width: 90%;
    }

    #footer .asociados .imagen {
        text-align: right;
    }
}

@media (min-width: 992px) {
    .card-paso {
        padding: 2rem;
        width: 90%;
    }
    
    #descripcion {
        margin-top: 2rem;
    }
    
    #descripcion h1 {
        font-size: 2.5rem ;
        line-height: 3.7rem ;
    }

    .card-paso .texto p {
        font-size: .9rem;
        line-height: 1rem;
    }

    .card-paso .titulo h3 {
        font-size: 1.1rem;
    }

    #beneficios .title h1 {
        font-size: 2.5rem;
        line-height: 3.3rem;
    }

    .beneficios p {
        font-size: 1rem;
        line-height: 1.2rem;
    }
}

@media (min-width: 1199px) {
    .card-paso {
        width: 85%;
    }

    #descripcion h1, #beneficios .title h1 {
        font-size: 2.8rem;
        line-height: 3.5rem;
    }

    #contacto .title h1 {
        font-size: 2.7rem;
    }
    
    #contacto .title p {
        font-size: 1.1rem;
        line-height: 1.4rem;
    }

    #footer .contacto li{
        font-size: 1rem;
        line-height: 1.3rem;
    }

    #footer h2 {
        font-size: 1.5rem;
        line-height: 2rem;
    }

}@media (min-width: 1200px) {
    .bordered-image{
        margin-right:0px !important
    }
}

@media (min-width: 1400px) {
    #footer h2 {
        font-size: 1.8rem;
        line-height: 2rem;
    }

}

.barraarriba {
    height: 50px !important;
    margin: auto;
    text-align: center;
    background-color: #010658;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .colorbarraarriba {
    color: white;
    text-align: center;
  }


  .bordered-image {
    border-bottom-right-radius: 160px;
    background-image: linear-gradient(to right, transparent 50%, white 50%);
    background-size: 200% 100%;
    transition: background-position 2s, border-bottom-right-radius 2s, box-shadow 2s;
    box-shadow: 20px -20px 0px #010658;
}

.bordered-image:hover {
    background-position: -100% 0;
    box-shadow: none;
}

.flecha{
    color:white;
    font-size: 20px;
}
.flecha:hover{
    color: #010658;
    font-size: 20px;
}
.hover-color:hover {
    filter: brightness(0.7); /* Cambia el brillo de la imagen al hacer hover */
}
.mobil{
    display: none;
}
@media(max-width: 448px){
    .image-container img{
        margin-left: 0px !important;
        max-width:300px !important;
    }
    .image-container{
        margin-left: 0px !important;
    }
}
@media (max-width: 740px) {
    .banner-ini{
        margin-top: 150px !important;
    }
    .image-container img{
        margin-left: 100px !important;
    }
    .mobil{
        display: block;
    }
    .pc{
        display: none;
    }
    .mbl{
        height: 300px;
        justify-content: center;
        align-items: center;
        text-align:center;
        
    }
    .bordered-image{
        align-items: center;

        min-width: 350px !important;
        max-width: 200px !important;
        margin-left: 50px !important;
        margin-top: 100px;
    }
    .h1banner{
        font-weight: 100px !important;
        font-size: 45px !important;
    }
    .spanbanner{
        font-weight: 100px !important;
        font-size: 20px !important;
        color:#fd9d01;
    }
    .h2banner{
        color: #010658 !important;
        font-weight: 100px !important;
        font-size: 30px !important;
    }
    .abanner{
       font-size: 10px;
    }
    .btn-cta{
        margin-bottom: 20px !important;
    }
    
}
.back{
    position: absolute;
    margin-bottom: -200px !important;
}
.banner-ini{
    margin-top: 170px;
}
.social-media > a {
    padding-right: 4px !important;
    padding-left: 4px !important;
}
.social-media > a > i {
    font-size: 15px;
    background: #012A66;
    color: white;
    border-radius: 50%;
    padding: 6px;
}
.social-media > a > i:hover {
    font-size: 15px;
    background:white;  
    color: #012A66;
    border-radius: 50%;

}
.imgterror {
    background-image: url('/imagenes/bgimgterror.png');
    background-repeat: no-repeat;
    background-size: cover;
    max-width: 500px;
    background-position: center;
    border-bottom-left-radius: 155px;
    transition: background-image 2s;
}

.imgterror:hover {
    background-image: url('/imagenes/Group 475.png');
    background-position: center;
    transition: background-image 2s;
}
.imgterror img {
    transition: transform 0.5s;
}

.imgterror img:hover {
    transform: scale(1.2) translate(8.0%, -8.0%);
}
.fade-in-animation {
    opacity: 0;
    animation: fade-in 1s ease-in forwards;
}

@keyframes fade-in {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
.fade-in-animation-title {
    opacity: 0;
    animation: fade-in-title 1s ease-in forwards;
}

@keyframes fade-in-title {
    0% {
        opacity: 0;
        transform: translateY(-20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
.h1banner{
    font-weight: 800 !important;
    font-size: 80px;
}
.spanbanner{
    color:#fd9d01;
    font-weight: 800 !important;
}

.abanner{
    
   font-size: 20px;
}


@media (max-width: 1400px) {
    .banner-ini{
        margin-top: 70px;
    }
    .h1banner{
        font-weight: 120px !important;
        font-size: 65px !important;
    }
    .spanbanner{
        font-weight: 100px !important;
        font-size: 25px !important;
        color:#fd9d01;
    }
    .h2banner{
        font-weight: 800 !important;
        color: #010658 !important;
        font-weight: 100px !important;
        font-size: 25px !important;
    }
    .abanner{
       font-size: 10px;
    }
    .bordered-image{
        align-items: center;

        min-width: 200px !important;
        max-width: 400px !important;
        margin-left: 50px !important;
        margin-top: 100px;
    }
    .pcimg{
        max-width: 450px !important;
        max-height: 220px;
        margin-left: 60px;
    }
    .pcimg img{
        max-width: 100px !important;
    }
}
@media (max-width: 991px) {
    .bordered-image{
       margin:auto !important;
    }
    .h1banner{
        font-weight: 120px !important;
        font-size: 50px !important;
    }
    .spanbanner{
        font-size: 20px !important;
        color:#fd9d01;
    }
    .h2banner{
        color: #010658 !important;
        font-size: 20px !important;
    }
    .abanner{
       font-size: 10px;
    }
    .bordered-image{
        align-items: center;
        margin-top: 70px !important;
        min-width: 180px !important;
        max-width: 320px !important;
        margin-left: 20px !important;
        margin-top:0px;
    }
    .imgterror{
        min-width: 180px !important;
        max-width: 380px !important;
        min-height: 500px !important;
    }
    .imgterror img {
        min-width: 180px !important;
        max-width: 380px !important;
        min-height: 500px !important;
    }
    .pcimg{
        max-width: 350px !important;
        max-height: 190px;
        margin-left: 60px;
    }
    .pcimg img{
        max-width: 100px !important;
    }
 
}
@media (max-width: 493px) {

    .bordered-image{
        align-items: center;
        text:center !important;
        margin-top: 70px !important;
        min-width: 180px !important;
        max-width: 320px !important;
        margin-top:0px;
        margin-left: 0px !important;
    }

 
}
.tredes{
    padding-left:10px;
}
.te{
    padding-right:125px !important;
}
#banner {
    background-image: url('/imagenes/PATRON\ BG.png'), linear-gradient(5deg, #FFFFFF 34.54%, #EAEAEA 40.52%, #C8CDFF 100%);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom, center 80%;
    background-blend-mode: overlay;
}
.h2banner{
    font-weight: 800 !important;
}
@media (max-width: 510px) {
    .banner-ini{
        margin-top: 50px !important;
    }
    #banner{
        margin-top: 0px;
    }
    .image-container img{
        max-width: 250px !important;
        margin-left: 25px !important;
        margin-right: auto !important;
    }
    .h1banner{
        font-weight: 10px !important;
        font-size: 40px !important;
    }
    .h2banner{
        font-size: 20px !important;
    }
    .spanbanner{
        font-size: 20px !important;
    }
    .mobil img{
        width: 200px;
        margin-bottom:0px;
    }
}