body {
    background: #F1F7F6 !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400 !important;
}

.tag p {
    margin: 0 !important;
}

header .navbar {
    background: #ffffff;
}

.banner-top .box {
    position: relative;
    background-image: url(../img/banner-topo.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
    height: 690px;
    border-radius: 21px;
    padding: 50px;
    display: flex;
    align-items: flex-end;
    background-position: center center;
}

.banner-top .box::before {
    position: absolute;
    content: '';
    background: linear-gradient(to bottom,
            rgba(2, 25, 22, 0) 0%,
            rgba(2, 25, 22, 0.68) 70%,
            rgba(2, 25, 22, 0.68) 100%);
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    border-radius: 21px;
}

.banner-top .box .title-new {
    position: relative;
}

.banner-top .box .title-new h1 {
    color: var(--white);
    font-size: 48px;
    font-weight: 400;
    margin-bottom: 40px;
}

.banner-top .box p {
    background-color: var(--green);
    border: solid 2px #4D8E86;
    color: var(--white);
    padding: 2px 14px;
    display: inline-block;
    border-radius: 30px;
    font-weight: 400;
    font-size: 12px;
    margin-bottom: 20px;
}

.banner-top .box a {
    display: inline-block;
    color: var(--black);
    padding: 8px 15px 8px 30px;
    background: var(--white);
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;

    font-size: 12px;
}

.banner-top .box a img {
    margin-left: 10px;
}

.mySwiperLogos {
    width: 100%;
    padding: 20px 0;
}

.mySwiperLogos .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
}

.mySwiperLogos img,
.logos-abt img {
    opacity: 0.8;
    filter: grayscale(100%) brightness(0.9);
    transition: all 0.3s ease;
}

.mySwiperLogos img:hover, .logos-abt img:hover {
    filter: grayscale(0%) brightness(1);
    opacity: 1;
}

.logos .swiper-wrapper {
    align-items: center;
}

.logos {
    padding: 50px 0;
}

.logos .text p {
    font-size: 12px;
}

.about {
    max-width: 1720px;
    margin: 0 auto;
    padding: 90px 0;
    border-top: solid rgba(153, 153, 153, 0.5) 1px;
}

.about {
    padding: 70px 0;
    border-top: solid rgba(153, 153, 153, 0.5) 1px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    justify-content: space-between;
    align-items: center;
}

.about .thumb {
    text-align: right;
}

.about .tag,
.solutions .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 2px 14px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
    background-color: #F1F7F6;
}

.solutions .tag p {
    font-size: 12px;
}

.about .tag {
    margin-bottom: 30px;
}

.flex-tag {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 0 0 30px;
}

.flex-tag hr {
    flex-grow: 1;
    border: none;
    border-top: 1px solid #999999;
    margin: 0;
    max-width: 100%;
}

.about h1,
.about h2,
.about h3,
.about h4,
.about h5,
.about h6,
.solutions h1,
.solutions h2,
.solutions h3,
.solutions h4,
.solutions h5,
.solutions h6 {
    color: var(--green);
    margin-bottom: 20px;
}

.about h2,
.solutions h2 {
    font-size: 44px;
    text-transform: none !important;
}

.solutions h2 {
    margin-bottom: 40px;
}

.about p {
    font-size: 12px;
}

.about .grid {
    padding: 10px 0;
    display: flex;
    gap: 50px;
    text-align: center;
}

.about .grid .count {
    font-size: 44px;
    line-height: 54px;
    color: var(--green);
}

.solutions {
    position: relative;
    overflow: hidden;
    padding: 70px 0 0;
    background: var(--white);
}

.solutions .grid {
    display: grid;
    grid-template-columns: 50% 1fr;
    gap: 100px;
    margin: 50px 0 100px;
    align-items: center;
}

.solutions .grid .item-img img {
    width: 100%;
}

.solutions .item-text .accordion-header {
    margin: 0;
}

.solutions .item-text .accordion .accordion-button {
    font-size: 18px;
    padding: 20px 0;
    text-transform: none;
}

.solutions .item-text .accordion .accordion-button:hover {
    color: var(--green);
}

.solutions .item-text .accordion .accordion-body.px-0 {
    padding: 0;
}

.solutions .item-text .accordion .accordion-item {
    font-size: 12px;
    color: var(--black);
}

.solutions .item-text .accordion .accordion-item a {
    display: inline-block;
    color: var(--black);
    padding: 8px 15px 8px 30px;
    border: solid 1px var(--green);
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 14px;
    margin: 0 0 20px;
}

.accordion-button:not(.collapsed) {
    color: var(--green);
    font-weight: 600;
}

.solutions .item-text .accordion .accordion-item a img {
    margin-left: 10px;
}

.cases {
    padding: 90px 0;
    background-color: #F1F7F6;
}

.cases .title-new {
    margin-bottom: 20px;
}

.cases .title-new .flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.cases .row.carrossel-cases,
.logos .row {
    padding: 0;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-.5 * var(--bs-gutter-x));
    margin-left: calc(-.5 * var(--bs-gutter-x));
    max-width: 100%;
}

.cases .flex-case {
    display: flex;
    align-items: center;
}

.cases .title-new .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 2px 14px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
    margin-bottom: 30px;
}

.cases .title-new h2 {
    font-size: 44px;
    color: var(--green);
    font-weight: 400;
    text-transform: none !important;
}

.cases .title-new p {
    font-size: 18px;
}

/* .cases .carrossel-cases {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 20px;
} */
.cases .carrossel-cases .mySwiperCases .item {
    position: relative;
    display: flex;
    align-items: flex-end;
}

.cases .carrossel-cases .mySwiperCases .item::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(2, 25, 22, 0) 0%, rgba(2, 25, 22, 0.68) 70%);
}

.cases .carrossel-cases .mySwiperCases .item img {
    width: 100%;
    border-radius: 16px;
}

.cases .carrossel-cases .mySwiperCases .item .text {
    position: absolute;
    z-index: 99;
    padding: 30px;
}

.cases .carrossel-cases .mySwiperCases .item .text p {
    text-transform: uppercase;
    display: inline-block;
    padding: 5px 15px;
    font-size: 12px;
    border-radius: 30px;
    background: var(--green);
    color: var(--white);
    margin-bottom: 20px;
}

.cases .carrossel-cases .mySwiperCases .item .text h3 {
    font-size: 24px;
    color: var(--white);
    margin-bottom: 20px;
    font-weight: 400;
    max-width: 90%;
    text-transform: none !important;
}

.boxs .item {
    position: relative;
    padding: 20px 30px;
    background: var(--white);
    margin: 20px 0;
    border-radius: 10px;
    display: block;
}

.boxs .item:hover {
    opacity: 1;
}

.boxs .item p {
    text-transform: uppercase;
    display: inline-block;
    padding: 3px 15px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
    color: #999999;
    margin-bottom: 10px;
}

.boxs .item h3 {
    font-size: 20px;
    margin-bottom: 10px;
    color: var(--black);
    max-width: 90%;
    text-transform: none !important;
}

.testimonials {
    overflow: hidden;
    position: relative;
    padding: 90px 0 230px;
    background: var(--green);
}

.testimonials .swiper {
    margin-top: 50px;
}

.testimonials .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 4px 14px;
    font-size: 12px;
    border-radius: 30px;
    background-color: var(--white);
    color: var(--green);
}

.testimonials .tag p {
    font-size: 12px;
}

.testimonials .item {
    background-color: var(--white);
    padding: 30px;
    border-radius: 16px;
}

.testimonials .item p {
    font-size: 12px;
}

.testimonials .item h4 {
    font-size: 20px;
    margin-top: 10px;
    color: var(--black);
}

.testimonials .item span {
    font-size: 12px;
    color: var(--green);
}

.testimonials .item img {
    margin-bottom: 20px;
    transform: rotate(180deg);
}

.banner-contact {
    background-image: url(../img/contact.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
    border-radius: 20px;
    padding: 70px;
    margin-top: -180px;
    position: relative;
}

.banner-contact p {
    background-color: var(--green);
    color: var(--white);
    padding: 5px 20px;
    display: inline-block;
    border-radius: 30px;
    font-weight: 400;
    font-size: 12px;
    margin-bottom: 20px;
    text-transform: uppercase;
}

.banner-contact h2 {
    color: var(--white);
    font-size: 38px;
    margin-bottom: 40px;
    text-transform: none !important;
}

.banner-contact a {
    color: var(--black);
    padding: 13px 20px 13px 30px;
    background: var(--white);
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 12px;
}

.banner-contact a:hover,
.blog .title-new a:hover,
.careers .content a:hover,
.contact-footer .box a:hover,
.footer-new .newss .bts a:hover,
.banner-top .box a:hover,
.cases .title-new .flex a:hover {
    background-color: var(--green);
    color: var(--white);
    opacity: 1;
    border: none;
}

.banner-contact a:hover img,
.blog .title-new a:hover img,
.careers .content a:hover img,
.contact-footer .box a:hover img,
.footer-new .newss .bts a:hover img,
.banner-top .box a:hover img,
.cases .title-new .flex a:hover img {
    filter: brightness(0) invert(1);

}

.banner-contact a img {
    margin-left: 10px;
}

.segments {
    position: relative;
    overflow: hidden;
    padding: 90px 0 0;
}

.segments .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 3px 15px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
}

.segments .tag p {
    font-size: 12px;
}

.segments .grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 40px;
    gap: 20px 30px;
}

.segments .grid a {
    border-radius: 16px;
    overflow: hidden;
    border: solid 1px #99999978;
    padding: 30px;
    transition: all 0.3s ease;
}

.segments .grid a:hover {
    opacity: 1;
    border-color: var(--green);
    background-color: var(--green);
}

.segments .grid a h3 {
    font-size: 20px;
    font-weight: 400;
    color: var(--green);
    text-transform: none !important;
}

.segments .grid a:hover h3,
.segments .grid a:hover p {
    color: var(--white);

}

.segments .grid a h3,
.segments .grid a p {
    transition: color 0.3s ease;
}

.segments .grid a p {
    font-size: 12px;
    color: var(--black);
    margin: 0;
}

a.bt-green {
    background: var(--green);
    display: grid;
    align-items: center;
}

.segments .grid a.bt-green h3 {
    color: var(--white);
    margin-bottom: 10px;
}

.segments .grid a.bt-green p {
    text-transform: uppercase;
    display: inline-block;
    padding: 8px 15px 6px 30px;
    font-size: 14px;
    border-radius: 30px;
    background-color: var(--white);
    color: var(--green);
    font-weight: 600;
}

.segments .grid a.bt-green p img {
    margin-left: 10px;
}


.blog .swiper-slide:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(2, 25, 22, 0) 0%, rgba(2, 25, 22, 0.68) 70%);
}

.blog .swiper-slide .title-new h3 {
    text-transform: none !important;
    position: absolute;
    bottom: 0;
    padding: 30px;
    max-width: 70%;
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    opacity: 0.85;
    transform: scale(1);
    transform-origin: left bottom;
    transition:
        opacity 0.25s ease,
        transform 0.4s ease,
        font-size 0.4s ease,
        color 0.3s ease,
        max-width 0.3s ease;
}

.blog .swiper-slide a:hover {
    opacity: 1;
}

.blog .slide-expanded .title-new h3 {
    font-size: 22px;
    transform: scale(1.2);
    opacity: 1;
    font-weight: 400;
    transition:
        opacity 0.25s ease 0.1s,
        /* reaparece um pouco depois */
        transform 0.4s ease 0.1s,
        font-size 0.4s ease 0.1s,
        color 0.3s ease 0.1s,
        max-width 0.3s ease 0.1s;
}

.blog .swiper {
    width: 100%;
    padding: 16px 0;
}

.blog .mySwiper {
    width: 100%;
    overflow: hidden;
}

.blog .swiper-slide {
    /* Tamanho padrão (menor) */
    width: 28%;
    height: 400px;

    /* Transição suave */
    transition: width 0.3s ease-in-out;

    overflow: hidden;
    border-radius: 1rem;


    /* Adicionado para os elementos internos 'absolute' */
    position: relative;
}


/* ADICIONADO: Nova classe para controlar a expansão */
.blog .slide-expanded {
    width: 40%;
}

/* --- Estilização dos Cards Internos --- */

.blog .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 16px;
}

.blog .slide-arrow,
.slide-arrow {
    position: absolute;
    bottom: 15px;
    right: 15px;
    opacity: 0;
    transform: translateX(-10px);
    transition: all 0.3s ease-in-out;
}

.blog .slide-arrow svg,
.slide-arrow svg {
    width: 2rem;

    height: 2rem;

}


.blog .slide-expanded .slide-arrow {
    opacity: 1;
    transform: translateX(0);
}

/* --- Estilização da Navegação --- */

.blog .navigation-container {
    display: flex;
    align-items: center;
    gap: 1rem;
    /* gap-4 */
    margin-top: 2rem;
    /* mt-8 */
}

/* Esconde as setas padrão do Swiper */
.blog .swiper-button-prev::after,
.blog .swiper-button-next::after {
    display: none;
}

/* Estilo customizado para os botões */
.blog .custom-nav-button {
    position: static;
    width: 44px;
    height: 44px;
    background-color: transparent;
    border: 1px solid #999999;
    /* gray-500 */
    color: white;
    border-radius: 5px;
    /* rounded-full */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    cursor: pointer;
    /* Adicionado para melhor UX */
}

.blog .custom-nav-button:hover {
    background-color: var(--green);
    /* gray-700 */
    border-color: var(--green);
    /* gray-600 */
}

/* Ícone da seta (SVG) */
.blog .custom-nav-icon {
    width: 20px;
    height: 20px;
    stroke-width: 2;
    color: #999999;
}

.blog {
    position: relative;
    overflow: hidden;
    padding: 90px 0 0;
}

.blog .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 3px 15px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
}

.blog .tag p {
    font-size: 12px;
}

.blog .title-new {
    display: flex;
    align-items: end;
    justify-content: space-between;
    margin-bottom: 50px;
}

.blog .title-new h2 {
    font-size: 44px;
    color: var(--green);
    font-weight: 400;
    margin: 30px 0 0;
    text-transform: none !important;
}

.blog .title-new a,
.cases .title-new .flex a {
    color: var(--black);
    padding: 8px 15px 8px 30px;
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 14px;
    background: var(--white);
}

.blog .title-new a img,
.cases .title-new .flex a img {
    margin-left: 10px;
}

.blog .flex.items-center {
    display: flex;
    margin-top: 30px;
}

.careers {
    position: relative;
    padding: 50px 0 90px;
}

.careers::before {
    position: absolute;
    content: '';
    background: url(../img/bg.svg);
    background-repeat: no-repeat;
    background-size: 793px;
    width: 793px;
    height: 753px;
    top: -60px;
    right: 0;
    z-index: -1;
}

.careers .content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 70px;
    align-items: center;
}

.careers .content .tag {
    text-transform: uppercase;
    display: inline-block;
    padding: 3px 15px;
    font-size: 12px;
    border-radius: 30px;
    border: solid 1px #999999;
    margin-bottom: 20px;
}

.careers .content h2 {
    font-size: 44px;
    color: var(--green);
    font-weight: 400;
    margin-bottom: 20px;
    text-transform: none !important;
}

.careers .content p {
    font-size: 12px;
    margin-bottom: 30px;
}

.careers .content a {
    color: var(--black);
    padding: 10px 15px 10px 30px;
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 14px;
    background: var(--white);
    border: solid 1px #999999;
}

.careers .content a img {
    margin-left: 10px;
    position: relative;
    top: -2px;
}

.contact-footer .box {
    position: relative;
    z-index: 99;
    background: var(--white);
    padding: 70px 50px;
    border-radius: 16px;
}

.contact-footer .box p {
    text-transform: uppercase;
    display: inline-block;
    padding: 3px 15px;
    font-size: 12px;
    border-radius: 30px;
    margin-bottom: 30px;
    background-color: rgba(204, 215, 213, 0.21);
}

.contact-footer .box h2 {
    font-size: 44px;
    color: var(--green);
    font-weight: 400;
    margin-bottom: 30px;
    text-transform: none !important;

}

.contact-footer .box a {
    color: var(--black);
    padding: 13px 15px 13px 30px;
    background: var(--white);
    border-radius: 30px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 12px;
    border: solid 1px rgba(153, 153, 153, 0.5);
}

.contact-footer .box a img {
    margin-left: 10px;
}

/*
 Responsive  */
@media (max-width: 1640px) {
    .container-fluid {
        padding: 0 60px;
    }
}

@media (max-width: 1440px) {

    .about h2 br,
    .solutions h2 br {
        display: none;
    }
}

@media (max-width: 1340px) {
    .container-fluid {
        padding: 0 30px;
    }

    .language {
        gap: 5px;
        padding-left: 20px;
    }

    .search {
        padding-left: 10px;
    }

    .about .grid {

        gap: 25px;

    }

    .solutions h2 br {
        display: none;
    }

    .solutions .grid {
        gap: 40px;
    }

}

@media (max-width: 991px) {
    .about {
        grid-template-columns: 1fr;
        justify-content: center;
        align-items: center;
    }

    .about .thumb {
        text-align: center;
        margin-top: 30px;
    }

    .about .thumb img {
        border-radius: 24px;
    }

    .solutions .grid {
        grid-template-columns: 1fr;
    }

    .cases .title-new .flex,
    .blog .title-new {
        display: block;
    }

    .cases .title-new .flex a {
        display: inline-block;
    }

    .boxs .item {
        margin: 20px 0;
    }

    .banner-contact h2 br {
        display: none;
    }

    .segments .grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .blog .title-new h2 {
        margin-bottom: 20px;
    }
}

@media (max-width: 767px) {
    .banner-top .box {
        height: 450px;
        padding: 30px;
    }

    .banner-top .box .title-new h1 {
        font-size: 20px;
        font-weight: 600;
        margin-bottom: 20px !important;
    }

    .banner-top .box .title-new h1 br {
        display: none;
    }

    .banner-top .box a {
        padding: 8px 10px 8px 15px;
        max-width: 260px;
    }

    .about .grid .count {
        font-size: 18px;
        line-height: 24px;
    }

    .about .grid {
        justify-content: space-between;
    }

    .about h2,
    .solutions h2,
    .cases .title-new h2,
    .banner-contact h2,
    .blog .title-new h2,
    .careers .content h2,
    .contact-footer .box h2 {
        font-size: 24px;
    }

    .about,
    .solutions,
    .cases {
        padding: 50px 0;
    }

    .solutions .grid {
        gap: 0;
        margin: 20px 0;
    }

    .cases .carrossel-cases .mySwiperCases .item .text h3,
    .boxs .item h3 {
        font-size: 18px;
        margin: 0;
    }

    .testimonials {
        padding-top: 50px;
    }

    .banner-contact {
        padding: 20px;
    }

    .banner-contact a {
        display: inline-block;
        text-align: center;
    }

    .segments,
    .blog {
        padding: 50px 0 0;
    }

    .segments .grid {
        grid-template-columns: repeat(1, 1fr);
    }

    .careers .content {
        grid-template-columns: 1fr;
        gap: 30px;
        padding: 0 30px;
    }

    .careers {
        padding: 50px 0;
    }

    .contact-footer .box {
        padding: 30px 20px;
    }

    .contact-footer .box h2 {
        font-size: 20px;
    }

    .contact-footer .box a {
        font-size: 10px;
    }

    .blog .slide-expanded,
    .blog .swiper-slide {
        width: 100%;
    }
}