/*
 * SM Construções — public shortcodes (editorial / architectural)
 * Hardened against Hello Elementor + Elementor default styles via:
 *  - Scoped reset inside .sm-espelho and .sm-public-card
 *  - !important on properties commonly overridden by Elementor globals
 */

/* ────────── Scoped reset (defensive against theme CSS) ────────── */
.sm-espelho,
.sm-espelho *,
.sm-espelho *::before,
.sm-espelho *::after,
.sm-public-grid,
.sm-public-grid *,
.sm-public-grid *::before,
.sm-public-grid *::after {
	box-sizing: border-box !important;
}

.sm-espelho,
.sm-public-grid {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif !important;
	font-size: 14px !important;
	line-height: 1.55 !important;
	color: #1c1916 !important;
	text-align: left !important;
}

.sm-espelho h1, .sm-espelho h2, .sm-espelho h3, .sm-espelho h4, .sm-espelho h5, .sm-espelho h6,
.sm-espelho p,
.sm-espelho ul, .sm-espelho ol, .sm-espelho li,
.sm-espelho dl, .sm-espelho dt, .sm-espelho dd,
.sm-espelho figure, .sm-espelho blockquote,
.sm-public-grid h1, .sm-public-grid h2, .sm-public-grid h3, .sm-public-grid h4, .sm-public-grid h5, .sm-public-grid h6,
.sm-public-grid p,
.sm-public-grid ul, .sm-public-grid ol, .sm-public-grid li,
.sm-public-grid dl, .sm-public-grid dt, .sm-public-grid dd,
.sm-public-grid figure, .sm-public-grid blockquote {
	margin: 0 !important;
	padding: 0 !important;
	font-family: inherit !important;
	font-weight: inherit !important;
	color: inherit !important;
	line-height: inherit !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	text-align: inherit !important;
	background: none !important;
	border: 0 !important;
}

.sm-espelho a,
.sm-public-grid a {
	color: inherit !important;
	text-decoration: none !important;
	background: transparent !important;
}

.sm-espelho button,
.sm-public-grid button {
	background: transparent !important;
	border: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	font: inherit !important;
	color: inherit !important;
	cursor: pointer !important;
	text-align: inherit !important;
	letter-spacing: inherit !important;
	text-transform: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	line-height: inherit !important;
	min-height: auto !important;
}

.sm-espelho img,
.sm-public-grid img {
	max-width: 100% !important;
	height: auto !important;
	display: block !important;
}

/* ────────── [sm_empreendimentos] grid ────────── */
.sm-public-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
	gap: 28px !important;
	margin: 28px 0 !important;
}

.sm-public-grid .sm-public-card {
	background: #ffffff !important;
	border: 1px solid #e8e4dd !important;
	border-radius: 0 !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	transition: box-shadow 0.2s ease !important;
}

.sm-public-grid .sm-public-card:hover {
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08) !important;
}

.sm-public-grid .sm-public-thumb {
	display: block !important;
	width: 100% !important;
	padding-top: 62% !important;
	background-size: cover !important;
	background-position: center !important;
	background-color: #f4f1ec !important;
}

.sm-public-grid .sm-public-body {
	padding: 22px 24px 24px !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
}

.sm-public-grid .sm-public-tag {
	display: inline-block !important;
	align-self: flex-start !important;
	color: #8b7350 !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 2px !important;
	border-bottom: 1px solid #c8a877 !important;
	padding: 0 0 4px !important;
	margin: 0 0 6px !important;
}

.sm-public-grid .sm-public-title {
	margin: 0 !important;
	font-size: 1.4rem !important;
	font-weight: 600 !important;
	color: #1a1a1a !important;
	letter-spacing: -0.4px !important;
}

.sm-public-grid .sm-public-title a { color: inherit !important; }

.sm-public-grid .sm-public-local {
	margin: 0 !important;
	color: #8e8a82 !important;
	font-size: 0.88rem !important;
	letter-spacing: 0.2px !important;
}

.sm-public-grid .sm-public-excerpt {
	margin: 4px 0 8px !important;
	color: #5a5a55 !important;
	font-size: 0.93rem !important;
}

.sm-public-grid .sm-public-btn {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	align-self: flex-start !important;
	background: transparent !important;
	color: #1a1a1a !important;
	padding: 10px 0 !important;
	border: 0 !important;
	border-bottom: 1px solid #1a1a1a !important;
	border-radius: 0 !important;
	font-size: 0.85rem !important;
	font-weight: 600 !important;
	letter-spacing: 1.5px !important;
	text-transform: uppercase !important;
	text-decoration: none !important;
	transition: color 0.15s ease, border-color 0.15s ease !important;
	margin-top: 8px !important;
}

.sm-public-grid .sm-public-btn::after { content: '→' !important; transition: transform 0.15s ease !important; }
.sm-public-grid .sm-public-btn:hover { color: #8b7350 !important; border-color: #8b7350 !important; }
.sm-public-grid .sm-public-btn:hover::after { transform: translateX(3px) !important; }

.sm-public-grid .sm-public-empty {
	padding: 14px !important;
	color: #8e8a82 !important;
	font-style: italic !important;
}

/* ────────── [sm_unidades] espelho ────────── */
.sm-espelho {
	--accent: #8b7350;
	--accent-dark: #6a5739;
	--ink: #1c1916;
	--ink-soft: #4a463f;
	--mute: #8a847b;
	--rule: #d7d1c4;
	--rule-soft: #e6e0d3;
	--paper: #f7f3ec;
	--paper-deep: #f0eadd;

	background: var(--paper) !important;
	padding: 48px 40px !important;
	margin: 32px 0 !important;
	border-top: 1px solid var(--rule) !important;
	border-bottom: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	font-feature-settings: 'tnum' on, 'lnum' on !important;
}

/* ──── header ──── */
.sm-espelho .sm-espelho-header {
	display: flex !important;
	justify-content: space-between !important;
	align-items: flex-end !important;
	gap: 32px !important;
	flex-wrap: wrap !important;
	text-align: left !important;
	margin: 0 0 36px !important;
	padding: 0 0 28px !important;
	border-bottom: 1px solid var(--rule) !important;
}

.sm-espelho .sm-espelho-header-main { min-width: 0 !important; flex: 1 1 auto !important; }

/* ──── legenda ──── */
.sm-espelho .sm-espelho-legenda {
	display: flex !important;
	gap: 16px !important;
	flex-wrap: wrap !important;
	margin: 0 !important;
	padding: 0 !important;
	flex: 0 0 auto !important;
}

.sm-espelho .sm-espelho-legenda-item {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
}

.sm-espelho .sm-espelho-legenda-item dt {
	margin: 0 !important;
	padding: 0 !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 1.8px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-legenda-swatch {
	display: inline-block !important;
	width: 14px !important;
	height: 14px !important;
	border: 1px solid var(--rule) !important;
	background: #fff !important;
}

.sm-espelho .sm-espelho-legenda-swatch.is-disponivel {
	background: var(--cell-disponivel, #ffffff) !important;
}

.sm-espelho .sm-espelho-legenda-swatch.is-reservado {
	background: var(--cell-reservado, var(--paper-deep)) !important;
	border-color: var(--rule) !important;
}

.sm-espelho .sm-espelho-legenda-swatch.is-vendido {
	background: var(--cell-vendido, var(--paper-deep)) !important;
	border-color: var(--rule) !important;
	position: relative !important;
}

.sm-espelho .sm-espelho-legenda-swatch.is-vendido::before {
	content: '' !important;
	position: absolute !important;
	left: 2px !important;
	right: 2px !important;
	top: 50% !important;
	height: 1px !important;
	background: var(--mute) !important;
	transform: translateY(-0.5px) !important;
}

@media (max-width: 700px) {
	.sm-espelho .sm-espelho-header { gap: 18px !important; }
	.sm-espelho .sm-espelho-legenda { gap: 12px !important; }
	.sm-espelho .sm-espelho-legenda-swatch { width: 12px !important; height: 12px !important; }
	.sm-espelho .sm-espelho-legenda-item dt { font-size: 9px !important; letter-spacing: 1.4px !important; }
}

.sm-espelho .sm-espelho-eyebrow {
	margin: 0 0 12px !important;
	color: var(--accent) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 4px !important;
	text-transform: uppercase !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-projeto {
	margin: 0 !important;
	font-size: clamp(28px, 4vw, 40px) !important;
	font-weight: 700 !important;
	letter-spacing: -1px !important;
	line-height: 1.05 !important;
	color: var(--ink) !important;
}

.sm-espelho .sm-espelho-meta {
	margin: 12px 0 0 !important;
	color: var(--mute) !important;
	font-size: 12px !important;
	letter-spacing: 0.5px !important;
}

/* ──── counters ──── */
.sm-espelho .sm-espelho-counters {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	margin: 0 0 48px !important;
	border-top: 1px solid var(--rule) !important;
	border-bottom: 1px solid var(--rule) !important;
	background: transparent !important;
}

.sm-espelho .sm-espelho-counter {
	display: flex !important;
	align-items: baseline !important;
	gap: 16px !important;
	padding: 20px 24px !important;
	border-right: 1px solid var(--rule) !important;
	background: transparent !important;
}

.sm-espelho .sm-espelho-counter:last-child { border-right: 0 !important; }

.sm-espelho .sm-espelho-counter-value {
	font-size: 38px !important;
	font-weight: 600 !important;
	letter-spacing: -1.5px !important;
	font-variant-numeric: tabular-nums !important;
	line-height: 1 !important;
	color: var(--ink) !important;
}

.sm-espelho .sm-espelho-counter-label {
	font-size: 11px !important;
	font-weight: 500 !important;
	letter-spacing: 2px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
	line-height: 1 !important;
}

@media (max-width: 700px) {
	.sm-espelho { padding: 28px 16px !important; margin: 20px 0 !important; }
	.sm-espelho .sm-espelho-header { margin: 0 0 24px !important; padding: 0 0 20px !important; }
	.sm-espelho .sm-espelho-counters { margin: 0 0 28px !important; }
	.sm-espelho .sm-espelho-counter { padding: 12px 14px !important; gap: 10px !important; }
	.sm-espelho .sm-espelho-counter-value { font-size: 24px !important; letter-spacing: -1px !important; }
	.sm-espelho .sm-espelho-counter-label { font-size: 9px !important; letter-spacing: 1.5px !important; }
}

@media (max-width: 480px) {
	.sm-espelho { padding: 22px 12px !important; }
	.sm-espelho .sm-espelho-counters {
		grid-template-columns: 1fr 1fr 1fr !important;
	}
	.sm-espelho .sm-espelho-counter {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 4px !important;
		padding: 10px 8px !important;
	}
	.sm-espelho .sm-espelho-counter-value { font-size: 20px !important; }
	.sm-espelho .sm-espelho-counter-label { font-size: 8px !important; letter-spacing: 1px !important; }
}

/* ──── body layout (torre + detalhes) ──── */
.sm-espelho .sm-espelho-body {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) 360px !important;
	gap: 48px !important;
	align-items: start !important;
}

@media (max-width: 900px) {
	.sm-espelho .sm-espelho-body { grid-template-columns: 1fr !important; gap: 32px !important; }
	.sm-espelho .sm-espelho-detalhes { position: static !important; top: auto !important; }
}

@media (max-width: 700px) {
	.sm-espelho .sm-espelho-andar {
		grid-template-columns: 44px 1fr !important;
		gap: 12px !important;
		padding: 10px 0 !important;
	}
	.sm-espelho .sm-espelho-andar-num-digit { font-size: 18px !important; letter-spacing: -0.5px !important; }
	.sm-espelho .sm-espelho-andar-num-label { font-size: 8px !important; letter-spacing: 1.5px !important; margin-top: 4px !important; }
	.sm-espelho .sm-espelho-cells { gap: 6px !important; }
	.sm-espelho .sm-espelho-cell {
		height: 54px !important;
		min-height: 54px !important;
		padding: 0 6px !important;
		overflow: hidden !important;
	}
	.sm-espelho .sm-espelho-cell.is-empty { height: 54px !important; min-height: 54px !important; }
	.sm-espelho .sm-espelho-cell-numero { font-size: 15px !important; }
	.sm-espelho .sm-espelho-cell-stamp { font-size: 7px !important; letter-spacing: 1.5px !important; padding: 1px 5px !important; }

	.sm-espelho .sm-espelho-detalhes { padding: 24px 20px !important; }
	.sm-espelho .sm-espelho-detalhes-numero { font-size: 44px !important; letter-spacing: -2px !important; }
	.sm-espelho .sm-espelho-detalhes-valor { font-size: 24px !important; }
	.sm-espelho .sm-espelho-detalhes-specs { row-gap: 14px !important; column-gap: 12px !important; }
	.sm-espelho .sm-espelho-spec-value { font-size: 14px !important; }
	.sm-espelho .sm-espelho-detalhes-cta { font-size: 11px !important; letter-spacing: 2px !important; padding: 10px 0 !important; }
}

@media (max-width: 480px) {
	.sm-espelho .sm-espelho-andar {
		grid-template-columns: 32px 1fr !important;
		gap: 8px !important;
	}
	.sm-espelho .sm-espelho-andar-num-digit { font-size: 16px !important; }
	.sm-espelho .sm-espelho-andar-num-label { display: none !important; }
	.sm-espelho .sm-espelho-andar-num { padding-left: 2px !important; }
	.sm-espelho .sm-espelho-cells { gap: 5px !important; }
	.sm-espelho .sm-espelho-cell {
		height: 46px !important;
		min-height: 46px !important;
		padding: 0 4px !important;
	}
	.sm-espelho .sm-espelho-cell.is-empty { height: 46px !important; min-height: 46px !important; }
	.sm-espelho .sm-espelho-cell-numero { font-size: 13px !important; letter-spacing: -0.2px !important; }
	.sm-espelho .sm-espelho-cell-stamp { font-size: 6px !important; letter-spacing: 1px !important; padding: 1px 4px !important; }

	.sm-espelho .sm-espelho-detalhes { padding: 20px 16px !important; }
	.sm-espelho .sm-espelho-detalhes-numero { font-size: 36px !important; }
	.sm-espelho .sm-espelho-detalhes-tipologia { margin: 0 0 18px !important; }
	.sm-espelho .sm-espelho-detalhes-specs { grid-template-columns: 1fr 1fr !important; row-gap: 12px !important; }
	.sm-espelho .sm-espelho-detalhes-valor { font-size: 22px !important; letter-spacing: -0.5px !important; }
	.sm-espelho .sm-espelho-planta-btn { font-size: 10px !important; letter-spacing: 1.2px !important; padding: 11px 12px !important; }
}

/* ──── torre ──── */
.sm-espelho .sm-espelho-torre { position: relative !important; }

.sm-espelho .sm-espelho-torre-cap {
	margin: 0 0 16px !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 4px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
	text-align: center !important;
	padding: 0 0 16px !important;
	border-bottom: 1px solid var(--rule) !important;
}

.sm-espelho .sm-espelho-torre-cap.bottom {
	margin: 24px 0 0 !important;
	padding: 16px 0 0 !important;
	border-bottom: 0 !important;
	border-top: 1px solid var(--rule) !important;
}

.sm-espelho .sm-espelho-andar {
	display: grid !important;
	grid-template-columns: 70px 1fr !important;
	gap: 24px !important;
	padding: 16px 0 !important;
	border-bottom: 1px dotted var(--rule-soft) !important;
	align-items: center !important;
}

.sm-espelho .sm-espelho-andar:last-of-type { border-bottom: 0 !important; }

.sm-espelho .sm-espelho-andar-num {
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	color: var(--mute) !important;
	line-height: 1 !important;
	padding-left: 4px !important;
	border-left: 1px solid var(--rule) !important;
}

.sm-espelho .sm-espelho-andar-num-digit {
	font-size: 26px !important;
	font-weight: 600 !important;
	font-variant-numeric: tabular-nums !important;
	color: var(--ink) !important;
	letter-spacing: -1px !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-andar-num-label {
	margin-top: 6px !important;
	font-size: 9px !important;
	letter-spacing: 2px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-cells {
	display: grid !important;
	gap: 12px !important;
	min-width: 0 !important;
}

.sm-espelho .sm-espelho-andar { min-width: 0 !important; }

.sm-espelho .sm-espelho-cell {
	position: relative !important;
	background: #ffffff !important;
	color: var(--ink) !important;
	border: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	padding: 18px 14px !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 64px !important;
	transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease !important;
	box-shadow: none !important;
	width: 100% !important;
}

.sm-espelho .sm-espelho-cell:hover,
.sm-espelho .sm-espelho-cell:focus,
.sm-espelho .sm-espelho-cell:focus-visible {
	border-color: var(--ink) !important;
	transform: translateY(-1px) !important;
	outline: 0 !important;
}

.sm-espelho .sm-espelho-cell.is-disponivel:hover,
.sm-espelho .sm-espelho-cell.is-disponivel:focus { color: var(--ink) !important; }

.sm-espelho .sm-espelho-cell.is-reservado:hover,
.sm-espelho .sm-espelho-cell.is-reservado:focus,
.sm-espelho .sm-espelho-cell.is-vendido:hover,
.sm-espelho .sm-espelho-cell.is-vendido:focus { color: var(--ink-soft) !important; }

.sm-espelho .sm-espelho-cell:hover .sm-espelho-cell-numero,
.sm-espelho .sm-espelho-cell:focus .sm-espelho-cell-numero {
	color: inherit !important;
}

.sm-espelho .sm-espelho-cell.is-active,
.sm-espelho .sm-espelho-cell.is-active:hover {
	border-color: var(--accent) !important;
	box-shadow: 0 0 0 1px var(--accent) !important;
}

.sm-espelho .sm-espelho-cell.is-active.is-disponivel { color: var(--ink) !important; }
.sm-espelho .sm-espelho-cell.is-active.is-reservado,
.sm-espelho .sm-espelho-cell.is-active.is-vendido { color: var(--ink-soft) !important; }

.sm-espelho .sm-espelho-cell.is-active .sm-espelho-cell-numero { color: inherit !important; }

.sm-espelho .sm-espelho-cell-numero {
	font-size: 20px !important;
	font-weight: 600 !important;
	font-variant-numeric: tabular-nums !important;
	letter-spacing: -0.3px !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-cell.is-disponivel {
	background: var(--cell-disponivel, #ffffff) !important;
	color: var(--cell-disponivel-text, var(--ink)) !important;
}

.sm-espelho .sm-espelho-cell.is-reservado {
	background: var(--cell-reservado, var(--paper-deep)) !important;
	color: var(--cell-reservado-text, var(--mute)) !important;
	border-color: var(--rule) !important;
}

.sm-espelho .sm-espelho-cell.is-vendido {
	background: var(--cell-vendido, var(--paper-deep)) !important;
	color: var(--cell-vendido-text, var(--mute)) !important;
	border-color: var(--rule) !important;
	overflow: hidden !important;
}

.sm-espelho .sm-espelho-cell.is-vendido .sm-espelho-cell-numero {
	text-decoration: line-through !important;
	text-decoration-thickness: 1px !important;
	opacity: 0.85 !important;
}

.sm-espelho .sm-espelho-cell-stamp { display: none !important; }

.sm-espelho .sm-espelho-cell.is-empty {
	background: transparent !important;
	border: 1px dashed var(--rule) !important;
	min-height: 64px !important;
	cursor: default !important;
}

.sm-espelho .sm-espelho-cell.is-empty:hover { transform: none !important; }

/* ──── detalhes lateral ──── */
.sm-espelho .sm-espelho-detalhes {
	background: #ffffff !important;
	border: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	padding: 32px 28px !important;
	position: sticky !important;
	top: 24px !important;
}

.sm-espelho .sm-espelho-placeholder { padding: 36px 0 !important; text-align: center !important; }

.sm-espelho .sm-espelho-placeholder-title {
	margin: 0 0 6px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: var(--ink) !important;
	letter-spacing: -0.2px !important;
}

.sm-espelho .sm-espelho-placeholder-hint {
	margin: 0 !important;
	color: var(--mute) !important;
	font-size: 13px !important;
	line-height: 1.6 !important;
}

.sm-espelho .sm-espelho-detalhes-eyebrow {
	margin: 0 0 6px !important;
	color: var(--accent) !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 3px !important;
	text-transform: uppercase !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-detalhes-numero {
	margin: 0 0 4px !important;
	font-size: 56px !important;
	font-weight: 600 !important;
	letter-spacing: -2.5px !important;
	line-height: 0.95 !important;
	color: var(--ink) !important;
	font-variant-numeric: tabular-nums !important;
}

.sm-espelho .sm-espelho-detalhes-tipologia {
	margin: 0 0 24px !important;
	color: var(--ink-soft) !important;
	font-size: 14px !important;
	letter-spacing: 0.1px !important;
}

.sm-espelho .sm-espelho-detalhes-rule {
	height: 1px !important;
	background: var(--rule) !important;
	margin: 22px 0 !important;
}

.sm-espelho .sm-espelho-detalhes-specs {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	row-gap: 18px !important;
	column-gap: 16px !important;
}

.sm-espelho .sm-espelho-spec-label {
	margin: 0 0 4px !important;
	font-size: 10px !important;
	font-weight: 500 !important;
	letter-spacing: 1.8px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
	line-height: 1 !important;
}

.sm-espelho .sm-espelho-spec-value {
	margin: 0 !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	color: var(--ink) !important;
	letter-spacing: -0.2px !important;
}

.sm-espelho .sm-espelho-detalhes-valor-label {
	margin: 0 0 4px !important;
	font-size: 10px !important;
	font-weight: 500 !important;
	letter-spacing: 1.8px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
}

.sm-espelho .sm-espelho-detalhes-valor {
	margin: 0 0 22px !important;
	font-size: 28px !important;
	font-weight: 600 !important;
	color: var(--ink) !important;
	letter-spacing: -1px !important;
	font-variant-numeric: tabular-nums !important;
}

.sm-espelho .sm-espelho-detalhes-valor-nota {
	margin: -16px 0 22px !important;
	font-size: 11px !important;
	line-height: 1.55 !important;
	color: var(--mute) !important;
	letter-spacing: 0.2px !important;
	font-style: italic !important;
}


.sm-espelho .sm-espelho-detalhes-status {
	display: inline-block !important;
	font-size: 10px !important;
	font-weight: 700 !important;
	letter-spacing: 3px !important;
	text-transform: uppercase !important;
	padding: 5px 11px !important;
	margin: 0 0 22px !important;
	border-radius: 0 !important;
	line-height: 1.4 !important;
}

.sm-espelho .sm-espelho-detalhes-status.is-disponivel {
	color: var(--accent) !important;
	border: 1px solid var(--accent) !important;
	background: transparent !important;
}

.sm-espelho .sm-espelho-detalhes-status.is-reservado {
	color: var(--ink) !important;
	background: var(--paper-deep) !important;
	border: 1px solid var(--rule) !important;
}

.sm-espelho .sm-espelho-detalhes-status.is-vendido {
	color: var(--paper) !important;
	background: var(--ink) !important;
	border: 1px solid var(--ink) !important;
}

.sm-espelho .sm-espelho-detalhes-cta {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px !important;
	background: transparent !important;
	color: var(--ink) !important;
	padding: 12px 0 !important;
	border: 0 !important;
	border-top: 1px solid var(--ink) !important;
	border-bottom: 1px solid var(--ink) !important;
	border-radius: 0 !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 2.5px !important;
	text-transform: uppercase !important;
	text-decoration: none !important;
	transition: color 0.15s ease, border-color 0.15s ease, gap 0.15s ease !important;
	width: 100% !important;
	justify-content: space-between !important;
	box-shadow: none !important;
}

.sm-espelho .sm-espelho-detalhes-cta:hover {
	color: var(--accent) !important;
	border-color: var(--accent) !important;
	gap: 16px !important;
}

.sm-espelho .sm-espelho-detalhes-cta.disabled {
	color: var(--mute) !important;
	border-color: var(--rule) !important;
	pointer-events: none !important;
}

.sm-espelho .sm-espelho-detalhes-cta-arrow {
	font-weight: 400 !important;
	font-size: 16px !important;
	letter-spacing: 0 !important;
}

.sm-espelho .sm-espelho-detalhes-obs {
	margin-top: 22px !important;
	padding-top: 18px !important;
	border-top: 1px dotted var(--rule) !important;
	color: var(--ink-soft) !important;
	font-size: 12px !important;
	line-height: 1.65 !important;
}

/* ────────── Plantas (botões no painel de detalhes) ────────── */
.sm-espelho .sm-espelho-plantas {
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
	margin: 18px 0 4px !important;
}

.sm-espelho .sm-espelho-planta-btn {
	width: 100% !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	padding: 12px 14px !important;
	background: transparent !important;
	color: var(--ink) !important;
	border: 1px solid var(--rule) !important;
	font-family: inherit !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 1.5px !important;
	text-transform: uppercase !important;
	cursor: pointer !important;
	transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease !important;
}

.sm-espelho .sm-espelho-planta-btn:hover {
	color: var(--accent) !important;
	border-color: var(--accent) !important;
	background: var(--paper-deep) !important;
}

.sm-espelho .sm-espelho-planta-btn-icon {
	font-size: 14px !important;
	line-height: 1 !important;
	color: var(--mute) !important;
}

.sm-espelho .sm-espelho-planta-btn:hover .sm-espelho-planta-btn-icon {
	color: var(--accent) !important;
}

/* ────────── Lightbox (planta baixa / humanizada) ────────── */
.sm-lightbox {
	position: fixed !important;
	inset: 0 !important;
	background: rgba(28, 25, 22, 0.92) !important;
	z-index: 99999 !important;
	display: flex !important;
	flex-direction: column !important;
	animation: sm-lightbox-fade 0.18s ease-out !important;
}

@keyframes sm-lightbox-fade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.sm-lightbox-bar {
	flex: 0 0 auto !important;
	display: flex !important;
	align-items: center !important;
	gap: 16px !important;
	padding: 14px 22px !important;
	background: rgba(0, 0, 0, 0.5) !important;
	color: #fff !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.sm-lightbox-label {
	flex: 1 !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 2px !important;
	text-transform: uppercase !important;
}

.sm-lightbox-open {
	color: rgba(255, 255, 255, 0.7) !important;
	text-decoration: none !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: 1.5px !important;
	text-transform: uppercase !important;
	border-bottom: 1px solid transparent !important;
	transition: color 0.15s ease, border-color 0.15s ease !important;
}

.sm-lightbox-open:hover {
	color: #fff !important;
	border-bottom-color: rgba(255, 255, 255, 0.5) !important;
}

.sm-lightbox-close {
	background: transparent !important;
	border: 0 !important;
	color: #fff !important;
	font-size: 28px !important;
	line-height: 1 !important;
	padding: 0 6px !important;
	cursor: pointer !important;
	transition: opacity 0.15s ease !important;
}

.sm-lightbox-close:hover { opacity: 0.7 !important; }

.sm-lightbox-stage {
	flex: 1 1 auto !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 24px !important;
	overflow: auto !important;
}

.sm-lightbox-img {
	max-width: 100% !important;
	max-height: 100% !important;
	width: auto !important;
	height: auto !important;
	display: block !important;
	background: #fff !important;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5) !important;
}

.sm-lightbox-frame {
	width: 100% !important;
	height: 100% !important;
	border: 0 !important;
	background: #fff !important;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5) !important;
}

/* ────────── Mobile: lightbox e grid público ────────── */
@media (max-width: 700px) {
	.sm-public-grid { gap: 20px !important; margin: 20px 0 !important; }
	.sm-public-grid .sm-public-body { padding: 18px 18px 20px !important; }
	.sm-public-grid .sm-public-title { font-size: 1.2rem !important; }

	.sm-lightbox-bar {
		flex-wrap: wrap !important;
		padding: 10px 14px !important;
		gap: 10px !important;
	}
	.sm-lightbox-label {
		flex: 1 1 100% !important;
		order: 1 !important;
		font-size: 11px !important;
		letter-spacing: 1.5px !important;
	}
	.sm-lightbox-open {
		order: 2 !important;
		font-size: 10px !important;
		letter-spacing: 1px !important;
	}
	.sm-lightbox-close {
		order: 3 !important;
		margin-left: auto !important;
	}
	.sm-lightbox-stage { padding: 12px !important; }
}

/* ────────── Mobile: bottom-sheet de detalhes da unidade ────────── */
@media (max-width: 900px) {
	.sm-espelho .sm-espelho-body > .sm-espelho-detalhes {
		display: none !important;
	}
}

.sm-detalhes-sheet {
	position: fixed !important;
	inset: 0 !important;
	z-index: 9999 !important;
	display: flex !important;
	align-items: flex-end !important;
	justify-content: center !important;
}

.sm-detalhes-sheet-backdrop {
	position: absolute !important;
	inset: 0 !important;
	background: rgba(28, 25, 22, 0.55) !important;
	animation: sm-sheet-fade 0.18s ease-out !important;
}

.sm-detalhes-sheet-card {
	position: relative !important;
	background: #ffffff !important;
	width: 100% !important;
	max-width: 560px !important;
	max-height: 90vh !important;
	overflow-y: auto !important;
	-webkit-overflow-scrolling: touch !important;
	box-shadow: 0 -12px 40px rgba(28, 25, 22, 0.25) !important;
	border-top-left-radius: 16px !important;
	border-top-right-radius: 16px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	animation: sm-sheet-up 0.22s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.sm-detalhes-sheet.is-closing .sm-detalhes-sheet-card {
	animation: sm-sheet-down 0.18s ease-in forwards !important;
}

.sm-detalhes-sheet.is-closing .sm-detalhes-sheet-backdrop {
	animation: sm-sheet-fade-out 0.18s ease-in forwards !important;
}

@keyframes sm-sheet-fade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes sm-sheet-fade-out {
	from { opacity: 1; }
	to   { opacity: 0; }
}

@keyframes sm-sheet-up {
	from { transform: translateY(100%); }
	to   { transform: translateY(0); }
}

@keyframes sm-sheet-down {
	from { transform: translateY(0); }
	to   { transform: translateY(100%); }
}

.sm-detalhes-sheet-handle {
	position: sticky !important;
	top: 0 !important;
	display: block !important;
	width: 44px !important;
	height: 4px !important;
	background: #d7d1c4 !important;
	border-radius: 2px !important;
	margin: 10px auto 0 !important;
	z-index: 2 !important;
}

.sm-detalhes-sheet-close {
	position: absolute !important;
	top: 8px !important;
	right: 12px !important;
	background: transparent !important;
	border: 0 !important;
	font-size: 28px !important;
	line-height: 1 !important;
	color: #8a847b !important;
	padding: 6px 10px !important;
	cursor: pointer !important;
	z-index: 3 !important;
}

.sm-detalhes-sheet-close:hover { color: #1c1916 !important; }

@media (min-width: 901px) {
	/* Desktop também usa? Não — só mobile. Mas se a tela for redimensionada com o sheet aberto, fica utilizável */
	.sm-detalhes-sheet { align-items: center !important; }
	.sm-detalhes-sheet-card { max-width: 520px !important; max-height: 85vh !important; border-radius: 0 !important; margin: 24px !important; }
	.sm-detalhes-sheet-handle { display: none !important; }
}

/* ────────── Modal: formulário WhatsApp (lead capture) ────────── */
.sm-wa-modal {
	position: fixed !important;
	inset: 0 !important;
	z-index: 99999 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 24px !important;
}

.sm-wa-modal-backdrop {
	position: absolute !important;
	inset: 0 !important;
	background: rgba(28, 25, 22, 0.6) !important;
	animation: sm-sheet-fade 0.18s ease-out !important;
}

.sm-wa-modal-card {
	position: relative !important;
	background: #ffffff !important;
	width: 100% !important;
	max-width: 460px !important;
	max-height: 90vh !important;
	overflow-y: auto !important;
	box-shadow: 0 24px 60px rgba(28, 25, 22, 0.3) !important;
	border: 1px solid #d7d1c4 !important;
	border-radius: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	animation: sm-wa-pop 0.18s ease-out !important;
}

@keyframes sm-wa-pop {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}

.sm-wa-modal-close {
	position: absolute !important;
	top: 8px !important;
	right: 12px !important;
	background: transparent !important;
	border: 0 !important;
	font-size: 26px !important;
	line-height: 1 !important;
	color: #8a847b !important;
	padding: 6px 10px !important;
	cursor: pointer !important;
	z-index: 3 !important;
}

.sm-wa-modal-close:hover { color: #1c1916 !important; }

.sm-wa-modal-body {
	padding: 36px 32px 32px !important;
}

.sm-wa-modal-eyebrow {
	margin: 0 0 8px !important;
	color: var(--accent) !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 3px !important;
	text-transform: uppercase !important;
	line-height: 1 !important;
}

.sm-wa-modal-title {
	margin: 0 0 6px !important;
	font-size: 22px !important;
	font-weight: 600 !important;
	letter-spacing: -0.4px !important;
	color: var(--ink) !important;
	line-height: 1.2 !important;
}

.sm-wa-modal-subtitle {
	margin: 0 0 28px !important;
	color: var(--mute) !important;
	font-size: 13px !important;
	line-height: 1.55 !important;
}

.sm-wa-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 18px !important;
}

.sm-wa-field {
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
}

.sm-wa-field > span {
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 1.8px !important;
	text-transform: uppercase !important;
	color: var(--mute) !important;
}

.sm-wa-field input {
	background: #ffffff !important;
	border: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	padding: 12px 14px !important;
	font-family: inherit !important;
	font-size: 14px !important;
	color: var(--ink) !important;
	width: 100% !important;
	transition: border-color 0.15s ease !important;
	box-shadow: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-sizing: border-box !important;
}

.sm-wa-field input:focus {
	outline: 0 !important;
	border-color: var(--ink) !important;
}

.sm-wa-error {
	margin: 0 !important;
	padding: 10px 12px !important;
	background: rgba(160, 64, 48, 0.05) !important;
	border: 1px solid rgba(160, 64, 48, 0.3) !important;
	color: #a04030 !important;
	font-size: 12px !important;
}

.sm-espelho .sm-wa-submit,
.sm-espelho .sm-wa-submit:hover,
.sm-espelho .sm-wa-submit:focus,
.sm-espelho .sm-wa-submit:active,
.sm-espelho .sm-wa-submit:focus-visible,
.sm-wa-modal .sm-wa-submit,
.sm-wa-modal .sm-wa-submit:hover,
.sm-wa-modal .sm-wa-submit:focus,
.sm-wa-modal .sm-wa-submit:active,
.sm-wa-modal .sm-wa-submit:focus-visible {
	margin-top: 4px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	width: 100% !important;
	background: #197531 !important;
	background-color: #197531 !important;
	color: #ffffff !important;
	border: 0 !important;
	outline: 0 !important;
	padding: 14px 22px !important;
	font-family: inherit !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	letter-spacing: 0.2px !important;
	text-transform: none !important;
	cursor: pointer !important;
	transition: none !important;
	border-radius: 4px !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-shadow: none !important;
	transform: none !important;
	text-decoration: none !important;
}

.sm-espelho .sm-wa-submit-icon,
.sm-wa-modal .sm-wa-submit-icon {
	color: #ffffff !important;
	fill: currentColor !important;
}

.sm-espelho .sm-wa-submit:disabled,
.sm-wa-modal .sm-wa-submit:disabled {
	opacity: 0.65 !important;
	cursor: wait !important;
	background: #6a8a73 !important;
	background-color: #6a8a73 !important;
}

.sm-wa-submit-icon {
	display: inline-block !important;
	flex: 0 0 auto !important;
	color: inherit !important;
	width: 18px !important;
	height: 18px !important;
}

@media (max-width: 600px) {
	.sm-wa-modal { align-items: flex-end !important; padding: 0 !important; }
	.sm-wa-modal-card {
		max-width: 100% !important;
		max-height: 92vh !important;
		border-top-left-radius: 16px !important;
		border-top-right-radius: 16px !important;
		animation: sm-sheet-up 0.22s cubic-bezier(0.16, 1, 0.3, 1) !important;
	}
	.sm-wa-modal-body { padding: 28px 22px 24px !important; }
}
