/* ----------------------------------------------------------
    Theme Name: Carnevali Engenharia Theme
    Theme URI: https://marcasite.com.br
    Author: Henrique Quintino
    Author URI: https://www.linkedin.com/in/henrique-quintino/
    Description: Tema oficial da Carnevali Engenharia criada pela Marcasite
    Requires at least: 6.4
    Tested up to: 6.4
    Requires PHP: 7.0
    Version: 1.0
    License: GNU General Public License v2 or later
    License URI: http://www.gnu.org/licenses/gpl-2.0.html
    ----------------------------------------------------------

/***************************************************************************
       Fonts
***************************************************************************/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/***************************************************************************
       Variáveis
***************************************************************************/

:root {
	--cor-branco: white;
	--cor-cinza: #46474a;
	--cor-azul: #1f2b50;
	--cor-laranja: #c99235;

	--font-Montserrat: "Montserrat", sans-serif;

	--font-extralight: 200;
	--font-light: 300;
	--font-regular: 400;
	--font-medium: 500;
	--font-semibold: 600;
	--font-bold: 700;
}

/***************************************************************************
        All
***************************************************************************/

.transition_on *,
.transition_on {
	transition: ease .4s all !important;
}

html,
body {
	margin: 0;
	overflow-x: clip;
}

* {
	margin: 0;
	box-shadow: 0 0 0 0;
	border: 0 none;
	outline: 0;
	font-family: var(--font-Montserrat);
}

a,
a:hover {
	text-decoration: none;
	color: var(--cor-branco);
}

section {
	padding: 80px 0;
}

span {
	font-size: 1.625rem;
	line-height: 1.875rem;
	color: var(--cor-laranja);
	font-weight: var(--font-medium);
}

h2,
h2>span {
	font-size: 2.1875rem;
	line-height: 2.4375rem;
	font-weight: var(--font-bold);
	text-transform: uppercase;
}

h2 {
	color: var(--cor-azul);
	margin-bottom: 0px;
}

h2>span {
	color: var(--cor-laranja);
}

p,
p>span {
	font-size: 1.25rem;
	line-height: 1.5rem;
	color: var(--cor-cinza);
}

p {
	margin-bottom: 0;
	font-weight: var(--font-light);
}

p>span {
	font-weight: var(--font-semibold);
}

img {
	transition: all 0.3s ease-in-out;
	width: 100%;
}

.btn-laranja {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	text-align: center;
	padding: 26px 42px;
	width: 100%;
	max-width: fit-content;
	height: 59px;
	font-size: 1rem;
	font-weight: var(--font-semibold);
	background-color: var(--cor-laranja);
	color: var(--cor-branco);
	transition: all 0.3s ease-in-out;
	border-radius: 0px;
	border: 0;
	transform: skewX(-20deg);
}

.btn-laranja:hover {
	background-color: #c09535;
	transform: skewX(-20deg) scale(1.05);
}

.btn-laranja span,
.btn-laranja img {
	transform: skewX(20deg) !important;
}

.btn-laranja span {
	text-transform: uppercase;
}

iframe {
	width: 100%;
	height: 520px;
	border: none;
}

.gap-6 {
	gap: 4rem !important;
}

.gap-7 {
	gap: 5rem !important;
}

.gap-8 {
	gap: 6rem !important;
}

.gap-9 {
	gap: 7rem !important;
}

.gap-10 {
	gap: 8rem !important;
}

.gap-11 {
	gap: 9rem !important;
}

.gap-12 {
	gap: 10rem !important;
}

/***************************************************************************
        Header
***************************************************************************/

header {
	position: absolute;
	width: 100%;
	z-index: 99;
	top: 80px;
}

header .container-fluid {
	padding: 0 50px;
}

header #menu-primeiro {
	max-width: 1650px;
	margin: auto;
	background-color: rgb(36, 46, 79, 0.95);
	box-shadow: 0px 0px 29.2px 10.8px rgba(31, 24, 19, 0.19);
	position: relative;
	transform: skewX(-10deg);
}

header .box-logo {
	position: absolute;
	top: -15px;
	left: 0;
	background-color: var(--cor-branco);
	transform: skewX(-10deg);
	transform-origin: top right;
	z-index: 0;
	padding: 22px 50px;
}

header .box-logo img {
	transform: skewX(20deg);
}

header .logo {
	max-width: 280px;
}

header #menu-primeiro .col-lg-4,
header #menu-primeiro .col-lg-8 {
	position: relative;
	z-index: 1;
}

header .topo-social {
	justify-content: end;
	gap: 12px;
}

header .topo-social .telefone,
.area-footer .topo-social .telefone,
.contato .topo-social .telefone {
	display: flex;
	align-items: center;
	gap: 10px;
}

header .topo-social .telefone img,
.area-footer .topo-social .telefone img,
.contato .topo-social .telefone img {
	width: 34px;
	height: 34px;
	object-fit: contain;
}

header .topo-social .telefone .content,
.area-footer .topo-social .telefone .content,
.contato .topo-social .telefone .content {
	display: flex;
	flex-direction: column;
	text-align: start;
}

header .topo-social .telefone .content span,
header .topo-social .telefone .content a,
.area-footer .topo-social .telefone .content a,
header .topo-social .telefone .content p,
.area-footer .topo-social .telefone .content span,
.area-footer .topo-social .telefone .content p,
.contato .topo-social .telefone .content span,
.contato .topo-social .telefone .content p,
.contato .topo-social .telefone .content a {
	font-size: 0.875rem;
	line-height: 1.125rem;
	color: var(--cor-cinza);
}

header .topo-social .telefone .content span,
.area-footer .topo-social .telefone .content span,
.contato .topo-social .telefone .content span {
	font-weight: var(--font-medium);
	font-family: var(--font-Poppins);
}

header .topo-social .telefone .content .box,
.area-footer .topo-social .telefone .content .box,
.contato .topo-social .telefone .content .box {
	display: flex;
	align-items: baseline;
}

header .topo-social .telefone .content .box,
.area-footer .topo-social .telefone .content .box,
header .topo-social .telefone .content p,
.area-footer .topo-social .telefone .content p,
.contato .topo-social .telefone .content p,
.contato .topo-social .telefone .content .box {
	margin-top: -1px;
}

header .topo-social .telefone .content span.separator,
.area-footer .topo-social .telefone .content span.separator,
.contato .topo-social .telefone .content span.separator {
	margin: 0 5px;
	color: var(--cor-cinza);
}

header hr {
	width: 100%;
	max-width: 637px;
	background: linear-gradient(to right, transparent, #92929236, #92929281);
	border: none;
	margin: 20px 0;
	opacity: 0.6;
	height: 1px;
}

header ul {
	width: 100%;
	display: flex;
	justify-content: space-around;
	align-items: center;
	gap: 15px;
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
	z-index: 1;
	padding-bottom: 20px;
}

header ul .nav-item .nav-link {
	font-size: 1rem;
	color: var(--cor-branco);
	font-weight: var(--font-regular);
	border-bottom: 3px solid transparent;
	transition: all 0.3s ease-in-out;
	text-transform: uppercase;
	transform: skewX(10deg);
}

header ul .nav-item .nav-link:hover,
header ul .nav-item.active .nav-link {
	color: var(--cor-laranja);
	border-bottom: 3px solid var(--cor-laranja);
}

header ul .nav-item.active .nav-link {
	font-weight: var(--font-semibold);
}

header .btn-contato {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 26px 42px;
	background-color: var(--cor-laranja);
	color: var(--cor-branco);
	font-size: 1rem;
	font-weight: var(--font-semibold);
	text-decoration: none;
	text-transform: uppercase;
	border: none;
	border-radius: 0;
	transform: skewX(-10deg);
	transition: all 0.3s ease-in-out;
	position: relative;
	z-index: 1;
	position: absolute;
	top: 0;
	right: 0;
	margin-right: -18px;
}

header .btn-contato span,
.btn-laranja span {
	transform: skewX(20deg);
	display: block;
	color: var(--cor-branco);
	font-size: 1rem;
	line-height: normal;
}

header .btn-contato img,
.btn-laranja img {
	width: 12px;
	height: 12px;
	object-fit: contain;
	transform: skewX(20deg);
}

header .btn-contato:hover {
	background-color: #c09535;
	transform: skewX(-10deg) scale(1.05);
}

#menu-primeiro .submenu,
.area-footer .submenu {
	min-width: 140px;
	top: calc(100% - -2px);
	list-style: disc;
	color: var(--cor-branco);
}

#menu-primeiro .nav-item .submenu .nav-link,
.area-footer .nav-item .submenu .nav-link {
	color: var(--cor-branco);
	border-bottom: 2px solid transparent;
}

#menu-primeiro .nav-item .submenu .nav-link:hover,
#menu-primeiro .nav-item .submenu .nav-item.active .nav-link {
	border-color: rgba(255, 255, 255, 0.572);
}

#menu-primeiro .menusegundo:hover .nav-link .seta,
.area-footer .menusegundo:hover .nav-link .seta,
header #opt_menu .nav-item.ativo:hover .nav-link .seta {
	transform: rotate(-180deg);
}

#menu-primeiro .menusegundo .nav-link,
.area-footer .menusegundo .nav-link {
	display: flex;
	align-items: center;
	gap: 2px;
}

#menu-primeiro .menusegundo .nav-link .seta,
.area-footer .menusegundo .nav-link .seta,
header #opt_menu .nav-item .nav-link .seta {
	transform: rotate(0deg);
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-image: url(https://clientemarcasite.com.br/carnevali-engenharia/wordpress/wp-content/uploads/2025/12/seta-menu.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

#menu-primeiro ul li ul,
.area-footer ul li ul {
	width: max-content;
	max-width: 280px;
	position: absolute;
	z-index: 10;
	visibility: hidden;
	opacity: 0;
	width: max-content;
	max-width: 280px;
	position: absolute;
	z-index: 10;
	visibility: hidden;
	opacity: 0;
	margin-top: -41px;
	flex-direction: column;
	float: none;
	margin: 0px 0px;
	padding: 20px 35px 20px 35px;
	border-radius: 12px;
	background-color: var(--cor-laranja);
	-webkit-box-shadow: 0 8px 15px rgb(0 0 0 / 10%);
	box-shadow: 0 8px 15px rgb(0 0 0 / 10%);
	align-items: start;
	gap: 0;
	justify-content: unset;
}

/* #menu-primeiro ul li ul::before,
.area-footer ul li ul::before {
	content: "";
	display: flex;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 6px;
	background: var(--cor-laranja);
} */

#menu-primeiro ul li:hover>ul,
.area-footer ul li:hover>ul {
	visibility: visible;
	opacity: 1;
	display: block;
}

/***************************************************************************
        Banner Principal
***************************************************************************/

section.banner-principal {
	display: flex;
	align-items: center;
	padding-top: 215px;
	background-image: url(https://clientemarcasite.com.br/carnevali-engenharia/wordpress/wp-content/uploads/2025/12/banner-principal.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	min-height: 562px;
	position: relative;
}

.banner-principal h2 {
	font-size: 2.375rem;
	line-height: 2.625rem;
	background: none;
	margin-bottom: -1px;
	color: var(--cor-branco);
}

.banner-principal p,
.banner-principal p>span {
	font-size: 1.375rem;
	line-height: 1.625rem;
	margin-bottom: 10px;
	max-width: 530px;
}

.pre-text {
	display: flex;
	align-items: center;
	gap: 10px;
}

.pre-text hr {
	width: 57px;
	height: 2px;
	background-color: var(--cor-laranja);
	margin: 0;
	border: 0;
	opacity: 1;
}

/***************************************************************************
        Referência
***************************************************************************/

.referencia-intro .title {
	max-width: 564px;
}

section.referencia {
	display: flex;
	align-items: center;
	background-image: url(https://clientemarcasite.com.br/carnevali-engenharia/wordpress/wp-content/uploads/2025/12/banner-diferenciais.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	min-height: 515px;
	padding: 0;
	margin-bottom: 150px;
}

.subtitle,
.subtitle>span {
	font-size: 1.875rem;
	line-height: 2.125rem;
	font-weight: var(--font-semibold);
	text-transform: none;
	max-width: 422px;
}

.referencia p {
	max-width: 430px;
}

.referencia .card {
	max-width: fit-content;
	display: flex;
	flex-direction: column;
	gap: 15px;
	background-color: var(--cor-laranja);
	border: 0;
	border-radius: 0;
	padding: 20px 10px;
	position: absolute;
	left: 140px;
	bottom: -110px;
}

.referencia .card img {
	width: 42px;
	height: 42px;
	object-fit: contain;
}

.referencia .card h3,
.referencia .card h3>span {
	font-size: 2.1875rem;
	line-height: 1.875rem;
	color: var(--cor-branco);
	font-weight: var(--font-bold);
	margin-bottom: -5px;
}

.referencia .card p {
	max-width: 175px;
	font-size: 1rem;
	line-height: 1.25rem;
	color: var(--cor-branco);
	font-weight: var(--font-light);
}

/***************************************************************************
        O que fazemos
***************************************************************************/

section#o-que-fazemos {
	background-image: url(https://clientemarcasite.com.br/carnevali-engenharia/wordpress/wp-content/uploads/2025/12/banner-o-que-fazemos-e1764861905757.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 709px;
	padding-bottom: 0;
	margin-bottom: 220px;
}

#o-que-fazemos h2 {
	color: var(--cor-branco);
	max-width: 555px;
}

#o-que-fazemos .card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	position: relative;
	padding: 70px 30px 60px 30px;
	border: 1px solid #e5e5e5;
	border-radius: 0;
	background-color: var(--cor-branco);
	height: 100%;
}

#o-que-fazemos .card .square {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	font-weight: var(--font-semibold);
	color: var(--cor-branco);
	background-color: var(--cor-laranja);
	width: 68px;
	height: 68px;
	position: absolute;
	top: -34px;
	left: 30px;
}

#o-que-fazemos .card h3 {
	max-width: 220px;
	font-size: 1.5rem;
	line-height: 1.75rem;
	color: var(--cor-azul);
	font-weight: var(--font-semibold);
	margin-bottom: -3px;
}

#o-que-fazemos .card p {
	font-size: 1.125rem;
	line-height: 1.375rem;
}

/***************************************************************************
        Nossos Diferenciais
***************************************************************************/

.nossos-diferenciais .card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 50px 25px;
	border: 1px solid #e5e5e5;
	border-radius: 0;
	background-color: var(--cor-branco);
	height: 100%;
}

.nossos-diferenciais .card img {
	width: 65px;
	height: 65px;
	object-fit: contain;
}

.nossos-diferenciais .card h3 {
	font-size: 1.375rem;
	line-height: 1.625rem;
	color: var(--cor-azul);
	font-weight: var(--font-semibold);
	margin-bottom: -3px;
	max-width: 210px;
}

/***************************************************************************
        Contato
***************************************************************************/

.contato .title {
	max-width: 384px;
}

.contato .box-info {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding-bottom: 20px;
	border-bottom: 1px solid rgb(215, 215, 215);
}

.contato .col-12:last-child .box-info {
	padding-bottom: 0;
	border-bottom: none;
}

.contato .box-info img {
	max-width: 52px;
	object-fit: contain;
}

.contato .box-info .content {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.contato .box-info .content h3 {
	font-size: 1.25rem;
	line-height: 1.5rem;
	color: var(--cor-azul);
	font-weight: var(--font-semibold);
	margin-bottom: 0;
	text-transform: uppercase;
}

.contato .box-info .content p {
	font-size: 1rem;
	line-height: 1.25rem;
	font-weight: var(--font-medium);
}

.contato form input::placeholder,
.contato form textarea::placeholder {
	opacity: 0.7;
}

.contato form {
	margin-top: 25px;
}

.contato form input {
	background-color: var(--cor-branco);
	width: 100%;
	height: 55px;
	padding: 15px;
	border: 1px solid rgb(215, 215, 215);
	border-radius: 5px;
	margin-bottom: 12px;
}

.contato form textarea {
	width: 100%;
	height: 165px !important;
	background-color: var(--cor-branco);
	padding: 15px;
	resize: none;
	border: 1px solid rgb(215, 215, 215);
	border-radius: 5px;
}

.contato form .btn-laranja {
	width: 100%;
	max-width: fit-content;
	background: var(--cor-laranja) !important;
	opacity: 1 !important;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem !important;
	border-radius: 0 !important;
}

.contato form .btn-laranja span {
	margin-top: -18px;
	font-weight: var(--font-semibold);
}

.contato form .btn-laranja:hover {
	transform: skewX(-20deg);
}

.wpcf7-not-valid-tip {
	margin-top: -5px;
	margin-bottom: 5px;
}

.wpcf7-form-control-wrap,
.wpcf7-list-item-label {
	font-family: var(--font-Montserrat);
	font-size: 1rem !important;
	line-height: normal !important;
}

.wpcf7-list-item-label {
	font-size: 13px !important;
	position: relative;
}

.wpcf7-list-item {
	display: flex !important;
	margin: 0 !important;
}

.wpcf7-list-item.first.last {
	position: absolute;
}

.wpcf7-list-item.first.last input {
	width: 18px;
	height: 18px;
	margin-right: 10px;
}

.wpcf7 form .wpcf7-response-output {
	margin: 0;
	margin-bottom: 30px;
}

.rodape-form p {
	display: flex;
	margin: 0;
	width: 100%;
}

.rodape-form p label {
	font-size: 13px;
	margin-left: 15px;
	margin-top: 15px;
	width: 100%;
	display: flex;
	gap: 4px;
	flex-wrap: wrap;
}

.rodape-form p label a {
	display: flex;
	justify-content: left;
	text-decoration: none !important;
	color: #0d6efd !important;
}

.rodape-form p label a:hover {
	color: #0d6efd;
}

.rodape-btn p {
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/***************************************************************************
        Mapa
***************************************************************************/

section.mapa {
	position: relative;
	padding: 0;
	z-index: 8;
	margin-bottom: -120px;
}

.mapa iframe {
	width: 100%;
	height: 370px;
	filter: grayscale(100%);
	transition: filter 0.3s ease-in-out;
}

.mapa iframe:hover {
	filter: grayscale(0%);
}

.mapa .card-flutuante {
	position: absolute;
	z-index: 11;
	top: 25%;
	right: 7%;
}

.mapa .card-flutuante a,
.mapa .card-flutuante a .card {
	max-width: 350px;
	cursor: pointer;
}

.mapa .card-flutuante .card img {
	width: 37px;
	height: 37px;
	object-fit: contain;
}

.mapa .card-flutuante .card .content span {
	color: var(--cor-cinza);
	font-weight: var(--font-medium);
	font-size: 1.125rem;
}

/***************************************************************************
        Footer
***************************************************************************/

footer {
	background-image: url(https://clientemarcasite.com.br/carnevali-engenharia/wordpress/wp-content/uploads/2025/12/banner-footer-e1764954210166.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-top: 5rem;
	padding-bottom: 1.875rem;
	color: var(--cor-branco);
	z-index: 9;
	position: relative;
	min-height: 27.125rem;
	display: flex;
	align-items: center;
}

footer .info-contato-footer {
	border-bottom: 0.0625rem solid rgba(255, 255, 255, 0.2);
}

footer .box-info-footer {
	display: flex;
	align-items: center;
	flex-direction: column;
	gap: 0.3125rem;
	text-decoration: none;
	transition: all 0.3s ease;
	text-align: center;
}

footer .box-info-footer:hover {
	transform: translateY(-0.1875rem);
}

footer .box-info-footer img {
	width: 3.125rem;
	height: 3.125rem;
	object-fit: contain;
}

footer .box-info-footer .content {
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
}

footer .box-info-footer .content span {
	font-size: 0.875rem;
	font-weight: var(--font-bold);
	color: var(--cor-branco);
	text-transform: uppercase;
	letter-spacing: 0.0625rem;
	margin-bottom: -0.3125rem;
}

footer .box-info-footer .content p {
	font-size: 0.875rem;
	font-weight: var(--font-regular);
	color: var(--cor-branco);
	margin: 0;
}

footer .btn-laranja {
	padding: 1.625rem;
}

footer .logo-footer {
	max-width: 14.375rem;
	width: 100%;
}

footer .titulo-footer {
	font-size: 1rem;
	font-weight: var(--font-bold);
	color: var(--cor-branco);
	text-transform: uppercase;
	letter-spacing: 0.0625rem;
}

footer .menu-footer {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

footer .menu-footer li a {
	font-size: 0.875rem;
	font-weight: var(--font-regular);
	color: var(--cor-branco);
	text-decoration: none;
	transition: all 0.3s ease;
}

footer .menu-footer li a:hover {
	color: var(--cor-laranja);
	padding-left: 0.3125rem;
}

footer .area-rodape {
	border-top: 0.0625rem solid rgba(255, 255, 255, 0.2);
	padding-top: 1.875rem;
}

footer .texto-rodape {
	font-size: 0.875rem;
	font-weight: var(--font-regular);
	color: var(--cor-branco);
	margin: 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

footer .texto-rodape a {
	display: inline-flex;
	align-items: center;
}

footer .logo-marcasite {
	width: 13.75rem;
	height: auto;
	transition: all 0.3s ease;
}

footer .logo-marcasite:hover {
	opacity: 0.8;
}

footer .link-politica {
	font-size: 0.875rem;
	font-weight: var(--font-regular);
	color: var(--cor-branco);
	text-decoration: none;
	transition: all 0.3s ease;
}

footer .link-politica:hover {
	color: var(--cor-laranja);
}

/***************************************************************************
        Responsivo
***************************************************************************/

.mobile,
.box-sfx {
	display: none;
}

@media (min-width: 1050px) and (max-width: 1199px) {
	section.referencia {
		background-position-x: -540px !important;
	}
}

@media (min-width: 992px) and (max-width: 1049px) {
	section.referencia {
		background-position-x: -640px;
	}
}

@media (min-width: 992px) and (max-width: 1199px) {
	header .box-logo {
		top: -18px;
	}

	header ul {
		justify-content: center;
		gap: 30px;
	}

	header .btn-contato {
		padding: 23px 42px;
	}

	header ul .nav-item .nav-link,
	.area-footer .atendimento .content p {
		font-size: 0.875rem;
		line-height: 1.125rem;
	}

	.area-footer .atendimento .content h2 {
		font-size: 1.125rem;
	}

	.area-footer .logo {
		max-width: 200px;
	}

	h2,
	h2>span {
		font-size: 2rem;
		line-height: 2.25rem;
	}

	.subtitle,
	.subtitle>span {
		font-size: 1.75rem;
		line-height: 2rem;
	}
}

@media (min-width: 992px) {
	.gap-lg-12 {
		gap: 10rem !important;
	}
}

@media (max-width: 991px) {
	.mobile {
		display: block;
	}

	.desktop {
		display: none !important;
	}

	header {
		padding-top: 0;
		top: 0;
	}

	header .logo {
		width: 200px;
	}

	header .hamburguer-bt {
		display: inline-block;
		height: fit-content;
		min-height: 32px;
		margin: 0px 15px;
		margin-bottom: -12px;
		float: right;
	}

	header .hamburguer-bt .hamburguer_line {
		background-color: var(--cor-laranja);
		width: 30px;
		height: 4px;
		margin: 5px 0;
	}

	header .hamburguer-bt.ativo .hamburguer-top {
		transform: rotate(45deg);
		margin-top: 11px;
	}

	header .hamburguer-bt.ativo .hamburguer-middle {
		opacity: 0;
	}

	header .hamburguer-bt.ativo .hamburguer-bottom {
		transform: rotate(-45deg);
		margin-top: -18px;
	}

	header #opt_menu {
		position: fixed;
		height: calc(100% - 86px);
		width: 320px;
		background: var(--cor-branco);
		opacity: 1;
		z-index: 99;
		right: -150%;
		top: 130px;
		padding: 10px;
		display: block;
		overflow: auto;
	}

	header #opt_menu.ativo {
		right: 0;
	}

	header .fundo_menu {
		background: #00000096;
		width: 100%;
		height: 100%;
		top: 130px;
		right: -100%;
		position: fixed;
		z-index: 89;
	}

	header .fundo_menu.ativo {
		right: 0;
	}

	header #opt_menu .navbar-brand {
		width: 100%;
		margin: 0;
		text-align: -webkit-center;
	}

	header #opt_menu .nav-item {
		display: flex;
		justify-content: center;
		text-align: center;
		padding: 0 20px;
		text-transform: uppercase;
	}

	header #opt_menu .nav-item.submenu {
		display: flex;
		flex-direction: column;
	}

	header #opt_menu .nav-item.ativo {
		flex-direction: column;
	}

	header #opt_menu .nav-item.ativo .submenu {
		display: flex;
	}

	.submenu {
		display: none;
		padding: 0;
		list-style: none;
		padding-top: 25px !important;
	}

	#opt_menu .nav-item .nav-link {
		font-size: 1.125rem;
		font-weight: var(--font-medium);
		display: flex;
		align-items: center;
		gap: 4px;
		color: var(--cor-azul);
		transform: skewX(0deg);
	}

	header #menu-segundo {
		display: flex;
		align-items: center;
		justify-content: center;
		background: var(--cor-branco);
		position: inherit;
		width: 100%;
		height: 130px;
		z-index: 99;
		box-shadow: 0px -3px 11px 4px;
	}

	header #opt_menu ul {
		padding-top: 40px;
		align-items: start;
		flex-direction: column;
		gap: 25px;
	}

	.banner-principal h2 {
		margin-bottom: 15px;
		line-height: 32px;
	}

	.banner-principal h2,
	.banner-principal p {
		max-width: 100%;
	}

	.responsivo {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		text-align: center;
	}

	span {
		font-size: 1.5rem;
		line-height: 1.75rem;
	}

	h2,
	h2>span {
		font-size: 1.875rem;
		line-height: 2.125rem;
	}

	.subtitle,
	.subtitle>span {
		font-size: 1.5rem;
		line-height: 1.75rem;
	}

	p,
	p>span {
		font-size: 1.125rem;
		line-height: 1.375rem;
	}

	section.referencia {
		background-image: none;
	}

	.referencia .card {
		left: auto;
		right: 0;
		bottom: 0;
		margin-right: .75rem;
	}

	.referencia .thumb {
		height: 515px;
		object-fit: cover;
	}

	section#o-que-fazemos {
		min-height: 709px;
		height: 100%;
		margin-bottom: 80px;
	}
}

@media (max-width: 767px) {
	.banner-principal h2 {
		font-size: 2rem;
		line-height: 2.25rem;
	}

	iframe {
		height: 350px;
	}

	span {
		font-size: 1.375rem;
		line-height: 1.625rem;
	}

	h2,
	h2>span {
		font-size: 1.75rem;
		line-height: 2rem;
	}

	.subtitle,
	.subtitle>span {
		font-size: 1.375rem;
		line-height: 1.625rem;
	}

	p,
	p>span {
		font-size: 1rem;
		line-height: 1.25rem;
	}
}

@media (max-width: 575px) {
	.btn-laranja {
		padding: 26px;
	}
}

@media (max-width: 567px) {

	.area-footer .col-md-6,
	.area-footer ul {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		text-align: center;
	}
}

@media (max-width: 475px) {}

@media (max-width: 467px) {

	.banner-principal p,
	.banner-principal p>span {
		font-size: 1.125rem;
		line-height: 1.375rem;
	}
}

@media (max-width: 400px) {}

.btn-topo {
	position: fixed;
	display: flex;
	align-items: center;
	justify-content: center;
	bottom: 70px;
	left: 12px;
	background: var(--cor-laranja);
	border: none;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	cursor: pointer;
	box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
	z-index: 99;
	opacity: 0;
	transition: all 0.3s ease-in-out;
}

#btnTopo.show {
	opacity: 1;
}

.btn-topo.disabled {
	cursor: default;
	pointer-events: none;
	opacity: 0;
}

.btn-topo img {
	width: 17px;
	height: 15px;
	transform: rotate(-90deg);
}

.wp-pagenavi {
	display: flex;
	align-items: center;
	gap: 10px;
}

.wp-pagenavi span.current {
	background: var(--cor-laranja);
	color: var(--cor-branco);
	cursor: default;
}

.wp-pagenavi span,
.wp-pagenavi a {
	font-size: 1rem;
	font-family: var(--font-Poppins);
	background-color: #f4f4f4;
	color: var(--cor-laranja);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 4px;
	padding: 0;
	margin: 0;
	width: 41px;
	height: 41px;
	cursor: pointer;
	border: none;
}

.whatsapp img {
	position: fixed;
	z-index: 8;
	bottom: 86px;
	right: 8px;
	width: 50px;
	height: 50px;
	opacity: 0.7;
	transition: ease .8s all;
}

.whatsapp a:hover img {
	opacity: 1;
	filter: drop-shadow(0px 0px 6px black);
}

.video-popup {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.8);
	justify-content: center;
	align-items: center;
	z-index: 1000;
}

.video-container {
	position: relative;
	width: 100%;
	max-width: 1000px;
}

video {
	width: 100%;
	border-radius: 8px;
}

.close-btn {
	position: absolute;
	top: -20px;
	right: -20px;
	background: #ff4d4d;
	color: white;
	border: none;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	font-size: 18px;
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
}