/*
Theme Name: Moroni Mattos
Text Domain: moroni_mattos
Author: NascerWeb | Christiano Amaral
Author URI: http://nascer.net/
Description: Template desenvolvido exclusivamente para a Moroni Câmara & Mattos de Souza Advogados Associados, em parceria com a designer Luciana Delboux.
Version: 1.0
*/
/*-------------------------------------------------------
RESET
-------------------------------------------------------*/
/* 0. Remove margins and padding */
html, body,
html *, body * {
	margin: 0;
	padding: 0;
	border: 0;	
}
/* 1. Box sizing global */
*,
*::before,
*::after {
  box-sizing: border-box;
}
/* 2. Previne o aumento automático de fontes em dispositivos móveis */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}
/* 3. Remove margens padrão e define o comportamento do scroll */
body, h1, h2, h3, h4, h5, h6 p, figure, blockquote, dl, dd {
  margin-block-end: 0;
}
/* 4. Remove estilos de lista apenas quando usamos o atributo 
   (Útil para acessibilidade sem perder o estilo padrão de textos longos) */
ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
/* 5. Configurações base do corpo do site */
body {
  min-height: 100vh;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased; /* Melhora a renderização no macOS/iOS */
}
/* 6. Melhora a legibilidade em títulos e elementos interativos */
h1, h2, h3, h4, h5, h6,
button, input, label {
  line-height: 1.1;
}
/* 7. Novidade: Evita viúvas e melhora o equilíbrio visual em títulos */
h1, h2, h3, h4, h5, h6 {
  text-wrap: balance;
}

/* 8. Evita espaços estranhos abaixo das imagens */
img,
picture {  
  display: block;
}
/* 9. Faz com que inputs e botões herdem as fontes do projeto */
input,
button,
textarea,
select,
address {
  font: inherit;
}
/* 10. Garante que textareas sem atributo 'rows' tenham um tamanho mínimo decente */
textarea:not([rows]) {
  min-height: 10em;
}
/* 11. limpa propriedades de campos de formulários */
input,
select,
textarea,
button {
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;	
    border: none;
    border-radius: 0;
	padding: 0;
	margin: 0;
}
/* 11. Adiciona margem de scroll para links internos (âncoras) não ficarem "colados" ao topo */
:target {
  scroll-margin-block: 5ex;
}
/* 12. ACESSIBILIDADE: Respeita a preferência de movimento reduzido do utilizador */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/*-------------------------------------------------------
GERAIS
-------------------------------------------------------*/
html{
	height:100%;    
}
body {
	background-color: #FFFFFF;
    color: #322f2f;
    font-family: "Open Sans", sans-serif;
    font-optical-sizing: auto;   
    font-size: 18px;
    font-weight: 300;
    font-style: normal;		
	overflow-x: hidden;
	min-height: 100%;	
}
body.no-scroll{
    overflow-y: hidden;
}
h1, h2, h3, h4, h5, h6 {	   
	font-weight: 300;	
	line-height: 1em;	
}
h1,
h2{	
	font-size: 48px;   
    text-transform: uppercase;      
}
h3{	
	font-size: 32px;	   
}
h4{
	font-size: 28px;	
}
h5{
	font-size: 24px;	
}
h6{
	font-size: 20px;
}
a{	
    color: #322f2f;
	text-decoration: none;
	transition: background-color 300ms ease, border-color 300ms ease, color 300ms ease;
}
strong{
	font-weight: 600;	
	}
em{
	font-style: italic;
}
p {
	line-height: 1.5em;
	margin-bottom: 1em;
}
p:last-child{
	margin-bottom: 0 !important;
}
.clearfix{
	clear:both;
}
.clearbox::after{
	content: "";
	display: table;
	clear:both;
}
img,
svg{
	display: block;
	height: auto;
}
.main {
	width: 100%;
	height: auto;   
	position: relative;		
}
section{	
	width: 100%;
	height: auto;
	position: relative;		
}
.inner{	
	width: 1180px;
	height: auto;  	
	margin: 0 auto;
    position: relative;   
}
/* VÍDEOS RESPONSIVOS (YOUTUBE / VIMEO) */
.video-container {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;  
    overflow: hidden;   
}
.video-wrapper {    
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    position: relative;
}
.video-wrapper iframe,
.video-wrapper embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}
/*EMENDAS OWL*/
.owl-nav {   	
	padding: 0;	
    display: flex;
	position: absolute;	   
    pointer-events: none;
}
.owl-nav::before{
    content: "";
    background-color: #d5d2d2;  
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 3;
}
.owl-prev,
.owl-next {
    background: #f1efef !important;         
    border: none !important;   
	width: 100px;
    height: 100px;
    display: block;       
    position: relative;
    pointer-events: all;
    transition: background-color 300ms ease;
}
.owl-prev span,
.owl-next span{
    border: 1px solid #384867;
    width: 32px;
    height: 32px;
    display: block;
    font-size: 0;
    color: transparent;
    text-indent: -9999px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform-origin: center center;
    transform: translate(-27px, -50%) rotate(45deg);
    transition: border-color 300ms ease;
}
.owl-prev span{
    border-top: none;
    border-right: none;  
    transform: translate(-8px, -50%) rotate(45deg);
}
.owl-next span{
    border-bottom: none;
    border-left: none;   
    transform: translate(-24px, -50%) rotate(45deg);
}
.owl-prev:hover,
.owl-next:hover{
    background-color: #384867 !important;     
}
.owl-prev:hover span,
.owl-next:hover span{
    border-color: #FFF;
}
.owl-prev.disabled,
.owl-next.disabled{
    background: #f1efef !important;        
    cursor: not-allowed !important;   
}
.owl-prev.disabled span,
.owl-next.disabled span{
    border-color: #384867;
    opacity: 0.3;
}
/*-------------------------------------------------------
HEADER
-------------------------------------------------------*/
header{
	background-color: #FFF;
	width: 100%;
	height: auto;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
}
header.fixed{
    position: fixed;
    top: -35px;
}
.header-inner {
	width: 1180px;
	height: auto;
	padding: 50px 0 15px;
	position: relative;
	margin: 0 auto;
    transition: padding 300ms ease;
}
.btn-menu{
    background: transparent;
    border: none;   
    padding: 0; 
    display: none;
    cursor: pointer;
}
.logo {
	width: max-content;
	height: auto;
	display: block;	
}
header .logo-img{
    width: auto;
    height: 122px;     
    transition: height 300ms ease;
}
/* SHRINK */
header.fixed .header-inner {	
	padding: 50px 0 15px 35px;	
}
header.fixed .logo-img{
    height: 70px;   
}
header.fixed .navegacao {
    padding: 10px 0 20px;
	top: 83px;
}
header.fixed .navegacao::before {
	width: 875px;	
}
/* DISTÂNCIA ROLAGEM TOPO */
#ps2id-dummy-offset{
    height: 140px;
}
/* NAVEGAÇÃO */
.navegacao {   
	background-color: #FFFFFF;
	width: 160px;
	height: auto;
	padding: 24px 0 20px;
	display: flex;
	align-items: end;
	position: absolute;
	right: 0;
	top: 108px;
	transition: top 300ms ease, padding 300ms ease, right 400ms ease-in-out;
}
.navegacao::before {
	content: "";
	border-top: 1px solid #322f2f;
	width: 723px;
	height: 1px;
	display: block;
	position: absolute;
	top: 0;
	right: 0;
    transition: width 300ms ease;
}
.navegacao::after{
    content: "";
    background-color: inherit;
    width: calc( 50vw - 590px);
    height: 100%;
    position: absolute;
    top: 0;
    left: 100%;    
}
.menu-header{
    width: 100%;   
}
.menu-header ul.menu{
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.menu-header ul.menu li{
   display: block;  
}
.menu-header ul li a {	
    width: max-content;
    display: block;
    position: relative;
	color: #322f2f;   
	font-size: 18px;
	font-weight: 400;
	line-height: 1em;	
    text-transform: lowercase;
    margin-left: auto;
}
.menu-header ul li a::before{
    content: "_";
    color: #FFFFFF;
    transition: color 300ms ease;
}
.menu-header ul li a:hover{
    color: #bd521c;
}
.menu-header ul li.current-menu-item a::before{  
    color: #bd521c;
}
.home .menu-header ul li.current-menu-item a::before{
    color: #FFFFFF;
}
.menu-header ul li a.mPS2id-highlight::before{
    color: #bd521c !important;
}
/*-------------------------------------------------------
FOOTER
-------------------------------------------------------*/
footer{    
    background: #FFF;    
}
footer .inner{
    padding: 65px 0 50px 80px;
    display: flex;
    flex-wrap: wrap;
    align-items: start;    
    gap: 100px 70px;
}
footer h2{
    width: 100%;
}
footer .logo-img{
    width: 200px;
}
.contato-infos{
    width: 670px;
    display: flex;
    flex-wrap: wrap;
    align-items: start;   
    gap: 50px; 
    font-size: 16px;
}
.contato-infos address{
    line-height: 1.5em;
}
.contato-infos p{
    margin-bottom: 1.75em;
}
.contato-infos .social a{   
    width: max-content;
    display: block;
    font-weight: 500;
    text-transform: uppercase;
    text-decoration: underline;
    margin-bottom: 1em;
}
.contato-infos a:hover{
    color: #bd521c;
}
.contato-infos strong{
    text-transform: uppercase;
}
.formulario{
    width: 100%;
}
.menu-footer ul{
    display: flex;   
    gap: 15px;
}
.menu-footer ul li{
   display: block;  
}
.menu-footer ul li a {	
    width: max-content;
    display: block;
    position: relative;
	color: #322f2f;   
	font-size: 14px;
	font-weight: 400;
}
.menu-footer ul li a:hover{
    color: #bd521c;
}
/* DIREITOS */
.direitos{
    border-top: 1px solid #322f2f;
    width: 1180px;
    padding: 20px 0 30px 350px;   
    margin: 0 auto;
}
.direitos p{   
    font-size: 12px;
    font-weight: 400;    
}
.direitos p br{
    display: none;
}
.direitos p a{
    transition: color 300ms ease;
}
.direitos p a:hover{
    color: #bd521c;
}
/*-------------------------------------------------------
HOME
-------------------------------------------------------*/
/* SOBRE */
.sobre{
    margin-bottom: -200px;
    z-index: 1;
}
.sobre .inner {
    height: 100vh;
	min-height: 647px;
	padding: 187px 0 0;
	display: flex;
	align-items: end;	
}
.box-titulo {
	background-color: #bd521c;
	width: 400px;
	height: 400px;
	padding: 0 0 122px 80px;
	display: flex;
	align-items: end;
    color: #FFFFFF;
}
.box-titulo h1,
.box-titulo h2{
    color: #FFFFFF;
}
.sobre .box-titulo h2{
    width: min-content;    
}
.box-texto{
    background-color: #FFF;
    width: 780px;
    padding: 0 160px 124px 70px; 
    position: relative;
}
.box-texto::after{
    content: "";
    background-color: inherit;
    width: calc( 50vw - 590px);
    height: 100%;
    position: absolute;
    top: 0;
    left: 100%;    
}
.btn-sobre {
	background-color: #FFF;
	border: 1px solid #384867;
	width: max-content;
	height: 42px;
	padding: 0 15px;
	display: block;
	position: absolute;
	bottom: 50px;
	left: 55px;
	color: #322f2f;
	font-size: 16px;
	font-weight: 700;
	line-height: 40px;
	text-transform: uppercase;
}
.btn-sobre:hover{
    background-color: #384867;
    color: #FFFFFF;
}
/* EQUIPE */
.equipe{
    background: url(img/bg-equipe.webp) no-repeat center top;
    background-size: auto 1090px;
}
.equipe .inner {
	padding: 690px 0 40px;
	display: flex;
	align-items: end;
}
.equipe-lista{
    width: 100%;
}
.equipe-lista .owl-nav {
	width: 200px;
	height: 100px;
	flex-direction: row;
	top: 300px;
	left: 800px;
}
.equipe-lista .owl-nav::before{  
    width: 2px;
    height: 78px; 
}
/* CARD */
.card-membro {   
    width: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;   
}
.card-membro-header{
    display: flex;
}
.card-membro .box-titulo {
	padding: 0 0 0 80px;	
}
.card-membro .box-titulo h2{   
	position: relative;
	transform: translateY(7px);
}
.card-membro-foto{
    width: 400px;
    height: 400px;
}
.card-membro-foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;  
}
.card-membro-info {
    background-color: #bd521c;
    width: 100%;   
    padding: 80px 180px 80px 80px;
    display: flex;
    flex-direction: column;    
    color: #FFF
}
.membro-resumo{
    height: 0;
    display: flex;
    align-items: last baseline;
    gap: 200px;
    overflow: hidden;   
}
.membro-resumo.open {   
    height: auto;   
}
.membro-resumo-info{
    width: 520px;
    font-size: 21px;
}
.membro-email {   
    color: #FFF; 
    font-weight: 500;
    word-break: break-all;
}
.membro-email:hover {
    color: #384867;
}
.btn-ler,
.btn-fechar {
	background: none;
	border: none;
	padding: 0;
    display: block;
    position: relative;
	color: #FFF;
	font-size: 16px;
	font-weight: 500;
	cursor: pointer;
    transition: color 300ms ease;
}
.btn-ler::before {
	content: ">";
	padding-right: 20px;
}
.btn-ler:hover,
.btn-fechar:hover{
    color: #384867;
}
.badge-wrapper {
	flex: 1;
}
.badge-consultor {   
    display: inline;   
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;  
    background-color: #FFFFFF;
    color: #bd521c;
    padding: 4px 10px;  
    line-height: 2.1;     
    font-size: 18px;
	font-weight: 700;   
    text-transform: uppercase;
}
.membro-curriculo {
    overflow: hidden;	
    position: relative;
}
.membro-curriculo.close{
    height: 0;
}
.membro-curriculo .btn-fechar{
    margin-left: auto;
}
/*-------------------------------------------------------
ATUAÇÃO
-------------------------------------------------------*/
.atuacao .inner{
    padding: 65px 0 40px;
    display: flex;
    flex-direction: column;
    gap: 100px;
}
.atuacao h2{
    margin-left: 80px;
}
.atuacao-container{
    display: flex;
    align-items: start;
    gap: 25px;
    position: relative;
}
.atuacao-imagem{
    width: 670px;
    position: relative;
    z-index: 0;
} 
.atuacao-imagem img {
    width: 100%;
    height: 480px;  
    object-fit: cover;
}
.atuacao-lista {
    width: 335px;
    position: relative;
    z-index: 1;
}
.atuacao-lista .owl-nav {
	width: 100px;
	height: 200px;
    flex-direction: column-reverse;
	top: 0;
	left: -125px;	
}
.atuacao-lista .owl-nav::before{  
    width: 78px;
    height: 2px; 
}
.card-area{
    height: 480px;
    padding: 2px 10px 0 20px;
    overflow-y: auto;   
}
h3.card-area-titulo {       
    font-weight: 400;
    text-transform: uppercase;
    margin-bottom: 0.625em;
}
.card-area-texto p{
    margin-bottom: 0.5rem;
}
.card-area-texto li{
    position: relative;
    line-height: 1.5em;
    margin-bottom: 0.5rem;
}
.card-area-texto li::before {
	content: "";
	background-color: #bd521c;
	width: 13px;
	height: 3px;
	position: absolute;
	top: 13px;
	left: -20px;
}
.card-area-texto p:last-child,
.card-area-texto li:last-child{
    margin-bottom: 0;
}
/*-------------------------------------------------------
COMPLIANCE
-------------------------------------------------------*/
.compliance{
    background: url(img/bg-compliance.webp) no-repeat center bottom;   
}
.compliance .inner { 
    padding: 0 0 600px;	
}
.compliance .inner::after{
    content: "";
    background: #FFF;
    width: calc( 100% + ( 50vw - 590px) );
    height: 230px;    
    display: block;
    position: absolute;
    bottom: 370px;
    left: 0;
}
.compliance-titulo{
    width: 400px;
    height: 100vh;
	min-height: 647px;
	padding: 187px 0 0;
	display: flex;
	align-items: end;	
    position: relative;
    z-index: 1;
    margin-bottom: -400px;
}
.compliance-titulo .box-titulo {
    padding: 0 0 0 80px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: start;	
}
.box-titulo span {
	border: 1px solid #FFF;
	width: max-content;
	height: 36px;
	padding: 0 12px;
	display: block;
	font-size: 16px;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 34px;
	margin: 0 0 1em -12px;
}
.box-titulo small {
	font-size: 32px;	
	display: inline-block;    
}
.compliance-container,
.privacidade-container  {
	display: flex;
	flex-direction: row-reverse;
}
.compliance-container .box-texto{  
    padding: 180px 160px 0 70px;    
}
.box-infos{
    width: 400px;
    padding: 480px 50px 0 80px;
}
.box-infos h3 {
	font-size: 28px;
	margin-bottom: 1em;
}
.box-infos a{
    text-decoration: underline;
}
.box-infos a{
    display: inline-block;
    margin-bottom: 0.5em;
}
.box-infos a:hover{
    color: #bd521c;
}
.box-infos strong{
    color: #bd521c;
}
/*-------------------------------------------------------
PRIVACIDADE
-------------------------------------------------------*/
.privacidade,
.politicas{
    background: url(img/bg-privacidade.webp) no-repeat center bottom;   
}
.lgpd-campos{  
    width: 780px;
    padding: 180px 160px 0 70px;    
}
.lgpd-campos h3 {
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 0.75em;
}
.lgpd-documentos{
    width: 400px;
    padding: 480px 0 0 80px;
}
.lgpd-documentos label.cf7-field-label{
    margin-bottom: 0;
}
/*-------------------------------------------------------
POLÍTICAS
-------------------------------------------------------*/
.politicas .box-titulo h1 {
	overflow-wrap: break-word;
	width: 100%;
	hyphens: auto;
	-webkit-hyphens: auto;
}
/*-------------------------------------------------------
FORMULÁRIOS
-------------------------------------------------------*/
.cf7-wrapper {
    width: 100%;   
    margin: 0;     
}
.cf7-fieldset {
    border: none;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: start;    
    gap: 20px 30px;
    margin: 0 0 15px;    
}
.cf7-field{
    width: calc( 50% - 15px );
}
.cf7-field.wide{
    width: 100%;
}
label.cf7-field-label {
    display: block;
	font-weight: 500;
	margin-bottom: 15px;	
}
input[type=text],
input[type=email],
input[type=tel],
input[type=password],
select,
textarea{    
    background-color: #FFF;
    border: 1px solid #322f2f;
    border-radius: 0;
    width: 100%;      
    height: 55px;
    padding: 0 20px;
    font-size: 16px;   
    color: #322f2f;
    outline: none;
    transition: border-color 300ms ease;   
}
select {
    background-image: url("data:image/svg+xml,%3Csvg id='Camada_1' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 17 9.2'%3E%3Cpolygon points='16.3 0 8.5 7.8 .7 0 0 .7 7.8 8.5 8.5 9.2 9.2 8.5 17 .7 16.3 0' fill='%23322f2f'/%3E%3C/svg%3E");    background-repeat: no-repeat;
    background-position: right 19px center;
    background-size: 17px auto;
    padding-right: 55px;
    cursor: pointer;  
}
textarea {
    height: 140px;
    padding: 20px;
    resize: none;
    line-height: 1.5em;
}
::placeholder {
    color: #322f2f;
    opacity: 0.75;
}
:focus::placeholder{   
    opacity: 0;
}
input:focus,
select:focus,
textarea:focus {
    border-color: #bd521c; 
}
.cf7-footer {
    display: block;   
}
.cf7-legend {		
    display: block;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.25em;
	margin-bottom: 15px;
}
.cf7-acceptance {	
	display: flex;
	align-items: start;
	gap: 5px;
    margin-bottom: 15px;
}
.cf7-acceptance .wpcf7-list-item {   
    margin: 0;
}
.cf7-acceptance input[type="checkbox"],
.cf7-acceptance .wpcf7-list-item input {
    width: 24px;
    height: 24px;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    cursor: pointer;   
    margin: 0;
    z-index: 10;
}
/* RADIO BUTTON */
.radio-item{
    display: block;
}
.radio-item .wpcf7-list-item {
    width: max-content;
    max-width: 100%;
	min-height: 25px;
	padding: 0 0 0 30px;
	display: block;
	position: relative;
	margin: 0 0 10px 0;
}
.radio-item .wpcf7-list-item:last-child{
    margin: 0;
}
.radio-item .wpcf7-list-item input {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    cursor: pointer;   
    margin: 0;
    z-index: 10;
}
.radio-item .wpcf7-list-item-label {
	line-height: 1.25em;
}
/* CHECKBOX */
.wpcf7-acceptance .wpcf7-list-item {
    width: 24px;
    height: 24px; 
	position: relative;	
}
.wpcf7-acceptance .wpcf7-list-item-label::before,
.radio-item .wpcf7-list-item-label::before {
    position: absolute;
    top: 3px;
    left: 0;
    height: 20px;
    width: 20px;
    background-color: #FFFFFF;
    border: 1px solid #322f2f;      
}  
.wpcf7-acceptance .wpcf7-list-item-label::after,
.radio-item .wpcf7-list-item-label::after {
	content: "";
	background: #bd521c;	
	position: absolute;
	top: 6px;
    left: 3px;
	width: 14px;
    height: 14px;
	opacity: 0;	
    transition: opacity 300ms ease;
}
.wpcf7-acceptance .wpcf7-list-item input:checked ~ .wpcf7-list-item-label::after,
.radio-item .wpcf7-list-item input:checked ~ .wpcf7-list-item-label::after{
    opacity: 1;	
}
.cf7-acceptance-text {
    padding-top: 4px;
    font-size: 13px;
    font-weight: 400;   
    line-height: 1.25em;   
}
.codedropz-upload-container {
	padding: 60px 20px;
}
.codedropz-upload-handler {
	border: 1px solid #384867;	
    border-radius: 0;
	margin-bottom: 0;	
}
.codedropz-upload-handler span{   
    font-size: 16px;
}
a.cd-upload-btn {
	background-color: #384867;
	color: #FFFFFF;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	padding: 3px 8px;
	display: block;
	width: max-content;
	margin: 5px auto 0;
}
a.cd-upload-btn:hover{
    background-color: #bd521c;
}
.dnd-upload-counter,
.dnd-upload-counter span {
	font-size: 12px !important;
	font-weight: 500;
}
.dnd-upload-status .dnd-upload-details .name {
	color: #384867;	
	padding-right: 25px;	
    font-size: 14px;
    font-weight: 400;
}
.dnd-upload-status .dnd-upload-details .name span {
	font-weight: 400;
}
.dnd-upload-status .dnd-upload-details .name em {
	color: #322f2f;
	font-weight: 600;
    font-style: normal !important;
}
.dnd-upload-status .dnd-upload-details .dnd-progress-bar {		
	background: #f1efef;
    border-radius: 0;
	height: 18px;
}
.dnd-upload-status .dnd-upload-details .dnd-progress-bar span {
	background: #bd521c;
    padding-right: 10px;
    font-weight: 500;
	line-height: 18px;		
}
.cf7-submit-wrap{
    width: 100%;
    position: relative;   
}
input[type="submit"] {
    background-color: #384867;
    border: none;   
    width: 135px;
    height: 50px;
    padding: 0;
    color: #FFFFFF;  
    cursor: pointer;
    transition: background-color 300ms ease;
}
input[type="submit"]:hover {
    background: #bd521c;    
}
input[type="submit"]:disabled {
	cursor: not-allowed;
    opacity: 0.5;
}
input[type="submit"]:disabled:hover{
    background-color: #384867;
}
.cf7-submit-wrap .wpcf7-spinner{
    background-color: #bd521c;	
	position: absolute;
    top: 50%;
	right: 0;	
	transform: translateY(-50%);
    margin: 0;
}
/* ── Mensagens de erro CF7 ── */
.wpcf7-not-valid-tip {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: #bd521c;
    margin-top: 5px;
}
.wpcf7-not-valid-tip::before{
	content: "🡡 ";
	font-weight: normal !important;
}
.wpcf7-not-valid {    
    box-shadow: 0 0 6px 3px rgba(189, 82, 28, 0.35);
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output{
    width: 100%;
    max-width: 940px;
    border: 1px solid !important;  
    padding: 20px;   
    position: relative;
    font-size: 1rem;
    font-weight: 600;
    text-align: center; 
    margin: 20px 0 0 !important;
}
.formulario-privacidade .wpcf7 form.invalid .wpcf7-response-output,
.formulario-privacidade .wpcf7 form.unaccepted .wpcf7-response-output{	
	left: 80px;	
}
.wpcf7 form.sent .wpcf7-response-output {
    background: rgba(48, 86143, 67, 0.1);
    border-color: #308F43 !important;
    color: #308F43;
} 
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    background: rgba(189, 82, 28, 0.1);
    border-color: #bd521c !important;
    color:#bd521c;
} 
.wpcf7 form.spam .wpcf7-response-output {
     background: rgba(252, 185, 0, 0.1);
    border-color: #FCB900 !important;
    color:#FCB900;
}
/*-------------------------------------------------------
PADRÃO
-------------------------------------------------------*/
.padrao h2,
.padrao h3 {
	position: relative;
	margin: 1.5rem 0;
}
.padrao h2:first-child,
.padrao h3:first-child {
	margin-top: 0;
}
.padrao h2{
	font-size: 36px;	
    font-weight: 500;
}
.padrao h3{
	font-size: 28px;
    font-weight: 500;   
}
.padrao p a{		
	text-decoration: underline;
}
.padrao p a:hover{
	color: #bd521c;
}
.padrao ul,
.padrao ol{  
	padding: 0 0 0 30px;
	margin: 1.5rem 0;	
}
.padrao ol{
	counter-reset: li;
}
.padrao li{
	position: relative;
	line-height: 1.5em;	
    margin-bottom: 0.5rem;
}
.padrao ul li::before {
	content: "";
	background-color: #bd521c;
	width: 13px;
	height: 3px;
	position: absolute;
	top: 13px;
	left: -20px;
}
.padrao ol li {
	counter-increment: li;
}
.padrao ol li::before {
	content: counter(li)'.';
    width: 25px;
    position: absolute;
	left: -30px;
	color: #bd521c;
	font-size: 1em;
	font-weight: 600;
    text-align: right;	
}
.padrao .wp-caption{
	width: 100% !important;
	height: auto;
    margin: 1.5rem 0;
}
.padrao .wp-caption img{
    margin-bottom: 0 !important;
}
.padrao .wp-caption-text {   
	padding: 10px 0 0;
    height: auto;   
	position: relative;	
	font-size: 12px;
	font-weight: 400;
	line-height: 1.5em;
}
.padrao img.size-conteudo,
.padrao img.size-full,
.padrao img.size-large,
.padrao img.size-medium{
	width: 100%;
	height: auto;
	margin: 1.5rem 0;
}
.padrao .table-container{
    margin: 1.5rem 0;
}
.padrao table {
    width: 100%;    
    border-collapse: collapse;    
}
.padrao table tr{
    border-top: 1px solid #bd521c;
}
.padrao table tr:last-child{
    border-bottom: 1px solid #bd521c;
}
.padrao table tr:nth-child(even) td{
    background-color: #E9EFF6;
}
.padrao table td {
    border: 1px solid #bd521c;
}
.padrao table th {   
    border: 1px solid #bd521c;           
    font-weight: 600;
}
.padrao table td,
.padrao table th {   
    border-top: none;
    border-bottom: none;   
    padding: 7px;
}
.padrao table td:first-child,
.padrao table th:first-child {
    border-left: none;     
}
.padrao table td:last-child,
.padrao table th:last-child {
    border-right: none;     
}
.padrao .video-container{
    margin: 1.5rem 0;
}
.padrao .gallery {
	width: 100%;	
    padding-bottom: 20px;
	margin: 1.5rem 0;
}
.padrao *:last-child{
    margin-bottom: 0 !important;
}
/*-------------------------------------------------------
POPUP
-------------------------------------------------------*/
.fancybox-bg {  
    background-color: rgba(180, 180, 180, 0.85) !important;
}
.fancybox-button {
	background-color: #384867;
    color: #FFFFFF !important;
	width: 50px;
	height: 50px;
    opacity: 1;
	transition: background-color 300ms ease;
}
.fancybox-button:hover {
	background-color: #bd521c;		
}
.popup{
    background-color: #FFF;
    width: 900px;    
    padding: 75px 90px;   
    box-shadow: 2px 2px 15px 0px rgba(0,0,0,0.2);
}
.popup h3{
    text-decoration: underline;
    margin-bottom: 0.75em;
}
/*----------------------------------------------------------------------------------------------------
------------------------------------------------------------------------------------------------------
RESPONSIVO
------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------*/
@media only screen and (max-width : 810px) {
/*-------------------------------------------------------
GERAIS
-------------------------------------------------------*/
body {
    font-size: 16px;   
}
body.no-scroll{
    overflow-y: hidden;
}
h1,
h2{	
	font-size: 27px;      
}
h3{	
	font-size: 24px;	   
}
h4{
	font-size: 20px;	
}
h5{
	font-size: 28px;	
}
h6{
	font-size: 16px;
}
.inner{	
	width: 100vw;
}
/*EMENDAS OWL*/
.owl-prev,
.owl-next {
	width: 50px;
	height: 50px;
}
.owl-prev span,
.owl-next span{   
    width: 16px;
    height: 16px;      
}
.owl-prev span{  
    transform: translate(-4px, -50%) rotate(45deg);
}
.owl-next span{ 
    transform: translate(-12px, -50%) rotate(45deg);
}
/*-------------------------------------------------------
HEADER
-------------------------------------------------------*/
header,
header.fixed{   
    position: fixed;
    top: 0;
}
.header-inner {
	width: 100vw;
	padding: 25px 20px;
}
.btn-menu {
	background: #384867;
	width: 40px;
	height: 40px;
	display: block;
	position: absolute;
	top: 60px;
	right: 20px;
    z-index: 2;
    transition: top 300ms ease;
}
.btn-menu .bar{
    width: 28px;
    height: 2px;
    background-color: #FFF;      
    display: block;   
    position: absolute;       
    left: 6px; 
    transform-origin: center center;
    transition: transform 200ms ease, opacity 200ms ease;
}
.btn-menu .bar.bar-1{    
    top: 10px;
}
.btn-menu .bar.bar-2,
.btn-menu .bar.bar-3{   
    top: 19px;         
}
.btn-menu .bar.bar-4{
    width: 14px;
    top: 28px;
}
.btn-menu.ativo .bar.bar-2{   
    transform: rotate(45deg);
}
.btn-menu.ativo .bar.bar-3{   
    transform: rotate(-45deg);
}
.btn-menu.ativo .bar.bar-1,
.btn-menu.ativo .bar.bar-4{
   opacity: 0;
}
header .logo-img{   
    height: 75px;        
}
/* SHRINK */
header.fixed .header-inner {	
	padding: 10px 20px 10px 10px;
}
header.fixed .logo-img{
    height: 50px;   
}
header.fixed .btn-menu{
    top: 20px;
}
header.fixed .navegacao {
    padding: 0;
	top: 70px;
}
header.fixed .navegacao::before {
	width: 875px;	
}
/* DISTÂNCIA ROLAGEM TOPO */
#ps2id-dummy-offset{
    height: 89px;
}
/* NAVEGAÇÃO */
.navegacao {   	
	width: 260px;
	height: auto;
	padding: 0;
	display: block;	
	right: -260px;
	top: 125px;	  
    z-index: 1;  
}
.navegacao.ativo{
    right: 0;
}
.navegacao::before{
	content: none;
}
.navegacao::after {
    background: transparent;  
    background-color: rgba(56, 72, 103, 0.35);
	/* background-color: #384867; */
	width: 100vw;
	height: calc( 100vh + 125px );
	right: -50vw;
	z-index: -1;
	left: auto;
	top: -125px;   
    backdrop-filter: blur(7px);
  --webkit-backdrop-filter: blur(7px);
    transition: right 200ms ease-in-out;
}
.navegacao.ativo::after{
    right: 0;
}
.menu-header{
    background-color: #FFF;
    width: 100%;   
    padding: 40px 20px;
    position: relative;
    z-index: 1;
}
.menu-header ul.menu{ 
    gap: 20px;
}
.menu-header ul li a {	  
	font-size: 24px;
}
/*-------------------------------------------------------
FOOTER
-------------------------------------------------------*/
footer .inner {
	padding: 40px 20px;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 20px;
}
footer h2{
   margin-bottom: 20px;
}
footer .logo-img{
    width: 100px;
}
.contato-infos{
    width: 100%;
    flex-direction: column;
	flex-wrap: nowrap;    
    gap: 1.25em;    
}
.contato-infos p{
    margin-bottom: 1.25em;
}
.formulario{
    width: 100%;
}
.menu-footer {
	margin-top: 20px;
}
.menu-footer ul{
    flex-direction: column;
    gap: 10px;
}
/* DIREITOS */
.direitos{
    width: 100%;
    padding: 30px 20px;      
}
.direitos p br{
    display: inline;
}
/*-------------------------------------------------------
HOME
-------------------------------------------------------*/
/* SOBRE */
.sobre{
    margin-bottom: -200px;
    z-index: 1;
}
.sobre .inner {
	height: auto;
	min-height: 100vh;
	padding: 125px 20px 0;
	flex-direction: column;
	justify-content: end;
	align-items: start;
}
.box-titulo {
	width: calc( 50vw - 20px );
	height: calc( 50vw - 20px );
	padding: 0 0 10vw 20px;
	position: relative;
	z-index: 1;
}
.box-texto {
	width: calc( 100vw - 20px );
	padding: 20px;   
}
.box-texto::after {
	width: 100%;
	height: calc( 50vw - 20px );
	top: calc( 0px - ( 50vw - 20px ) );
	left: 0;
}
.btn-sobre {	
	position: relative;
	bottom: 0;
	left: 0;
	font-size: 14px;
    margin-top: 20px;	
}
/* EQUIPE */
.equipe{
    background: url(img/bg-equipe.webp) no-repeat center top;
    background-size: auto 1090px;
}
.equipe .inner {
	padding: 0 20px 20px;
	display: flex;
	align-items: end;
}
.equipe-lista .owl-nav {
	width: 100px;
    height: 50px;
	top: 0;
	left: calc( ( 50vw - 20px ) - 100px );
}
.equipe-lista .owl-nav::before{  
    width: 2px;
    height: 38px; 
}
/* CARD */
.card-membro .box-titulo {
	padding: 0 0 0 20px;	
}
.card-membro .box-titulo h2{   	
	transform: translateY(2px);
}
.card-membro-foto{
    width: calc( 50vw - 20px );
	height: calc( 50vw - 20px );
}
.card-membro-info {	
	padding: 20px 20px 40px;	
}
.membro-resumo {
	flex-direction: column;
	align-items: end;
	gap: 20px;
}
.membro-resumo-info {
	width: 100%;
	font-size: 16px;
}
.badge-wrapper {
    width: 150px;
}
.badge-consultor {     
    padding: 2px 5px;  
    line-height: 2.1;     
    font-size: 14px;	
}
.membro-curriculo {
    overflow: hidden;	
    position: relative;
}
.membro-curriculo.close{
    height: 0;
}
.membro-curriculo .btn-fechar{
    margin-left: auto;
}
/*-------------------------------------------------------
ATUAÇÃO
-------------------------------------------------------*/
.atuacao .inner {
	padding: 40px 0 20px;
	gap: 40px;
}
.atuacao h2{
    margin-left: 20px;
}
.atuacao-container {
	flex-direction: column;
	gap: 20px;
}
.atuacao-imagem{
    width: 100vw;  
} 
.atuacao-imagem img {
	height: 64vw;
}
.atuacao-lista {
	width: 100vw;
}
.atuacao-lista .owl-nav {
	width: 100px;
	height: 50px;
	flex-direction: row;
	top: -70px;
	left: auto;
	right: 0;
}
.atuacao-lista .owl-nav::before{  
    width: 2px;
    height: 38px; 
}
.card-area{
    height: auto;
    padding: 0 20px;   
}
/*-------------------------------------------------------
COMPLIANCE
-------------------------------------------------------*/
.compliance{   
    background-position: center bottom 20px;
    background-size: auto 120px;
}
.compliance .inner {
	padding: 0 20px 180px;
}
.compliance .inner::after {
	content: none;
}
.compliance-titulo {
	width: 100%;
	height: auto;
	min-height: unset;
	padding-top: 41vh;
	margin-bottom: 0;
    z-index: 2;
}
.compliance-titulo .box-titulo {
	padding: 0 0 0 20px;
}
.box-titulo span {
	height: 30px;
	padding: 0 8px;
	font-size: 14px;
	line-height: 28px;
	margin: 0 0 0.75em -8px;
}
.box-titulo small {
	font-size: 18px;		
}
.compliance-container,
.privacidade-container  {
	flex-direction: column;
    position: relative;
    z-index: 1;
}
.compliance-container .box-texto {
	padding: 20px 20px 20px 0;
}
.box-infos {
	width: 100%;
	padding: 0;
}
.box-infos h3 {
	font-size: 20px;
	margin-bottom: 1em;
}
.box-infos a{
    text-decoration: underline;
}
.box-infos a{
    display: inline-block;
    margin-bottom: 0.5em;
}
.box-infos a:hover{
    color: #bd521c;
}
.box-infos strong{
    color: #bd521c;
}
/*-------------------------------------------------------
PRIVACIDADE
-------------------------------------------------------*/
.privacidade{   
    background-size: auto 120px; 
}
.lgpd-campos {
	width: 100%;
	padding: 20px 0;
}
.lgpd-campos h3 {
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 0.75em;
}
.lgpd-documentos {
	width: 100%;
	padding:0;
}
.lgpd-documentos .cf7-fieldset {
	margin: 0;
}
.lgpd-documentos label.cf7-field-label{
    margin-bottom: 0;
}
/*-------------------------------------------------------
FORMULÁRIOS
-------------------------------------------------------*/
.cf7-fieldset {   
    flex-direction: column;
    flex-wrap: nowrap;  
    gap: 15px;   
}
.cf7-field,
.cf7-field.wide{
    width: 100%;
}
label.cf7-field-label {   
	margin-bottom: 10px;	
}
.codedropz-upload-container {
	padding: 40px 20px;
}
/* ── Mensagens de erro CF7 ── */
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output{  
    padding: 16px;      
    margin: 16px 0 0 !important;
}
.formulario-privacidade .wpcf7 form.invalid .wpcf7-response-output,
.formulario-privacidade .wpcf7 form.unaccepted .wpcf7-response-output {
	left: 0;
}
/*-------------------------------------------------------
PADRÃO
-------------------------------------------------------*/
.padrao h2,
.padrao h3{
    position: relative;   
	margin-bottom: 1.5rem;    
}
.padrao h2{
	font-size: 24px;	
    font-weight: 600;
}
.padrao h3{
	font-size: 20px;
    font-weight: 600;  
}
/*-------------------------------------------------------
POPUP
-------------------------------------------------------*/
.fancybox-button {
	width: 40px;
	height: 40px;
}
.fancybox-button:hover {
	background-color: #bd521c;		
}
.popup {
	padding: 40px 20px 30px 20px;
}
}