/**
 * rg-pages.css — Estilos das páginas institucionais
 *
 * Carregado em: contato, sobre-nos, anunciar-imovel, perguntas-frequentes, favoritos, lancamentos
 * Depende de: rg-global.css
 *
 * Figma nodes:
 *   35:1062  — /sobre-nos
 *   29:8961  — /perguntas-frequentes
 *   28:7529  — /favoritos
 *   29:7901  — /favoritos com imoveis
 *
 * @package HelloElementorChild
 * @since   0.1.0 — Sprint 4 (placeholder)
 * @todo    Implementar na Sprint 4
 */

/* ==========================================================================
   404 — Página não encontrada (Figma node 18:2555)
   ========================================================================== */

.rg-404 {
	background-color: var(--rg-color-bg-gray);
	min-height: calc(100vh - 160px); /* header ~80px + footer ~80px */
	display: flex;
	align-items: center;
	padding-block: var(--rg-space-20);
}

.rg-404__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	max-width: 672px;
	margin-inline: auto;
}

.rg-404__number {
	font-family: var(--rg-font-heading);
	font-size: 128px;
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	line-height: 1;
	margin: 0 0 var(--rg-space-4);
	letter-spacing: -0.02em;
}

.rg-404__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-2xl);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	margin: 0 0 var(--rg-space-4);
	line-height: 1.3;
}

.rg-404__text {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-md);
	color: var(--rg-color-text-muted);
	line-height: 1.6;
	margin: 0 0 var(--rg-space-8);
	max-width: 56ch;
}

.rg-404__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--rg-space-4);
}

/* Variante accent (amarelo) — usada no botão Buscar Imóveis */
.rg-btn.rg-btn--accent {
	background-color: var(--rg-color-accent-bright);
	color: var(--rg-color-text-on-accent);
	border-color: var(--rg-color-accent-bright);
}

.rg-btn.rg-btn--accent:hover {
	background-color: var(--rg-color-accent);
	color: var(--rg-color-text-on-accent);
	border-color: var(--rg-color-accent);
}

@media (max-width: 480px) {
	.rg-404__number {
		font-size: 96px;
	}

	.rg-404__actions {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.rg-404__actions .rg-btn {
		justify-content: center;
	}
}

/* ==========================================================================
   FAVORITOS — Figma 28:7529 (vazia) + 29:7901 (com imóveis)
   ========================================================================== */

/* Hero */
.rg-fav-hero {
	background-color: var(--rg-color-primary);
	padding-block: var(--rg-space-16);
	text-align: center;
}

.rg-fav-hero__icon {
	color: var(--rg-color-accent-bright);
	margin-bottom: var(--rg-space-4);
	line-height: 0;
}

.rg-fav-hero__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-4xl);
	font-weight: var(--rg-font-weight-bold);
	margin: 0 0 var(--rg-space-4);
	line-height: 1.2;
}

/* Especificidade 0,2,0 supera .elementor-kit-31 h1 (0,1,1) */
.rg-fav-hero .rg-fav-hero__title {
	color: var(--rg-color-text-on-dark);
}

.rg-fav-hero__subtitle {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-md);
	color: #e8f4f8;
	max-width: 620px;
	margin: 0 auto;
	line-height: 1.6;
}

/* Conteúdo geral */
.rg-fav-content {
	background-color: var(--rg-color-bg-gray);
	padding-block: var(--rg-space-12) var(--rg-space-16);
}

/* ---- Estado Vazio ---- */
.rg-fav-empty {
	background-color: var(--rg-color-bg-white);
	border-radius: var(--rg-radius-lg);
	padding: var(--rg-space-16) var(--rg-space-12);
	text-align: center;
	max-width: 800px;
	margin-inline: auto;
}

.rg-fav-empty__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 96px;
	height: 96px;
	border-radius: var(--rg-radius-full);
	background-color: #e8f4f8;
	color: var(--rg-color-primary-light);
	margin: 0 auto var(--rg-space-6);
}

.rg-fav-empty__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-2xl);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	margin: 0 0 var(--rg-space-4);
}

.rg-fav-empty__text {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-md);
	color: var(--rg-color-text-muted);
	max-width: 52ch;
	margin: 0 auto var(--rg-space-8);
	line-height: 1.6;
}

.rg-fav-empty__actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: var(--rg-space-4);
	margin-bottom: var(--rg-space-10);
}

.rg-fav-empty__regions {
	border-top: 1px solid var(--rg-color-border);
	padding-top: var(--rg-space-8);
}

.rg-fav-empty__regions-title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-lg);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	margin: 0 0 var(--rg-space-4);
}

.rg-fav-empty__regions-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--rg-space-2);
}

.rg-fav-empty__region-pill {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-sm);
	font-weight: var(--rg-font-weight-medium);
	color: var(--rg-color-primary);
	background-color: #e8f4f8;
	padding: var(--rg-space-2) var(--rg-space-4);
	border-radius: var(--rg-radius);
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.rg-fav-empty__region-pill:hover {
	background-color: var(--rg-color-primary-light);
	color: var(--rg-color-text-on-dark);
}

/* ---- Estado Preenchido ---- */
.rg-fav-filled {
	display: flex;
	flex-direction: column;
	gap: var(--rg-space-6);
}

/* Stats */
.rg-fav-stats {
	background-color: var(--rg-color-bg-white);
	border-radius: var(--rg-radius-lg);
	padding: var(--rg-space-6) var(--rg-space-8);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--rg-space-4);
	text-align: center;
}

.rg-fav-stats__value {
	display: block;
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-2xl);
	font-weight: var(--rg-font-weight-bold);
	line-height: 1.2;
	margin-bottom: var(--rg-space-1);
}

.rg-fav-stats__label {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-sm);
	color: var(--rg-color-text-muted);
}

/* Grid de cards */
.rg-fav-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--rg-space-5);
}

/* Card de imóvel */
.rg-fav-card {
	background-color: var(--rg-color-bg-white);
	border-radius: var(--rg-radius-lg);
	overflow: hidden;
	box-shadow: var(--rg-shadow);
	transition: transform 0.2s ease;
}

.rg-fav-card:hover {
	transform: translateY(-3px);
}

.rg-fav-card__media {
	position: relative;
	height: 224px;
	overflow: hidden;
}

.rg-fav-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.rg-fav-card__img-placeholder {
	width: 100%;
	height: 100%;
	background-color: var(--rg-color-bg-gray);
}

/* Botão remover (coração preenchido no canto superior esquerdo) */
.rg-fav-card__remove {
	position: absolute;
	top: var(--rg-space-3);
	left: var(--rg-space-3);
	width: 40px;
	height: 40px;
	border-radius: var(--rg-radius-full);
	background-color: rgba(0, 0, 0, 0.4);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--rg-color-accent-bright);
	transition: background-color 0.2s ease, transform 0.15s ease;
	z-index: 1;
}

.rg-fav-card__remove:hover {
	background-color: rgba(0, 0, 0, 0.65);
	transform: scale(1.1);
}

/* Badge status (Venda/Aluguel) — canto superior direito */
.rg-fav-card__badge {
	position: absolute;
	top: var(--rg-space-3);
	right: var(--rg-space-3);
	background-color: var(--rg-color-accent);
	color: var(--rg-color-text-on-accent);
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-xs);
	font-weight: var(--rg-font-weight-bold);
	padding: 3px var(--rg-space-2);
	border-radius: var(--rg-radius-full);
}

/* Corpo do card — é um link */
.rg-fav-card__body {
	display: block;
	padding: var(--rg-space-5);
	text-decoration: none;
	color: inherit;
}

.rg-fav-card__price {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-xl);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	margin: 0 0 var(--rg-space-2);
}

.rg-fav-card__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-md);
	font-weight: var(--rg-font-weight-bold);
	color: #000000;
	margin: 0 0 var(--rg-space-2);
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.rg-fav-card__local {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-sm);
	color: var(--rg-color-text-muted);
	margin: 0 0 var(--rg-space-3);
}

.rg-fav-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: var(--rg-space-3);
}

.rg-fav-card__stat {
	display: flex;
	align-items: center;
	gap: var(--rg-space-1);
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-sm);
	font-weight: var(--rg-font-weight-medium);
	color: #000000;
}

/* CTA Encontre mais (fundo branco) */
.rg-fav-more {
	background-color: var(--rg-color-bg-white);
	border-radius: var(--rg-radius-lg);
	padding: var(--rg-space-10) var(--rg-space-8);
	text-align: center;
}

.rg-fav-more__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-xl);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-primary);
	margin: 0 0 var(--rg-space-3);
}

.rg-fav-more__text {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-base);
	color: var(--rg-color-text-muted);
	margin: 0 0 var(--rg-space-6);
}

/* CTA Falar com consultor (fundo escuro) */
.rg-fav-consult {
	background-color: var(--rg-color-primary);
	border-radius: var(--rg-radius-lg);
	padding: var(--rg-space-10) var(--rg-space-8);
	text-align: center;
}

.rg-fav-consult__title {
	font-family: var(--rg-font-heading);
	font-size: var(--rg-text-xl);
	font-weight: var(--rg-font-weight-bold);
	color: var(--rg-color-text-on-dark);
	margin: 0 0 var(--rg-space-3);
}

.rg-fav-consult__text {
	font-family: var(--rg-font-body);
	font-size: var(--rg-text-base);
	color: #e8f4f8;
	margin: 0 0 var(--rg-space-6);
}

/* Responsivo */
@media (max-width: 1024px) {
	.rg-fav-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.rg-fav-hero__title {
		font-size: var(--rg-text-2xl);
	}

	.rg-fav-stats {
		grid-template-columns: 1fr 1fr;
		gap: var(--rg-space-6);
	}

	.rg-fav-stats__item:last-child {
		grid-column: 1 / -1;
	}

	.rg-fav-empty {
		padding: var(--rg-space-10) var(--rg-space-6);
	}
}

@media (max-width: 580px) {
	.rg-fav-grid {
		grid-template-columns: 1fr;
	}

	.rg-fav-empty__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.rg-fav-empty__actions .rg-btn {
		justify-content: center;
	}

	.rg-fav-stats {
		grid-template-columns: 1fr;
	}

	.rg-fav-stats__item:last-child {
		grid-column: auto;
	}
}
