@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@300..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');


:root {

    --black: #000000;
    --white: #FFFFFF;

    --color-1: #8FAAAF;
    --color-2: #00124D;
    --color-3: #C3973B;
    --color-4: #837A69;
    --color-5: #EEDFC8;
    --color-6: #B2B5BE;


    --color-white: #FFFFFF;
    --color-gris: #FAFAFB;

    --fw-100: 100;
    --fw-200: 200;
    --fw-300: 300;
    --fw-400: 400;
    --fw-500: 500;
    --fw-600: 600;
    --fw-700: 700;
    --fw-800: 800;
    --fw-900: 900;

    --fs-14: 14px;
    --fs-16: 16px;
    --fs-18: 18px;
    --fs-20: 20px;
    --fs-22: 22px;
    --fs-24: 24px;
    --fs-25: 25px;
    --fs-26: 26px;
    --fs-28: 28px;
    --fs-30: 30px;
    --fs-32: 32px;
    --fs-34: 34px;
    --fs-35: 35px;
    --fs-38: 38px;
    --fs-40: 40px;
    --fs-42: 42px;
    --fs-48: 48px;
    --fs-50: 40px;
    --fs-55: 55px;
    --fs-60: 40px;

    --xxs: 5px;
    --xs: 10px;
    --s: 15px;
    --xmd: 20px;
    --md: 30px;
    --lg: 40px;
    --x-lg: 60px;
    --xx-lg: 80px;
    --xxx-lg: 100px;
    --xxxx-lg: 150px;

    /* LINE HEIGHT */

    --lh-auto: normal;
    --lh-100: 100%;
    --lh-110: 110%;
    --lh-120: 120%;
    --lh-140: 140%;


    --font-1: "Libre Baskerville", serif;
    --font-2: "Comfortaa", sans-serif;
    --font-3: "Montserrat", sans-serif;


}

a {
    text-decoration: none;
}

body {
    overflow-x: hidden;
}


.font-1 {
    font-family: var(--font-1);
}

.font-2 {
    font-family: var(--font-2);
}

.font-3 {
    font-family: var(--font-3);
}


.color-1 {
    color: var(--color-1);
}

.color-2 {
    color: var(--color-2);
}

.color-3 {
    color: var(--color-3);
}

.color-4 {
    color: var(--color-4);
}

.color-5 {
    color: var(--color-5);
}

.color-6 {
    color: var(--color-6);
}

.color-7 {
    color: var(--color-7);
}


.color-black {
    color: var(--color-black);
}

.color-white {
    color: var(--color-white);
}

.color-gris {
    color: var(--color-gris);
}

.bg-1 {
    background-color: var(--color-1);
}

.bg-2 {
    background-color: var(--color-2);
}

.bg-3 {
    background-color: var(--color-3);
}

.bg-4 {
    background-color: var(--color-4);
}

.bg-5 {
    background-color: var(--color-5);
}

.bg-6 {
    background-color: var(--color-6);
}



.bg-Black {
    background-color: var(--color-black);
}

.bg-White {
    background-color: var(--color-white);
}

.bg-gris {
    background-color: var(--color-gris);
}

.bg-transparent {
    background-color: var(--color-transparent);
}

.fs-60 {
    font-size: var(--fs-60);
}

.fs-50 {
    font-size: var(--fs-50);
}

.fs-48 {
    font-size: var(--fs-48);
}

.fs-42 {
    font-size: var(--fs-42);
}

.fs-41 {
    font-size: var(--fs-41);
}

.fs-40 {
    font-size: var(--fs-40);
}

.fs-35 {
    font-size: var(--fs-35);
}

.fs-38 {
    font-size: var(--fs-38);
}

.fs-32 {
    font-size: var(--fs-32);
}

.fs-30 {
    font-size: var(--fs-30);
}

.fs-28 {
    font-size: var(--fs-28);
}

.fs-25 {
    font-size: var(--fs-25);
}

.fs-24 {
    font-size: var(--fs-24);
}

.fs-22 {
    font-size: var(--fs-22);
}

.fs-20 {
    font-size: var(--fs-20);
}

.fs-18 {
    font-size: var(--fs-18);
}

.fs-16 {
    font-size: var(--fs-16);
}

.fs-14 {
    font-size: var(--fs-14);
}

.fs-12 {
    font-size: var(--fs-12);
}

.fs-10 {
    font-size: var(--fs-10);
}

.lh-auto {
    line-height: normal;
}

.lh-100 {
    line-height: var(--lh-100);
}

.lh-110 {
    line-height: var(--lh-110);
}

.lh-120 {
    line-height: var(--lh-120);
}

.lh-140 {
    line-height: var(--lh-140);
}

.mb-40 {
    margin-bottom: 40px;
}

.mt-40 {
    margin-top: 40px;
}

.mt-60 {
    margin-top: 60px;
}

.mt-20 {
    margin-top: 20px;
}

.mb-80 {
    margin-bottom: 80px;
}

.mt-80 {
    margin-top: 80px;
}

.pb-80 {
    padding-bottom: 80px;
}

.pt-80 {
    padding-top: 80px;
}

.p-80 {
    padding: 55px;
}

.fondo-color {
    border-radius: 80px 80px 0px 0px;
    background: linear-gradient(237deg, rgba(0, 18, 77, 0) 25%, rgba(0, 18, 77, 1) 77%);
}
.nowrap{
    white-space: nowrap;
}

/* Botones */

.btn-primario {
    border-radius: 100px;
    background-color: var(--color-2);
    color: var(--color-white);
    border: none;
    padding: 16px 40px;
    width: fit-content;
    white-space: nowrap;
}

.btn-secundario {
    border-radius: 100px;
    background-color: var(--color-1);
    color: var(--color-white);
    border: none;
    padding: 16px 40px;
}





/*============ PRELOADER START ============*/
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: table;
    width: 100%;
    height: 100%;
    z-index: 9999;
    background: var(--color-white);
    -webkit-transition: background-color 0s ease-in-out !important;
    -moz-transition: background-color 0s ease-in-out !important;
    transition: background-color 0s ease-in-out !important;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#102a63", endColorstr="#384d7a", GradientType=1);
}

/*#preloader .preloader-logo-container svg{
    width: 343px;
    height: 71px;
}*/

#preloader.transparent {
    background-color: transparent;
}

#preloader .preloader-logo-container {
    opacity: 0;
    overflow: hidden;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
}

#preloader .preloader-logo-container.show {
    opacity: 1;
    animation: showLogo 1s ease-out 0s;
    transform: translate(0%, 0%);
    -o-transform: translate(0%, 0%);
    -moz-transform: translate(0%, 0%);
    -webkit-transform: translate(0%, 0%);
    transition: opacity 1s ease-out, transform 1s ease-in-out 1.1s;
    -o-transition: opacity 1s ease-out, transform 1s ease-in-out 1.1s;
    -moz-transition: opacity 1s ease-out, transform 1s ease-in-out 1.1s;
    -webkit-transition: opacity 1s ease-out, transform 1s ease-in-out 1.1s;
}

/* ANIMATION */



#preloader .preloader-logo-container img path {
    opacity: 0;
    animation: reveal 1s forwards;
}

#preloader .preloader-logo-container img path:nth-child(1) {
    animation-delay: 0s;
}

#preloader .preloader-logo-container img path:nth-child(2) {
    animation-delay: 0.1s;
}

#preloader .preloader-logo-container img path:nth-child(3) {
    animation-delay: 0.2s;
}

#preloader .preloader-logo-container img path:nth-child(4) {
    animation-delay: 0.3s;
}

#preloader .preloader-logo-container img path:nth-child(5) {
    animation-delay: 0.4s;
}

#preloader .preloader-logo-container img path:nth-child(6) {
    animation-delay: 0.5s;
}

#preloader .preloader-logo-container img path:nth-child(7) {
    animation-delay: 0.6s;
}

#preloader .preloader-logo-container img path:nth-child(8) {
    animation-delay: 0.7s;
}

#preloader .preloader-logo-container img path:nth-child(9) {
    animation-delay: 0.8s;
}

#preloader .preloader-logo-container img path:nth-child(10) {
    animation-delay: 0.9s;
}

#preloader .preloader-logo-container img path:nth-child(11) {
    animation-delay: 1s;
}



/*============ PRELOADER END ============*/

/* NAB */

.dropdown-menu {
    background-color: var(--color-1);
    padding: 20px;
}

.dropdown-menu hr {
    color: var(--color-white);
    margin-top: 12px;
    margin-bottom: 12px;
    opacity: 1;
}

.dropdown-item.active, .dropdown-item:active {
    color: var(--bs-dropdown-link-active-color);
    text-decoration: none;
    background-color: var(--color-gris);
}

.dropdown-item:focus, .dropdown-item:hover {
    color: var(--bs-dropdown-link-hover-color);
    background-color: #f8f9fa87;
}

.circulo-azul-nav {
    width: 15px;
    height: 15px;
    border-radius: 100px;
    background-color: var(--color-1);
    display: inline-block;
    margin-right: 5px;
}

.dropdown-toggle::after {
    display: none;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid;
    border-right: .3em solid transparent;
    border-bottom: 0;
    border-left: .3em solid transparent;
}


/* HOME */


.banner-home {
    background-image: url(../img/banner-home.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 80px 80px 0px 0px;
    height: 600px;
    position: relative;
}

.boton-aparece {
    border-radius: 0px 40px 40px 30px;
    padding: 20px 20px;
    background-color: var(--color-3);
    color: var(--color-white);
    width: fit-content;
}

@media (min-width: 992px) {
    #texto-1 {
        width: 41%;
    }

    .content-p {
        height: 628px;
    }
}

@media (max-width: 769px) {

    .fs-50 {
        font-size: var(--fs-30);
    }

    .fs-40 {
        font-size: var(--fs-28);
    }

    .fs-32 {
        font-size: var(--fs-18);
    }

    .fs-18 {
        font-size: var(--fs-16);
    }

    .fs-25 {
        font-size: var(--fs-18);
    }

    .mb-40 {
        margin-bottom: 20px;
    }

    .mt-40 {
        margin-top: 20px;
    }

    .mb-80 {
        margin-bottom: 40px;
    }

    .mt-80 {
        margin-top: 40px;
    }

    .p-80 {
        padding: 16px;
    }

    .cuadrado {
        width: 100%;
        max-width: 70px;
        height: 100%;
        min-height: 70px;
        padding: 22px 20px;
        border-radius: 20px;
    }

    .banner-home {
        background-image: url(../img/banner-home.png);
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        border-radius: 80px 80px 0px 0px;
        height: 410px;
        position: relative;
    }
}

.texto-aparece {
    opacity: 0;
    animation: fadeIn 2s ease-in forwards;
    animation-delay: 2s;
    /* Aparece después de 1s */
}

.boton-aparece {
    opacity: 0;
    animation: fadeIn 2s ease-in forwards;
    animation-delay: 3s;
    /* Aparece después de 2s */
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.border-radius-30 {
    border-radius: 30px;
}

.banner-home-2 {
    background-image: url(../img/banner-home-2.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    min-height: 2039px;
    border-radius: 50px;
    position: relative;
}

#linea-centro {
    position: absolute;
    top: 0px;
    left: 246px;
    z-index: 3;
    width: 725px;
    height: 1854px;
}



#linea-relleno {
    stroke-dasharray: 1;
    stroke-dashoffset: 1;
    animation: line-animation 0.8s linear forwards;
    animation-timeline: scroll();
    animation-range-start: 6%;
    animation-range-end: 50%;
}


@keyframes line-animation {
    from {
        stroke-dashoffset: 1;
    }

    to {
        stroke-dashoffset: 0;
    }
}


#linea-centro-movil {
    display: none;
}


#linea-relleno-movil {
    stroke-dasharray: 5300.391;
    stroke-dashoffset: 5300.391;
    animation: line-animation-movil linear forwards;
    animation-timeline: scroll();
    animation-range: 10% 90%;

}


@keyframes line-animation-movil {

    to {
        stroke-dashoffset: 0;
    }
}



.mostrar-1,
.mostrar-2,
.mostrar-3,
.mostrar-4,
.mostrar-5,
.mostrar-6 {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.mostrar-1.visible,
.mostrar-2.visible,
.mostrar-3.visible,
.mostrar-4.visible,
.mostrar-5.visible,
.mostrar-6.visible {
    opacity: 1;
    transform: translateY(0);
}



/* #linea-relleno {
    stroke-dasharray: 100; 
    stroke-dashoffset: 100; 
    transition: stroke-dashoffset 0.2s ease-out; 
}


.mostrar-1 {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
} */

.card-lineas-container {
    position: absolute;
}

.caracteristicas {
    margin-top: 856px;
    position: absolute;
    z-index: 3;
    padding-left: 185px;
}

.caracteristica {
    margin-top: 40px;
    display: flex;
    gap: 40px;
    align-items: center;
}

.icon-background {
    background-color: var(--color-white);
    padding: 24px 35px;
    border-radius: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 140px;
    height: 140px;
}

#relleno {
    transition: stroke-dashoffset 0.2s linear;
}

@media (max-width: 1300px) {
    #linea-centro {
        position: absolute;
        top: 0px;
        left: 111px;
        z-index: 3;
        width: 725px;
        height: 1854px;
    }

    .fs-40 {
        font-size: var(--fs-32);
    }
}

@media (max-width: 767px) {
    .fs-60 {
        font-size: var(--fs-20) !important;
    }

    .banner-home-2 {
        background-image: url(../img/banner-home-2.png);
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        min-height: 1603px;
        border-radius: 50px;
    }

    .icon-background {
        background-color: var(--color-white);
        padding: 24px 35px;
        border-radius: 20px;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 98px !important;
        height: 98px !important;
    }

    .caracteristicas {
        margin-top: 727px;
        position: absolute;
        z-index: 3;
        padding-left: 37px;
    }

    .caracteristica {
        margin-top: 40px;
        display: flex;
        gap: 20px;
        align-items: center;
    }

    #texto-1 {
        width: 70%;
    }

    #texto-2 {
        width: 73%;
    }

    #texto-3 {
        width: 48%;
    }

    #texto-1 p {
        font-size: var(--fs-22);
    }

    #texto-2 p {
        font-size: var(--fs-22);
    }

    #texto-3 p {
        font-size: var(--fs-22);
    }

    #linea-centro-movil {
        position: absolute;
        top: 0px;
        left: 45px;
        z-index: 3;
        display: block;
    }


    #linea-centro {
        display: none;
    }

}

.content-p {
    height: 776px;
}

.p-70-40-20 {
    padding: 70px 20px 20px 20px;
}

.p-70-40-20-2 {
    padding: 70px 20px 20px 20px;
}

.border-radius-30 {
    border-radius: 30px;
}

.boton-noticias {
    border-radius: 30px 40px 40px 0px;
    width: fit-content;
    padding: 10px 20px;
}

.circulo-blanco {
    border-radius: 40px;
    background-color: var(--color-white);
    border: none;
    padding: 16px 20px;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease;
}

.ayudas:hover .circulo-blanco {
    transform: scale(1.2);
    /* Agranda el círculo un 20% */
}

.noticias:hover .circulo-blanco {
    transform: scale(1.2);
    /* Agranda el círculo un 20% */
}

.mt-100 {
    margin-top: 100px;
}

.mb-63 {
    margin-bottom: 63px;
}

.cuadrado {
    width: 100%;
    max-width: 80px;
    height: 100%;
    min-height: 80px;
    /* padding: 26px 26px; */
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.text-shadow {
    text-shadow: 3px 3px 8px rgba(0, 0, 0, 0.6);
}

.image-container {
    position: relative;
    display: inline-block;
}

.image-container img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 30px 30px 0px 0px;
}

.image-container::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 30px 30px 0px 0px;
    background: linear-gradient(266deg, rgba(0, 18, 77, 0) 0%, rgba(0, 18, 77, 1) 100%);
}

.border-radius-30-0 {
    border-radius: 30px 30px 0px 0px;
}

.border-radius-b30 {
    border-radius: 0px 0px 30px 30px;
}

@media (max-width: 769px) {

    .content-p {
        height: 676px;
    }

    .p-70-40-20-2 {
        padding: 30px 20px 20px 20px;
    }

    .mt-100 {
        margin-top: 40px;

    }

    .img-movil {
        height: 224px;
    }

    .mb-63 {
        margin-bottom: 38px;
    }

    .pb-80 {
        padding-bottom: 40px;
    }

    .pt-80 {
        padding-top: 40px;
    }

}

@media (max-width: 992px) {
    .dropdown-menu.show{
        position: absolute;
        left: 0;
        right: 0;
        display: block;
    }
    .bg-opaco {
        height: 100%;
        border-radius: 30px;
        display: flex;
        flex-direction: column;
        justify-content: end;
    }

    .boton-noticias {
        border-radius: 30px 40px 40px 0px;
        width: fit-content;
        padding: 5px;
        margin-left: auto;
        margin-right: 0;
    }

    .fs-60 {
        font-size: var(--fs-30);
    }

    .fs-24 {
        font-size: var(--fs-18);
    }

    .fs-30 {
        font-size: var(--fs-25);
    }

    .icon-background {
        background-color: var(--color-white);
        padding: 24px 35px;
        border-radius: 20px;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 122px;
        height: 122px;
    }

    .cuadrado-2 {
        width: 100%;
        max-width: 86px !important;
        height: 100%;
        min-height: 86px !important;
        padding: 26px 26px;
        border-radius: 20px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .fa-2xl {
        font-size: 40px;
        line-height: .03125em;
        vertical-align: -.1875em;
    }

}

.slick-dots li button:before {
    font-family: 'slick';
    font-size: 15px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: '•';
    text-align: center;
    opacity: .25;
    color: black;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* QUIERES_SOMOS */

.boton-deforme {
    border-radius: 0px 40px 40px 30px;
    padding: 20px 20px;
    background-color: var(--color-1);
    color: var(--color-white);
    width: fit-content;
}

.cuadrado-2 {
    width: 100%;
    max-width: 140px;
    height: 100%;
    min-height: 140px;
    padding: 26px 26px;
    border-radius: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.fa-2xl {
    font-size: 50px;
    line-height: .03125em;
    vertical-align: -.1875em;
}

.border-radius-80 {
    border-radius: 80px;
}

/* novedades */

.img-novedades {
    max-width: 580px;
    width: 100%;
    height: 100%;
    max-height: 318px;
    object-fit: cover;
    border-radius: 30px;
}


.image-container-2::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    max-width: 580px;
    width: 100%;
    height: 100%;
    max-height: 318px;
    border-radius: 30px;
    background: linear-gradient(266deg, rgba(0, 18, 77, 0) 0%, rgba(0, 18, 77, 1) 100%);
}

.circulo-azul {
    border-radius: 40px;
    background-color: var(--color-2);
    border: none;
    padding: 16px 18px;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease;
}

.noticias:hover .circulo-azul {
    transform: scale(1.2);
    /* Agranda el círculo un 20% */
}

/* ASESORAMIENTO_FISCAL */

.boton-deforme-contabilidad {
    border-radius: 0px 40px 40px 30px;
    padding: 20px 20px;
    background-color: var(--color-3);
    color: var(--color-white);
    width: fit-content;
}

.cuadrado-check {
    width: 100%;
    max-width: 50px;
    height: 100%;
    min-height: 50px;
    padding: 11px 0px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cuadrado-check i {
    font-size: 33px;
    line-height: .03125em;
    vertical-align: -.1875em;
}

.p-70-40 {
    padding: 70px 40px;
}

@media (max-width: 769px) {
    .p-70-40 {
        padding: 10px 40px;
    }

    .info-gerente {
        text-align: center;
    }
}

/* Contacto */

.boton-deforme-contacto {
    border-radius: 0px 40px 40px 30px;
    padding: 20px 20px;
    background-color: var(--color-1);
    color: var(--color-white);
    width: fit-content;
}

.border-radius-20 {
    border-radius: 20px;
}

.form-control {
    display: block;
    width: 100%;
    padding: 20px 40px;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #FAFAFB;
    background-clip: padding-box;
    border: none;
    border-radius: 80px;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.form-control:focus {
    color: var(--bs-body-color);
    background-color: #FAFAFB;
    border-color: #C3973B;
    outline: 0;
    box-shadow: 0 0 0 .25rem rgb(189 156 0 / 22%);
}

/* footer */
.borde {
    border-radius: 80px 80px 0px 0px;
}

.info-gerente {
    max-width: 547px;
}

.bg-opaco {
    background-color: rgba(0, 0, 0, 0.3);
    border-bottom-left-radius: 30px;

}

.cuerpo-articulo img {
    display: none;
}

.cuerpo p,
.cuerpo span {
    font-family: var(--font-3);
    font-size: var(--fs-18);
    line-height: 1.5;
    color: var(--color-black);
}