header.fixed{
    /*position: fixed;*/
    /*top: 0;*/
    /*left: 0;*/
    /*width: 100%;*/
    /*z-index: 1000;*/
    background-color: white;
    border-bottom: 1px solid #000000;
    transition: all 0.3s ease-out;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    height: 71px!important;
}
@keyframes slideDown {
    from {
        transform: translateY(-100%);
    }
    to {
        transform: translateY(0);
    }
}
header.fixed .nav-link{
    color: #000000!important;
}
header.fixed svg .cls-1{
    fill: #000000;
}
header.fixed .header-logo svg {
    width: 60px;
}
header.fixed .nav-link.active::after {
    background-color: #000000!important;
}
header.fixed .header-menu .navbar-nav .nav-item .nav-link {
    padding: 25px 20px!important;
}
header.fixed .nav-link.dropdown-toggle::before {
    background-color: #000!important;
}
header.fixed .nav-link::after {
    background-color: #000!important;
}
.header-logo svg .cls-1{
    fill: #ffffff;
    transition: all 0.3s ease-out;
}
.header-logo svg {
    width: 80px;
    aspect-ratio: 1/1;
    object-fit: contain;
    transition: all 0.3s ease-out;
}



.max-width,
.space-header {
    max-width: 1920px
}

.dropdown .dropdown-menu,
.header-menu .navbar-nav .nav-item .nav-link {
    font-family: var(--font-family-DM, sans-serif);
    line-height: 1.2em;
    margin: 0
}

.m09 .percentage,
.m09 .year {
    top: -11px;
    position: absolute
}

:root {
    --font-family-sora: "Sora";
    --font-family-DM: "DM Sans"
}

.space-header {
    margin: 100px auto 0
    /*margin: 0 auto 0*/
}

.header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    height: 100px;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    /*background: #fff;*/
    background-color: rgba(0,0,0,0.4);
    z-index: 20
}

.header-main {
    border-bottom: 1px solid #ffffff;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
}


.header-logo,
.searchempty {
    position: relative
}

.header-logo__clicktag {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.header-logo img {
    width: 70px;
    /*height: 70px;*/
    height:auto;
    -o-object-fit: contain;
    object-fit: contain
    aspect-ratio: 1/1;
}

@media screen and (min-width:1200px) {
    .header-menu {
        position: relative
    }

    .header-menu .navbar-nav {
        gap: 24px
    }
}

.header-menu {
    position: unset;
    padding:0;
}

@media screen and (min-width:1200px) {
    .header-menu .navbar-nav {
        gap: 10px
    }

    .header-menu .navbar-nav .nav-item .nav-link {
        padding: 10px 0;
    }
}

.nav-link{
    position: relative;
}

.nav-link::after{
    content: '';
    width: 0;
    height: 4px;
    background-color: #ffffff;
    position: absolute;
    bottom: 0;
    left: 0;
    transition: .4s;
}

.nav-link:hover::after{
    width: 100%;
}

.header-menu .navbar-nav {
    gap: 5px
}

.not-flound {
    background-color: #f3f5f6;
    min-height: 500px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.button-primary-not-flound,
.button-rounded {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    -webkit-box-pack: center;
    -webkit-transition: .3s ease-in;
    -o-transition: .3s ease-in
}

.not-flound-main {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 350px
}

.button-primary-not-flound {
    background: #4d5154;
    width: auto;
    min-width: 105px;
    font-family: var(--font-family-DM);
    font-weight: 700;
    text-align: center;
    text-decoration: none !important;
    display: inline-flex;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    outline: 0;
    cursor: pointer;
    transition: .3s ease-in;
    padding: 16px 24px;
    border-radius: 5px;
    color: #fff
}

.button-primary-not-flound:hover {
    background-color: #111219;
    color: #fff
}

@media screen and (min-width:568px) {
    .not-flound-main {
        background-size: 500px
    }
}

.header-menu .navbar-nav .nav-item .nav-link {
    font-size: 19px;
    font-weight: 400;
    color: #111219;
    /*color: #ffffff;*/
    position: relative;
    padding: 38px 20px;
    width: 100%;
}

@media screen and (max-width:1200px) {
    .header-menu .navbar-nav .nav-item .nav-link {
        padding: 10px 20px
    }
    .header-menu .navbar-nav .nav-item {
        align-items: center;
    }
}

.header-menu .navbar-nav .nav-item.dropdown,
.testimonial .swiper-slide {
    width: auto
}

.header-menu .navbar-nav .nav-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    /*-webkit-box-align: center;*/
    /*-ms-flex-align: center;*/
    /*align-items: center*/
    align-items: flex-start;
}

.nav-item.dropdown{
    flex-direction: column;
    align-items: flex-start;
}

.nav-item.dropdown .nav-link{
    position: relative;
}

.nav-item.dropdown .nav-link::after{
    content: '';
    width: 0;
    height: 4px;
    background-color: #000000;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 4;
    transition: .4s;
}

.nav-item.dropdown:hover .nav-link::after{
    width: 100%;
}

.header-menu .navbar-nav .nav-item.dropdown .nav-link.dropdown-toggle::after {
    
    display: none;
}

.nav-link.dropdown-toggle::before{
    content: '';
    width: 0;
    height: 4px;
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: #fff;
    transition: .4s;
}

.nav-item.dropdown:hover .nav-link::before{
    
    width: 100%;
}

.dropdown .dropdown-toggle.show::after {
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg)
}

@media screen and (min-width:1200px) {
    .header-menu .navbar-nav .dropdown-menu {
        position: static
        margin-right: auto;
        border-bottom: 1px solid #000000;
        background-color: #fff!important;
        padding: 0;
    }
    .dropdown-menu{
        background-color: transparent;
    }
}

.header-menu .navbar-nav .dropdown-menu {
    top: 100%;
    left: 0;
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    /*background-color: #fff;*/
    background-color: #EFEFEF;
    position: absolute;
    margin-right: auto;
}

.dropdown .dropdown-menu {
    width: 100%;
    font-size: 1.125rem;
    font-weight: 500;
    color: #fff;
    border: none;
    -webkit-box-shadow: 0 4px 15px 0 rgba(59, 138, 199, .21);
    box-shadow: 0 4px 15px #3b8ac736
    margin-right: auto;
}

.header-menu-colapse {
    position: absolute;
    width: 100%;
    top: calc(100% + .4px);
    left: 0;
    background-color: #fff;
}

.header-menu .navbar-nav .nav-item .nav-link.active::after {
    content: "";
    /*width: 4px;*/
    width: 100%;
    height: 4px;
    /*border-radius: 50%;*/
    /*background-color: #111219;*/
    background-color: #ffffff;
    position: absolute;
    /*left: 10px;*/
    left: 0;
    /*top: 50%;*/
    bottom: 0;
    /*-webkit-transform: translateY(-50%);*/
    /*-ms-transform: translateY(-50%);*/
    /*transform: translateY(-50%)*/
}

.header-menu .navbar-nav .nav-item .nav-link.active {
    color: #ffffff;
    font-weight: 800
}



.btn {
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 14px;
    font-weight: 400;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    transition: .3s
}

.button-primary,
.button-rounded {
    text-decoration: none !important;
    outline: 0;
    cursor: pointer
}

.btn-outline-secondary {
    color: #333;
    border: 1px solid #000;
    background-color: #fff
}

.btn-outline-secondary:hover {
    background-color: #f8f9fa;
    color: #000
}

.btn-dark {
    color: #fff !important;
    background-color: #000;
    border: 1px solid #000
}

.btn-dark:hover {
    background-color: #23272b
}

.fa-circle-user {
    font-size: 16px
}

.m10 .btn-custom {
    width: auto;
    padding-left: 2rem;
    padding-right: 2rem
}

.m10 .btn-container {
    display: flex;
    justify-content: start;
    margin-top: 1rem
}

.m10 .card-image img {
    max-height: 550px;
    object-fit: cover
}

.fade-out {
    opacity: 0;
    transition: opacity .5s ease-out
}

.custom-member-image:hover .custom-overlay,
.fade-in {
    opacity: 1
}

.fade-in {
    transition: opacity .5s ease-in
}

.m14 .section-charter {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    max-width: 1440px;
    margin: 0 auto;
    height: auto
}

.m14 .flex-content-charter {
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
    overflow: hidden;
    position: relative
}

.m14 .parent-content-charter {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 20px
}

.m14 .text-charter {
    max-width: 340px
}

.m14 .icon-charter {
    width: 100%;
    height: 73px;
    max-width: 73px;
    max-height: 73px;
    object-fit: cover
}

.m16 .accordion-border {
    border: 2px solid #000;
    border-left: 0;
    border-right: 0
}

.m16 .accordion-item-border {
    border: var(--bs-accordion-border-width) solid #000;
    border-left: 0;
    border-right: 0
}

.custom-form-check-label,
.custom-form-check-label a,
.m16 .accordion-button:not(.collapsed) {
    color: #000
}

.m17 .grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    grid-gap: 100px 20px;
    justify-items: center;
    align-items: center;
    margin: 0 auto;
    width: 60%
}

.m17 .grid-item,
.select-filter option {
    text-align: center
}

.m17 .grid-item-logo img {
    max-width: 100%;
    height: auto
}

.icon-ligth {
    color: #111219;
    font-size: 28px
}

.title-banner-general h1,
.title-banner-general h2 {
    font-family: var(--font-family-sora, sans-serif);
    font-size: clamp(var(--size, 2.6rem), 4vw, var(--size-lg, 4.5rem));
    font-weight: var(--bold, 800);
    line-height: clamp(50px, 4vw, 72px);
    letter-spacing: 1.5px;
    color: var(--color, #fff)
}

.title-h2,
.title-h2 h2 {
    font-family: var(--font-family, "Sora");
    font-size: clamp(var(--size, 2.75rem), 4vw, var(--size-lg, 3.25rem));
    font-weight: var(--bold, 600);
    line-height: var(--spacing, 1.2);
    letter-spacing: .7px;
    color: var(--color, #111219)
}

.paragraph,
.paragraph a,
.paragraph button,
.paragraph h2,
.paragraph h3,
.paragraph h4,
.paragraph h5,
.paragraph li,
.paragraph p {
    font-family: var(--font-family-DM, sans-serif);
    color: var(--color, #111219);
    font-size: var(--size, 1.125rem);
    font-weight: var(--bold, 400);
    line-height: var(--spacing, 1.4)
}

.bold-900 {
    --bold: 900
}

.bold-800 {
    --bold: 800
}

.bold-700 {
    --bold: 700
}

.bold-600 {
    --bold: 600
}

.bold-500 {
    --bold: 500
}

.bold-400 {
    --bold: 400
}

.color-white {
    --color: #fff
}

.color-custom-1 {
    --color: #757575
}

.color-custom-2 {
    --color: #010101
}

.color-custom-3 {
    --color: #FFFFFFB2
}

.size-12 {
    --size: 0.75rem
}

.size-14 {
    --size: 0.875rem
}

.size-16 {
    --size: 1rem
}

.size-18 {
    --size: 1.125rem
}

.size-20 {
    --size: 1.25rem
}

.size-22 {
    --size: 1.375rem
}

.size-24 {
    --size: 1.5rem
}

.size-26 {
    --size: 1.625rem
}

.size-28 {
    --size: 1.75rem
}

.size-30 {
    --size: 1.875rem
}

.size-32 {
    --size: 2rem
}

.size-52 {
    --size: 3.25rem
}

.size-56 {
    --size: 3.5rem
}

.size-lg-18 {
    --size-lg: 1.125rem
}

.size-lg-20 {
    --size-lg: 1.25rem
}

.size-lg-22 {
    --size-lg: 1.375rem
}

.size-lg-24 {
    --size-lg: 1.5rem
}

.size-lg-26 {
    --size-lg: 1.625rem
}

.size-lg-28 {
    --size-lg: 1.75rem
}

.size-lg-30 {
    --size-lg: 1.875rem
}

.size-lg-32 {
    --size-lg: 2rem
}

.size-34 {
    --size-lg: 2.125rem
}

.size-36 {
    --size-lg: 2.25rem
}

.size-38 {
    --size-lg: 2.375rem
}

.size-40 {
    --size-lg: 2.5rem
}

.size-42 {
    --size-lg: 2.625rem
}

.size-50 {
    --size-lg: 3.125rem
}

.size-80 {
    --size: 5rem
}

.spacing-34 {
    --spacing: 2.15rem
}

.spacing-36 {
    --spacing: 2.25rem
}

.family-DM {
    --font-family: "DM Sans"
}

.navbar-toggler{
    background-color: #fff;
    border: 1px solid #fff;
}

.navbar-toggler-icon {
    border-color: #fff
}

.button-ham,
.swiper-button-next,
.swiper-button-prev {
    color: #111219
}

.home-galeria {
    max-height: 850px
}

.home-galeria__slider picture.banner-height {
    display: block;
    position: relative
}

.home-galeria__slider .banner-height {
    max-height: 600px
}

.banner-main-navigation {
    position: relative;
    width: 100%;
    bottom: 70px;
    z-index: 2
}

.button-rounded {
    background: var(--color, #111219);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    transition: .3s ease-in;
    color: #fff
}

.button-rounded--white {
    background-color: #ffffff20;
    color: var(--color, #111219)
}

.button-rounded--white:hover,
.swiper-pagination-custom .swiper-pagination-bullet-active {
    background-color: #fff
}

.swiper-button-disabled:hover {
    background-color: #ffffff20
}

.button-rounded .icon {
    font-size: 15px
}

.banner-main-pagination {
    position: relative;
    width: 100%;
    bottom: 80px !important;
    z-index: 2
}

.home-galeria__slider img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.layer-front {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background-color: rgba(0, 0, 0, .2)
}

.button-primary {
    width: auto;
    min-width: 105px;
    font-family: var(--font-primary, Lato);
    font-weight: 700;
    text-align: center;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: 1px solid;
    -webkit-transition: .3s ease-in;
    -o-transition: .3s ease-in;
    transition: .3s ease-in;
    padding: 16px 24px;
    border-radius: 20px;
    color: var(--color, #fff)
}

#heading-contact-us,
.button-contact,
.footer-legal:hover,
.m11 .grid-item a {
    text-decoration: none
}

.button-primary:hover {
    background-color: var(--color, #111219);
    color: var(--color, #fff);
    border: 1px solid var(--color, #111219)
}

.container-parent {
    margin: 3vh
}

.Card-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
    align-items: center;
    max-width: 1300px;
    margin: 0 auto 36px
}

.Card-grid:nth-child(2n) {
    grid-template-areas: "contenido imagen"
}

.content-img {
    grid-area: imagen;
    width: 100%
}

.title-grid h3 {
    color: #212529;
    font-family: Lato;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 21.6px;
    margin-top: 10px
}

.Photo {
    width: 100%;
    border-radius: 6px;
    height: auto
}

.CardGrid_paragraph p {
    color: var(--Texto, #595959);
    font-family: Lato;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px
}

.footer {
    background: #111219
}

.icon-footer {
    color: #fff;
    font-size: 30px
}

.footer-legal:hover {
    color: #fff
}

.footer-bbt-main__bbt {
    width: 80px
}

.footer-bbt-main span {
    width: 15px
}

.footer-bbt-main span img,
.footer-bbt-main__bbt img {
    width: 100%;
    -o-object-fit: contain;
    object-fit: contain
}

.training-swiper__item img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.training-swiper .swiper-pagination-custom {
    position: static
}

.training-swiper__text {
    position: absolute;
    margin-left: 24px;
    bottom: 0
}

.content-image img {
    max-width: 630px;
    max-height: 460px;
    object-fit: cover
}

.image-m6,
.testimonial {
    background: #f7f7f7
}

.new-card-testimonial {
    background: #fff;
    position: relative
}

.quote-icon-svg {
    position: absolute;
    top: 20px;
    left: 20px;
    width: 50px;
    height: auto;
    opacity: .1;
    z-index: 0
}

.boxsize {
    width: 500px;
    height: auto
}

@media (max-width:568px) {
    .boxsize {
        width: 380px
    }
}

.content-image-m6 {
    max-width: 850px;
    max-height: 480px;
    object-fit: cover
}

.content-image-map {
    max-width: 635px;
    max-height: 762px;
    object-fit: cover
}

.button-contact {
    color: #000;
    background: #fff;
    width: 150px;
    height: 53px;
    border: #000;
    border-radius: 4px
}

.button-contact:hover {
    color: #000;
    background: #fff
}

.m09 .survey-chart {
    display: flex;
    flex-direction: column;
    gap: 30px
}

.m09 .survey-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.m09 .bar {
    width: 100%;
    background-color: #f0f0f0;
    height: 6px;
    position: relative;
    margin-bottom: 5px
}

.m09 .progress {
    height: 100%;
    background-color: #000
}

.m09 .labels {
    display: flex;
    justify-content: space-between;
    position: relative;
    width: 100%;
    margin-top: 5px
}

.m09 .year {
    left: 0;
    font-weight: 700
}

.m09 .percentage {
    font-weight: 700;
    transform: translateX(-50%);
    bottom: 0
}

.testimonial-avatar {
    width: 48px;
    height: 48px;
    object-fit: cover;
    border-radius: 50%
}

.grid-img,
.m11 .grid-item {
    border-radius: 8px;
    transition: transform .3s;
    background-color: #fff;
    text-align: center
}

.avatar-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px
}

.m11 .nav-link {
    font-weight: 700;
    color: #000
}

.m11 .nav-link.active,
.m24 .nav-link.active {
    color: #000;
    border-bottom: 2px solid #000
}

.m11 .grid-container,
.m21 .people-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 10px
}

.form-select--admin .nice-select:after,
.nice-select:after {
    display: none
}

.interna-grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px
}

.grid-img img {
    width: 100%;
    height: 300px;
    margin-bottom: 10px;
    object-fit: cover;
    cursor: pointer
}

.m11 .grid-item {
    padding: 10px
}

.m11 .grid-item img {
    width: 100%;
    height: 290px;
    margin-bottom: 10px;
    object-fit: cover
}

.m11 .grid-item:hover {
    transform: translateY(-5px)
}

.pagination-page {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background-color: #fff;
    border: 1px solid;
    color: #393737;
    font-weight: 700;
    margin-right: 10px;
    -webkit-transition: .3s;
    transition: .3s
}

.pagination-arrow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    color: #959595;
    border: none;
    background-color: transparent;
    margin: 0 10px
}

.pagination-page:is(:hover, :active, :focus, .active) {
    background-color: #757575;
    border-color: #757575;
    color: #fff
}

.form-select--admin .nice-select,
.nice-select {
    font-weight: 400;
    background-color: var(--white);
    padding: .75rem 10px;
    font-size: var(--font-size, 16px);
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.searchempty-image img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover
}

.searchempty-content {
    position: relative;
    display: grid;
    place-content: center;
    place-items: center;
    height: clamp(200px, 30vw, 250px)
}

.m12 {
    max-height: 600px
}

.layer-front-services {
    position: absolute;
    left: 0;
    top: 127px;
    height: 100%;
    max-height: 600px
}

.nice-select {
    color: var(--font-color, var(--dark));
    font-family: var(--font-family-DM, var(--font-secondary));
    width: 100%;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid #000
}

.nice-select:before {
    content: "";
    width: 20px;
    height: 20px;
    color: var(--blue-primary);
    position: absolute;
    top: 30%;
    right: 12px;
    z-index: 1
}

.nice-select.open .nice-select-dropdown {
    width: 100%
}

.nice-select .option.focus,
.nice-select .option.selected.focus,
.nice-select .option:hover {
    background-color: #cbdcef
}

.form-select--admin .nice-select {
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    width: 100%;
    height: 45.17px;
    border-radius: 5px;
    border: 1px solid var(--gray-secondary)
}

.form-select--admin .nice-select::-webkit-input-placeholder {
    font-size: var(--font-size, 16px);
    font-weight: var(--font-weight, 400);
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.form-select--admin .nice-select::-moz-placeholder {
    font-size: var(--font-size, 16px);
    font-weight: var(--font-weight, 400);
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.form-select--admin .nice-select:-ms-input-placeholder {
    font-size: var(--font-size, 16px);
    font-weight: var(--font-weight, 400);
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.form-select--admin .nice-select::-ms-input-placeholder {
    font-size: var(--font-size, 16px);
    font-weight: var(--font-weight, 400);
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.form-select--admin .nice-select::placeholder {
    font-size: var(--font-size, 16px);
    font-weight: var(--font-weight, 400);
    color: var(--font-color, var(--dark));
    font-family: var(--font-family, var(--font-secondary));
    line-height: var(--line-height, 1.2em);
    letter-spacing: var(--letter-spacing);
    margin: 0
}

.form-select--admin .nice-select::marker {
    display: none
}

.form-select--admin .nice-select:focus {
    outline: 0 !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important
}

.form-select--admin .nice-select:before {
    content: "";
    width: 20px;
    height: 20px;
    color: var(--gray-secondary);
    position: absolute;
    top: 30%;
    right: 12px;
    z-index: 1
}

.form-select--admin .nice-select.open:before {
    -webkit-transform: rotate(-90deg) !important;
    -ms-transform: rotate(-90deg) !important;
    transform: rotate(-90deg) !important
}

.content-image-m18 {
    max-width: 310px;
    max-height: 222px;
    object-fit: cover
}

.clients-logo img {
    -webkit-filter: grayscale(1);
    filter: grayscale(1)
}

.custom-modal-content {
    border-radius: 0;
    background-color: transparent;
    border: none
}

.custom-modal-header {
    border-bottom: none;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.custom-modal-title {
    color: #000;
    font-size: 20px;
    margin: 0;
    font-weight: 700
}

.custom-modal-body {
    padding: 2rem;
    background-color: #fff
}

.custom-form-control,
.custom-form-select {
    background-color: transparent;
    color: #000;
    border: none;
    border-bottom: 1px solid #000;
    border-radius: 0
}

.custom-form-control:focus {
    background-color: transparent;
    color: #000;
    box-shadow: none
}

.custom-form-select:focus {
    background-color: transparent;
    color: #000;
    box-shadow: none;
    border-color: #000
}

.custom-form-select option {
    background-color: #1e1e1e;
    color: #fff
}

.custom-form-check-input {
    width: 20px;
    height: 20px;
    border-radius: 3px;
    border: 1px solid #000;
    appearance: none;
    -webkit-appearance: none;
    outline: 0;
    cursor: pointer;
    display: inline-block;
    vertical-align: middle;
    position: relative
}

.custom-form-check-input::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 100%;
    background-color: transparent
}

.custom-form-check-input:checked::before {
    content: "\2713";
    color: #000;
    font-size: 16px;
    border: 1px solid #000;
    display: flex;
    align-items: center;
    justify-content: center
}

.custom-form-check-input:checked {
    background-color: #fff;
    border-color: #fff
}

.custom-btn-primary,
.custom-btn-primary:hover {
    background-color: #000;
    color: #fff
}

.custom-btn-primary {
    font-weight: 700;
    border: none;
    padding: .5rem 1rem;
    display: block;
    margin: 25px auto
}

.custom-form-control::placeholder {
    color: #4f4f4f
}

.modal-header .custom-button-close {
    margin: 0 -3rem -1rem auto;
    border-radius: 0;
    background-color: transparent;
    border: none;
    font-size: 1.5rem
}

.container-people {
    max-width: 1440px;
    margin: 0 auto
}

.m21 .person-info {
    text-align: center;
    padding: 10px;
    border-radius: 8px;
    background-color: #fff;
    word-wrap: break-word;
    overflow: hidden
}

.m21 .person-info .person-name,
.m21 .person-info .person-role {
    white-space: normal;
    word-break: break-word
}

.m21 .person-info img {
    height: 350px;
    margin-bottom: 10px;
    object-fit: cover
}

.m13 .image-services {
    height: 210px
}

.m13 .image-services img {
    height: 100%;
    width: 100%;
    object-fit: cover
}

.custom-slider {
    padding: 50px 0;
    position: relative
}

.custom-slide {
    width: 100%;
    display: flex;
    justify-content: center
}

.custom-member-container {
    width: 300px;
    display: flex;
    flex-direction: column;
    align-items: center
}

.custom-member-image {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    width: 300px;
    height: 400px
}

.custom-member-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.custom-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, .7);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .3s;
    padding: 20px;
    text-align: center;
    color: #fff
}

.custom-info {
    margin-top: 15px;
    text-align: center;
    width: 100%
}

.custom-button-next,
.custom-button-prev {
    position: absolute;
    top: 50%;
    width: 40px;
    height: 40px;
    margin-top: -20px;
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #000;
    background-color: rgba(255, 255, 255, .5);
    border-radius: 50%
}

.custom-button-next {
    right: 10px
}

.custom-button-prev {
    left: 10px
}

.custom-button-next::after,
.custom-button-prev::after {
    font-size: 20px
}

.custom-container {
    max-width: 1420px;
    margin-left: auto;
    margin-right: auto
}

@media screen and (min-width:450px) {
    .home-galeria__slider .banner-height {
        height: 850px;
        max-height: none
    }
}

@media screen and (min-width:564px) {
    .button-footer {
        width: auto;
        min-width: 100px;
        font-family: var(--font-primary, Lato);
        font-weight: 700;
        text-align: center;
        text-decoration: none !important;
        display: inline-flex;
        justify-content: center;
        align-items: center;
        border: 1px solid;
        cursor: pointer;
        padding: 12px 20px;
        border-radius: 40px;
        color: rgba(255, 255, 255, .25);
        background: rgba(255, 255, 255, .25)
    }

    .button-footer:hover {
        border: 1px solid var(--color, rgba(255, 255, 255, .25))
    }

    .m13 .image-services {
        height: 280px
    }
}

.paragraph-Blog,
.tag-blog {
    color: #010101
}

@media screen and (min-width:768px) {
    .header {
        height: 97px
    }

    .space-header {
        margin-top: 95px
    }

    .header-logo img {
        width: 80px;
        height:auto;
        objet-fit: content;
        aspect-ratio:1/1;
    }

    .not-flound-main {
        background-size: 600px
    }

    .header-menu .navbar-nav .nav-item .nav-link.active::after {
        bottom: 0;
        /*left: 50%;*/
        left: 0;
        top: unset;
        /*-webkit-transform: translateX(-50%);*/
        /*-ms-transform: translateX(-50%);*/
        /*transform: translate(-50%)*/
    }

    .gap-16 {
        gap: 1rem
    }

    .banner-main-navigation {
        bottom: 110px
    }

    .button-rounded {
        width: 64px;
        height: 64px
    }

    .button-rounded .icon {
        font-size: 25px
    }

    .banner-main-pagination {
        bottom: 120px !important
    }

    .swiper-pagination-bullet {
        width: 12px;
        height: 12px
    }

    .modal-interna {
        display: none;
        position: fixed;
        z-index: 1000;
        padding-top: 60px;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        overflow: auto;
        background-color: rgba(0, 0, 0, .9)
    }

    .modal-interna .modal-content {
        position: relative;
        margin: auto;
        display: flex;
        align-items: center;
        justify-content: center;
        max-width: 85%;
        max-height: 85%
    }

    .modal-interna .modal-image {
        width: 100%;
        height: auto;
        max-height: 100dvh;
        object-fit: cover
    }

    .modal-interna .next,
    .modal-interna .prev {
        cursor: pointer;
        position: absolute;
        top: 50%;
        width: auto;
        padding: 16px;
        color: #fff;
        font-weight: 700;
        transition: .6s;
        user-select: none
    }

    .modal-interna .next {
        right: -60px;
        border-radius: 3px 0 0 3px;
        font-size: 30px
    }

    .modal-interna .prev {
        left: -60px;
        border-radius: 3px 3px 0 0;
        font-size: 30px
    }

    .modal-interna .close {
        position: absolute;
        top: 10px;
        right: 25px;
        color: #fff;
        font-size: 35px;
        font-weight: 700;
        transition: .3s;
        cursor: pointer
    }

    .modal-interna .close:focus,
    .modal-interna .close:hover {
        color: #bbb;
        text-decoration: none;
        cursor: pointer
    }

    .container-form {
        padding: 20px 100px
    }

    .m13 .image-services {
        height: 170px
    }
}

.Related-blog .grid-container,
.m24 .grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr))
}

@media screen and (min-width:992px) {
    .button-rounded {
        width: 90px;
        height: 90px
    }

    .banner-main-navigation {
        bottom: 120px
    }

    .banner-main-pagination {
        bottom: 140px !important
    }

    .m13 .image-services {
        height: 250px
    }
}

@media screen and (min-width:1200px) {
    .header-menu-colapse {
        position: relative;
        top: 0;
        background-color: transparent;
    }
    .header-menu .navbar-nav .nav-item .nav-link{
        color: #ffffff;
        width: auto;
    }

    .m13 .image-services {
        height: 310px
    }
}

@media screen and (min-width:1400px) {
    .m13 .image-services {
        height: 370px
    }
}

.checkbox-secondary-modal .checkbox-square-modal {
    position: absolute;
    opacity: 0;
    width: 20px;
    height: 26px;
    z-index: 2
}

.checkbox-secondary-modal .checkbox-square-modal+label {
    position: relative;
    cursor: pointer;
    padding: 0
}

.checkbox-secondary-modal .checkbox-square-modal+label:before {
    content: "";
    margin-right: 10px;
    display: inline-block;
    vertical-align: text-top;
    width: 20px;
    height: 20px;
    background: 0 0;
    border: 1px solid #000
}

.checkbox-secondary-modal .checkbox-square-modal:checked+label:before,
.checkbox-secondary-modal .checkbox-square-modal:hover+label:before {
    background: 0 0
}

.checkbox-secondary-modal .checkbox-square-modal:focus+label:before {
    -webkit-box-shadow: none;
    box-shadow: none
}

.checkbox-secondary-modal .checkbox-square-modal:disabled+label {
    color: #fff;
    cursor: auto
}

.checkbox-secondary-modal .checkbox-square-modal:disabled+label:before {
    -webkit-box-shadow: none;
    box-shadow: none;
    background: #fff
}

.checkbox-secondary-modal .checkbox-square-modal:checked+label:after {
    content: "";
    position: absolute;
    left: 5px;
    top: 9px;
    background: #000;
    width: 2px;
    height: 2px;
    -webkit-box-shadow: 2px 0 0 #000, 4px 0 0 #000, 4px -2px 0 #000, 4px -4px 0 #000, 4px -6px 0 #000, 4px -8px 0 #000;
    box-shadow: 2px 0 0 #000, 4px 0 0 #000, 4px -2px 0 #000, 4px -4px 0 #000, 4px -6px 0 #000, 4px -8px 0 #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}

.checkbox-secondary-modal .checkbox-label-modal,
.checkbox-secondary-modal .checkbox-label-modal a {
    color: #000;
    font-size: 14px;
    margin: 0
}

.blog-swiper__img img {
    max-height: 480px;
    width: 100%;
    height: 480px;
    object-fit: cover
}

.custom-pagination-blog {
    position: absolute !important;
    top: 50% !important;
    right: -98% !important;
    left: auto !important;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: fit-content
}

.custom-pagination-blog .swiper-pagination-bullet {
    background-color: #282829
}

.custom-pagination-blog .swiper-pagination-bullet-active {
    background-color: #010101
}

.blog-swiper__text {
    background: #f8f8f8
}

@media (max-width:991px) {
    .custom-pagination-blog {
        position: static !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: 5px
    }
}

@media (min-width:1400px) {
    .custom-slider {
        padding: 50px 60px
    }

    .blog-swiper__text {
        padding-right: 5rem !important;
        padding-left: 5rem !important
    }
}

.m24 .grid-container {
    gap: 50px 30px
}

.Related-blog .grid-container .container-img img,
.m24 .grid-item .content-image img {
    width: 100%;
    height: 230px;
    margin-bottom: 10px;
    object-fit: cover
}

.m24 .nav-link {
    font-weight: 700;
    color: #757575
}

.link-interna a img {
    width: 11px;
    height: 11px;
    vertical-align: middle;
    margin-left: 10px
}

.container-blog img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0;
    width: 100%;
    object-fit: cover
}

.paragraph-Blog :is(h1, h2, h3, h4, h5, h6) {
    font-family: var(--font-family, "Sora")
}

.paragraph-Blog :is(ul, ol, p) {
    font-family: var(--font-family-DM, sans-serif)
}

.paragraph-Blog :is(h3, h4, h5, h6, ul, ol, p) {
    margin-bottom: 1.5rem
}

.header-container-blog {
    max-width: 1720px;
    margin: 0 auto;
    text-align: center
}

.tag-blog {
    display: inline-block;
    padding: 4px 16px;
    font-size: 14px;
    text-transform: uppercase;
    border: 1px solid #010101;
    border-radius: 20px
}

.header-title-blog {
    font-size: clamp(1.875rem, 5vw, 3.5rem);
    margin-bottom: 1rem;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto
}

.header-date-blog {
    font-size: 1.125rem;
    font-weight: 400;
    color: #757575
}

.header-container-blog picture img {
    width: 100%;
    height: auto;
    max-height: 600px;
    object-fit: cover
}

.Related-blog .grid-container {
    gap: 30px
}

.text-truncate-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis
}

.avatar-author,
.select-filter {
    display: flex;
    align-items: center
}

.select-filter {
    border: 2px solid #333;
    border-radius: 30px;
    padding: 8px 16px;
    width: 100%;
    background-color: #fff;
    font-size: 14px;
    cursor: pointer;
    box-shadow: none;
    height: 42px;
    text-align-last: center;
    background-position: right 16px center
}

.select-filter:focus {
    border-color: #333;
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(51, 51, 51, .15)
}

.content-blog {
    max-width: 1720px
}

.avatar-author {
    justify-content: center;
    width: 50px;
    height: 50px
}

.image-author {
    width: 50px;
    height: 50px;
    object-fit: cover;
    border-radius: 50%;
    border: 2px solid
}

.container-author {
    border-bottom: 1px solid #000;
    width: max-content;
    max-width: 100%
}

#heading-contact-us {
    color: #fff;
    font-weight: 900;
    cursor: pointer;
    font-size: 3.25rem;
    transition: color .3s, border-color .3s;
    border-bottom: 2px solid #fff;
    display: inline-flex;
    align-items: center;
    gap: 10px
}

#heading-contact-us:hover {
    color: #f0f0f0;
    border-color: #f0f0f0
}

#heading-contact-us i {
    font-size: 2rem
}

@media (max-width:767px) {
    .blog-swiper__img img {
        height: 440px
    }

    #heading-contact-us {
        font-size: 2.5rem
    }

    #heading-contact-us i {
        font-size: 1.5rem
    }
}

@media screen and (max-width:576px) {
    .modal-header .custom-button-close {
        margin: 0 -1rem 0 auto
    }
}

.dropdown-menu {
  min-width: max-content;
  /*max-width: 280px;*/
  padding: 5px 0;
  background-color: #EFEFEF;
  max-width: unset;
}




/*.dropdown-menu::after {*/
/*    content: '';*/
/*    position: absolute;*/
/*    top: 0;*/
/*    left: -70vw;*/
/*    width: 150vw;*/
/*    height: 100%;*/
/*    background-color: #ffffff;*/
/*    border-bottom:1px solid #000000;*/
/*    z-index: -1;*/
/*}*/



@media screen and (max-width:1200px) {
    .dropdown-menu {
        position:static!important;
        border-bottom:1px solid #000000;
    }
    .dropdown-menu::after {
        display: none;
    }
   
}


.dropdown-menu .dropdown-item {
   white-space: nowrap;
   overflow: hidden;
   text-overflow: ellipsis;
   padding: 15px 20px;
   position: relative;
    cursor: pointer;
}

.dropdown-item::after {
   content: '';
   width: 0px;
   height: 100%;
   position: absolute;
   left: 0;
   top: 0;
   background-color: #000000;
   transition: width 0.2s ease;
}
.dropdown-item:hover {
   background-color: #fff;
}
.dropdown-item:hover::after {
   width: 4px;
}
.dropdown-item.active {
    background-color: #ffffff!important;
    color: #000000!important;
    font-weight: 800px!important;
}
.dropdown-item.active::after {
   width: 4px;
   background-color: #000000!important;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
}

.blog-card {
  position: relative;
  background-color: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.blog-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
}

.blog-card__image img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.blog-card__content {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.blog-card__title h3 {
  font-size: 1.25rem;
  line-height: 1.4;
  color: #212529;
  margin: 0 0 1rem 0;
  font-weight: 700;
}

.blog-card__title-truncate {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  min-height: 84px; 
}

.blog-card__stretched-link {
  text-decoration: none;
  color: inherit;
}

.blog-card__stretched-link::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1; 
}

.blog-card__footer {
  margin-top: auto;
  padding-top: 1rem;
  border-top: 1px solid #dee2e6;
  position: relative; 
  z-index: 2; 
}

.blog-card__footer a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  color: #757575;
  font-weight: 700;
  font-size: 0.875rem;
}

.blog-card__footer a img {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}

.blog-card__footer a:hover img {
  transform: translateX(3px);
}








