.responsive-text {
    font-size: 28px; /* Tamanho inicial */
    text-align: right; /* Alinhamento à direita */
    font-family: 'Exo 2', sans-serif;
    font-weight: 400;
}

@media only screen and (max-width: 1651px) {
    .responsive-text {
        font-size: 26px; /* Tamanho menor em telas até 1024px */
    }
}

@media only screen and (max-width: 1545px) {
    .responsive-text {
        font-size: 24px; /* Tamanho ainda menor em telas até 600px */
    } 
}

@media only screen and (max-width: 1430px) {
    .responsive-text {
        font-size: 22px; /* Tamanho ainda menor em telas até 600px */
    }
}
@media only screen and (max-width: 1320px) {
    .responsive-text {
        font-size: 20px; /* Tamanho ainda menor em telas até 600px */
    }
}
@media only screen and (max-width: 1230px) {
    .row.flexible-direction {
        flex-direction: column;
    }

    .flexible-direction .col {
        width: 100%;
        box-sizing: border-box;
    }

    .responsive-text {
        font-size: 20px;
       
    }
}

@media only screen and (max-width: 1185px) {
   

    .responsive-text {
        font-size: 18px;
       
    }
}
@media only screen and (max-width: 1074px) {
    .quebra01 {
        display: none;
    }

    .text_sobre {
        width: 100% !important;
        margin-bottom: 20px;
    }
    .text_sobre p {
        font-size: 24px;
    }
    .img_empresa {
        width: 100% !important;
    }
}
@media only screen and (max-width: 750px) {
   .text_sobre p {
    font-size: 18px;
   }
}
.sobre {
    margin-bottom: 120px !important; 
}
@keyframes slideUp {
    from {
        transform: translateY(40px); /* Começa 20px abaixo da posição final */
        opacity: 0; /* Começa totalmente transparente */
    }
    to {
        transform: translateY(0); /* Termina na posição final */
        opacity: 1; /* Termina totalmente opaco */
    }
}

.sobre {
    animation: slideUp 2s ease forwards; /* Aplica a animação na classe .sobre */
}


.bloco {
    width: 600px;
    height: 300px;
    background-color: #77A037;
    margin: 0 auto;
    margin-bottom: 25px !important;
    padding-left: 35px;
    padding-top: 2px;
    border-radius: 20px; 
}

.blocos {
    margin-top: 100px;
    margin-bottom: 100px !important;
    
}

.blocos h3 {
    font-family: 'Exo 2', sans-serif;
    font-weight: 800;
    font-size: 60px !important;
    color: white;
    
}

.bloco p {
    font-family: 'Exo 2', sans-serif;
    font-weight: 300;
    font-size: 30px;
    color: white;
}

.bloco_meio {
    text-align: right;
    padding-right: 35px;
    
}

@media only screen and (max-width: 1300px) {
    .bloco {
        width: 500px;
        height: 250px
    }

    .icon {
        width: 90px !important;
        height: 90px !important;    
        background-size: 60% !important; 
    }
    
    .icon01 {
        background-image: url(/img/alvo.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 320px !important;
        margin-top: -50px !important;
        
    }
    
    .icon02 {
        background-image: url(/img/grafico.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 20px !important;
        margin-top: -50px !important;
    }
    .icon03 {
        background-image: url(/img/maos-dadas.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 320px !important;
        margin-top: -50px !important;
    }
.bloco h3 {
    font-size: 56px !important;
    margin-bottom: 5px;
}

    .bloco p {
        font-size: 24px;
    }
}


@media only screen and (max-width: 780px) {
    .bloco {
        width: 420px;
        height: 220px;
        padding-right: 15px;

    }
    .icon01 {
        background-image: url(alvo.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 250px !important;
        margin-top: -50px !important;
        
    }
    
    .icon02 {
        background-image: url(grafico.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 15px !important;
        margin-top: -50px !important;
    }
    .icon03 {
        background-image: url(maos-dadas.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 250px !important;
        margin-top: -50px !important;

    }


    .bloco h3 {
        font-size: 40px !important;
        margin-bottom: 5px;
    }
    
        .bloco p {
            font-size: 21px;
        }
}










@media only screen and (max-width: 450px) {
    .bloco {
        width: 100%;
        height: 230px;
        text-align: right !important;
        padding-right: 15px;
        margin-bottom: 10px !important;

    }

    .icon {
        width: 80px !important;
        height: 80px !important;
    }
    .icon01 {
        background-image: url(alvo.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 10px !important;
        margin-top: -50px !important;
        
    }
    
    .icon02 {
        background-image: url(grafico.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 10px !important;
        margin-top: -50px !important;
    }
    .icon03 {
        background-image: url(maos-dadas.png);
        background-repeat: no-repeat;
        background-position: center;
        margin-left: 10px !important;
        margin-top: -50px !important;

    }


    .bloco h3 {
        font-size: 40px !important;
        margin-bottom: 5px;
    }
    
        .bloco p {
            font-size: 21px;
        }}





















/* Estilos responsivos (opcional) */
@media only screen and (max-width: 600px) {
    .custom-block {
        height: 100px; /* Altura menor para telas pequenas */
    }
}
span {
    font-weight: 800;
}








.icon {
    position: absolute;
    width: 120px;
    height: 120px;
    background-color: #393939;
    border-radius: 10px;
}

.icon01 {
    background-image: url(/img/alvo.png);
    background-repeat: no-repeat;
    background-position: center;
    margin-left: 360px;
    margin-top: -60px;
    
}

.icon02 {
    background-image: url(/img/grafico.png);
    background-repeat: no-repeat;
    background-position: center;
    margin-left: 40px;
    margin-top: -60px;
    background-size: 70%;
}
.icon03 {
    background-image: url(/img/maos-dadas.png);
    background-repeat: no-repeat;
    background-position: center;
    margin-left: 360px;
    margin-top: -60px;
    background-size: 70%;
}

.responsive-iframe {
    width: 100%;
    height: 700px; /* Altura inicial */
    border: 0;
    margin-bottom: -5px;
}

/* Media queries para ajustar a altura em telas menores */
@media only screen and (max-width: 1100px) {
    .responsive-iframe {
        height: 600px; /* Altura menor para telas pequenas */
    }
}

@media only screen and (max-width: 800px) {
    .responsive-iframe {
        height: 500px; /* Altura ainda menor para telas muito pequenas */
    }
}

@media only screen and (max-width: 500px) {
    .responsive-iframe {
        height: 400px; /* Altura ainda menor para telas muito pequenas */
    }
}

@media only screen and (max-width: 400px) {
    .responsive-iframe {
        height: 300px; /* Altura ainda menor para telas muito pequenas */
    }
}



/* Animações básicas */
@keyframes slideFromLeft {
    from {
        transform: translateX(-40px);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slideFromRight {
    from {
        transform: translateX(40px);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Estilo inicial dos blocos */
.blocos .bloco {
    opacity: 0;
    transform: translateX(-40px); /* Posição inicial para blocos da esquerda */
}

.blocos .bloco.bloco_meio {
    transform: translateX(40px); /* Posição inicial para o bloco do meio */
}

/* Classes de animação */
.blocos .bloco.start-animation {
    animation-duration: 1s;
    animation-fill-mode: forwards;
    opacity: 1;
}

.blocos .bloco:nth-child(1).start-animation {
    animation-name: slideFromLeft;
}

.blocos .bloco:nth-child(2).start-animation {
    animation-name: slideFromRight;
}

.blocos .bloco:nth-child(3).start-animation {
    animation-name: slideFromLeft;
}