/**
 * CSS Base Não-Crítico
 */

/* ========== Web Fonts ========== */
/* A Inter é carregada via Google Fonts pelo FontManager. */

/* ========== Base Styles ========== */
body {
	font-family: var(--font-primary);
}

/* Section opcional com fundo “gelo” (usar em um Group/section específico) */
.section-ice {
	background-color: #eaeaea;
}

.section-ice .box {
	background-color: #eaeaea;
}

/* ========== Post Card Component ========== */
.post-card {
	position: relative;
	border-radius: 0;
	overflow: hidden;
	background-color: #fff;
	border-top: 1px solid rgba(0, 0, 0, 0.1);
	padding-top: 16px;
}

.post-card__link {
	display: block;
	text-decoration: none;
	color: inherit;
	border-radius: 0;
}

.post-card__thumbnail {
	width: 100%;
	overflow: hidden;
	position: relative;
	height: 0;
	padding-bottom: 56.25%;
	border-radius: 10px;
}

.post-card__thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	will-change: transform;
	border-radius: inherit;
}

.post-card:hover .post-card__thumbnail img {
	transform: scale(1.1);
}

.post-card__title {
	font-family: "Inter", var(--font-primary);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.4;
	margin: 0 0 0.5rem;
	color: #111;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

@media (max-width: 992px) {
	.post-card__title {
		font-size: 16px;
	}
}

@media (max-width: 768px) {
	.post-card__title {
		font-size: 15px;
	}
}

.post-card__content {
	padding: 0.75rem 0 0;
}

/* ========== Category Badge Component ========== */
.category-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background-color: color-mix(in srgb, var(--color-secondary-base, #3498db) 20%, transparent);
	padding-inline: 0.625rem;
	padding-block: 0.5rem;
	border-radius: 4px;
	font-weight: 400;
	font-size: 0.875rem;
	color: var(--color-secondary-base, #3498db);
	text-decoration: none;
}

.category-badge:hover {
	background-color: color-mix(in srgb, var(--color-secondary-base, #3498db) 60%, transparent);
}

/* ========== Section Header Component ========== */
.section-header {
	position: relative;
	padding-left: 1rem;
	font-family: "Inter", var(--font-primary);
	font-weight: 700;
	font-style: normal;
	font-size: 24px;
	line-height: 32.5px;
	letter-spacing: 0;
	vertical-align: middle;
}

.section-header::before {
	content: " ";
	display: block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--color-secondary-base, #3498db);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
}

/* Responsivo: Tablet grande */
@media (max-width: 1200px) {
	.section-header {
		font-size: 22px;
		line-height: 30px;
	}
}

/* Responsivo: Tablet */
@media (max-width: 992px) {
	.section-header {
		font-size: 20px;
		line-height: 28px;
	}
}

/* Responsivo: Mobile grande */
@media (max-width: 768px) {
	.section-header {
		font-size: 18px;
		line-height: 26px;
	}
}

/* Responsivo: Mobile */
@media (max-width: 480px) {
	.section-header {
		font-size: 18px;
		line-height: 26px;
	}
}

/* ========== Fallback Messages Component ========== */
.module-fallback {
	margin: 0;
	font-size: 0.8125rem;
	line-height: 1.5;
	color: rgba(0, 0, 0, 0.6);
	font-style: italic;
}

.module-fallback a {
	color: rgba(0, 0, 0, 0.8);
	text-decoration: underline;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.module-fallback a:hover,
.module-fallback a:focus {
	color: var(--color-primary-base, #2c3e50);
	opacity: 0.8;
}

.module-footer .module-fallback,
[class*="module-"][class*="--dark"] .module-fallback {
	color: rgba(255, 255, 255, 0.6);
}

.module-footer .module-fallback a,
[class*="module-"][class*="--dark"] .module-fallback a {
	color: rgba(255, 255, 255, 0.8);
}

.module-footer .module-fallback a:hover,
.module-footer .module-fallback a:focus,
[class*="module-"][class*="--dark"] .module-fallback a:hover,
[class*="module-"][class*="--dark"] .module-fallback a:focus {
	color: rgba(255, 255, 255, 1);
}

/* ========== Layout CSS - Estrutura da Página ========== */

/* ========== Contact Form 7 (Formulário: Contato) ========== */
/* CF7 normalmente não usa o id do shortcode como id do <form>.
   Então estilizamos o CF7 de forma segura, escopando no wrapper .wpcf7. */
.wpcf7 {
	--cf7-radius: 12px;
	--cf7-border: rgba(0, 0, 0, 0.12);
	--cf7-bg: #ffffff;
	--cf7-text: rgba(0, 0, 0, 0.88);
	--cf7-muted: rgba(0, 0, 0, 0.62);
	--cf7-danger: #dc2626;
	--cf7-success: #16a34a;
	--cf7-focus: color-mix(in srgb, var(--color-primary-base, #2c3e50) 35%, transparent);
}

.wpcf7 form.wpcf7-form p {
	margin: 0 0 0.9rem;
}

.wpcf7 form.wpcf7-form label {
	display: block;
	font-weight: 600;
	color: var(--cf7-text);
	margin-bottom: 0.35rem;
}

.wpcf7 form.wpcf7-form .wpcf7-form-control-wrap {
	display: block;
}

.wpcf7 form.wpcf7-form input[type="text"],
.wpcf7 form.wpcf7-form input[type="email"],
.wpcf7 form.wpcf7-form input[type="tel"],
.wpcf7 form.wpcf7-form input[type="url"],
.wpcf7 form.wpcf7-form input[type="number"],
.wpcf7 form.wpcf7-form select,
.wpcf7 form.wpcf7-form textarea {
	width: 100%;
	max-width: 100%;
	border: 1px solid var(--cf7-border);
	border-radius: var(--cf7-radius);
	background: var(--cf7-bg);
	color: var(--cf7-text);
	padding: 0.75rem 0.9rem;
	font-size: 1rem;
	line-height: 1.25;
	outline: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.wpcf7 form.wpcf7-form textarea {
	min-height: 140px;
	resize: vertical;
}

.wpcf7 form.wpcf7-form input:focus,
.wpcf7 form.wpcf7-form select:focus,
.wpcf7 form.wpcf7-form textarea:focus {
	border-color: color-mix(in srgb, var(--color-primary-base, #2c3e50) 60%, #000);
	box-shadow: 0 0 0 4px var(--cf7-focus);
}

/* Placeholder */
.wpcf7 form.wpcf7-form ::placeholder {
	color: rgba(0, 0, 0, 0.42);
}

/* Botão */
.wpcf7 form.wpcf7-form input[type="submit"] {
	appearance: none;
	border: 0;
	border-radius: 999px;
	background: var(--color-primary-base, #2c3e50);
	color: #fff;
	font-weight: 700;
	padding: 0.85rem 1.25rem;
	cursor: pointer;
	transition: transform 0.08s ease, filter 0.15s ease, opacity 0.15s ease;
	width: 100%;
}

.wpcf7 form.wpcf7-form input[type="submit"]:hover {
	filter: brightness(1.05);
}

.wpcf7 form.wpcf7-form input[type="submit"]:active {
	transform: translateY(1px);
}

/* Estado "enviando" */
.wpcf7 form.wpcf7-form .wpcf7-spinner {
	margin-left: 0.5rem;
}

/* Mensagens e validações */
.wpcf7 form.wpcf7-form .wpcf7-not-valid-tip {
	color: var(--cf7-danger);
	font-size: 0.875rem;
	margin-top: 0.35rem;
}

.wpcf7 form.wpcf7-form .wpcf7-response-output {
	margin: 1rem 0 0;
	border-radius: var(--cf7-radius);
	padding: 0.9rem 1rem;
	border: 1px solid var(--cf7-border);
	color: var(--cf7-text);
}

.wpcf7 form.wpcf7-form.sent .wpcf7-response-output {
	border-color: color-mix(in srgb, var(--cf7-success) 55%, #000);
	background: color-mix(in srgb, var(--cf7-success) 12%, #fff);
}

.wpcf7 form.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7 form.wpcf7-form.failed .wpcf7-response-output {
	border-color: color-mix(in srgb, var(--cf7-danger) 55%, #000);
	background: color-mix(in srgb, var(--cf7-danger) 10%, #fff);
}

/* 2 colunas quando tiver campos lado-a-lado (se usar wrappers) */
.wpcf7 form.wpcf7-form .cf7-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.9rem;
}

@media (max-width: 640px) {
	.wpcf7 form.wpcf7-form .cf7-grid {
		grid-template-columns: 1fr;
	}
}