/*
Theme Name: Aparecida Saúde
Theme URI: https://exemplo.com/aparecidasaude
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: aparecidasaude
*/

/* 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: #27577E;
	--cor-secundaria-0: #f8cc53;
}

/*
| ----------------------------
| GERAL
| ----------------------------
*/

body a {
	color: var(--cor-primaria-0);
	text-decoration: none;
}
body a.btn {
	color: #FFF;
	font-weight: bold;
	padding: 15px 35px;
}
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 a.cta {
	background: #EB3B12;
	border: 0;
	border-radius: 100px;
	color: #FFF;
	font-size: 1.5rem;
	font-weight: bold;
	padding: 15px 100px;
	text-shadow: 1px 1px 0 #9F4119;
	transition: transform 0.3s ease;
}
body a.cta:hover {
	background: #EB3B12;
	transform: scale(1.05);
}

.wrapper {
	padding: 4rem 0;
}

body h2 {
	color: var(--cor-primaria-0);
	font-size: 2.25rem;
	/*! 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 {
	padding: 6px;
	width: 100%;
}
header nav.navbar .navbar-text {
	color: #FFF;
}
header nav.navbar ul li a {
	border-bottom: 3px solid #F9F9F9;
	display: inline-block;
	color: #000;
	padding-bottom: 3px;
}
header nav.navbar ul li a:hover {
	border-bottom: 3px solid var(--cor-primaria-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: 215px;
}
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 .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ÁGINAS > AGENDA
| ----------------------------
*/

body.page-agenda header,
body.page-agenda footer,
body.politica-de-privacidade header,
body.politica-de-privacidade footer,
body.termos-de-uso header,
body.termos-de-uso footer {
	display: none;
}

/*
| ----------------------------
| 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 top;
	background-size: 100% auto;
	padding: 3rem 0;
	position: relative;
}
body header .box {
	margin-top: 0rem;
	position: relative;
	width: 55%;
	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 {
	color: #FFF;
	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 .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 ul li {
	font-size: 1.65rem;
}
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;
}

/* Tipo de mudança */

.tipo-mudanca {
	background: #F5F5F5;
	text-align: center;
}
.tipo-mudanca .box-icon {
	border: 1px solid #000;
	border-radius: 7px;
	padding: 11px 16px;
}
.tipo-mudanca h3 {
	font-weight: bold;
	padding-left: 25px;
}

/* Seguro */

.seguro {
	background: #003278;
	color: #FFF;
}
.seguro a.btn:hover {
	background: #FFF;
	color: #003278;
}

/* Serviços */

.servicos h3 {
	padding-top: 1.5rem;
}
.servicos ul {
	padding-left: 0;
}
.servicos ul li {
	overflow: hidden;
	padding-bottom: 10px; 
}

/* 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;
}
.sobre {
	background: #F5F5F5;
}
body .cta-section {
	background: url('img/bg-cta-section.webp') no-repeat center center;
	background-size: cover;
	color: #FFF;
	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: #FFF;
	padding-bottom: 3.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-left: 0;
}
footer .f-contato ul li i {
	border: 1px solid #FFF;
	border-radius: 100px;
	display: inline-block;
	font-size: 0.65rem;
	font-weight: 600;
	margin-right: 8px;
	padding: 6px;
	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;
	}
	body .beneficios ul li {
	font-size: 1.25rem;
}
	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 .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 {
		font-size: 1.5rem;
		margin-bottom: 15px;
	}
	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;
	}
	body .sobre h2 {
		padding: 0 0 2rem;
		text-align: center;
	}
	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: 15px;
		padding-bottom: 15px; 
	}
	.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: 1.75rem;
		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.2rem;
		margin-bottom: 0;
		padding: 10px 0;
		width: 100%;
	}
} /* 412px */