/* Design tokens */
:root {
	--ngk-primary: #6C5CE7; /* indigo */
	--ngk-secondary: #FFD166; /* amber */
	--ngk-bg: #0b0d12;
	--ngk-surface: #151822;
	--ngk-text: #F5F7FA;
	--ngk-text-dim: #C7CFDB;
	--ngk-accent: #22D3EE; /* cyan */
	--ngk-success: #22c55e;
	--ngk-shadow: 0 10px 30px rgba(0,0,0,.35);
	--ngk-radius: 14px;
}
html { scroll-behavior: smooth; }
body {
	background: var(--ngk-bg);
	color: var(--ngk-text);
	/* sobrescreve paddings globais do tema WP para permitir footer/header full-width */
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* Sticky header */
.ngk-header {
	position: sticky; top: 0; z-index: 1000;
	backdrop-filter: saturate(160%) blur(10px);
	background: color-mix(in srgb, #0b0d12 80%, transparent);
	border-bottom: 1px solid color-mix(in srgb, #ffffff 10%, transparent);
}
.ngk-header-inner {
	max-width: 1200px; margin: 0 auto; padding: 12px 20px;
	display: flex; align-items: center; justify-content: center;
}
.ngk-logo { display: none; }
.ngk-logo img { height: 36px; width: auto; }
.ngk-nav { display: flex; align-items: center; gap: 18px; }
.ngk-nav a { 
	color: var(--ngk-text-dim); 
	text-decoration: none; 
	padding: 8px 10px; 
	border-radius: 10px;
	transition: all 0.3s ease;
	position: relative;
}
.ngk-nav a:hover { 
	color: var(--ngk-text); 
	background: color-mix(in srgb, #ffffff 12%, transparent);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.ngk-nav a.active,
.ngk-nav a.active:hover {
	color: var(--ngk-text); 
	background: color-mix(in srgb, var(--ngk-primary) 18%, transparent);
	transform: translateY(-2px);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}
.ngk-nav a::after {
	content: '';
	position: absolute;
	bottom: 4px;
	left: 50%;
	width: 0;
	height: 2px;
	background: var(--ngk-accent);
	transition: all 0.3s ease;
	transform: translateX(-50%);
}
.ngk-nav a:hover::after {
	width: calc(100% - 20px);
}
.ngk-nav a.active::after {
	width: calc(100% - 20px);
}
.ngk-cta, .ngk-cta-secondary {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 12px 18px; border-radius: 999px; text-decoration: none; transition: .2s ease; font-weight: 600;
	box-shadow: var(--ngk-shadow);
}
.ngk-cta {
	background: #0073BC;
	color: #fff;
	border-radius: 999px !important;
}
.ngk-cta:hover { background: #005a94; transform: translateY(-1px); }

/* Botão especial do Hero */
.ngk-hero-button {
	background: transparent !important;
	color: rgb(255, 255, 255) !important;
	border: 1px solid color-mix(in srgb, #ffffff 20%, transparent) !important;
	box-shadow: none !important;
}
.ngk-hero-button:hover {
	background: rgba(255, 255, 255, 0.1) !important;
	transform: translateY(-1px);
}

/* Header CTA must match Elementor primary buttons */
.ngk-header .ngk-cta { background: #0073BC; color: #fff; }
.ngk-header .ngk-cta:hover { background: #005a94; transform: translateY(-1px); }
.ngk-cta-secondary { background: transparent; color: var(--ngk-text); border: 1px solid color-mix(in srgb, #ffffff 20%, transparent); box-shadow: none; }
.ngk-cta-secondary:hover { background: color-mix(in srgb, #ffffff 8%, transparent); }

/* Mobile menu */
.ngk-burger { display: none; width: 42px; height: 42px; align-items: center; justify-content: center; border-radius: 10px; border: 1px solid color-mix(in srgb, #ffffff 15%, transparent); background: transparent; color: var(--ngk-text); }
@media (max-width: 900px) {
	.ngk-header-inner { justify-content: flex-end; }
	.ngk-nav { display: none; position: fixed; inset: 64px 14px auto 14px; background: var(--ngk-surface); padding: 12px; border-radius: 14px; box-shadow: var(--ngk-shadow); flex-direction: column; }
	.ngk-nav.open { display: flex; }
	.ngk-burger { display: inline-flex; }
}

/* Apply consistent vertical padding to every Elementor section */
.e-con.e-parent {
	--padding-top: 20px;
	--padding-bottom: 20px;
	padding-top: 20px;
	padding-bottom: 20px;
}

/* Hero micro-improvements */
.ngk-hero-badge {
	display: inline-block; padding: 8px 12px; border-radius: 999px;
	background: color-mix(in srgb, var(--ngk-secondary) 45%, transparent);
	color: #1a1a1a; font-weight: 700; letter-spacing: .2px;
}
.ngk-hero-ctas { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; }

/* Section cards */
.ngk-section-card {
	background: var(--ngk-surface);
	border: 1px solid color-mix(in srgb, #ffffff 8%, transparent);
	border-radius: var(--ngk-radius);
	box-shadow: var(--ngk-shadow);
	padding: 24px;
	margin: 50px 0;
}
.ngk-section-card h2 { margin-top: 0; }
.ngk-section-card > * + * { margin-top: 20px; }
.ngk-section-card#ngk-section-depoimentos {
	padding-top: 40px;
	padding-bottom: 40px;
	margin-top: 40px;
	margin-bottom: 40px;
}
.ngk-section-card#ngk-section-depoimentos h2 {
	margin-bottom: 20px;
}
.ngk-section-card#ngk-section-alerta,
.ngk-section-card#ngk-section-seguranca {
	padding-top: 20px;
	padding-bottom: 20px;
}

/* Espaçamento claro entre ALERTA e SEGURANÇA */
#ngk-section-seguranca {
	margin-top: 80px;
}

/* Layout em coluna dentro do card de segurança (carrossel + botão) */
#ngk-section-seguranca .elementor-element[data-id="4811152"] {
	display: flex;
	flex-direction: column;
	gap: 25px;
}

/* Botão dentro do card de segurança, alinhado à esquerda */
#ngk-section-seguranca .elementor-element-assinar-btn {
	margin-top: 30px;
	align-self: flex-start;
}
#ngk-section-seguranca .elementor-element-assinar-btn .elementor-button-wrapper {
	text-align: left;
}

/* Versão mobile: centralizar o botão \"Quero proteger minha família\" */
@media (max-width: 768px) {
	#ngk-section-seguranca .elementor-element-assinar-btn {
		align-self: center;
		width: 100%;
	}
	#ngk-section-seguranca .elementor-element-assinar-btn .elementor-button-wrapper {
		text-align: center;
	}

	/* Hero - Centralização completa na versão mobile */
	/* Logo */
	.elementor-7 .elementor-element.elementor-element-21ddf4b,
	.elementor-7 .elementor-element.elementor-element-21ddf4b .elementor-widget-container {
		text-align: center !important;
	}

	.elementor-7 .elementor-element.elementor-element-21ddf4b img {
		margin-left: auto !important;
		margin-right: auto !important;
		display: block !important;
	}

	/* Título */
	.elementor-7 .elementor-element.elementor-element-5ee2f51,
	.elementor-7 .elementor-element.elementor-element-5ee2f51 .elementor-widget-container,
	.elementor-7 .elementor-element.elementor-element-5ee2f51 .elementor-heading-title {
		text-align: center !important;
	}

	/* Subtítulo */
	.elementor-7 .elementor-element.elementor-element-cc1490a,
	.elementor-7 .elementor-element.elementor-element-cc1490a .elementor-widget-container,
	.elementor-7 .elementor-element.elementor-element-cc1490a p {
		text-align: center !important;
	}

	/* Container principal */
	.elementor-7 .elementor-element.elementor-element-b617096 {
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		align-items: center !important;
	}

	.elementor-7 .elementor-element.elementor-element-b617096 .elementor-widget {
		width: 100% !important;
	}
}

/* Testimonials */
.elementor-element[data-id="d459ef4"] > .e-con-inner {
	max-width: 1400px;
	width: 100%;
	margin: 0 auto;
	padding-left: 20px;
	padding-right: 20px;
}

.ngk-testimonials-intro {
	max-width: 720px;
	margin-bottom: 20px;
	color: var(--ngk-text-dim);
}
.ngk-testimonials {
	display: grid;
	gap: 20px 30px;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.ngk-testimonial-card {
	background: var(--ngk-surface);
	padding: 20px;
	min-height: 220px;
	border-radius: var(--ngk-radius);
	border: 1px solid color-mix(in srgb, #ffffff 10%, transparent);
	box-shadow: var(--ngk-shadow);
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.ngk-testimonial-quote {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--ngk-text);
}
.ngk-testimonial-author {
	display: flex;
	flex-direction: column;
	gap: 2px;
	color: var(--ngk-text-dim);
	font-size: 0.85rem;
}
.ngk-testimonial-author strong {
	color: var(--ngk-text);
	font-size: 1rem;
}

/* Carrosséis - deixar seletores (paginação) brancos */
.swiper-pagination-bullet {
	background: #ffffff !important;
	opacity: 0.6;
}
.swiper-pagination-bullet-active {
	background: #ffffff !important;
	opacity: 1;
}

/* FAQ tweaks */
.e-n-accordion {
	border-radius: var(--ngk-radius);
	/* Removido overflow: hidden para evitar sombra nos cantos */
}

.e-n-accordion .e-n-accordion-item {
	/* Removido overflow: hidden para evitar sombra nos cantos */
	margin: 10px 0;
	border: 1px solid color-mix(in srgb, #ffffff 12%, transparent);
	border-radius: var(--ngk-radius);
	color: rgb(255, 255, 255) !important;
	background: #000000 !important;
	box-shadow: none !important;
	filter: none !important;
}

.e-n-accordion .e-n-accordion-item:first-child {
	border-top-left-radius: var(--ngk-radius);
	border-top-right-radius: var(--ngk-radius);
	background: #000000 !important;
}

.e-n-accordion .e-n-accordion-item:last-child {
	border-bottom-left-radius: var(--ngk-radius);
	border-bottom-right-radius: var(--ngk-radius);
	background: #000000 !important;
}

.e-n-accordion .e-n-accordion-item-title {
	padding: 16px 18px;
	border-radius: var(--ngk-radius);
	color: rgb(255, 255, 255) !important;
	background: #0069B1 !important;
	box-shadow: none !important;
	filter: none !important;
}

.e-n-accordion .e-n-accordion-item[open] .e-n-accordion-item-title {
	border-bottom-left-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
	background: #0069B1 !important;
	box-shadow: none !important;
	filter: none !important;
}

/* Garantir background uniforme preto no conteúdo interno */
.e-n-accordion .e-n-accordion-item[open] > div[role="region"],
.e-n-accordion .e-n-accordion-item[open] div[role="region"],
.e-n-accordion .e-n-accordion-item[open] .elementor-element,
.e-n-accordion .e-n-accordion-item[open] .e-con,
.e-n-accordion .e-n-accordion-item[open] .e-con-inner,
.e-n-accordion .e-n-accordion-item[open] .elementor-widget-container {
	background: #000000 !important;
	background-color: #000000 !important;
	background-image: none !important;
	box-shadow: none !important;
	filter: none !important;
	-webkit-filter: none !important;
	border-radius: 0 0 var(--ngk-radius) var(--ngk-radius) !important;
	overflow: visible !important;
}

/* Remover qualquer sombra, gradiente ou efeito nos cantos */
.e-n-accordion .e-n-accordion-item *,
.e-n-accordion .e-n-accordion-item[open] *,
.e-n-accordion .e-n-accordion-item-title * {
	box-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	text-shadow: none !important;
	filter: none !important;
	-webkit-filter: none !important;
}

/* Garantir que o último item aberto tenha cantos inferiores arredondados */
.e-n-accordion .e-n-accordion-item:last-child[open] > div[role="region"],
.e-n-accordion .e-n-accordion-item:last-child[open] div[role="region"],
.e-n-accordion .e-n-accordion-item:last-child[open] .elementor-element,
.e-n-accordion .e-n-accordion-item:last-child[open] .e-con,
.e-n-accordion .e-n-accordion-item:last-child[open] .e-con-inner {
	border-bottom-left-radius: var(--ngk-radius) !important;
	border-bottom-right-radius: var(--ngk-radius) !important;
}
.e-n-accordion .e-n-accordion-item-title-text,
.e-n-accordion .e-n-accordion-item * {
	color: rgb(255, 255, 255) !important;
}

/* Ícones de expansão do FAQ em branco */
.e-n-accordion .e-n-accordion-item-title-icon svg,
.e-n-accordion .e-n-accordion-item-title-icon .e-font-icon-svg {
	fill: #ffffff !important;
	stroke: #ffffff !important;
	color: #ffffff !important;
}
.e-n-accordion .e-n-accordion-item-title-icon svg path {
	fill: #ffffff !important;
	stroke: #ffffff !important;
}
/* Aumentar tamanho da fonte das respostas do FAQ */
.e-n-accordion .e-n-accordion-item .elementor-widget-text-editor,
.e-n-accordion .e-n-accordion-item .elementor-widget-text-editor p,
.e-n-accordion .e-n-accordion-item .elementor-widget-container p {
	font-size: 1.1rem !important;
	line-height: 1.6 !important;
}

/* Footer enhancements */
.ngk-footer {
	background: #0a0c10;
	border-top: 1px solid color-mix(in srgb, #ffffff 10%, transparent);
	/* footer sempre full-width, sem margens externas */
	width: 100vw !important;
	max-width: 100vw !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.ngk-footer-inner {
	/* conteúdo interno também ocupa 100% da largura */
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 36px 20px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
.ngk-footer a { 
	color: var(--ngk-text-dim); 
	text-decoration: none;
	transition: all 0.3s ease;
	display: inline-block;
	padding: 2px 0;
	position: relative;
}
.ngk-footer a:hover { 
	color: var(--ngk-text);
	transform: translateX(4px);
}
.ngk-footer a.active,
.ngk-footer a.active:hover {
	color: var(--ngk-text);
	transform: translateX(4px);
}
.ngk-footer a::before {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 1px;
	background: var(--ngk-accent);
	transition: width 0.3s ease;
}
.ngk-footer a:hover::before {
	width: 100%;
}
.ngk-copy { text-align: center; padding: 14px 10px; color: var(--ngk-text-dim); border-top: 1px solid color-mix(in srgb, #ffffff 8%, transparent); }

/* Botão CTA do footer com mais espaço */
.ngk-footer .ngk-cta {
	padding: 16px 28px !important;
	font-size: 1rem !important;
	white-space: nowrap;
}

@media (max-width: 900px) { .ngk-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .ngk-footer-inner { grid-template-columns: 1fr; } }

/* Scroll reveal base */
.reveal { opacity: 0; transform: translateY(12px); transition: opacity .4s ease, transform .4s ease; }
.in-view { opacity: 1; transform: none; }

/* Card Plano - Novo Design */
.section-plano,
.section-plano .e-con-inner,
.section-plano [data-id="b077836"] {
	background: #060606 !important;
}
.section-plano {
	padding: 40px 0;
	text-align: center;
}

/* Remove sombra de containers pais */
.section-plano [data-id="0130071"],
.section-plano .card-plano,
[data-id="b077836"] [data-id="0130071"],
[data-id="eb3c9ce"] [data-id="0130071"] {
	box-shadow: none !important;
}
.card-plano {
	background: rgb(255, 255, 255) !important;
	border-radius: 14px;
	/* box-shadow: 0 4px 12px rgb(0, 0, 0)!important; */
	padding: 24px;
	max-width: 420px;
	margin: 0 auto;
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
}
.card-plano,
[data-id="0130071"] {
	background: rgb(255, 255, 255) !important;
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
}

/* Sobrescreve o background azul do Elementor */
.elementor-7 .elementor-element.elementor-element-0130071:not(.elementor-motion-effects-element-type-background),
.elementor-7 .elementor-element.elementor-element-0130071 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
[data-id="0130071"]:not(.elementor-motion-effects-element-type-background),
[data-id="0130071"] > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.elementor-element.elementor-element-0130071,
.elementor-element[data-id="0130071"],
.e-con[data-id="0130071"],
.e-con-full[data-id="0130071"] {
	background-color: rgb(255, 255, 255) !important;
	background-image: none !important;
	box-shadow: none !important;
}

/* Remove sombra de todos os elementos relacionados ao card */
.card-plano *,
[data-id="0130071"] *,
.card-plano::before,
.card-plano::after,
[data-id="0130071"]::before,
[data-id="0130071"]::after,
.elementor-element.elementor-element-0130071::before,
.elementor-element.elementor-element-0130071::after {
	box-shadow: none !important;
}
.card-plano h2 {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.5px;
	margin-bottom: 16px;
	color: #0b0b0b;
}
.card-plano .divisor {
	height: 1px;
	background: rgb(0, 0, 0);
	margin: 16px 0;
}
.card-plano ul {
	list-style: none;
	padding: 0;
	margin: 16px 0;
	text-align: left;
}
.card-plano li {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #000000;
	font-size: 0.95rem;
	line-height: 1.5;
	margin-bottom: 8px;
}
.card-plano li::before {
	content: "✔";
	color: rgb(136, 200, 162);
	font-weight: bold;
	font-size: 1.1rem;
}
.card-preco {
	font-size: 1.8rem;
	font-weight: bold;
	color: #000;
	margin: 16px 0 4px;
}
.card-subtexto {
	color: rgb(0, 0, 0);
	font-size: 0.9rem;
	margin-bottom: 20px;
}
.card-button {
	background: #0073BC;
	color: #fff;
	border-radius: 999px;
	padding: 10px 24px;
	font-weight: bold;
	text-transform: uppercase;
	transition: all .2s ease;
	text-decoration: none;
	display: inline-block;
}
.card-button:hover {
	background: #005a94;
	transform: translateY(-2px);
}

/* Menu anchor com fundo preto */
.elementor-menu-anchor {
	background: #000;
}

/* Centralizar container e textos */
[data-id="4a7cdc1"],
.elementor-element[data-id="4a7cdc1"],
.e-con[data-id="4a7cdc1"] {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	text-align: center !important;
	width: 100% !important;
}
[data-id="e34edd5"],
.elementor-element[data-id="e34edd5"],
[data-id="e34edd5"] .elementor-widget-container,
[data-id="e34edd5"] h2,
.elementor-widget-heading[data-id="e34edd5"] {
	text-align: center !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Centralizar citação bíblica */
[data-id="d17027a"],
.elementor-element[data-id="d17027a"],
[data-id="d17027a"] .elementor-widget-container,
[data-id="d17027a"] p,
.elementor-widget-text-editor[data-id="d17027a"] {
	text-align: center !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Aplicar border-radius do ngk-hero-button no botão Elementor */
.elementor-button.elementor-button-link.elementor-size-sm {
	border-radius: 999px !important;
}

/* Estilos para botões CTA azuis */
.ngk-cta-button {
	background-color: #0073BC !important;
	color: #fff !important;
}

/* Estilo para título da seção de plano */
.ngk-plano-title {
	color: #f7f5f5 !important;
	font-weight: 500 !important;
}

/* Modal de imagens da seção de segurança */
.ngk-image-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ngk-modal-backdrop {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.85);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

/* Blur na seção quando modal aberto */
body.modal-open #ngk-section-seguranca {
	filter: blur(5px);
	pointer-events: none;
	transition: filter 0.3s ease;
}

.ngk-modal-content {
	position: relative;
	z-index: 10001;
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.ngk-modal-close {
	position: absolute;
	top: -50px;
	right: 0;
	background: rgba(255, 255, 255, 0.2);
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	width: 44px;
	height: 44px;
	color: #fff;
	font-size: 32px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
	backdrop-filter: blur(10px);
}

.ngk-modal-close:hover {
	background: rgba(255, 255, 255, 0.3);
	border-color: rgba(255, 255, 255, 0.5);
	transform: scale(1.1);
}

.ngk-modal-image-container {
	position: relative;
	max-width: 85vw;
	max-height: 85vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ngk-modal-image-container img {
	max-width: 100%;
	max-height: 85vh;
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: 12px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

/* Tornar imagens do carrossel clicáveis */
#ngk-section-seguranca .swiper-slide-image {
	cursor: pointer;
	transition: transform 0.2s ease;
}

#ngk-section-seguranca .swiper-slide-image:hover {
	transform: scale(1.05);
}

@media (max-width: 768px) {
	.ngk-modal-content {
		max-width: 95vw;
		max-height: 95vh;
	}
	
	.ngk-modal-image-container {
		max-width: 95vw;
		max-height: 90vh;
	}
	
	.ngk-modal-close {
		top: -40px;
		width: 36px;
		height: 36px;
		font-size: 24px;
	}
}

