/* ==========================================================================
   Variant B — Modern Coastal
   Styles for the split-screen hero, stats bar, horizontal-scroll
   listings, alternating sections, and testimonials context override.
   All colour / font tokens reference --arr-* variables from global.css.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Hero B — Split-Screen
   -------------------------------------------------------------------------- */

.arr-hero-b {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 85vh;
}

.arr-hero-b__image-col {
	position: relative;
	overflow: hidden;
}

.arr-hero-b__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.arr-hero-b__content-col {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--arr-cream, #F6F3EE);
	padding: 4rem 3rem;
}

.arr-hero-b__content {
	max-width: 520px;
}

.arr-hero-b__heading {
	font-family: var(--arr-font-heading, 'Playfair Display', serif);
	font-size: clamp(2.25rem, 4vw, 3.5rem);
	color: var(--arr-dark, #3F3A35);
	line-height: 1.15;
	margin: 0 0 1.25rem;
}

.arr-hero-b__subheading {
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 1.125rem;
	color: var(--arr-dark, #3F3A35);
	opacity: 0.8;
	line-height: 1.6;
	margin: 0 0 2rem;
}

.arr-hero-b__cta.arr-btn {
	display: inline-block;
	padding: 0.9rem 2.25rem;
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--arr-cream, #F6F3EE);
	background-color: var(--arr-dark, #3F3A35);
	border: none;
	border-radius: 2px;
	text-decoration: none;
	transition: background-color 0.3s ease, transform 0.3s ease;
}

.arr-hero-b__cta.arr-btn:hover {
	background-color: var(--arr-deep-green, #4F5F52);
	transform: translateY(-1px);
}

/* --------------------------------------------------------------------------
   2. Stats Bar
   -------------------------------------------------------------------------- */

.arr-stats-bar {
	background-color: var(--arr-sage, #A8B59F);
	padding: 3rem 2rem;
}

.arr-stats-bar__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2.5rem;
	max-width: 1200px;
	margin: 0 auto;
	flex-wrap: wrap;
}

.arr-stats-bar__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	color: #fff;
}

.arr-stats-bar__number {
	font-family: var(--arr-font-heading, 'Playfair Display', serif);
	font-size: clamp(2.25rem, 4vw, 3.5rem);
	font-weight: 700;
	line-height: 1.1;
	margin-bottom: 0.35rem;
}

.arr-stats-bar__label {
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	opacity: 0.9;
}

.arr-stats-bar__divider {
	width: 1px;
	height: 3rem;
	background-color: rgba(255, 255, 255, 0.35);
	flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   3. Featured Listings — Horizontal Scroll
   -------------------------------------------------------------------------- */

.arr-listings-scroll {
	padding: 5rem 2rem;
	background-color: var(--arr-cream, #F6F3EE);
	overflow: hidden;
}

.arr-listings-scroll__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1400px;
	margin: 0 auto 2rem;
}

.arr-listings-scroll__heading {
	font-family: var(--arr-font-heading, 'Playfair Display', serif);
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	color: var(--arr-dark, #3F3A35);
	margin: 0;
}

.arr-listings-scroll__nav {
	display: flex;
	gap: 0.75rem;
}

.arr-listings-scroll__prev,
.arr-listings-scroll__next {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border: 1px solid var(--arr-tan, #CBB79E);
	border-radius: 50%;
	background: transparent;
	color: var(--arr-dark, #3F3A35);
	cursor: pointer;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.arr-listings-scroll__prev:hover,
.arr-listings-scroll__next:hover {
	background-color: var(--arr-dark, #3F3A35);
	color: var(--arr-cream, #F6F3EE);
	border-color: var(--arr-dark, #3F3A35);
}

.arr-listings-scroll__track {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	padding-bottom: 1rem;
	max-width: 1400px;
	margin: 0 auto;

	/* Hide scrollbar across browsers */
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.arr-listings-scroll__track::-webkit-scrollbar {
	display: none;
}

.arr-listings-scroll__track > * {
	min-width: 340px;
	max-width: 380px;
	flex-shrink: 0;
	scroll-snap-align: start;
}

/* --------------------------------------------------------------------------
   4. Alternating Sections
   -------------------------------------------------------------------------- */

.arr-alternating {
	padding: 5rem 2rem;
	max-width: 1400px;
	margin: 0 auto;
}

.arr-alternating__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	align-items: center;
	margin-bottom: 5rem;
}

.arr-alternating__row:last-child {
	margin-bottom: 0;
}

.arr-alternating__row--reversed .arr-alternating__image-col {
	order: 2;
}

.arr-alternating__row--reversed .arr-alternating__text-col {
	order: 1;
}

.arr-alternating__image-col {
	overflow: hidden;
	border-radius: 4px;
}

.arr-alternating__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 4px;
	aspect-ratio: 4 / 3;
}

.arr-alternating__text-col {
	padding: 2rem 1rem;
}

.arr-alternating__heading {
	font-family: var(--arr-font-heading, 'Playfair Display', serif);
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	color: var(--arr-dark, #3F3A35);
	line-height: 1.2;
	margin: 0 0 1rem;
}

.arr-alternating__text {
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 1rem;
	color: var(--arr-dark, #3F3A35);
	opacity: 0.8;
	line-height: 1.7;
	margin-bottom: 1.75rem;
}

.arr-alternating__cta.arr-btn {
	display: inline-block;
	padding: 0.8rem 2rem;
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--arr-cream, #F6F3EE);
	background-color: var(--arr-dark, #3F3A35);
	border-radius: 2px;
	text-decoration: none;
	transition: background-color 0.3s ease, transform 0.3s ease;
}

.arr-alternating__cta.arr-btn:hover {
	background-color: var(--arr-deep-green, #4F5F52);
	transform: translateY(-1px);
}

/* --------------------------------------------------------------------------
   5. Testimonials — Variant B Override
   -------------------------------------------------------------------------- */

.variant-b .arr-testimonials {
	background-color: var(--arr-dark, #3F3A35);
	color: var(--arr-cream, #F6F3EE);
	padding: 5rem 2rem;
}

.arr-variant-b .arr-testimonials__grid {
    display: grid;
    gap: 2rem;
}

.variant-b .arr-testimonials__heading {
	color: var(--arr-gold, #D8C8A8);
}

.variant-b .arr-testimonials__card {
	background-color: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 4px;
	padding: 2.5rem;
	text-align: center;
}

.variant-b .arr-testimonials__quote {
	font-family: var(--arr-font-heading, 'Playfair Display', serif);
	font-size: 1.15rem;
	font-style: italic;
	line-height: 1.7;
	color: var(--arr-cream, #F6F3EE);
	margin-bottom: 1.25rem;
}

.variant-b .arr-testimonials__author {
	font-family: var(--arr-font-body, 'Montserrat', sans-serif);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--arr-gold, #D8C8A8);
}

/* Slider-like single-card display for variant-b */
.variant-b .arr-testimonials__track {
	display: flex;
	overflow: hidden;
	scroll-snap-type: x mandatory;
}

.variant-b .arr-testimonials__card {
	flex: 0 0 100%;
	scroll-snap-align: center;
}

/* --------------------------------------------------------------------------
   6. Animations — Fade Up
   -------------------------------------------------------------------------- */

.arr-animate {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.arr-animate.arr-animate--visible {
	opacity: 1;
	transform: translateY(0);
}

/* --------------------------------------------------------------------------
   7. Responsive
   -------------------------------------------------------------------------- */

@media (max-width: 768px) {

	/* Hero stacks vertically */
	.arr-hero-b {
		grid-template-columns: 1fr;
		min-height: auto;
	}

	.arr-hero-b__image-col {
		min-height: 50vh;
	}

	.arr-hero-b__content-col {
		padding: 3rem 1.5rem;
	}

	/* Stats bar wraps */
	.arr-stats-bar__inner {
		gap: 1.5rem;
	}

	.arr-stats-bar__divider {
		display: none;
	}

	.arr-stats-bar__item {
		flex: 1 1 40%;
	}

	/* Listings scroll */
	.arr-listings-scroll {
		padding: 3rem 1rem;
	}

	.arr-listings-scroll__header {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}

	.arr-listings-scroll__track > * {
		min-width: 280px;
	}

	/* Alternating sections stack */
	.arr-alternating {
		padding: 3rem 1rem;
	}

	.arr-alternating__row {
		grid-template-columns: 1fr;
		gap: 1.5rem;
		margin-bottom: 3rem;
	}

	.arr-alternating__row--reversed .arr-alternating__image-col,
	.arr-alternating__row--reversed .arr-alternating__text-col {
		order: unset;
	}

	.arr-alternating__text-col {
		padding: 0;
	}

	/* Testimonials */
	.variant-b .arr-testimonials {
		padding: 3rem 1rem;
	}
}
