/*
Theme Name: Vianobre
Theme URI: https://exemplo.com/vianobre
Author: Anderson Felipe
Author URI: https://andersonwebdesigner.com.br
Description: Um tema personalizado para WordPress.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vianobre
*/

/* Adicione seus estilos personalizados abaixo desta linha */

@charset "utf-8"; body, html {height: 100% !important;}

@font-face {
	font-display: swap;
	font-family: 'Montserrat';
	font-style: normal;
	font-weight: 400;
	src: url('fonts/montserrat-v30-latin-regular.woff2') format('woff2');
}

@font-face {
	font-display: swap;
	font-family: 'Montserrat';
	font-style: normal;
	font-weight: 700;
	src: url('fonts/montserrat-v30-latin-700.woff2') format('woff2');
}

body {
	font: 1.1rem 'Montserrat', sans-serif !important;
} 
:root {
	--cor-primaria-0: #172741;
	--cor-secundaria-0: #f4cc87;
	--cor-secundaria-1: #bb7321;
}

/*
| ----------------------------
| GERAL
| ----------------------------
*/

body a {
	color: var(--cor-primaria-0);
	text-decoration: none;
}
body a.btn {
	color: #FFF;
	font-weight: bold;
	padding: 15px 35px;
}
body a.btn:hover {
	color: #FFF;
}
body .btn-primary {
	background: var(--cor-primaria-0);
	color: #FFF;
}
body .btn-secondary-outline, body .btn-secondary-outline:hover {
	border-color: #FFF;
	color: #FFF;
}

body .cta {
	background: #BB7321;
	background: linear-gradient(0deg, rgba(187, 115, 33, 1) 0%, rgba(244, 204, 135, 1) 100%);
	border: 0;
	border-radius: 10px;
	color: #FFF;
	font-size: 1.5rem;
	font-weight: bold;
	padding: 15px 100px;
	text-shadow: 1px 1px 0 #00540F;
	transition: transform 0.3s ease;
}
body a.cta:hover {
	background: #BB7321;
	background: linear-gradient(0deg, rgba(187, 115, 33, 1) 0%, rgba(244, 204, 135, 1) 100%);
	transform: scale(1.05);
}

.wrapper {
	padding: 4rem 0;
}

body h2 {
	font-size: 2.5rem;
	font-weight: bold;
	padding-bottom: 1rem;
}

a.whatsapp-float {
	animation: pulse 1.5s infinite;
	right:25px; position:fixed;width:60px;height:60px;bottom:40px;z-index:100;
	transition: transform 0.3s ease;
}
@keyframes pulse {
	0% {
		transform: scale(1); /* Tamanho original */
	}
	50% {
		transform: scale(1.5); /* Aumenta o botão */
	}
	100% {
		transform: scale(1); /* Volta ao tamanho original */
	}
}

ul li {
	padding-bottom: 1.25rem;
}
ul li:last-child {
	padding-bottom: 0;
}

.bg-cinza {
	background: #F5F5F5;
}

/*
| ----------------------------
| HEADER > NAV
| ----------------------------
*/
header nav.navbar {
	background: #FFF;
	color: var(--cor-primaria-0);
	padding: 6px;
	width: 100%;
}
header nav.navbar .navbar-text {
	color: #FFF;
}
header nav.navbar ul li a {
	border-bottom: 3px solid #FFF;
	display: inline-block;
	color: var(--cor-primaria-0);
	padding-bottom: 3px;
}
header nav.navbar ul li a:hover {
	border-bottom: 3px solid var(--cor-secundaria-0);
}
header nav.navbar .collapse {
	padding-left: 4rem;
}
header nav.navbar .collapse ul {
	float: right;
	list-style: none;
}
header nav.navbar ul li {
	display: inline-block;
	padding-left: 25px;
}
header nav.navbar .brand {
	float: left;
	max-width: 175px;
}
header nav.navbar button.navbar-toggler, header nav.navbar .menu-principal {
	position: relative;
	z-index: 3;
}
header nav.navbar .menu-principal {
	margin-top: 2rem;
}
header nav.navbar .actions a.cta {
	font-size: 1rem;
	padding: 7px 20px;
	border-radius: 6px;
}
header nav.navbar .actions a.cta:hover {
	color: #FFF;
}

header nav.navbar .info .fone {
	color: #fff;
}
header nav.navbar .fone i {
	display: inline-block;
	margin-left: 10px;
	margin-right: 5px;
	vertical-align: middle;
}

/*
| ----------------------------
| HEADER
| ----------------------------
*/

header {
	background: var(--cor-primaria-0);
	color: #FFF;
	padding-top: 0; 
}
header .container {
	position: relative;
}
header .box {
	position: relative;
}
header .box h1 small {
	display: block;
}

/*
| ----------------------------
| PÁGINA > HOME
| ----------------------------
*/
body header {
	background: var(--cor-primaria-0);
}
body header, body header.container {
	position: relative;
}
body header .jumbotron {
	background: url('img/bn-home.webp') no-repeat center center;
	background-size: cover;
	padding: 7rem 0;
	position: relative;
}
body header .box {
	margin-top: 0rem;
	position: relative;
	width: 45%;
	z-index: 3;
}
body header .box h1 {
	font-size: 2.75rem;
	font-weight: bold;
	line-height: 3.5rem;
	padding-bottom: 0.75rem;
}
body header .box h2 {
	font-size: 1.5rem;
	font-weight: bold;
	padding-bottom: 1rem;
}
body header .box h2 span {
	display: block;
	font-size: 1.5rem;
	padding-top: 1rem;
	text-transform: uppercase;
}
body header .box h2 span i {
	display: inline-block;
	font-size: 1.2rem;
	padding-right: 5px;
}
body header .box .cta {
	width: auto;
}

.rastreio, .sobre {
	min-height: 325px;
	padding: 3rem 0;
	position: relative;
}
.rastreio::before {
	background: url('img/bg-rastreio.webp') no-repeat -50% top;
	background-size: 100% 100%;
	content: '';
	height: 150%;
	/*left: -30%;*/
	position: absolute;
	right: 0;
	top: 0;
	width: 130%;
	z-index: -1;
}
.rastreio::after {
	background: url('img/bg-rastreio-2.webp') no-repeat -50% top;
	background-size: 100% 100%;
	content: '';
	height: 200px;
	position: absolute;
	right: 0;
	top: 33%;
	width: 200px;
	z-index: 1;
}
.rastreio, .rastreio h2 {
	color: #FFF;
}
.rastreio h2, .sobre h2 {
	font-size: 2rem;
}
.rastreio p {
	width: 75%
}
.rastreio form {
	width: 70%;
}
.rastreio form button {
	background: #BB7321;
	background: linear-gradient(0deg, rgba(187, 115, 33, 1) 0%, rgba(244, 204, 135, 1) 100%);
	border-color: #cdcdcd;
	color: #FFF;
}

.sobre {
	background: url('img/bg-sobre.webp') no-repeat center center;
	background-size: cover;
	border: 0;
	border-radius: 10px;
	color: var(--cor-primaria-0);
	padding: 3rem;
	min-height: 0;
}
.sobre * {
	position: relative;
	z-index: 3;
}
.sobre::after {
	background: url('img/bg-sobre-2.webp') no-repeat right bottom;
	background-size: auto 100%;
	bottom: 0;
	content: '';
	height: 95%;
	position: absolute;
	right: -80px;
	width: 100%;
	z-index: 0;
}
.sobre h2 {
	width: 85%;
}
.sobre p, .sobre ul {
	width: 75%;
}
.sobre ul {
	padding-left: 0;
}
.sobre ul li {
	font-weight: bold;
	list-style: none;
}
.sobre ul li i {
	color: var(--cor-secundaria-0);
}
.sobre .cta {
	display: inline-block;
	font-size: 1rem;
	padding: 15px 35px;
	text-align: center;
}
body .parceiros .item {
	align-items: center;
	display: flex;
	float: left;
	justify-content: center;
	height: 100%;
	text-align: center;
	width: 16.5%;
}
body .parceiros .item img {
	width: 75%;
}

body .beneficios {
	color: #333;
}
body .beneficios img {
}
body .beneficios h3 {
	font-weight: bold;
	padding-bottom: 15px;
}
body .box-text {
	border: 1px solid #DDD;
	border-radius: 10px;
	min-height: 210px;
	padding: 20px 25px;
}
body .beneficios p {
	font-size: 1.2rem;
	margin-bottom: 0;
}
body .beneficios .icon {
	float: left;
	margin-right: 20px;
	width: 75px;
}
body .beneficios .icon img {
	max-width: 100%;
}
body .beneficios .box-text {
	overflow: hidden
}
body .beneficios .box-text h2 {
	font-size: 1.75rem;
	margin-bottom: 0;
	padding-bottom: 0.75rem;
}


/* Serviços */

.servicos ul {
	list-style: none;
	padding-left: 0;
}
.servicos ul li {
	height: 110px;
	margin-bottom: 20px;
	overflow: hidden;
	padding-bottom: 10px; 
}
.servicos ul li .item-title {
	align-items: center;
	border-right: 1px solid #DEDEDE;
	color: var(--cor-primaria-0);
	display: flex;
	float: left;
	font-weight: bold;
	height: 100%;
	justify-content: right;
	margin-right: 20px;
	padding-right: 20px;
	overflow: hidden;
	text-transform: uppercase;
	width: 35%;
}
.servicos ul li .item-text {
	align-items: center;
	display: flex;
	height: 100%;
}

/* Como Funciona */

main section.como-funciona {
	background: #E5ECEE;
}
main section.como-funciona h2 {
	font-weight: bold;
	padding-bottom: 5rem;
}
main section.como-funciona .box {
	align-items: center;
	background: var(--cor-primaria-0);
	color: #FFF;
	display: flex;
	flex-direction: column;
	font-size: 1.1rem;
	font-weight: bold;
	justify-content: center;
	height: 150px;
	padding: 30px 20px;
	position: relative;
}
main section.como-funciona .box:after {
	content: "";
	position: absolute;
	right: -20px;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
	border-left: 20px solid var(--cor-primaria-0); /* Mesma cor do fundo da box */
	z-index: 1;
}
main section.como-funciona .box.last-child:after {
	display: none;
}
main section.como-funciona .box .number {
	align-items: center;
	background: #fff;
	border: 0;
	border-radius: 100px;
	box-shadow: 3px 8px 6px var(--cor-primaria-0);
	color: #000;
	display: flex;
	font-size: 1.75rem;
	height: 75px;
	justify-content: center;
	margin-top: -68px;
	width: 75px;
}
main section.como-funciona .box p {
	padding-top: 25px;
}

body .cta-section {
	background: #FFF;
	background-size: cover;
	text-align: center;
}
body .cta-section .box-img {
	height: 100%;
	overflow: visible;
	position: relative;
	z-index: 1;
}
body .cta-section .box-img:before {
	background: radial-gradient(circle,rgba(28, 76, 150, 1) 0%, rgba(87, 199, 133, 0) 8%) no-repeat;
	background-position: calc(50% + 40px) 50%; /* Centralizado verticalmente, 20px à direita do centro */
	background-size: 1000% 100%; /* Ajuste conforme necessário */
	height: 100%;
	content: '';
	position: absolute;
	width: 100%;
	z-index: 0;
}

body .cta-section h2 {
	color: var(--cor-primaria-0);
	padding-bottom: 0.5rem;
}
body .cta-section p {
	padding-bottom: 0.5rem;
}
body .cta-section a {
	display: inline-block;
}
body .cta-section .group-btn {
	padding-top: 2rem;
	text-align: center;
}

body .faq .accordion-item {
	border: 0;
}
body .faq h2 button {
	font-size: 1.25rem;
}
body .faq button.accordion-button {
	font-weight: bold;
}
body .faq h2 button.accordion-button:hover {
	color: var(--cor-primaria-0);
}
body .faq .accordion-button:not(.collapsed) {
	background: transparent !important;
}


.entry-title, .page-title {
	display: none;
}

/*
| ----------------------------
| FOOTER
| ----------------------------
*/

footer {
	background: var(--cor-primaria-0);
	color: #FFF;
	padding: 2rem;
}
footer h6 {
	font-size: 1.25rem;
	padding-bottom: 25px;
}
footer .f-brand {
	padding-bottom: 2rem;
}
footer .f-contato ul {
	list-style: none;
	padding-bottom: 20px;
	padding-left: 0;
}
footer .f-contato ul li i {
	color: var(--cor-secundaria-0);
	display: inline-block;
	font-size: 2rem;
	margin-right: 8px;
	vertical-align: middle;
}
footer .f-info {
	padding-bottom: 2rem;
}
footer .f-info .item {
	opacity: 1;
}
footer .f-social a {
	color: #FFF;
	display: inline-block;
	margin-right: 30px;
	transition: transform 0.3s ease-in-out;
}
footer .f-social a i {
	color: #FFF;
	font-size: 2rem;
	display: inline-block;
	margin-right: 8px;
	vertical-align: middle;
}
footer ul {
	padding-left: 15px;
}
footer ul li {
	padding-bottom: 15px;
}
footer ul li a {
	color: #FFF;
}
footer ul li a:hover {
	text-decoration: underline;
}
footer .f-copy {
	font-size: 0.8rem;
}

/*
# ----------------------------
# MEDIA QUERIES
# ----------------------------
*/

@media (max-width: 1200px) {
	header nav.navbar button.navbar-toggler {
		background: #FFF;
		margin-right: 160px;
	}
	header nav.navbar .navbar-collapse ul {
		background: #FFF;
		border: 0;
		border-radius: 25px;
		float: none;
		padding: 25px 15px 15px;
	}
	header nav.navbar .navbar-collapse ul li {
		padding-bottom: 15px;
	}
	header nav.navbar .navbar-collapse ul li a {
		color: #000;
	}
	.sobre::after {
			display: none;
		}
	main section.parceiros .item {
		height: 100px;
		margin-bottom: 2rem;
		overflow: hidden;
		padding: 5px;
		width: 33%;
	}
	main section.parceiros .item img {
		max-height: 100%;
		max-width: 95%;
		width: auto;
	}
} /* 1200px */

@media (max-width: 992px) {
		header nav.navbar {
			z-index: 9999;
		}
		header nav.navbar .brand {
			float: none;
			margin: 0 auto;
		}
		header nav.navbar .actions a.cta {
			display: none;
		}
		header nav.navbar .navbar-text {
			display: block;
			padding-top: 7px;
			text-align: center;
			width: 100%;
		}
		header nav.navbar .info {
			position: absolute;
			right: 15px;
			top: 15px;
			width: auto;
		}
		header nav.navbar button.navbar-toggler {
			margin-right: 0;
		}
		body header .jumbotron {
			background: url('img/bn-home-mob.webp') no-repeat center top;
			background-size: cover;
			padding: 3rem 0;
		}
		body header .jumbotron .box {
			text-align: center;
			width: 100%;
			z-index: 2;
		}
		body header .box h1 {
			font-size: 2.5rem;
			line-height: 2.75rem;
		}
		body .beneficios .box-text {
			margin-bottom: 15px;
			min-height: 0;
			padding: 15px 20px;
		}
		body header .box .cta {
			display: inline-block;
			font-size: 1.25rem;
			margin-bottom: 15px;
			width: auto;
		}
		body .beneficios .icon {
			margin-right: 20px;
			width: 55px;
		}
		body .wrapper .box-img img {
			padding-bottom: 1rem;
		}
		body .tipo-mudanca div {
			flex-direction: column;
		}
		body .tipo-mudanca .box-icon {
			display: block;
			margin-bottom: 15px;
			padding: 9px 14px;
		}
		body .tipo-mudanca h3 {
			padding-left: 0;
		}
		body .cta-section .cta {
			font-size: 1.3rem;
			margin: 0 auto;
			width: auto;
		}
		.rastreio form {
			width: 75%;
		}
		.rastreio::after {
			height: 125px;
			top: 60%;
			width: 125px;
		}
		.sobre {
			padding: 2rem;
		}
		.sobre h2 {
			padding: 0 0 1.5rem;
			width: 100%;
		}
		.sobre p, .sobre ul {
			width: 100%;
		}
		.sobre .cta {
			width: 100%;
		}
		body .sobre img {
			display: block;
			margin: 0 auto;
			margin-top: 25px;
	}

} /* 992px */

		@media (max-width: 768px) {
			body a.cta {
				display: block;
				margin: 0 auto;
				position: relative;
				width: 75%;
			}
			header nav.navbar .navbar-text {
				position: absolute;
				right: 15px;
				top: 15px;
				width: auto;
			}
			header nav.navbar .info {
				display: block;
				padding: 15px 0 4px;
				position: relative;
				right: auto;
				text-align: center;
				top: auto;
				width: 100%;
			}
			body .beneficios img {
				display: block;
				margin: 0 auto;
			}
			body .beneficios .list-item {
				display: flex;
				flex-wrap: wrap; /* Permite que os itens quebrem para a próxima linha */
				justify-content: space-between; /* Distribui os itens uniformemente */
				gap: 15px; /* Espaçamento opcional entre os itens (caso queira) */
			}
			body .beneficios .list-item .item {
				flex: 0 0 calc(50% - 15px); /* Largura de 50% menos o espaçamento */
				max-width: calc(50% - 15px); /* Garante que não ultrapasse 50% */
				box-sizing: border-box; /* Evita que padding/margin interfiram na largura */
			}
			body .beneficios .list-item .item .icon {
				width: 45px;		
			}
			body .beneficios .list-item .item h2 {
				font-size: 1.475rem;
			}
			body .beneficios .list-item .item p {
				font-size: 1rem;;
			}
			.servicos ul li {
				border-bottom: 1px solid #DEDEDE;
				height: auto;
				margin-top: 25px;
				padding-bottom: 25px; 
			}
			.servicos ul li:last-child {
				border: 0;
				margin-bottom: 0;
				padding-bottom: 0;
			}
			.servicos ul li .item-title {
				border: 0;
				display: block;
				float: none;
				height: auto;
				margin-right: auto;
				padding-right: 0;
				text-align: center;
				width: auto;
			}
			.servicos ul li .item-text {
				display: block;
				padding-top: 20px;
			}
			footer {
				text-align: center;
			}
			footer .f-social {
				display: flex;
				justify-content: center;
				padding-top: 3rem;
			}
			} /* 768px */

			@media (max-width: 576px) {
				body a.cta {
					font-size: 1rem;
					padding: 15px;
					width: auto;
				}
				header nav.navbar .brand img {
					/*! width: 175px; */
				}
				header nav.navbar .navbar-text {
					font-size: 0.9rem;
				}
				header nav.navbar .fone {
					font-size: 0.9rem;
				}
				header nav.navbar .collapse {
					padding-left: 0;
				}
				body h2 {
					font-size: 2rem;
					padding-bottom: 1.25rem;
				}
				body .beneficios p, body .sobre p {
					padding-bottom: 0.75rem;
				}

				body .beneficios img {
					max-width: 75%;
				}
				body .beneficios h3 {
					padding: 15px 0;
				}
				.seguro a.btn {
					display: block;
					margin-bottom: 15px;
				}
				.seguro a.btn:last-child {
					margin-bottom: 0;
				}
				body .cta-section .box-img img {
					max-width: 75%;
				}
				footer h6, footer .f-info {
					text-align: center;
				}
				footer .f-social {
					padding-top: 2rem;
				}
				footer .f-copy {
					padding-top: 3rem;
					text-align: center;
				}
				} /* 576px */

				@media (max-width: 412px) {
					body a.cta {
						display: block;
						margin: 0 auto;
						width: 85%;
					}
					body h2 {
						font-size: 1.75rem;
						padding-bottom: 1.75rem;
					}
					header nav.navbar .brand {
						max-width: 135px;
					}
					header nav.navbar .navbar-text {
						text-align: right;
						top: 10px;
						width: 40%;
					}
					body header .box h1 {
						font-size: 2rem;
						line-height: 2.25rem;
					}
					body header .box h2 {
						font-size: 1.25rem;
					}
					body header .box h2 span {
						font-size: 1.2rem;
					}
					body header .box .cta {
						font-size: 1.25rem;
						margin-bottom: 0;
					}
} /* 412px */