/* Reset e fonte padrão */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;

}

body {
	
	font-size: 20px; /* Tamanho padrão do texto */
	font-family: 'Montserrat', sans-serif; 
    color: #333333; /* Cor padrão do texto */

    overflow-x: hidden;
	line-height: 1.5; /* Espaçamento entre linhas */
    letter-spacing: -0.2px; /* Reduzindo o espaçamento entre letras */
	font-weight: 200;
}


/* Quando a página rolar, o menu de navegação ganha um fundo */
.scrolled {
    background: rgba(100, 100, 100, 0.7);
   
}


/* Contêiner da logo e do nome */
.logo-container {
    display: flex;
    align-items: center; /* Mantém a logo e o nome alinhados verticalmente */
    height: 60px;
     /* Ajustado para melhor flexibilidade */
     justify-content: center;
     align-content: center;
     
}

/* Logo do escritório */
.logo {
	margin-top:0px;
	width:60px;
	margin-bottom:0px;
	background-color:#6c927b;
    height: 60px;
    margin-left: 30px;
    transition: all 0.3s ease-in-out; /* Suaviza qualquer alteração de posição */
}

/* Logo do escritório */
.logo_a {
	display:flex;
	justify-content: center;
	align-content:center;
	align-items: center;
	margin-top:0px;
	width:60px;
	margin-bottom:0px;
	background-color:#6c927b;
    height:60px;
    margin-left: 30px;
    transition: all 0.3s ease-in-out; /* Suaviza qualquer alteração de posição */
}

.logo_a img{
	width:60px;
	height: 60px;
}

/* Nome ao lado da logo */
.nl {
    margin-left: 10px;
    color: white;
    font-size: 18px;
    font-weight: 180;
    display: flex;
    align-items: center; /* Mantém o nome alinhado verticalmente à logo */
    transition: all 0.3s ease-in-out; /* Evita pequenos deslocamentos ao rolar */
    
}


/* === Menu de navegação fixo e responsivo === */
nav {
    font-size: 13px;
    background: transparent;
    position: fixed;
    width: 100%;
    top:0px;
    left: 0;
    z-index: 1000;
    display: flex;
    align-items: center; /* Alinha os itens verticalmente */
    justify-content: space-between; /* Distribui os itens nos cantos */
    padding: 0px 35px; /* Diminuída a altura do menu */
    transition: background 0.3s ease-in-out;
}


/* === Menu Horizontal (Computador) === */
.nav-links {
    list-style: none;
    display: flex;
    align-items: center; /* Alinha os itens do menu com a logo */
    justify-content: center;   
}


.nav-links li {
    margin: 0 12px;
}

.nav-links a {
    color: white;
    text-decoration: none;
    font-weight: 600;
}



.nav-links a:hover {
    opacity: 0.8;
}

/* === MENU HAMBÚRGUER (Aparece Apenas em Telas Pequenas) === */
.menu-hamburger {
    display: none;
    flex-direction: column;
    cursor: pointer;
    position: absolute;
    left: 14px;
    top: 10px;
    z-index: 1100;
}

.menu-hamburger div {
	
    width: 30px;
    height: 4px;
    background: white;
    margin:4px;
    transition: 0.3s;
}

/* === MENU RECOLHÍVEL (Vertical) === */
.mobile-menu {
    z-index: 1050;
    display: none;
    position: fixed;
    top: 60px;
    left: -250px;
    width: 250px;
    height: 100vh;
    background: rgba(114, 108, 72, 0.9);
    text-align: left;
    padding-top: 60px;
    transition: left 0.3s ease-in-out;
    
}

.mobile-menu.active {
    left: 0;
}

/* Estilização dos links do menu recolhível */
.mobile-menu a {
    color: white;
    display: block;
    padding: 20px;
    padding-left:30px;
    
    text-decoration: none;
    font-weight: bold;
}

.mobile-menu a:hover {
    background: rgba(255, 255, 255, 0.1);
}



/* === RESPONSIVIDADE === */
@media (max-width: 768px) {
    .nav-links {
        display: none; /* Esconde o menu horizontal */
    }

    .menu-hamburger {
        display: flex; /* Exibe o menu hambúrguer */
    }

    .mobile-menu {
        display: block;
    }
    .telas_max{
    	display: none;
    }
    .telas_mini{
     display: flex;
    }
    
    .nl{
     opacity: 0.6;
     font-size:15px;
    }
    
}

@media (min-width: 769px) {

	.telas_max{
		display: flex;
	}
	
	.telas_mini{
		display: none;
	}
	
}



.overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    width: 100%;
    z-index: 5;

    color: #fff;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;

    pointer-events: none;
}

/* =========================================================
   CORREÇÃO DO CABEÇALHO / OVERLAY / CORPO DO SITE
   Objetivo:
   1. O cabeçalho controla sua própria área.
   2. O overlay fica preso dentro do parallax.
   3. O corpo do site começa abaixo do cabeçalho.
   4. O main não sobrepõe o overlay.
========================================================= */

header {
    position: relative;
    z-index: 10;
}

.parallax-container {
    position: relative;
    width: 100%;
    min-height: 32vw;
    max-height: 550px;
    overflow: hidden;
}

.parallax-background {
    position: relative;
    z-index: 1;
    height: 30vw;
    max-height: 580px;
    min-height: 360px;
}


main {
    position: relative;
    z-index: 0;
    top: 0;
    margin-top: 0;
}


.logo-menor {
	
	width: 50%; /* Reduzido para um tamanho proporcional adequado */
	min-width:200px;
 	max-width: 305px; /* Define um limite máximo para evitar que fique grande demais */
    margin-top: 25px;
    margin-bottom: 0px;
    padding-bottom: 0px;
	border: 15px solid #ffffff;
	border-radius: 50%;
}

.bl {
    margin-top: 80px;
    font-size: 18px;
    font-style:normal;
    text-align: center;
    margin-bottom: 0px;
}
.titulos{
/*	color: #000080; */
	color:#7f8d84;
/*	color: #726c48; */

	
}

/* ==============================
   SOBRE NÓS - ESTRUTURA
============================== */

.bloco-sobre {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 30px;
    align-items: center;
    width: 100%;
    margin-top: 35px;
	margin-bottom:0px;
}

.img_esquerda,
.img_direita {
    grid-column: span 5;
    height: 380px;
}

.icone-grande{
	 grid-column: span 3;
	
}

.texto_quemsomos,
.texto-bloco-info {
    grid-column: span 7;
}

.bloco-sobre > div,
.bloco-sobre > p {
    flex: 1;
}

.texto_quemsomos {
    text-align: justify;
    line-height: 1.8;
}

/* Faz a imagem respeitar a altura completa da div */
/* ==============================
   SOBRE NÓS - ESTRUTURA DESKTOP
============================== */

.bloco-sobre {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 30px;
    align-items: start;
    width: 100%;
    margin-top: 35px;
}

.img_esquerda,
.img_direita {
    grid-column: span 5;

    width: 100%;
    height: 500px;

    overflow: hidden;

    display: block;

    border-radius: 2px;
}

@media (min-width: 1470px) {
    .img_esquerda,
    .img_direita {
        height: 620px;
        max-height: 620px;
    }
}

.texto_quemsomos,
.texto-bloco-info {
    grid-column: span 7;
}

/* A imagem sempre preenche toda a div */
.img_esquerda img,
.img_direita img {
    width: 100%;
    height: 100%;

    display: block;

    object-fit: cover;
    object-position: center center;

    border-radius: 2px;
    border: 1px solid #33333310;
}


/* ==============================
   BLOCOS INFERIORES EM LINHA
============================== */

.blocos-inferiores {
    display: flex;
    flex-direction: column;
    gap: 45px;
    width: 100%;
}

.bloco-info-linha {
    display: flex;
    align-items: center;
    gap: 25px;
    width: 100%;
    margin: 35px auto;
    border: none;
}

.texto-bloco-info {
    flex: 1;
    text-align: justify;
    font-size: 15px;
    line-height: 1.8;
    color: #333333;
}

.texto-bloco-info .titulos {
    text-align: left;
 /*   margin-bottom: 5px;*/
}

/* Ícone grande no lugar da imagem */
/* ==============================
   IMAGENS DOS BLOCOS INFERIORES
   O QUE FAZEMOS / ATUAÇÃO
============================== */

.imagem-bloco-home {
    flex: 0 0 40%;
    width: 40%;
    height: 420px;

    overflow: hidden;
    padding: 0;

    display: block;

    border-radius: 2px;
    border: 1px solid #33333310;

    background: transparent;
}

.imagem-bloco-home img {
    width: 100%;
    height: 100%;

    display: block;

    object-fit: cover;
    object-position: center center;
}

/* Mantém a classe antiga sem interferir quando ela estiver junto da imagem */
.icone-grande.imagem-bloco-home {
    min-height: initial;
    color: inherit;
    background: transparent;
    align-items: initial;
    justify-content: initial;
}



/* Remove limitações antigas dos cards inferiores */
.bloco_fazemos,
.bloco_servicos {
    height: auto;
    min-height: initial;
    max-height: initial;
    border: none;
}



/* Responsivo */
@media (max-width: 768px) {
    .bloco-info-linha {
        flex-direction: column;
        gap: 18px;
    }

    .bloco-info-linha.bloco-invertido {
        flex-direction: column-reverse;
    }

    .icone-grande {
        width: 100%;
        min-height: 180px;
    }
/*
    .texto-bloco-info .titulos {
        text-align: center;
    }
*/
	
	.titulo-com-icone {
		display: flex;
		justify-content: left;
		align-items: left;
		gap: 10px;
		
	}

	.base-icone{
		display: flex;
		justify-content: center;
		align-items: center;
		height:50px;
		width:50px;
		padding:10px;
		background-color:#7f8d84;
		border-radius:50%;
		
	}

	.titulo-com-icone i {
		color: #fff;
		font-size: 0.6em;
	}
	
	.conteudo .titulos{
		font-size:25px;
		text-align:left;
	}
	
	.conteudo h1{
		font-size:25px;
		text-align:left;
	}
	
}

	

/* ==============================
   ESTADO INICIAL
============================== */
/* =========================================================
   ANIMAÇÕES DA HOME - VERSÃO INSTITUCIONAL / EDITORIAL
   Movimento mais lento, direcional e perceptível.
========================================================= */

.animar-scroll {
    opacity: 0;

    transition:
        opacity 1.65s cubic-bezier(0.19, 1, 0.22, 1),
        transform 1.65s cubic-bezier(0.19, 1, 0.22, 1);

    transition-delay: var(--anim-delay, 0s);

    will-change: opacity, transform;
    backface-visibility: hidden;
    transform-style: preserve-3d;
}

/* Títulos: descem suavemente até a posição final */
.animar-titulo {
    transform: translate3d(0, -95px, 0);
}

/* Elementos que entram da esquerda */
.animar-img-esquerda,
.animar-texto-esquerda,
.animar-card-esquerda {
    transform: translate3d(-165px, 0, 0);
}

/* Elementos que entram da direita */
.animar-img-direita,
.animar-texto-direita,
.animar-card-direita {
    transform: translate3d(165px, 0, 0);
}

/* Elementos auxiliares que sobem */
.animar-card-baixo {
    transform: translate3d(0, 105px, 0);
}

/* Estado final */
.animar-scroll.ativo {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

/*
   Mobile:
   Aqui está o ajuste principal.
   Antes tudo vinha de baixo para cima.
   Agora preservamos direção lateral, mas com distância menor.
*/
@media (max-width: 768px) {
    .animar-scroll {
        transition-duration: 1.45s;
    }

    .animar-titulo {
        transform: translate3d(0, -70px, 0);
    }

    .animar-img-esquerda,
    .animar-texto-esquerda,
    .animar-card-esquerda {
        transform: translate3d(-72px, 0, 0);
    }

    .animar-img-direita,
    .animar-texto-direita,
    .animar-card-direita {
        transform: translate3d(72px, 0, 0);
    }

    .animar-card-baixo {
        transform: translate3d(0, 70px, 0);
    }
}

@media (max-width: 480px) {
    .animar-scroll {
        transition-duration: 1.35s;
    }

    .animar-img-esquerda,
    .animar-texto-esquerda,
    .animar-card-esquerda {
        transform: translate3d(-52px, 0, 0);
    }

    .animar-img-direita,
    .animar-texto-direita,
    .animar-card-direita {
        transform: translate3d(52px, 0, 0);
    }

    .animar-titulo {
        transform: translate3d(0, -54px, 0);
    }
}

/* Acessibilidade */
@media (prefers-reduced-motion: reduce) {
    .animar-scroll {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* FINAL */



@media (max-width: 1450px) {
    .parallax-container {
        min-height: 500px;
    }

    .parallax-background {
        
        min-height: 300px;
    }

    main {
        margin-top: 0px;
		
    }
}

@media (max-width: 1000px) {
    .parallax-container {
        min-height: 465px;
    }

    .parallax-background {
        
        min-height: 300px;
    }

    main {
        margin-top: 0px;
		
    }
}

@media (max-width: 500px) {
    .parallax-container {
        min-height: 400px;
    }

    .parallax-background {
        
        min-height: 300px;
    }

    main {
        margin-top: 0px;
		
    }
}



/* ==============================
   FIM DA ANIMAÇÃO - INICIAL
============================== */


main {
    position: relative;
    z-index: 0;

    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;

    width: 100%;
    max-width: 1900px;

    padding: 0;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;

    line-height: 1.6;
    background-color: #fff;
    text-align: center;
}

.conteudo {
	
	margin:0px;
	padding:0px;
    width: 85%;
    text-align: justify;
}

#home{
	margin-right:10px;
	margin-left:10px;
	margin-top: 20px;
}

.linha_rsocial1{
	opacity:0.6;
	margin-top:0px;
	border: none;
    height: 1px;
    background-color: #ccc;
    width: 100%;
    margin-bottom:10px; 
}

.linha_rsocial2{
	opacity:0.6;
	border: none;
    height: 1px;
    background-color: #ccc;
    margin-bottom:0;
    margin-top:10px;
    width: 50%;
}

.linha_meio {
	opacity:0.6;
    border: none;
    height: 2px;
    background-color: #7f8d84;
    margin-bottom: 35px;
    margin-top: 35px;
    width: 100%;
}


footer {
	
    justify-content: center;
    padding: 0px;
    background: #33333399;
    position: relative;
    bottom: 0;
    width: 100%;
    font-size: 12px;
    min-height: 300px; 
    
}
.rodape-container{
	
	padding:0px;
	justify-content: center;
	align-items: center;
	align-self: center;
	width: 100%;
	font-size-adjust: 10px;
	line-height: 20px;
	height: 400px;
}

.rodape-container p{
	
	color:#fff;
	
	margin-left: 20px;
	margin-bottom:5px;
}
.local{
	
	padding-bottom:40px;
	
}
.rodape-container .localizacao{
	position: absolute;
	right:5%;
	bottom:10%;
	transform: translateX(-50%);
	font-weight: bold;
	font-size:13px;
	border-radius:30px;
/*	border-bottom-right-radius:40px;*/
	color:#33333399;	
	top:80px;
	width: 200px;
	height: 50px;
	background-color: #fff;
	display: flex;
	justify-content: center;
	align-content:center;
	align-items:center;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
}

@media (max-width: 768px) {
	.rodape-container .localizacao{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-weight: bold;
	font-size:13px;
	border-radius:30px;
/*	border-bottom-right-radius:40px;*/
	color:#33333399;	
	top:80px;
	width: 200px;
	height: 50px;
	background-color: #fff;
	display: flex;
	justify-content: center;
	align-content:center;
	align-items:center;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
	
	}   
}

.rodape-container .localizacao::after{
/*	
	content: '';
	position: absolute;
	bottom: -10px; /* Distância do triângulo em relação à base da div */
/*	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 55px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid #fff; /* Mesma cor da div */

}


.r_esq{
	
	
	margin-left: 6%;
	padding-top:130px;
	margin-top:50px;
	max-width:68%; 
	font-weight: bold;
	
	
}

.cnpj{
	color:#fff;
	margin-bottom:50px;
	font-size:10px;
	
	
}

.cnpj p{
	color:#fff;
	
	text-align:left;
	border-top: 2px solid #ffffff50;
	
	font-size:10px;
	
}


.rodape-container .localizacao img{
	
	
}

#waurlsite {
	width: 100%;
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
    font-size: 11px;
    
/*	background-color: #000; 
	width: 100%;
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo 
    justify-content: center; /* Alinha os itens horizontalmente no centro 
    background: #fff;
    color: #000;
    font-size: 11px;
    align-items: center; /* Alinha os itens verticalmente no centro 
    gap: 15px; /* Espaçamento entre os elementos 
    margin: 0 auto; /* Centraliza o container na página */
}





.bt-whatsApp {
	position: absolute;
	right:15px;
	width: 35px; /* Define um tamanho fixo para o botão */
    height: 35px;
}

.bt-whatsApp img {
	width: 35px;
    height: 35px;
}

.texto_quemsomos{
	
	color: #333333;
	font-size: 16px;
	font-weight: lighter;
}

.im_curriculo{
	width: 100%;
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
    justify-content: center; /* Alinha os itens horizontalmente no centro */
/*	background-color: #000; */
}

.curriculo_interno{
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
    justify-content: center; /* Alinha os itens horizontalmente no centro */
    align-items: center; /* Alinha os itens verticalmente no centro */
    gap: 30px; /* Espaçamento entre os elementos */
    width: 100%;
    margin: 0 auto; /* Centraliza o container na página */
	
	
}

.curriculo_01{
	position:relative;
	justify-content: center;
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
	flex-direction: column;
	flex: 1 1 300px; /* Permite que os itens se redimensionem, com largura mínima de 300px */
	
	border: 1px solid rgba(204, 204, 204, 0.5);

	border-radius: 5px;
	
	margin-left: 0px;
	justify-content: center;	
}
.curriculo_02{
	position:relative;
	justify-content: center;
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
/*	min-width: 300px;
	max-width: 800px;
	width: 44%;
*/	flex-direction: column;
	flex: 1 1 300px; /* Permite que os itens se redimensionem, com largura mínima de 300px */
	
/*	background-color: #fff; */
	border: 1px solid rgba(204, 204, 204, 0.5);
	border-radius: 5px;
	margin-right: 0px;
	justify-content: center;
}

.curFoto{
	justify-content: center;
	margin-bottom:0px;
	padding-bottom:0px;
	align-self: center;
	width: 40%;
	min-width:150px;
	max-width: 320px;
	margin-top: 20px;
}
.nome_adv{
	text-align: center;
	font-size: 20px;
	color: #333333;
	align-items: center;
	margin-bottom: 0px;
	margin-top: 10px;
}

.curriculo{
	line-height: 1.5;
	height:8lh;
	min-height: calc(4lh);
	max-height: calc(5lh + 4lh);
	color: #333333;
	margin-top:15px;
	margin-bottom:20px;
	margin-left:10px;
	margin-right:10px;
	text-align:center;
	font-size: 14px;
	margin-top: 10px;
}

 .bloco_infor_1 {
 	
    display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
    align-items: center; /* Alinha os itens verticalmente no centro */
    gap: 30px; /* Espaçamento entre os elementos */
    width: 100%;    
    margin: 0 auto; /* Centraliza o container na página */
}

.bloco_fazemos {
	position:relative;
	line-height: 1.5;
	height:calc(14lh);
	min-height: calc(11lh);
	max-height: calc(12lh + 4lh);
	color: #333333;
	text-align:justify;
	font-size: 14px;
		
	display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
/*	min-width: 300px;
	max-width: 800px;
	width: 44%; */	
	flex-direction: column;
	flex: 1 1 350px; /* Permite que os itens se redimensionem, com largura mínima de 300px */
	
/*	background-color: #fff; */
	border: 1px solid rgba(204, 204, 204, 0.5);
	border-radius: 5px;		
}
        
.bloco_servicos{
    position:relative;
    line-height: 1.5;
	height:calc(14lh);
	min-height: calc(9lh);
	max-height: calc(12lh + 6lh);
	color: #333333;
	text-align:justify;
	font-size: 14px;
       
    display: flex;
    flex-wrap: wrap; /* Permite que os itens quebrem para a linha de baixo */
/*	min-width: 300px;
	max-width: 800px;
	width: 44%;
*/	flex-direction: column;
	flex: 1 1 350px; /* Permite que os itens se redimensionem, com largura mínima de 300px */
	
/*	background-color: #fff; */
	border: 1px solid rgba(204, 204, 204, 0.5);
	border-radius: 5px;
}

/* =========================================================
   AJUSTE DE ALINHAMENTO - TEXTOS
   Remove margem lateral que empurrava o texto para dentro
========================================================= */

.blocos-inferiores .texto_servicos {
    margin-left: 0;
    margin-right: 0;
}

/*
   Mantém o espaçamento entre texto e imagem apenas pelo gap do bloco.
   Assim o texto de Atuação alinha com o título.
*/
.blocos-inferiores .bloco-info-linha {
    gap: 28px;
}


.icone_infor{
	
	position: absolute;
    top: -3px;
    right: -3px;
    display: flex;
    align-items: center;
    justify-content: center;
    
}

/* =========================================================
   AJUSTE DE ALINHAMENTO - APENAS NO DESKTOP
========================================================= */

@media (min-width: 769px) {
    .blocos-inferiores .texto_servicos {
        margin-left: 0;
        margin-right: 0;
    }

    .blocos-inferiores .bloco-info-linha {
        gap: 28px;
    }
}

.img_icones{	
	width: 60px;
}

/* =========================================================
   BOTÕES - PÁGINA MEU DIREITO
   Objetivo:
   1. Todos os botões com o mesmo tamanho.
   2. Máximo de 4 botões por linha no desktop.
   3. Botões alinhados em grade.
   4. No celular, cada botão ocupa 100% da largura.
========================================================= */

#b_meudireito {
    position: relative;
    z-index: 4;
    width: 100%;
    display: flex;
    justify-content: center;
    font-size: 14px;
}

#b_meudireito .conteudo_interno_s {
    width: 100%;
    max-width: 1500px;
    margin: auto;
	margin-top:0px;
    display: grid;

    /*
       4 colunas fixas no máximo.
       Mesmo em tela muito grande, nunca passa de 4 botões por linha.
    */
    grid-template-columns: repeat(4, minmax(0, 1fr));

    gap: 20px;
    align-items: stretch;
}

/* Botão individual */
#b_meudireito .botao_s {
    width: 100%;
    min-height: 92px;

    display: flex;
    align-items: center;
    justify-content: flex-start;

    gap: 14px;

    padding: 18px 20px;

    background-color: #ffffff;
    
    border-radius: 12px;

    box-shadow: 0 0 25px rgba(0, 0, 0, 0.15);

    text-decoration: none;
    color: #333333;

    transition:
        transform 0.25s ease,
        box-shadow 0.25s ease,
        border-color 0.25s ease,
        background-color 0.25s ease;
}

#b_meudireito .botao_s:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.10);
    border-color: rgba(127, 141, 132, 0.65);
    background-color: #ffffff;
}

/* Círculo do ícone */
#b_meudireito .icone-botao-meudireito {
    width: 42px;
    height: 42px;
    min-width: 42px;

    border-radius: 50%;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    background-color: #6c927b90;
    color: #ffffff;

    flex-shrink: 0;
}

/* Ícone Font Awesome */
#b_meudireito .icone-botao-meudireito i {
    color: #ffffff;
    font-size: 18px;
    line-height: 1;
}

/* Caso algum botão ainda use imagem */
#b_meudireito .icone-botao-img {
    overflow: hidden;
    background-color: rgba(108, 146, 123, 0.15);
}

#b_meudireito .icone-botao-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

/* Texto do botão */
#b_meudireito .texto-botao-meudireito {
    display: block;

    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;

    text-align: left;
    color: #333333;
}

/* Até 1200px: 3 botões por linha */
@media (max-width: 1200px) {
    #b_meudireito .conteudo_interno_s {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* Até 850px: 2 botões por linha */
@media (max-width: 850px) {
    #b_meudireito .conteudo_interno_s {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Celular: 1 botão por linha ocupando toda a largura */
@media (max-width: 600px) {
    #b_meudireito .conteudo_interno_s {
		margin-top:0px;
		padding-top:0px;
        grid-template-columns: 1fr;
        gap: 14px;
        width: 100%;
    }

    #b_meudireito .botao_s {
        width: 100%;
        min-height: 90px;
        padding: 20px;
		margin-bottom:8px;
    }

    #b_meudireito .texto-botao-meudireito {
        font-size: 14px;
    }
}



/* =========================================================
   AJUSTE FINAL - HOME: TEXTO ALINHADO AO TOPO + MOBILE
   Objetivo:
   1. Fazer o texto começar rente ao topo da imagem.
   2. Evitar texto centralizado verticalmente ao lado da imagem.
   3. No celular, imagem e texto ocupam 100% da largura.
   4. Manter a ordem correta dos blocos invertidos.
========================================================= */

/* Alinha todos os itens da home pelo topo, não pelo centro */
.bloco-sobre {
    align-items: start;
}

/* Garante que imagem e texto comecem no topo da linha */
.bloco-sobre > div,
.bloco-sobre > p,
.bloco-sobre .texto-bloco-info {
    align-self: start;
}

/* Remove a sensação de texto "descendo" por margem interna antiga */
.texto_quemsomos,
.texto-bloco-info,
.texto_fazemos,
.texto_servicos {
    margin-top: 0;
}

/* Nos blocos inferiores, o flex também deve alinhar pelo topo */
.bloco-info-linha {
    align-items: flex-start;
}

/* Imagens do bloco "Sobre nós" com altura padronizada */


/* Faz a imagem preencher o quadro sem deformar */
/*.img_esquerda img,
.img_direita img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
*/

/* Imagens dos blocos inferiores */
.imagem-bloco-home {
    min-height: 300px;
    
    overflow: hidden;
}


/* Ajuste de leitura do texto ao lado das imagens */
.texto_quemsomos,
.texto-bloco-info {
    padding-top: 0;
}

/* =========================================================
   RESPONSIVO - CELULAR
========================================================= */

@media (max-width: 768px) {

    /*
       Como .bloco-sobre é GRID, não adianta apenas usar flex-direction.
       Aqui transformamos todos os blocos da home em uma única coluna.
    */


    .bloco-sobre {
        display: grid;
        grid-template-columns: 1fr;
        gap: 18px;
        align-items: start;
        margin-top: 28px;
    }

    .bloco-sobre > div,
    .bloco-sobre > p,
    .img_esquerda,
    .img_direita,
    .icone-grande,
    .imagem-bloco-home,
    .texto_quemsomos,
    .texto-bloco-info {
        grid-column: 1 / -1;
        width: 100%;
        max-width: 100%;
    }

    .img_esquerda,
    .img_direita,
    .imagem-bloco-home {
        width: 100%;
        height: auto;
        max-height: none;
        min-height: initial;
        min-width: initial;
        overflow: visible;
    }

    .img_esquerda img,
    .img_direita img,
    .imagem-bloco-home img {
        width: 100%;
        height: auto;
        max-height: none;
        object-fit: contain;
        display: block;
    }

    .bloco-normal .img_esquerda,
    .bloco-normal .imagem-bloco-home {
        order: 1;
    }

    .bloco-normal .texto_quemsomos,
    .bloco-normal .texto-bloco-info {
        order: 2;
    }

    .bloco-invertido .img_direita,
    .bloco-invertido .imagem-bloco-home {
        order: 1;
    }

    .bloco-invertido .texto_quemsomos,
    .bloco-invertido .texto-bloco-info {
        order: 2;
    }

    .texto_quemsomos,
    .texto-bloco-info {
        font-size: 15px;
        line-height: 1.75;
        text-align: justify;
        margin-left: 0;
        margin-right: 0;
    }

    .texto-bloco-info .titulos,
    .texto_fazemos .titulos,
    .texto_servicos .titulos {
        text-align: left;
    }

    .conteudo {
        width: 85%;
    }

    #home {
        margin-left: 0;
        margin-right: 0;
    }
}

.subloco_1 .texto_quemsomos strong{
	
	font-size: 16px;
    font-weight: 800;
	color: #7f8d84;

}




/* =========================================================
   ANIMAÇÕES - PÁGINA MEU DIREITO
   Movimento aplicado ao bloco inteiro dos botões
   ========================================================= */

.meudireito-page {
    padding-top: 45px;
    padding-bottom: 60px;
}

/* Estado inicial */
.md-anim {
    opacity: 0;
    filter: blur(1px);

    transition:
        opacity 1.25s cubic-bezier(0.22, 1, 0.36, 1),
        transform 1.25s cubic-bezier(0.22, 1, 0.36, 1),
        filter 1.25s cubic-bezier(0.22, 1, 0.36, 1);

    will-change: opacity, transform, filter;
}

/* Movimento mais nítido */
.md-anim-left {
    transform: translateX(-110px);
}

.md-anim-right {
    transform: translateX(110px);
}

.md-anim-top {
    transform: translateY(-110px);
}

.md-anim-bottom {
    transform: translateY(110px);
}

/* Estado visível */
.md-anim.visivel {
    opacity: 1;
    filter: blur(0);
    transform: translate(0, 0);
}

/* A div completa dos botões aparece primeiro */
#b_meudireito .conteudo_interno_s.md-anim {
    transition-delay: 0.08s;
}

/* Linha e redes sociais aparecem depois */
.linha_meio.md-anim {
    transition-delay: 0.24s;
}

.md-rsocial.md-anim {
    width: 100%;
    transition-delay: 0.34s;
}

/* Mobile: movimento vertical mais nítido */
@media (max-width: 768px) {
    .md-anim-left,
    .md-anim-right,
    .md-anim-top,
    .md-anim-bottom {
        transform: translateY(62px);
    }
}

/* Acessibilidade */
@media (prefers-reduced-motion: reduce) {
    .md-anim {
        opacity: 1;
        filter: none;
        transform: none;
        transition: none;
    }
}


/* =========================================================
   AJUSTE EXCLUSIVO - PÁGINA MEU DIREITO NO MOBILE
   Remove sobra entre o topo e os botões
========================================================= */

@media (max-width: 768px) {

    .pagina-meudireito .meudireito-page {
        padding-top: 0;
    }

    .pagina-meudireito .parallax-container {
        min-height: 450px;
    }

    .pagina-meudireito .parallax-background {
        min-height: 350px;
    }

    .pagina-meudireito .logo-menor {
        margin-top: 10px;
    }

    .pagina-meudireito .bl {
        margin-top: 70px;
    }
}

@media (max-width: 500px) {

    .pagina-meudireito .meudireito-page {
        padding-top: 0;
    }

    .pagina-meudireito .parallax-container {
        min-height: 360px;
    }

    .pagina-meudireito .parallax-background {
        min-height: 245px;
    }

    .pagina-meudireito .logo-menor {
        margin-top: 8px;
        max-width: 230px;
        min-width: 180px;
        border-width: 15px;
    }

    .pagina-meudireito .bl {
        margin-top: 68px;
    }
}

/* =========================================================
   AJUSTE FINAL - TÍTULOS DA HOME
   Objetivo:
   1. Manter todos os títulos da home na mesma estética.
   2. Fazer "O que fazemos" e "Atuação" alinharem à esquerda.
   3. Impedir que o flex dos blocos inferiores centralize os títulos.
========================================================= */

#home > .titulos,
.blocos-inferiores > .titulos {
    width: 100%;
    display: block;

    text-align: left;
    align-self: stretch;

    color: #7f8d84;

    font-size: clamp(24px, 2.4vw, 38px);
    font-weight: 700;
    line-height: 1.18;

    margin-top: 26px;
    margin-bottom: 8px;

    letter-spacing: -0.7px;
}

/*
   Corrige interferência da classe antiga .bloco_infor_1,
   que aparece depois no CSS e centraliza os filhos.
*/
.blocos-inferiores {
    align-items: stretch !important;
}

/*
   Mantém os blocos de imagem + texto alinhados pelo topo.
*/
.blocos-inferiores .bloco-info-linha {
    align-items: flex-start;
}

/* =========================================================
   AJUSTE REFINADO - LEITURA DOS TEXTOS DA HOME
   Padrão mais sofisticado para desktop e mobile
========================================================= */

.texto_quemsomos,
.texto-bloco-info,
.texto_fazemos,
.texto_servicos,
.texto-bloco-info p {
    font-size: clamp(15.5px, 1.02vw, 16.5px);
    line-height: 1.78;
    font-weight: 300;
    color: #333333;
    letter-spacing: -0.12px;
}

/*
   Evita que o strong fique com aparência exagerada no mobile.
*/
.subloco_1 .texto_quemsomos strong,
.texto-bloco-info strong {
    font-size: inherit;
    font-weight: 800;
    color: #7f8d84;
}

/*
   Desktop: mantém texto elegante e alinhado.
*/
@media (min-width: 769px) {
    .texto_quemsomos,
    .texto-bloco-info,
    .texto_fazemos,
    .texto_servicos,
    .texto-bloco-info p {
        text-align: justify;
    }
}

/*
   Mobile: leitura mais natural.
   Justificado em telas pequenas pode criar buracos entre palavras.
*/
@media (max-width: 768px) {
    .texto_quemsomos,
    .texto-bloco-info,
    .texto_fazemos,
    .texto_servicos,
    .texto-bloco-info p {
        font-size: 16px;
        line-height: 1.72;
/*        text-align: left;*/
        text-align: justify;
		letter-spacing: -0.08px;
        font-weight: 300;
    }

    #home > .titulos,
    .blocos-inferiores > .titulos {
        font-size: 25px;
        line-height: 1.15;
        margin-top: 22px;
        margin-bottom: 4px;
    }
}

@media (max-width: 480px) {
    .conteudo {
        width: 88%;
    }

    .texto_quemsomos,
    .texto-bloco-info,
    .texto_fazemos,
    .texto_servicos,
    .texto-bloco-info p {
        font-size: 15.8px;
        line-height: 1.70;
    }

    #home > .titulos,
    .blocos-inferiores > .titulos {
        font-size: 24px;
    }
}

/* =========================================================
   AJUSTE DE ESPAÇAMENTO - TÍTULOS DOS BLOCOS INFERIORES
   Reduz o espaço entre "O que fazemos" / "Atuação" e o conteúdo
========================================================= */

.blocos-inferiores {
    gap: 26px;
}

.blocos-inferiores > .titulos {
    margin-bottom: 0;
}

.blocos-inferiores .bloco-info-linha {
    margin-top: 10px;
    margin-bottom: 28px;
}

/* Mobile: espaço ainda mais controlado */
@media (max-width: 768px) {
    .blocos-inferiores {
        gap: 20px;
    }

    .blocos-inferiores > .titulos {
        margin-bottom: 0;
    }

    .blocos-inferiores .bloco-info-linha {
        margin-top: 6px;
        margin-bottom: 24px;
    }
}

