/*
 * Areas — template-area.php (individual area pages) and template-areas.php (hub).
 * Enqueued on those templates only.
 * All values use existing design tokens — no new variables.
 */

/*--------------------------------------------------------------
# Shared — prose container for long-form area content
--------------------------------------------------------------*/

.area-prose {
	max-width: var(--prose-max);
	margin-inline: auto;
	padding-inline: var(--space-5);
	font-size: var(--text-lg);
	line-height: 1.7;
	color: var(--ink);
}

.area-prose > * + * {
	margin-top: var(--space-4);
}

.area-prose p {
	margin: 0;
}

.area-prose p + p {
	margin-top: var(--space-4);
}

.area-prose a {
	color: var(--wine);
}

.area-prose a:hover,
.area-prose a:focus {
	color: var(--wine-dark);
}

/*--------------------------------------------------------------
# Hero — full-bleed photo with text overlay
--------------------------------------------------------------*/

.area-hero {
	position: relative;
	overflow: hidden;
	min-height: 480px;
	display: flex;
	align-items: flex-end;
}

.area-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.area-hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 50%;
	display: block;
}

.area-hero__bg .placeholder-image {
	width: 100%;
	height: 100%;
	min-height: 480px;
	border: none;
	border-radius: 0;
}

.area-hero__bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(26, 31, 36, 0.78) 0%,
		rgba(26, 31, 36, 0.35) 55%,
		rgba(26, 31, 36, 0.10) 100%
	);
}

.area-hero__content {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: var(--space-9) var(--space-5) var(--space-7);
	max-width: var(--container-max);
	margin-inline: auto;
}

.area-hero__inner {
	max-width: 720px;
}

.area-hero__eyebrow {
	display: inline-block;
	font-family: 'Inter', sans-serif;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gold);
	margin-bottom: var(--space-3);
}

.area-hero__title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(var(--text-3xl), 6vw, var(--text-4xl));
	font-weight: 700;
	line-height: 1.05;
	color: #fff;
	margin: 0 0 var(--space-3);
}

.area-hero__dek {
	font-family: 'Fraunces', Georgia, serif;
	font-style: italic;
	font-weight: 400;
	font-size: clamp(var(--text-lg), 2.5vw, var(--text-xl));
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.92);
	margin: 0;
	max-width: 640px;
}

/*--------------------------------------------------------------
# Intro body — first prose block under the hero
--------------------------------------------------------------*/

.area-intro {
	background-color: var(--bone);
	padding: var(--space-8) 0;
}

.area-intro .area-prose {
	font-size: var(--text-lg);
}

/* The opening intro paragraphs get a slightly larger first paragraph for emphasis */
.area-intro .area-prose > p:first-child {
	font-size: clamp(var(--text-lg), 1.6vw, 1.25rem);
}

/*--------------------------------------------------------------
# Skeleton note — small notice on in-progress area pages
--------------------------------------------------------------*/

.area-skeleton-note {
	background-color: var(--paper);
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	padding: var(--space-5) 0;
}

.area-skeleton-note .area-prose {
	font-size: var(--text-base);
	color: var(--mute);
	font-style: italic;
}

/*--------------------------------------------------------------
# Lifestyle sections — repeater output
# Each section sits on alternating bone/paper backgrounds
--------------------------------------------------------------*/

.area-sections {
	background-color: var(--paper);
}

.area-section {
	padding: var(--space-8) 0;
	border-bottom: 1px solid var(--rule);
}

.area-section:last-child {
	border-bottom: none;
}

.area-section:nth-child(even) {
	background-color: var(--bone);
}

.area-section__inner {
	max-width: var(--prose-max);
	margin-inline: auto;
	padding-inline: var(--space-5);
}

.area-section__title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(var(--text-xl), 3vw, var(--text-2xl));
	font-weight: 700;
	line-height: 1.2;
	color: var(--ink);
	margin: 0 0 var(--space-5);
}

.area-section__figure {
	margin: 0 0 var(--space-5);
}

.area-section__figure img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 2px;
}

.area-section__body {
	max-width: none;
	margin-inline: 0;
	padding-inline: 0;
}

/*--------------------------------------------------------------
# Market commentary — optional rich text block
--------------------------------------------------------------*/

.area-market {
	background-color: var(--bone);
	padding: var(--space-8) 0;
	border-top: 1px solid var(--rule);
}

.area-market .area-prose .eyebrow {
	margin-bottom: var(--space-2);
}

.area-market .area-prose h2 {
	font-family: 'Fraunces', Georgia, serif;
	font-size: var(--text-2xl);
	font-weight: 700;
	line-height: 1.2;
	color: var(--ink);
	margin: 0 0 var(--space-4);
}

/*--------------------------------------------------------------
# Available properties section
--------------------------------------------------------------*/

.area-properties {
	background-color: var(--paper);
	padding: var(--space-8) 0;
	border-top: 1px solid var(--rule);
}

.area-properties .container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-5);
}

.area-properties .section-footer {
	margin-top: var(--space-6);
	text-align: center;
}

/*--------------------------------------------------------------
# Closing CTA — area-aware, two side-by-side buttons
--------------------------------------------------------------*/

.area-close {
	background-color: var(--wine);
	padding: var(--space-8) var(--space-5);
	text-align: center;
}

.area-close .container {
	max-width: 720px;
	margin-inline: auto;
}

.area-close .eyebrow {
	display: block;
	color: rgba(255, 255, 255, 0.65);
	margin-bottom: var(--space-3);
}

.area-close h2 {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(var(--text-2xl), 3.5vw, var(--text-3xl));
	font-weight: 700;
	line-height: 1.15;
	color: #fff;
	margin: 0 0 var(--space-4);
}

.area-close p {
	font-size: var(--text-lg);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.88);
	margin: 0 auto var(--space-6);
	max-width: 600px;
}

.area-close__actions {
	display: flex;
	gap: var(--space-3);
	justify-content: center;
	flex-wrap: wrap;
}

.area-close .btn--primary {
	background-color: #fff;
	color: var(--wine);
	border-color: #fff;
}

.area-close .btn--primary:hover,
.area-close .btn--primary:focus {
	background-color: var(--bone);
	border-color: var(--bone);
	color: var(--wine-dark);
}

.area-close .btn--outline {
	background-color: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.7);
}

.area-close .btn--outline:visited {
	color: #fff;
}

.area-close .btn--outline:hover,
.area-close .btn--outline:focus {
	background-color: rgba(255, 255, 255, 0.12);
	border-color: #fff;
	color: #fff;
}

/*=================================================================
# AREAS HUB — template-areas.php
=================================================================*/

.areas-header {
	padding: var(--space-9) var(--space-5) var(--space-7);
	text-align: center;
	background-color: var(--bone);
}

.areas-header__inner {
	max-width: var(--prose-max);
	margin-inline: auto;
}

.areas-header .page-eyebrow {
	display: block;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mute);
	margin-bottom: var(--space-3);
}

.areas-title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(var(--text-2xl), 5vw, var(--text-3xl));
	font-weight: 700;
	line-height: 1.1;
	color: var(--ink);
	margin: 0 0 var(--space-3);
}

.areas-dek {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(var(--text-lg), 2.5vw, var(--text-xl));
	font-weight: 400;
	font-style: italic;
	color: var(--mute);
	line-height: 1.4;
	margin: 0 0 var(--space-5);
}

.areas-rule {
	width: 60px;
	height: 2px;
	background-color: var(--gold);
	border: none;
	margin: 0 auto;
}

.areas-grid-section {
	background-color: var(--paper);
	padding: var(--space-8) 0;
}

.areas-grid-section .container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-5);
}

.areas-grid--hub {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-4);
	margin-top: 0;
}

/* Single-card hub layout — centres a single area card and caps its
   width so it doesn't stretch across the three-column slot. */
.areas-grid--single {
	grid-template-columns: minmax(0, 480px);
	justify-content: center;
}

.areas-note {
	max-width: var(--prose-max);
	margin: var(--space-6) auto 0;
	text-align: center;
	font-size: var(--text-base);
	color: var(--mute);
	line-height: 1.6;
}

/*--------------------------------------------------------------
# Area card — mirrors the home page area preview pattern
# Duplicated here because home.css is front-page-only
--------------------------------------------------------------*/

.areas-grid--hub .area-card {
	position: relative;
	text-decoration: none;
	color: var(--ink);
	overflow: hidden;
	aspect-ratio: 4 / 5;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background-color: var(--bone);
	border: 1px solid var(--rule);
}

.areas-grid--hub .area-card--live {
	border: none;
}

.areas-grid--hub .area-card--placeholder {
	background-color: var(--bone);
	opacity: 0.72;
}

.areas-grid--hub .area-card__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.areas-grid--hub .area-card__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.areas-grid--hub .area-card__bg .placeholder-image {
	height: 100%;
	min-height: 0;
}

.areas-grid--hub .area-card__bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(26, 31, 36, 0.72) 0%, transparent 60%);
}

.areas-grid--hub .area-card__label {
	position: relative;
	z-index: 1;
	padding: var(--space-4);
	color: #fff;
}

.areas-grid--hub .area-card--placeholder .area-card__label {
	color: var(--mute);
}

.areas-grid--hub .area-card__tag {
	display: inline-block;
	font-family: 'Inter', sans-serif;
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--gold);
	margin-bottom: var(--space-2);
}

.areas-grid--hub .area-card--placeholder .area-card__tag {
	color: var(--mute);
}

.areas-grid--hub .area-card__name {
	display: block;
	font-family: 'Fraunces', Georgia, serif;
	font-size: var(--text-xl);
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: var(--space-1);
}

.areas-grid--hub .area-card--placeholder .area-card__name {
	color: var(--ink);
}

.areas-grid--hub .area-card__sub {
	display: block;
	font-size: var(--text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0.85;
}

.areas-grid--hub .area-card--live:hover,
.areas-grid--hub .area-card--live:focus {
	text-decoration: none;
}

.areas-grid--hub .area-card--live:hover .area-card__name,
.areas-grid--hub .area-card--live:focus .area-card__name {
	text-decoration: underline;
}

/*--------------------------------------------------------------
# Responsive
--------------------------------------------------------------*/

@media (max-width: 900px) {
	.area-hero {
		min-height: 380px;
	}

	.area-hero__content {
		padding: var(--space-7) var(--space-4);
	}

	.areas-grid--hub {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.area-hero {
		min-height: 340px;
	}

	.area-hero__title {
		font-size: var(--text-3xl);
	}

	.area-hero__dek {
		font-size: var(--text-lg);
	}

	.area-intro,
	.area-market,
	.area-properties {
		padding: var(--space-7) 0;
	}

	.area-section {
		padding: var(--space-7) 0;
	}

	.area-prose {
		padding-inline: var(--space-4);
		font-size: var(--text-base);
	}

	.area-intro .area-prose > p:first-child {
		font-size: var(--text-lg);
	}

	.area-properties .container,
	.areas-grid-section .container {
		padding-inline: var(--space-4);
	}

	.area-close {
		padding: var(--space-7) var(--space-4);
	}

	.area-close__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.area-close__actions .btn {
		justify-content: center;
	}

	.areas-header {
		padding: var(--space-7) var(--space-4) var(--space-6);
	}

	.areas-grid--hub {
		grid-template-columns: 1fr;
	}
}
