/* -------------------
 * Dynamics 365 contact form — make responsive on mobile
 *
 * The form's FormLoader.bundle.js injects inline style="width:600px" on
 * .onFormSubmittedFeedback. Inline styles can only be overridden with
 * !important — this is narrowly scoped to the form widget.
 * ------------------- */

[data-form-id],
[data-form-id] > div,
[data-form-id] .onFormSubmittedFeedback,
[data-form-id] .onFormSubmittedFeedbackInternalContainer,
[data-form-id] .onFormSubmittedFeedbackMessage,
[data-form-id] .dialogProviderLinkContainer,
[data-form-id] .enableFormHosting {
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box;
}
[data-form-id] {
	overflow-x: hidden;
}


/* "Explore the community" iframe — its inline aspect-ratio (1200/650 widescreen)
   makes it shrink to ~165px tall on mobile. Force a min-height on small screens. */
@media (max-width: 740px) {
	#community iframe {
		min-height: 600px;
	}
}


/* Back-to-top button — UiCore's icon font content is empty, so we draw our own
   up-arrow via a CSS chevron pseudo-element. Also restyles to Brightmore brand. */
#uicore-back-to-top {
	background: var(--bm-primary) !important;
	width: 48px !important;
	height: 48px !important;
	border-radius: 50% !important;
	box-shadow: 0 2px 8px rgba(5, 38, 60, .2) !important;
	transition: background .15s ease, transform .15s ease !important;
}
#uicore-back-to-top:hover {
	background: var(--bm-primary-dk) !important;
	transform: translateY(-2px);
}
#uicore-back-to-top::before {
	content: "" !important;
	display: block !important;
	width: 12px;
	height: 12px;
	margin: 18px auto 0;
	border-top: 2px solid var(--bm-white);
	border-right: 2px solid var(--bm-white);
	transform: rotate(-45deg);
	font-family: inherit !important;
}


/*
 * Brightmore BDX Listings — ported from Tradition's app.scss
 * Colors mapped from Tradition palette to Brightmore Elementor kit:
 *   teal       #42B3AB -> primary  #4BBBDE
 *   dark-blue  #11385C -> headline #05263C
 *   yellow     #E3B424 -> accent   #F5D54E
 *   medium-blue#196D94 -> secondary#7BC7EF
 *   light-blue #E6F1F9 -> light-neutral #F5F9FC
 *   light-gray #F3F7FA -> light-neutral #F3F7FA
 *   dark-text  #242424 -> #242424
 * Font: Lato -> Inter (already loaded by Vault/Elementor kit)
 */

:root {
	--bm-primary:    #4BBBDE;
	--bm-primary-dk: #2A9DC1;
	--bm-headline:   #05263C;
	--bm-accent:     #F5D54E;
	--bm-secondary:  #7BC7EF;
	--bm-light:      #F5F9FC;
	--bm-light-gray: #F3F7FA;
	--bm-text:       #242424;
	--bm-white:      #FFFFFF;

	--bm-breakpoint-medium: 740px;
	--bm-breakpoint-large:  1160px;
}


/* -------------------
 * Layout primitives
 * ------------------- */

.flexgrid .flexrow {
	max-width: var(--bm-breakpoint-large);
	margin: 0 auto;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-around;
}
.flexgrid .flexrow.vertical-center { align-items: center; }
.flexgrid .flexrow .flexitem        { flex: 1; }

.flexgrid .flexrow.threeAcross {
	gap: 40px;
	justify-content: flex-start;
}
.flexgrid .flexrow.threeAcross .flexitem {
	flex-basis: 30%;
	flex-grow: 1;
}
@media (max-width: 740px) {
	.flexgrid .flexrow.threeAcross .flexitem { flex-basis: 100%; }
}


/* -------------------
 * Listing Card
 * ------------------- */

.listingCard {
	position: relative;       /* anchors the whole-card-clickable pseudo-element */
	background: var(--bm-white);
	width: 100%;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	color: var(--bm-text);
	overflow: hidden;
	transition: transform .2s ease, box-shadow .2s ease;
	box-shadow: 0 2px 12px rgba(5, 38, 60, .08);
}
.listingCard:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(5, 38, 60, .14);
}
@media (min-width: 740px) {
	.listingCard { width: 350px !important; }
}

.listingCard p { margin: 0; }

.listingCard .listingImage {
	padding-bottom: 67%;
	background: center no-repeat;
	background-size: cover;
}

.listingCard .qmihBanner {
	padding: 8px 20px;
	background: var(--bm-accent);
	font-size: 11px;
	letter-spacing: 1px;
	text-transform: uppercase;
	text-align: center;
}
.listingCard .qmihBanner p,
.listingCard .qmihBanner .moveInDate {
	color: #09232E;
}
.listingCard .qmihBanner p { font-weight: 600; }
.listingCard .qmihBanner .moveInDate { font-weight: 700; }

.listingCard .topSpacer    { display: block; height: 10px; }
.listingCard .bottomSpacer { display: block; height: 32px; }

.listingCard .details { padding: 8px 30px 30px; }

.listingCard .details .planType {
	margin: 10px 0;
	color: var(--bm-primary);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1px;
	text-transform: uppercase;
}
.listingCard .details .name,
.listingCard .details .price { color: var(--bm-headline); }

.listingCard .details .name {
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
}
.listingCard .details .price {
	margin: 10px 0;
	font-weight: 700;
	font-size: 21px;
	letter-spacing: -0.5px;
}
.listingCard .details .statsLine,
.listingCard .details .sqft {
	color: var(--bm-text);
	font-size: 15px;
	line-height: 1.6;
}

.listingCard .detailLink {
	background: var(--bm-primary);
	position: relative;
}
.listingCard .detailLink a {
	display: block;
	padding: 14px 0;
	color: var(--bm-white);
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 1px;
}
.listingCard .detailLink:hover { background: var(--bm-primary-dk); }

/* Whole-card-clickable: one focusable link, click anywhere on card */
.listingCard .detailLink a::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
}


/* -------------------
 * Cards container
 * ------------------- */

.filterableItemContainer {
	padding: 20px 0 40px;
}
.filterableItemContainer .resultsMessage,
.filterableItemContainer .noResultsMessage {
	width: 100%;
	text-align: center;
	color: var(--bm-text);
	margin: 16px 0;
}
.filterableItemContainer .noResultsMessage { display: none; }
.filterableItemContainer .noResultsMessage a {
	cursor: pointer;
	color: var(--bm-headline);
	text-decoration: underline;
}
.filterableItemContainer .listingCards {
	gap: 40px;
}
.filterableItemContainer .placeholder { visibility: hidden; pointer-events: none; }

/* JS-driven hide for filtered-out cards */
.filterableItem.hidden { display: none !important; }


/* -------------------
 * Filter bar
 * ------------------- */

#listingFilterBar {
	max-width: var(--bm-breakpoint-large);
	margin: 30px auto 20px;
	font-family: 'Inter', sans-serif;
	overflow: visible;
}

/* Top row: listing type radio + sort dropdown */
#listingFilterBar .topBar {
	gap: 12px;
}

#listingFilterBar .listingTypeSelector {
	flex-basis: auto;
	border: 1px solid var(--bm-primary);
}
@media (max-width: 740px) {
	#listingFilterBar .listingTypeSelector { flex-basis: 100%; }
}
#listingFilterBar .listingTypeSelector .selectionItem {
	flex: 1;
	padding: 8px 30px;
	background: var(--bm-white);
	color: var(--bm-primary);
	cursor: pointer;
	text-align: center;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}
@media (max-width: 740px) {
	#listingFilterBar .listingTypeSelector .selectionItem { flex: auto; padding: 8px 15px; }
}
#listingFilterBar .listingTypeSelector .selectionItem:not(:last-child) {
	border-right: 1px solid var(--bm-primary);
}
#listingFilterBar .listingTypeSelector .selectionItem.selected {
	background: var(--bm-primary);
	color: var(--bm-white);
}

#listingFilterBar .topRightItems {
	padding: 0;
	font-size: 14px;
	color: var(--bm-text);
	text-align: right;
}
@media (max-width: 740px) {
	#listingFilterBar .topRightItems { padding: 14px 0; text-align: center; }
}
#listingFilterBar .topRightItems a { cursor: pointer; }
#listingFilterBar .topRightItems .separator { margin: 0 12px; color: rgba(36,36,36,.3); }
#listingFilterBar .topRightItems .clearFiltersButton { color: var(--bm-headline); }
#listingFilterBar .topRightItems .sortButton {
	text-decoration: underline;
	text-underline-offset: 3px;
	color: var(--bm-headline);
	margin-left: 8px;
}
#listingFilterBar .topRightItems .sortButton::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: 6px;
	vertical-align: middle;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid var(--bm-headline);
}
#listingFilterBar .topRightItems .dropdownContainer .dropdownContent {
	top: 130%;
	left: auto;
	right: 0;
	width: auto;
}

/* Main bar: price slider + dropdowns */
#listingFilterBar .mainBar {
	gap: 2px;
}
#listingFilterBar .mainBar .mainBarItem {
	padding: 20px 24px;
	background: var(--bm-headline);
	color: var(--bm-white);
	font-size: 14px;
}
@media (min-width: 740px) {
	#listingFilterBar .mainBar .mainBarItem { margin-top: 15px; }
}

#listingFilterBar .mainBar .priceSelector {
	display: flex;
	flex-basis: auto;
	justify-content: space-around;
	align-items: center;
}
@media (max-width: 740px) {
	#listingFilterBar .mainBar .priceSelector {
		flex: 100% 2;
		order: 3;
		padding: 20px 15px;
		background: var(--bm-light);
		color: var(--bm-headline);
	}
}
#listingFilterBar .priceSelector .label { flex: none; }
#listingFilterBar .priceSelector .doubleSlider {
	flex: 1;
	position: relative;
	margin: 0 16px;
	padding: 7px;
	min-width: 120px;
}
#listingFilterBar .priceSelector .doubleSlider .track {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	margin-top: -1px;
	height: 2px;
	background: rgba(245, 213, 78, 0.3);
	border-radius: 1px;
}
#listingFilterBar .priceSelector .doubleSlider .trackActive {
	position: absolute;
	top: 50%;
	margin-top: -1px;
	height: 2px;
	background: var(--bm-accent);
	border-radius: 1px;
	pointer-events: none;
}
#listingFilterBar .priceSelector .doubleSlider .slideButton { position: relative; z-index: 2; }
#listingFilterBar .priceSelector .doubleSlider .slideButtonContainer {
	position: absolute;
	top: 0;
}
#listingFilterBar .priceSelector .doubleSlider .slideButtonContainer.lower { left: 0; }
#listingFilterBar .priceSelector .doubleSlider .slideButtonContainer.upper { right: 0; }
#listingFilterBar .priceSelector .doubleSlider .slideButton {
	box-sizing: border-box;
	border-radius: 50%;
	width: 18px;
	height: 18px;
	background: var(--bm-white);
	border: 5px solid var(--bm-accent);
	cursor: pointer;
}

/* Dropdowns (Home Type, Beds, Baths, Sort) */
#listingFilterBar .dropdownContainer {
	position: relative;
	text-align: center;
	cursor: pointer;
}
#listingFilterBar .dropdownContainer .toggleLabel {
	display: inline-block;
	position: relative;
	padding-right: 18px;
}
#listingFilterBar .dropdownContainer .toggleLabel::after {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	margin-top: -3px;
	width: 0;
	height: 0;
	border-left: 7px solid transparent;
	border-right: 7px solid transparent;
	border-top: 8px solid var(--bm-accent);
}
#listingFilterBar .dropdownContainer .toggleLabel.blue::after { border-top-color: var(--bm-headline); }

#listingFilterBar .dropdownContainer .dropdownContent {
	display: none;
	position: absolute;
	width: max-content;
	min-width: 100%;
	left: 0;
	top: 100%;
	z-index: 10;
	background: var(--bm-white);
	color: var(--bm-headline);
	border-radius: 2px;
	box-shadow: 0 2px 12px rgba(36, 36, 36, 0.18);
	text-align: left;
	margin-top: 4px;
}
#listingFilterBar .dropdownContainer .dropdownContent.visible { display: block; }
#listingFilterBar .dropdownContainer .dropdownContent .padded   { padding: 12px 18px; }
#listingFilterBar .dropdownContainer .dropdownContent .centered { text-align: center; }
#listingFilterBar .dropdownContainer .dropdownContent .rightAligned { text-align: right; }

#listingFilterBar .mainBarItem .selectionDisplay {
	display: block;
	margin-top: 2px;
	font-size: 11px;
	min-height: 14px;
	opacity: 0.85;
}

/* Radio + Checkbox items (shared selection indicator) */
#listingFilterBar .radioItem,
#listingFilterBar .checkboxItem {
	line-height: 22px;
	cursor: pointer;
	padding: 6px 0;
	display: block;
}
#listingFilterBar .radioItem .selectionIndicator,
#listingFilterBar .checkboxItem .selectionIndicator {
	display: inline-block;
	width: 18px;
	height: 18px;
	margin-right: 10px;
	border-radius: 50%;
	border: 1px solid var(--bm-headline);
	background: var(--bm-light-gray);
	vertical-align: middle;
	line-height: 18px;
	text-align: center;
	font-size: 12px;
	color: transparent;
	transition: background .15s ease, color .15s ease;
}
#listingFilterBar .radioItem.selected .selectionIndicator,
#listingFilterBar .checkboxItem.selected .selectionIndicator {
	background: var(--bm-headline);
	color: var(--bm-white);
}
#listingFilterBar .radioItem.selected .selectionIndicator.checkmark::after,
#listingFilterBar .checkboxItem.selected .selectionIndicator.checkmark::after {
	content: '✓';
	color: var(--bm-white);
	font-size: 13px;
	line-height: 18px;
}
#listingFilterBar .radioItem .label,
#listingFilterBar .checkboxItem .label {
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
	color: var(--bm-headline);
}
#listingFilterBar .radioItem .label.hidden,
#listingFilterBar .checkboxItem .label.hidden { display: none; }

/* "textInsideButton" variant (number tiles for Beds/Baths) */
#listingFilterBar .radioItem.textInsideButton,
#listingFilterBar .checkboxItem.textInsideButton {
	display: inline-block;
	width: 38px;
	height: 38px;
	padding: 0;
	margin: 3px 4px;
	text-align: center;
	border-radius: 4px;
	background: var(--bm-light-gray);
}
#listingFilterBar .radioItem.textInsideButton .selectionIndicator,
#listingFilterBar .checkboxItem.textInsideButton .selectionIndicator {
	width: 100%;
	height: 100%;
	margin: 0;
	border-radius: 4px;
	border: 1px solid var(--bm-headline);
	background: transparent;
	color: var(--bm-headline);
	font-size: 14px;
	font-weight: 600;
	line-height: 36px;
}
#listingFilterBar .radioItem.textInsideButton.selected .selectionIndicator,
#listingFilterBar .checkboxItem.textInsideButton.selected .selectionIndicator {
	background: var(--bm-headline);
	color: var(--bm-white);
}

/* Mobile small-filters collapsible */
#listingFilterBar .smallFilters {
	display: none;
	order: 4;
	flex: 100%;
	padding: 0 15px 30px;
	background: var(--bm-light);
	color: var(--bm-headline);
}
@media (max-width: 740px) {
	#listingFilterBar .smallFilters.visible { display: block; }
}
#listingFilterBar .smallFilters hr {
	margin: 0 0 12px;
	border: 0;
	border-bottom: 1px solid rgba(5, 38, 60, .08);
}
#listingFilterBar .smallFilters .otherFilters {
	padding: 0 10px;
	gap: 18px 30px;
	justify-content: flex-start;
}
#listingFilterBar .smallFilters .otherFilters .flexitem.halfWidth { flex: 40% 1 1; }
#listingFilterBar .smallFilters .otherFilters .flexitem.fullWidth { flex: 80% 0 1; }

.filterField {
	flex: auto;
}
.filterField .fieldLabel {
	padding: 4px 0;
	margin-bottom: 8px;
	border-bottom: 2px solid var(--bm-accent);
	color: var(--bm-headline);
	font-weight: 600;
	font-size: 14px;
}

/* Visibility helpers */
@media (max-width: 740px) {
	#listingFilterBar .notSmall { display: none; }
}
@media (min-width: 740px) {
	#listingFilterBar .smallOnly { display: none; }
}

/* Advanced filters drawer */
#listingFilterBar .advancedFilters {
	flex: 100%;
	border: 1px solid var(--bm-headline);
	border-top: none;
}
#listingFilterBar .advancedFilters.hideFilters .closeButton,
#listingFilterBar .advancedFilters.hideFilters .advancedFilterContent {
	display: none;
}
#listingFilterBar .advancedToggleBar {
	flex: 100%;
	justify-content: space-between;
	padding: 10px 24px;
	background: var(--bm-light);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1px;
	text-transform: uppercase;
	cursor: pointer;
	color: var(--bm-headline);
}
#listingFilterBar .advancedToggleBar .title::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: 10px;
	vertical-align: middle;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 7px solid var(--bm-headline);
	transition: transform .15s ease;
}
/* When drawer is OPEN (hideFilters removed), point the caret up */
#listingFilterBar .advancedFilters:not(.hideFilters) .advancedToggleBar .title::after {
	transform: rotate(180deg);
}
@media (max-width: 740px) {
	#listingFilterBar .advancedToggleBar { display: none; }
}
#listingFilterBar .advancedToggleButton {
	text-align: right;
	padding-right: 8px;
}
#listingFilterBar .advancedToggleButton .advancedToggleLink {
	color: var(--bm-headline);
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 3px;
	font-size: 13px;
}
#listingFilterBar .advancedFilterContent .content {
	padding: 20px 30px 30px;
	gap: 40px;
	justify-content: flex-start;
	color: var(--bm-headline);
}
#listingFilterBar .advancedFilterContent .sqft .dropdownContainer .dropdownToggle {
	padding: 8px 12px;
	border: 1px solid var(--bm-headline);
	font-size: 12px;
	text-transform: uppercase;
	font-weight: 600;
}
#listingFilterBar .advancedFilterContent .sqft .dash {
	flex: none;
	align-self: center;
	padding: 0 6px;
}


/* -------------------
 * Detail page (single-ef_homeplan / single-ef_qmih)
 * ------------------- */

/* Hide Vault/UiCore auto-generated page title banner on listing detail pages */
.single-ef_homeplan .uicore-page-title,
.single-ef_qmih .uicore-page-title,
.single-ef_homeplan .ui-page-title,
.single-ef_qmih .ui-page-title {
	display: none !important;
}

.page-listingDetail {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	color: var(--bm-text);
}

.listingDetailTemplate {
	max-width: var(--bm-breakpoint-large);
	margin: 0 auto;
	padding: 0 20px;
}
.listingDetailTemplate p { margin: 0; }

.listingDetailTemplate section {
	padding: 60px 0;
}
.listingDetailTemplate .sectionTitle,
.listingDetailTemplate h2 {
	color: var(--bm-primary);
	font-size: 45px;
	line-height: 1.15;
	letter-spacing: -0.5px;
	margin-bottom: 28px;
	font-weight: 500;
	text-align: center;
}
@media (max-width: 740px) {
	.listingDetailTemplate .sectionTitle,
	.listingDetailTemplate h2 { font-size: 36px; }
}

/* Vault's parent CSS sets .gallery { display: flex } for WP's gallery shortcode.
   Our <section class="gallery"> collides — undo it so the heading and grid stack normally. */
.listingDetailTemplate section.gallery {
	display: block;
	flex-wrap: initial;
	margin: 0;
}

/* 1. Top section — full-bleed brand-tinted background, content constrained inside */
.listingDetailTemplate section.topSection {
	/* Break out of parent .listingDetailTemplate's max-width via 100vw trick */
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
	margin-top: 0;
	padding: 60px 0;
	background: var(--bm-light);
	border-radius: 0;
}
.listingDetailTemplate .topGrid {
	max-width: var(--bm-breakpoint-large);
	margin: 0 auto;
	padding: 0 20px;
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 740px) {
	.listingDetailTemplate section.topSection { padding: 36px 0; }
	.listingDetailTemplate .topGrid { padding: 0 24px; }
}
@media (max-width: 740px) {
	.listingDetailTemplate .topGrid {
		grid-template-columns: 1fr;
		gap: 28px;
	}
}
.listingDetailTemplate .topImage img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 4px;
	border-bottom: 6px solid var(--bm-accent);
}
.listingDetailTemplate .topInfo .qmihBanner {
	display: inline-block;
	padding: 6px 18px;
	margin-bottom: 16px;
	background: var(--bm-accent);
	font-size: 11px;
	letter-spacing: 1px;
	text-transform: uppercase;
}
.listingDetailTemplate .topInfo .qmihBanner p,
.listingDetailTemplate .topInfo .qmihBanner .moveInDate {
	color: #09232E;
}
.listingDetailTemplate .topInfo .qmihBanner .moveInDate { font-weight: 700; }

.listingDetailTemplate .topInfo .planType {
	margin-bottom: 18px;
	color: var(--bm-primary);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1px;
	text-transform: uppercase;
}
.listingDetailTemplate .topInfo .name {
	margin-bottom: 18px;
	color: var(--bm-headline);
	font-size: 40px;
	line-height: 1.15;
	font-weight: 600;
	letter-spacing: -0.5px;
}
.listingDetailTemplate .topInfo .price {
	margin-bottom: 18px;
	color: var(--bm-headline);
	font-weight: 700;
	font-size: 26px;
	letter-spacing: -0.5px;
}
.listingDetailTemplate .topInfo .statsLine,
.listingDetailTemplate .topInfo .sqft {
	color: var(--bm-text);
	font-size: 16px;
	line-height: 1.8;
}
@media (max-width: 740px) {
	.listingDetailTemplate .topInfo .name { font-size: 30px; }
	.listingDetailTemplate .topInfo .price { font-size: 22px; }
}

/* 2. Home Design Details — heading left, text right (2-col grid) */
.listingDetailTemplate section.description {
	border-top: 1px solid rgba(5, 38, 60, .08);
}
.listingDetailTemplate .descriptionGrid {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 60px;
	align-items: start;
}
@media (max-width: 740px) {
	.listingDetailTemplate .descriptionGrid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
}
.listingDetailTemplate .descriptionTitle h2 {
	margin: 0;
	color: var(--bm-primary);
	font-size: 45px;
	line-height: 1.15;
	font-weight: 500;
	letter-spacing: -1px;
	text-align: left;
}
@media (max-width: 740px) {
	.listingDetailTemplate .descriptionTitle h2 { font-size: 36px; }
}
.listingDetailTemplate .descriptionBody p {
	color: var(--bm-text);
	font-size: 16px;
	line-height: 1.75;
}

/* 3. Gallery — full-bleed horizontal scroll-snap carousel with arrow buttons */
.listingDetailTemplate .galleryCarousel {
	/* Break out of parent .listingDetailTemplate's max-width to span viewport */
	position: relative;
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
}
.listingDetailTemplate .galleryTrack {
	display: flex;
	gap: 16px;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	padding: 0 20px 4px;
}
.listingDetailTemplate .galleryTrack::-webkit-scrollbar { height: 6px; }
.listingDetailTemplate .galleryTrack::-webkit-scrollbar-track { background: rgba(5, 38, 60, .06); border-radius: 3px; }
.listingDetailTemplate .galleryTrack::-webkit-scrollbar-thumb { background: var(--bm-primary); border-radius: 3px; }

.listingDetailTemplate .galleryItem {
	display: block;
	flex: 0 0 calc(25% - 12px);
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 4px;
	background: var(--bm-light-gray);
	scroll-snap-align: start;
}
@media (max-width: 1160px) {
	.listingDetailTemplate .galleryItem { flex: 0 0 calc(33.333% - 11px); }
}
@media (max-width: 740px) {
	.listingDetailTemplate .galleryItem { flex: 0 0 88%; scroll-snap-align: center; }
}
.listingDetailTemplate .galleryItem img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s ease;
}
.listingDetailTemplate .galleryItem:hover img { transform: scale(1.04); }

/* Prev / Next arrow buttons */
.listingDetailTemplate .galleryNav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 0;
	background: var(--bm-primary);
	color: var(--bm-white);
	font-size: 28px;
	line-height: 40px;
	cursor: pointer;
	z-index: 2;
	box-shadow: 0 2px 8px rgba(5, 38, 60, .18);
	transition: background .15s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}
.listingDetailTemplate .galleryNav:hover { background: var(--bm-primary-dk); }
.listingDetailTemplate .galleryNavPrev { left: 16px; }
.listingDetailTemplate .galleryNavNext { right: 16px; }

/* 4. Floorplan embed — taller than 16:9 since floorplans show a top-down layout */
.listingDetailTemplate .floorplanEmbed {
	position: relative;
	width: 100%;
	height: 720px;
	background: var(--bm-light-gray);
	border-radius: 4px;
	overflow: hidden;
}
.listingDetailTemplate .floorplanEmbed iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
@media (max-width: 740px) {
	.listingDetailTemplate .floorplanEmbed { height: 560px; }
}

/* 5. Virtual tour section — full-bleed blue background with dark heading */
.listingDetailTemplate section.virtualTour {
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
	padding: 60px calc(50vw - 50%);
	background: var(--bm-primary);
}
.listingDetailTemplate section.virtualTour h2.sectionTitle {
	color: var(--bm-headline);
}
.listingDetailTemplate .virtualTourEmbed {
	position: relative;
	width: 100%;
	height: 720px;
	background: var(--bm-light-gray);
	border-radius: 4px;
	overflow: hidden;
}
.listingDetailTemplate .virtualTourEmbed iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
@media (max-width: 740px) {
	.listingDetailTemplate section.virtualTour { padding: 36px 20px; }
	.listingDetailTemplate .virtualTourEmbed { height: 560px; }
}

/* 6. More Homes — related listings grid using the homepage card markup */
.listingDetailTemplate section.moreHomes {
	border-top: 1px solid rgba(5, 38, 60, .08);
	padding: 60px 0;
}
.listingDetailTemplate .moreHomesGrid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
@media (max-width: 740px) {
	.listingDetailTemplate .moreHomesGrid {
		grid-template-columns: 1fr;
	}
}
/* Card width override — homepage uses fixed 350px, here we want them to fill the grid cell */
.listingDetailTemplate .moreHomesGrid .listingCard {
	width: 100% !important;
}

/* 7. Back-to-listings button (matches homepage Elementor button) */
.listingDetailTemplate .backToListings {
	text-align: center;
	padding: 40px 0 60px;
}
.listingDetailTemplate .bmButton {
	display: inline-block;
	padding: 18px 36px;
	background: var(--bm-primary);
	color: var(--bm-white);
	text-decoration: none;
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0;
	border: none;
	border-radius: 4px;
	transition: background .15s ease;
}
.listingDetailTemplate .bmButton:hover {
	background: var(--bm-primary-dk);
	color: var(--bm-white);
}

/* 7. Contact section (two-col, mirrors homepage #contact) */
.listingDetailTemplate section.contactSection {
	background: var(--bm-light);
	border-radius: 4px;
	padding: 60px 48px;
	margin: 0 0 40px;
}
.listingDetailTemplate .contactGrid {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 60px;
	align-items: start;
}
@media (max-width: 740px) {
	.listingDetailTemplate section.contactSection { padding: 40px 24px; }
	.listingDetailTemplate .contactGrid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
}

.listingDetailTemplate .contactHeading {
	margin: 0 0 14px;
	color: var(--bm-headline);
	font-size: 36px;
	line-height: 1.15;
	font-weight: 600;
	letter-spacing: -0.5px;
}
.listingDetailTemplate .contactSubtitle {
	color: var(--bm-text);
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 28px;
}

.listingDetailTemplate .contactList {
	list-style: none;
	padding: 0;
	margin: 0;
}
.listingDetailTemplate .contactList li { margin: 0 0 14px; }
.listingDetailTemplate .contactList a {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--bm-headline);
	text-decoration: none;
	font-size: 15px;
	transition: color .15s ease;
}
.listingDetailTemplate .contactList a:hover { color: var(--bm-primary); }
.listingDetailTemplate .contactIcon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--bm-primary);
	color: var(--bm-white);
	border-radius: 50%;
	font-size: 14px;
	flex-shrink: 0;
}

.listingDetailTemplate .contactFormLabel {
	color: var(--bm-headline);
	font-size: 18px;
	font-weight: 600;
	margin: 0 0 16px;
}
.listingDetailTemplate .contactForm {
	width: 100%;
}

/* Footer "Connect with our team" heading: UICore split-text animation's
   Waypoint never fires on normal scroll (stale trigger position from
   layout shifts on a ~11500px-tall page), leaving the widget at opacity:0.
   Force visible. */
.elementor-element-4670a3b9,
.elementor-element-4670a3b9 .char,
.elementor-element-4670a3b9 .word {
	opacity: 1 !important;
}
