/*
Theme Name: Casa Imobiliária
Theme URI: https://example.com/casa-imobiliaria
Author: Zaraim
Description: Tema moderno e sofisticado para imobiliárias (textos em português do Brasil — pt-BR). Layout limpo, tipografia elegante e foco na apresentação de imóveis.
Version: 1.0.98
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: casa-imobiliaria
*/

:root {
	--casa-color-bg: #faf9f7;
	--casa-color-surface: #ffffff;
	--casa-color-text: #1a1a1a;
	--casa-color-text-muted: #5c5c5c;
	--casa-color-border: #e8e6e3;
	--casa-color-accent: #2d5a4a;
	--casa-color-accent-hover: #234a3d;
	--casa-font-heading: "Plus Jakarta Sans", "Segoe UI", sans-serif;
	--casa-font-body: "DM Sans", "Segoe UI", sans-serif;
	--casa-radius: 12px;
	--casa-radius-sm: 8px;
	--casa-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	--casa-shadow-hover: 0 8px 28px rgba(0, 0, 0, 0.1);
	/* Largura padrão alinhada ao conteúdo; Personalizar → Layout → «0» mantém este teto. */
	--casa-max-width: min(100%, 1200px);
	--casa-header-height: 72px;
	/* Logo: valores padrão; o tema pode sobrescrever via CSS inline (Customizer) */
	--casa-logo-max-height: 52px;
	--casa-logo-max-width: 280px;
	--casa-logo-object-fit: contain;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--casa-font-body);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--casa-color-text);
	background: var(--casa-color-bg);
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--casa-font-heading);
	font-weight: 600;
	line-height: 1.25;
	margin: 0 0 0.75em;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
p { margin: 0 0 1em; }
a { color: var(--casa-color-accent); text-decoration: none; transition: color 0.2s ease; }
a:hover { color: var(--casa-color-accent-hover); }
img { max-width: 100%; height: auto; display: block; }

.casa-site { display: flex; flex-direction: column; min-height: 100vh; }
.casa-main {
	flex: 1;
	width: 100%;
	max-width: var(--casa-max-width);
	margin: 0 auto;
	padding: 2rem 1.5rem;
}
@media (min-width: 768px) {
	.casa-main { padding: 3rem 2rem; }
}

/* Layout 1, 2 e 3 colunas */
.casa-main-inner {
	display: grid;
	gap: 2rem;
}
.casa-layout-1col .casa-main-inner {
	grid-template-columns: 1fr;
}
.casa-layout-2col .casa-main-inner {
	grid-template-columns: 1fr;
}
.casa-layout-3col .casa-main-inner {
	grid-template-columns: 1fr;
}
@media (min-width: 768px) {
	.casa-layout-2col .casa-main-inner {
		grid-template-columns: 1fr 280px;
	}
	.casa-layout-3col .casa-main-inner {
		grid-template-columns: 1fr 240px 240px;
	}
}
@media (min-width: 1024px) {
	.casa-layout-3col .casa-main-inner {
		grid-template-columns: 1fr 260px 260px;
	}
}
.casa-content {
	min-width: 0;
}
.casa-sidebar {
	min-width: 0;
}
.casa-sidebar .widget {
	margin-bottom: 1.5rem;
}
.casa-sidebar .widget:last-child {
	margin-bottom: 0;
}
.casa-sidebar .widget-title {
	font-family: var(--casa-font-heading);
	font-size: 1rem;
	margin: 0 0 0.75rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--casa-color-border);
}
.casa-sidebar ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.casa-sidebar ul li {
	margin-bottom: 0.5rem;
}

.casa-header {
	position: sticky;
	top: 0;
	z-index: 100;
	min-height: var(--casa-header-height);
	height: auto;
	background: var(--casa-color-surface);
	border-bottom: 1px solid var(--casa-color-border);
	box-shadow: var(--casa-shadow);
}
.casa-header-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem 1rem;
	min-height: var(--casa-header-height);
	height: auto;
	width: 100%;
	max-width: var(--casa-max-width);
	margin: 0 auto;
	padding: 0 1.5rem;
	box-sizing: border-box;
}
.casa-header-tools {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.35rem 1rem;
	flex: 0 1 auto;
	margin-left: auto;
	min-width: 0;
	max-width: 100%;
}
.casa-header-tools .casa-nav {
	flex: 0 1 auto;
	min-width: 0;
	max-width: 100%;
}
.casa-header-social {
	flex: 0 0 auto;
}
.casa-header-social-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.2rem 0.35rem;
}
.casa-header-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.3rem;
	border-radius: 6px;
	line-height: 0;
	transition: color 0.2s ease, opacity 0.2s ease;
}
.casa-header .casa-social-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.35rem;
	height: 1.35rem;
}
.casa-header .casa-social-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}
.casa-logo {
	font-family: var(--casa-font-heading);
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--casa-color-text);
	line-height: 1.2;
}
.casa-logo a { color: inherit; }
.casa-logo a:hover { color: var(--casa-color-accent); }

/* Logo de imagem (Identidade do site): cabeçalho — evita distorção e “espremido” no flex */
.casa-header .casa-logo {
	display: flex;
	align-items: center;
	min-width: 0;
	flex: 0 1 auto;
	max-width: min(100%, var(--casa-logo-max-width));
}
.casa-header .casa-logo .custom-logo-link {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	line-height: 0;
	max-width: 100%;
	text-decoration: none;
}
.casa-header .casa-logo .custom-logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: min(var(--casa-logo-max-height), calc(var(--casa-header-height) - 16px));
	object-fit: var(--casa-logo-object-fit);
	object-position: left center;
}
.casa-nav .casa-nav-menu,
.casa-nav ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	/* Espaço entre itens: só via Customizer (column-gap/row-gap em .casa-nav > ul no CSS dinâmico).
	   Um gap aqui com .casa-nav .casa-nav-menu tinha especificidade maior e anulava o controlo. */
	list-style: none;
	margin: 0;
	padding: 0;
}
/* Lista principal: largura pelo conteúdo (o PHP do Customizer também reforça em .casa-nav > ul) */
.casa-nav > ul {
	width: max-content;
	max-width: 100%;
}
.casa-nav .casa-nav-menu > li {
	position: relative;
}
.casa-nav a {
	display: block;
	color: var(--casa-color-text-muted);
	font-weight: 500;
	text-decoration: none;
	transition: color 0.2s ease, background-color 0.2s ease;
}
.casa-nav a:hover,
.casa-nav .current-menu-item a { color: var(--casa-color-accent); }

/* Dropdown / submenu */
.casa-nav .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 100;
	display: none;
	list-style: none;
	margin: 0;
	padding: 0;
}
.casa-nav .menu-item-has-children:hover > .sub-menu,
.casa-nav .menu-item-has-children.focus > .sub-menu {
	display: block;
}
.casa-nav .sub-menu .sub-menu {
	top: 0;
	left: 100%;
}

.casa-footer {
	margin-top: auto;
	padding: 2rem 1.5rem;
	background: var(--casa-color-surface);
	border-top: 1px solid var(--casa-color-border);
	color: var(--casa-color-text-muted);
	font-size: 0.9rem;
}
.casa-footer-inner { max-width: var(--casa-max-width); margin: 0 auto; text-align: center; }
.casa-footer a { color: var(--casa-color-text-muted); }
.casa-footer a:hover { color: var(--casa-color-accent); }

.casa-back-to-top {
	position: fixed;
	right: 1.25rem;
	bottom: 1.25rem;
	z-index: 120;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--casa-color-border);
	border-radius: 999px;
	background: var(--casa-color-accent);
	color: #fff;
	box-shadow: var(--casa-shadow);
	cursor: pointer;
	font-size: 1.1rem;
	line-height: 1;
	transition: background 0.2s ease, transform 0.2s ease;
}

.casa-back-to-top:hover {
	filter: brightness(0.92);
	transform: translateY(-2px);
}

.casa-entry-header { margin-bottom: 2rem; }
.casa-entry-title { margin-bottom: 0.25em; }
.casa-entry--template-sem-titulo .casa-entry-content { margin-top: 0; }
.casa-entry--template-sem-titulo .casa-entry-thumbnail { margin-bottom: 1.5rem; }
.casa-entry-meta { font-size: 0.9rem; color: var(--casa-color-text-muted); }
.casa-entry-content { max-width: 70ch; }
.casa-entry-content > * + * { margin-top: 1.25em; }

/* IMPORTANTE: Quando o conteúdo tem plugin de imobiliária, remover limite de largura */
.casa-entry-content:has(.imobiliaria-listagem),
.casa-entry-content:has(.imobiliaria-resultados),
.casa-entry-content:has(.imobiliaria-busca) {
	max-width: none !important;
	width: 100% !important;
}

/* Fallback para navegadores sem suporte a :has() - aplica direto nos elementos */
.imobiliaria-listagem,
.imobiliaria-resultados,
.imobiliaria-busca {
	width: 100% !important;
	max-width: none !important;
	box-sizing: border-box !important;
}

/* Quando a página tem o plugin de imobiliária, expandir o conteúdo */
.has-imobiliaria-plugin .casa-entry-content {
	max-width: none !important;
	width: 100% !important;
}

.casa-btn {
	display: inline-block;
	padding: 0.75rem 1.5rem;
	font-family: var(--casa-font-body);
	font-size: 1rem;
	font-weight: 500;
	text-align: center;
	color: #fff;
	background: var(--casa-color-accent);
	border: none;
	border-radius: var(--casa-radius-sm);
	cursor: pointer;
	transition: background 0.2s ease;
}
.casa-btn:hover { background: var(--casa-color-accent-hover); }

.imobiliaria-listagem { 
	padding: 0;
	width: 100%;
	max-width: 100%;
}
/* Aspeto do formulário .imobiliaria-busca: fundo, borda, sombra e cantos vêm do plugin (Definições → Formulário de busca). */
.imobiliaria-card-link {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow);
}
.imobiliaria-card-link:hover { box-shadow: var(--casa-shadow-hover); }
.imobiliaria-card-titulo { font-family: var(--casa-font-heading); font-weight: 600; color: var(--casa-color-text); }
.imobiliaria-nenhum {
	background: var(--casa-color-surface);
	border-radius: var(--casa-radius);
	border: 1px solid var(--casa-color-border);
	color: var(--casa-color-text-muted);
}
.imobiliaria-paginacao a, .imobiliaria-paginacao span { border-radius: var(--casa-radius-sm); font-weight: 500; }
.imobiliaria-ficha {
	background: var(--casa-color-surface);
	border-radius: var(--casa-radius);
	border: 1px solid var(--casa-color-border);
	padding: 1.5rem;
	margin: 2rem 0;
}
.imobiliaria-ficha-title { font-family: var(--casa-font-heading); font-size: 1.25rem; margin-bottom: 1rem; }
.imobiliaria-atrativos-title { font-family: var(--casa-font-heading); font-size: 1.25rem; margin: 2rem 0 1rem; }

/* Carrossel na página do imóvel – refinamentos do tema */
.casa-entry-imovel .imobiliaria-carrossel {
	border-radius: var(--casa-radius);
	overflow: hidden;
	box-shadow: var(--casa-shadow);
	border: 1px solid var(--casa-color-border);
	margin-bottom: 2rem;
}
.casa-entry-imovel .imobiliaria-carrossel-principal {
	background: var(--casa-color-bg);
}
.casa-btn-voltar {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.5rem 1rem;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--casa-color-text-muted);
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius-sm);
	text-decoration: none;
	transition: all 0.2s ease;
}
.casa-btn-voltar:hover {
	color: var(--casa-color-accent);
	border-color: var(--casa-color-accent);
	background: var(--casa-color-bg);
}
.casa-entry-content-imovel .imobiliaria-ficha-grid {
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

.casa-entry-content-imovel .imobiliaria-ficha-icon-wrap .casa-icone {
	color: var(--casa-color-text-muted);
}

.casa-entry-content-imovel .imobiliaria-ficha-dashicon.dashicons {
	color: var(--casa-color-text-muted);
}

/* Atrativos do imóvel (plugin) — logo a seguir à ficha */
.casa-entry-content-imovel .imobiliaria-atrativos {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	padding: 1.5rem;
	margin: 2rem 0;
	box-shadow: var(--casa-shadow);
}

.casa-entry-content-imovel .imobiliaria-atrativos-titulo {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	font-family: var(--casa-font-heading);
	font-size: 1.25rem;
	margin: 0 0 1rem;
}

.casa-entry-content-imovel .imobiliaria-atrativos-titulo-icon {
	color: var(--casa-color-accent);
}

.casa-entry-content-imovel .imobiliaria-atrativos-titulo-icon .casa-icone {
	color: inherit;
}

.casa-entry-content-imovel .imobiliaria-atrativo-icon-wrap {
	color: var(--casa-color-accent);
}

.casa-entry-content-imovel .imobiliaria-atrativo-icon-wrap .casa-icone {
	color: inherit;
}

.casa-entry-content-imovel .imobiliaria-atrativo-dashicon.dashicons {
	color: inherit;
}

.casa-entry-content-imovel .imobiliaria-atrativo-item {
	border-bottom-color: var(--casa-color-border);
}

.casa-entry-content-imovel .imobiliaria-atrativo-tipo,
.casa-entry-content-imovel .imobiliaria-atrativo-descricao {
	color: var(--casa-color-text-muted);
}

.casa-entry-content-imovel .imobiliaria-atrativo-distancia {
	color: var(--casa-color-accent);
}

.casa-entry-content-imovel .imobiliaria-atrativos-mapa {
	border-color: var(--casa-color-border);
}

/* Página inicial */
.casa-home {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin: 0 -1.5rem;
	position: relative;
	z-index: 1;
}

/* Separador logo após o slideshow: fica fora de .casa-home — alinhar às margens do bloco home */
.casa-main > .casa-home-separator-parallax {
	margin-left: -1.5rem;
	margin-right: -1.5rem;
	width: auto;
	max-width: none;
	box-sizing: border-box;
}

.casa-main > .casa-home-separator-parallax--constrained {
	margin-left: auto;
	margin-right: auto;
	max-width: var(--casa-separator-max-w, 1200px);
	width: 100%;
}

/* Separador dentro de .casa-home (a maior parte dos «slots»): margens como filho direto de .casa-main */
.casa-home > .casa-home-separator-parallax {
	margin-left: -1.5rem;
	margin-right: -1.5rem;
	width: auto;
	max-width: none;
	box-sizing: border-box;
}

.casa-home > .casa-home-separator-parallax--constrained {
	margin-left: auto;
	margin-right: auto;
	max-width: var(--casa-separator-max-w, 1200px);
	width: 100%;
}

/* Sem padding lateral herdado de .casa-home-section — senão a faixa não encosta às margens da área da home */
.casa-home-section.casa-home-separator-parallax {
	padding-left: 0;
	padding-right: 0;
	padding-top: 0;
	padding-bottom: 0;
}

/* Separador com imagem (parallax — Personalizar → Página inicial) */
.casa-home-separator-parallax {
	position: relative;
	z-index: 0;
	min-height: var(--casa-parallax-vh, 45vh);
	animation: none;
	padding-top: 0;
	padding-bottom: 0;
}

.casa-home-separator-parallax--constrained {
	max-width: var(--casa-separator-max-w, 1200px);
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.casa-home > .casa-home-section:not(.casa-home-separator-parallax) {
	position: relative;
	z-index: 1;
}

/*
 * Com imagem: a faixa fica «presa» sob o cabeçalho (sticky) enquanto o resto da home rola por cima.
 * background-attachment: fixed dentro de .casa-home (flex) costuma falhar no Chrome — não usar.
 */
.casa-home-separator-parallax--fixed {
	position: sticky;
	top: var(--casa-header-height, 72px);
	align-self: stretch;
	width: 100%;
	max-width: none;
	box-sizing: border-box;
	flex-shrink: 0;
}

@media (prefers-reduced-motion: reduce) {
	.casa-home-separator-parallax--fixed {
		position: relative;
		top: auto;
		align-self: stretch;
	}
}

.casa-home-section {
	padding: var(--casa-home-section-space-top, 3.5rem) 1.5rem var(--casa-home-section-space-bottom, 3.5rem);
	animation: casaFadeUp 0.7s ease both;
}

/* :where() mantém especificidade 0 para o listrado — assim cor/borda dos blocos (Personalizar) aplicam */
:where(.casa-home-section:nth-child(even):not(.casa-home-separator-parallax)) {
	background: rgba(255, 255, 255, 0.72);
}

.casa-home-section:nth-child(2) { animation-delay: 0.08s; }
.casa-home-section:nth-child(3) { animation-delay: 0.16s; }
.casa-home-section:nth-child(4) { animation-delay: 0.24s; }
.casa-home-section:nth-child(5) { animation-delay: 0.32s; }
.casa-home-section:nth-child(6) { animation-delay: 0.4s; }

.casa-home-container {
	max-width: var(--casa-max-width);
	margin: 0 auto;
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
}

.casa-home-section-header {
	width: 100%;
	max-width: none;
	margin-bottom: 1.5rem;
}

.casa-home-setting,
.casa-home-section-title,
.casa-home-section-text,
.casa-home-richtext {
	display: block;
	width: 100%;
	max-width: none;
}

.casa-home-section-title {
	font-size: clamp(1.8rem, 3vw, 2.6rem);
	margin-bottom: 0.5rem;
}

.casa-home-section-title > *:last-child,
.casa-home-section-text > *:last-child {
	margin-bottom: 0;
}

.casa-home-section-title h1,
.casa-home-section-title h2,
.casa-home-section-title h3,
.casa-home-section-title h4,
.casa-home-section-title h5 {
	margin-bottom: 0.5rem;
}

.casa-home-section-title > *,
.casa-home-section-text > *,
.casa-home-richtext > * {
	text-align: inherit;
}

.casa-home-section-text {
	color: var(--casa-color-text-muted);
	font-size: 1.05rem;
}

.casa-home-search-box,
.casa-home-panel,
.casa-home-entry {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow);
}

.casa-home-search-box {
	padding: 1.75rem;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* Na home o shortcode traz .imobiliaria-busca com fundo e margens próprios — funde no cartão para alinhar com painéis / grelha */
.casa-home-search-box .imobiliaria-busca {
	background: transparent !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
}

.casa-home-search-box .imobiliaria-busca-campos {
	width: 100%;
	max-width: 100%;
	min-width: 0;
	box-sizing: border-box;
}

/* Opções do plugin (min-width dos campos) não devem fazer o flex “estourar” o cartão da home */
.casa-home-search-box .imobiliaria-busca-campos select,
.casa-home-search-box .imobiliaria-busca-campos input[type="text"],
.casa-home-search-box .imobiliaria-busca-campos input[type="number"] {
	min-width: 0 !important;
	max-width: 100% !important;
}

.casa-home-entry {
	padding: 2rem;
}

.casa-home-entry-content {
	max-width: none;
}

.casa-home-area-grid,
.casa-home-attractions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.5rem;
}

.casa-home-featured-grid {
	display: grid;
	grid-template-columns: repeat(var(--casa-featured-columns, 3), minmax(0, 1fr));
	gap: 1.5rem;
}

.casa-home-news-grid {
	display: grid;
	grid-template-columns: repeat(var(--casa-news-columns, 3), minmax(0, 1fr));
	gap: var(--casa-news-gap, 24px);
}

@media (max-width: 700px) {
	.casa-home-news-grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Feed social — shortcode Smash Balloon (página inicial) */
.casa-home-smash-balloon-inner {
	max-width: 100%;
	overflow-x: auto;
}

.casa-home-smash-balloon-inner iframe {
	max-width: 100%;
}

/* Depoimentos (página inicial) */
.casa-home-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(var(--casa-testimonials-columns, 3), minmax(0, 1fr));
	gap: 1.5rem;
	align-items: stretch;
}

.casa-home-testimonial-card {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: 12px;
	padding: 1.35rem 1.35rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	box-shadow: var(--casa-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.casa-home-testimonial-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--casa-shadow-hover);
}

.casa-home-testimonial-card__avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	border: 2px solid var(--casa-color-border);
}

.casa-home-testimonial-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.casa-home-testimonial-card__quote {
	margin: 0;
	font-size: 1rem;
	line-height: 1.55;
	color: var(--casa-color-text, #0f172a);
}

.casa-home-testimonial-card__quote p {
	margin: 0;
}

.casa-home-testimonial-stars {
	display: flex;
	flex-wrap: wrap;
	gap: 0.12rem;
	font-size: 1.1rem;
	line-height: 1;
	letter-spacing: 0.02em;
}

.casa-home-testimonial-star.is-filled {
	color: var(--casa-color-accent, #0f766e);
}

.casa-home-testimonial-star.is-empty {
	color: var(--casa-color-muted, #94a3b8);
	opacity: 0.55;
}

.casa-home-testimonial-card__footer {
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	font-size: 0.9rem;
}

.casa-home-testimonial-card__name {
	font-style: normal;
	font-weight: 600;
	font-family: var(--casa-font-heading);
	color: var(--casa-color-text, #0f172a);
}

.casa-home-testimonial-card__role {
	color: var(--casa-color-muted, #64748b);
	font-size: 0.85rem;
}

@media (max-width: 700px) {
	.casa-home-testimonials-grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

.casa-home-news-card {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-news-card-radius, 12px);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.casa-home-news--shadow-none .casa-home-news-card {
	box-shadow: none;
}

.casa-home-news--shadow-sm .casa-home-news-card {
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);
}

.casa-home-news--shadow-md .casa-home-news-card {
	box-shadow: var(--casa-shadow);
}

.casa-home-news--shadow-lg .casa-home-news-card {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

.casa-home-news-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--casa-shadow-hover);
}

.casa-home-news--shadow-none .casa-home-news-card:hover {
	box-shadow: none;
}

.casa-home-news-media {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: linear-gradient(135deg, var(--casa-color-accent), #6ca08f);
}

.casa-home-news-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	vertical-align: middle;
}

.casa-home-news-body {
	padding: 1.1rem 1.25rem 1.25rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.casa-home-news-title {
	margin: 0;
	font-family: var(--casa-font-heading);
	font-size: 1.05rem;
	font-weight: 600;
	line-height: 1.35;
}

.casa-home-news-title a {
	color: inherit;
	text-decoration: none;
}

.casa-home-news-title a:hover {
	color: var(--casa-color-accent);
}

.casa-home-news-excerpt {
	margin: 0;
	font-size: 0.92rem;
	color: var(--casa-color-text-muted);
	line-height: 1.5;
	flex: 1;
}

.casa-home-news-actions {
	margin: 0.35rem 0 0;
}

.casa-home-news-readmore {
	font-size: 0.88rem;
	padding: 0.45rem 1rem;
}

.casa-home-area-card {
	display: block;
	overflow: hidden;
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow);
	color: inherit;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.casa-home-area-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--casa-shadow-hover);
	color: inherit;
}

.casa-home-featured-card {
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow);
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	display: flex;
	flex-direction: column;
	position: relative;
	isolation: isolate;
}

.casa-home-featured-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--casa-shadow-hover);
}

.casa-home-featured-link {
	display: inline-flex;
	color: inherit;
	text-decoration: none;
}

.casa-home-featured-link:hover {
	color: inherit;
}

.casa-home-featured-link-media {
	display: block;
}

.casa-home-featured-media {
	position: relative;
	z-index: 1;
	aspect-ratio: 16 / 10;
	background: linear-gradient(135deg, var(--casa-color-accent), #6ca08f);
	overflow: hidden;
}

.casa-home-featured-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.casa-home-featured-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.35rem 0.7rem;
	border-radius: 999px;
	background: rgba(26, 26, 26, 0.78);
	color: #fff;
	font-size: 0.78rem;
	font-weight: 600;
}

.casa-home-featured-badge .casa-icone .casa-icone__svg {
	width: 1em;
	height: 1em;
}

.casa-home-featured-body {
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

/* Ícones SVG (assets/icons) — helper casa_imobiliaria_icon() em functions.php */
.casa-icone {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	vertical-align: middle;
	line-height: 0;
	color: inherit;
}

.casa-icone img {
	display: block;
	width: 1.25em;
	height: 1.25em;
	object-fit: contain;
}

.casa-icone .casa-icone__svg {
	display: block;
	width: 1.25em;
	height: 1.25em;
	flex-shrink: 0;
}

/* Degradê / sobreposição dos cartões em destaque na home: plugin Imobiliária (Listagem e cards) */

.casa-home-featured-body h3 {
	margin-bottom: 0.5rem;
}

.casa-home-featured-title a {
	color: inherit;
}

.casa-home-featured-category-text {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	flex-wrap: wrap;
	margin-bottom: 0.75rem;
	color: var(--casa-color-accent);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.casa-home-featured-category-text .casa-icone .casa-icone__svg {
	width: 1em;
	height: 1em;
}

.casa-home-featured-price {
	margin-bottom: 0.75rem;
	color: var(--casa-color-accent);
	font-size: 1.2rem;
	font-weight: 700;
}

.casa-home-featured-excerpt {
	margin-bottom: 1rem;
	color: var(--casa-color-text-muted);
}

.casa-home-featured-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	list-style: none;
	margin: 0;
	padding: 0;
	color: var(--casa-color-text-muted);
	font-size: 0.92rem;
}

.casa-home-featured-meta li {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding-right: 0.75rem;
	border-right: 1px solid var(--casa-color-border);
}

.casa-home-featured-meta li .casa-icone {
	opacity: 0.9;
	flex-shrink: 0;
}

.casa-home-featured-meta li:last-child {
	padding-right: 0;
	border-right: none;
}

.casa-home-featured-actions {
	margin-top: auto;
	padding-top: 1rem;
}

.casa-home-featured-button {
	display: inline-flex;
}

/* Imóveis por categoria (home) */
.casa-home-by-category-inner {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}

.casa-home-by-category--layout-2 .casa-home-by-category-inner {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 2rem;
	align-items: start;
}

.casa-home-by-category-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}

.casa-home-by-category-title {
	margin: 0;
	font-family: var(--casa-font-heading);
	font-size: 1.35rem;
	font-weight: 600;
	color: var(--casa-color-text);
}

.casa-home-by-category-more {
	font-weight: 600;
	color: var(--casa-color-accent);
	text-decoration: none;
	white-space: nowrap;
}

.casa-home-by-category-more:hover {
	text-decoration: underline;
	color: var(--casa-color-accent-hover);
}

.casa-home-by-category-scroll {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 1.25rem;
	overflow-x: auto;
	padding-bottom: 0.35rem;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
}

.casa-home-by-category-scroll .casa-home-featured-card {
	flex: 0 0 min(300px, 88vw);
	max-width: min(300px, 88vw);
	scroll-snap-align: start;
}

@media (min-width: 782px) {
	.casa-home-by-category-scroll--sized .casa-home-featured-card {
		flex: 0 0 var(--casa-by-cat-scroll-basis, min(300px, 88vw));
		max-width: var(--casa-by-cat-scroll-basis, min(300px, 88vw));
	}
}

.casa-home-area-media {
	aspect-ratio: 16 / 10;
	background: linear-gradient(135deg, var(--casa-color-accent), #6ca08f);
	overflow: hidden;
}

.casa-home-area-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.casa-home-area-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	color: #fff;
	font-size: 3rem;
	font-family: var(--casa-font-heading);
	font-weight: 700;
}

.casa-home-area-body {
	padding: 1.25rem;
}

.casa-home-area-body h3 {
	margin-bottom: 0.35rem;
}

.casa-home-area-body p {
	margin: 0;
	color: var(--casa-color-text-muted);
}

.casa-home-two-col {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
}

.casa-home-two-col > :only-child {
	grid-column: 1 / -1;
}

.casa-home-panel {
	padding: 1.75rem;
}

.casa-home-richtext {
	color: var(--casa-color-text-muted);
}

.casa-home-richtext p:last-child {
	margin-bottom: 0;
}

.casa-home-contact-list {
	display: grid;
	gap: 1rem;
	margin: 1.5rem 0;
}

.casa-home-contact-list div {
	display: grid;
	gap: 0.25rem;
	padding-bottom: 0.9rem;
	border-bottom: 1px solid var(--casa-color-border);
}

.casa-home-contact-list div:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.casa-home-contact-list strong {
	font-family: var(--casa-font-heading);
}

.casa-home-map-embed {
	border-radius: var(--casa-radius-sm);
	overflow: hidden;
	min-height: 420px;
}

.casa-home-map-embed iframe {
	display: block;
	width: 100%;
	min-height: 420px;
	border: 0;
}

.casa-home-attraction-card {
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	padding: 1.4rem;
	background: var(--casa-color-surface);
	border: 1px solid var(--casa-color-border);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow);
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.casa-home-attraction-card:hover {
	border-color: rgba(45, 90, 74, 0.35);
	box-shadow: var(--casa-shadow-hover);
}

.casa-home-attraction-card__main {
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	flex: 1 1 auto;
	min-height: 0;
	cursor: pointer;
	border-radius: calc(var(--casa-radius-sm) - 2px);
}

.casa-home-attraction-card__main:focus-visible {
	outline: 2px solid var(--casa-color-accent);
	outline-offset: 2px;
}

.casa-home-attraction-card__title {
	margin: 0;
	font-size: 1.15rem;
}

.casa-home-attraction-card__excerpt {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

.casa-home-attraction-card__map {
	position: relative;
	z-index: 2;
	cursor: pointer;
}

.casa-home-attraction-card__hint {
	margin: 0;
	margin-top: -0.25rem;
	font-size: 0.8rem;
	color: var(--casa-color-text-muted);
}

.casa-home-attraction-dialog {
	padding: 0;
	border: none;
	background: transparent;
	max-width: min(32rem, 94vw);
	width: 100%;
}

.casa-home-attraction-dialog::backdrop {
	background: rgba(26, 26, 26, 0.45);
}

.casa-home-attraction-dialog__inner {
	padding: 1.5rem 1.5rem 1.25rem;
	background: var(--casa-color-surface);
	border-radius: var(--casa-radius);
	box-shadow: var(--casa-shadow-hover);
	border: 1px solid var(--casa-color-border);
}

.casa-home-attraction-dialog__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}

.casa-home-attraction-dialog__title {
	margin: 0;
	font-size: 1.25rem;
	line-height: 1.3;
	flex: 1;
	min-width: 0;
}

.casa-home-attraction-dialog__head form {
	margin: 0;
	flex-shrink: 0;
}

.casa-home-attraction-dialog__close {
	font-family: var(--casa-font-body);
	font-size: 0.9rem;
	font-weight: 600;
	padding: 0.45rem 0.85rem;
	border-radius: var(--casa-radius-sm);
	border: 1px solid var(--casa-color-border);
	background: var(--casa-color-bg);
	color: var(--casa-color-text);
	cursor: pointer;
}

.casa-home-attraction-dialog__close:hover {
	border-color: var(--casa-color-accent);
	color: var(--casa-color-accent);
}

.casa-home-attraction-dialog__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.casa-home-attraction-dialog__body {
	color: var(--casa-color-text-muted);
	line-height: 1.55;
	margin-bottom: 1rem;
}

.casa-home-attraction-dialog__body:empty {
	display: none;
}

.casa-home-attraction-dialog__footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	font-size: 0.95rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--casa-color-border);
}

.casa-home-attraction-dialog__footer:empty {
	display: none;
}

.casa-home-attraction-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.casa-home-chip {
	display: inline-flex;
	align-items: center;
	padding: 0.3rem 0.7rem;
	border-radius: 999px;
	background: var(--casa-color-accent);
	color: #fff;
	font-size: 0.8rem;
	font-weight: 600;
}

.casa-home-chip-soft {
	background: rgba(45, 90, 74, 0.12);
	color: var(--casa-color-accent);
}

.casa-home-attraction-card__main .casa-home-attraction-card__excerpt {
	color: var(--casa-color-text-muted);
	margin-bottom: 0;
}

.casa-home-attraction-footer {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0.75rem;
	margin-top: auto;
	font-size: 0.95rem;
}

.casa-home-empty {
	padding: 1rem 1.25rem;
	background: var(--casa-color-surface);
	border: 1px dashed var(--casa-color-border);
	border-radius: var(--casa-radius-sm);
	color: var(--casa-color-text-muted);
}

/* Rodapé */
.casa-footer {
	padding-top: 3rem;
	padding-bottom: 2rem;
}

.casa-footer-inner {
	max-width: var(--casa-max-width);
	margin: 0 auto;
	text-align: left;
}

.casa-footer-grid {
	display: grid;
	gap: 2rem;
}
.casa-footer-grid--1 {
	grid-template-columns: 1fr;
}
.casa-footer-grid--2 {
	grid-template-columns: 1.3fr 1fr;
}
.casa-footer-grid--3 {
	grid-template-columns: 1.3fr 1fr 1fr;
}

.casa-footer-grid h3 {
	font-size: 1rem;
	margin-bottom: 0.9rem;
}

.casa-footer-brand .casa-logo {
	margin-bottom: 0.75rem;
}
.casa-footer-brand .casa-logo .custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 0;
	max-width: 100%;
}
.casa-footer-brand .casa-logo .custom-logo {
	display: block;
	width: auto;
	height: auto;
	max-width: min(100%, 240px);
	max-height: 64px;
	object-fit: contain;
	object-position: left center;
}

.casa-nav-footer ul,
.casa-footer-social-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.6rem;
}

.casa-footer-social-list a,
.casa-nav-footer a {
	color: var(--casa-color-text-muted);
}

.casa-footer-social-list a {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
}

.casa-footer .casa-social-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	height: 1.25rem;
}

.casa-footer .casa-social-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.casa-footer-social-list a:hover,
.casa-nav-footer a:hover {
	color: var(--casa-color-accent);
}

.casa-footer-credits {
	margin-top: 2rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--casa-color-border);
	font-size: 0.92rem;
	color: var(--casa-color-text-muted);
}

.casa-footer-credits p {
	margin: 0;
}

@media (min-width: 768px) {
	.casa-home {
		margin: 0 -2rem;
	}

	.casa-main > .casa-home-separator-parallax {
		margin-left: -2rem;
		margin-right: -2rem;
	}

	.casa-home > .casa-home-separator-parallax {
		margin-left: -2rem;
		margin-right: -2rem;
	}

	.casa-main > .casa-home-separator-parallax--constrained {
		margin-left: auto;
		margin-right: auto;
	}

	.casa-home-section {
		padding-left: 2rem;
		padding-right: 2rem;
	}
}

@media (max-width: 900px) {
	.casa-home-two-col,
	.casa-footer-grid {
		grid-template-columns: 1fr;
	}

	.casa-home-by-category--layout-2 .casa-home-by-category-inner {
		grid-template-columns: 1fr;
	}

	.casa-home-featured-grid {
		grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	}
}

@media (max-width: 640px) {
	.casa-home-featured-grid {
		grid-template-columns: 1fr;
	}
}

@keyframes casaFadeUp {
	from {
		opacity: 0;
		transform: translateY(18px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.casa-home-section,
	.casa-home-area-card,
	.casa-home-featured-card,
	.casa-home-attraction-card {
		animation: none !important;
		transition: none !important;
	}

	.casa-home-by-category-scroll {
		scroll-snap-type: none;
	}
}
