/* ============================================================
   Components — paddlemallowsbay.org / mallows-v4
   One file, sections delimited by section-header block comments
   below. (CSS comments do not nest, so do not embed a literal
   star-slash sequence inside another comment.)
   Loaded after base.css and depends on tokens.css.
   ============================================================ */

/* === hero-story === */

.hero-story {
	position: relative;
	height: 80vh;             /* Deterministic — gives the absolutely-positioned media a sized parent. */
	min-height: 540px;        /* Floor for short viewports so the headline still has room. */
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	color: var(--paper);
}
.hero-story__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.hero-story__image,
.hero-story__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hero-story__scrim {
	position: absolute;
	inset: 0;
	background: linear-gradient( to bottom, rgba(43, 33, 24, 0.15) 0%, rgba(43, 33, 24, 0.55) 60%, rgba(43, 33, 24, 0.78) 100% );
}
.hero-story__content {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding: var(--space-16) var(--space-6);
}
.hero-story__headline {
	color: var(--paper);
	font-size: var(--text-5xl);
	max-width: 18ch;
	margin-bottom: var(--space-4);
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}
.hero-story__subhead {
	color: var(--tideflat);
	font-size: var(--text-xl);
	max-width: 50ch;
	margin-bottom: var(--space-8);
	line-height: var(--leading-snug);
}
.hero-story__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}
.hero-story__cta {
	display: inline-block;
	padding: var(--space-3) var(--space-6);
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
	font-size: var(--text-base);
	text-decoration: none;
	border-radius: var(--radius);
	letter-spacing: 0.01em;
	transition: transform 0.15s var(--ease), background 0.15s var(--ease), color 0.15s var(--ease);
}
.hero-story__cta--primary {
	background: var(--oxide);
	color: var(--paper);
}
.hero-story__cta--primary:hover {
	background: #C26133;
	color: var(--paper);
	transform: translateY(-1px);
}
.hero-story__cta--secondary {
	background: transparent;
	color: var(--paper);
	border: 1px solid rgba(244, 240, 230, 0.7);
}
.hero-story__cta--secondary:hover {
	background: var(--paper);
	color: var(--tannin-deep);
}

@media (max-width: 640px) {
	.hero-story { min-height: 70vh; }
	.hero-story__content { padding: var(--space-12) var(--space-4); }
	.hero-story__headline { font-size: var(--text-4xl); }
	.hero-story__subhead { font-size: var(--text-lg); }
}

/* === stats-card === */

.stats-card {
	background: var(--tideflat);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius-lg);
	padding: var(--space-6) var(--space-6);
	margin: var(--space-8) auto;
	max-width: var(--container);
}
.stats-card__label {
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
	font-size: var(--text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tannin);
	margin-bottom: var(--space-4);
}
.stats-card__list {
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax( 160px, 1fr ) );
	gap: var(--space-6) var(--space-8);
	margin: 0;
}
.stats-card__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
}
.stats-card__key {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--tannin);
}
.stats-card__val {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--weight-semibold);
	color: var(--tannin-deep);
	line-height: var(--leading-tight);
	margin: 0;
}

/* === narrative-block === */

.narrative-block {
	max-width: var(--container);
	margin: var(--space-8) auto;
	padding: 0 var(--space-6);
}
.narrative-block__lede {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	line-height: var(--leading-snug);
	color: var(--tannin);
	max-width: var(--measure);
	margin-bottom: var(--space-8);
	text-wrap: balance;
}
.narrative-block__body {
	font-size: var(--text-lg);
	line-height: var(--leading-normal);
	color: var(--color-text);
}
.narrative-block__body > * {
	max-width: var(--measure);
	margin-inline: 0;
}
.narrative-block__body > * + * {
	margin-top: var(--space-4);
}
.narrative-block__body h2,
.narrative-block__body h3 {
	margin-top: var(--space-8);
}
.narrative-block__body img,
.narrative-block__body figure {
	max-width: 100%;
	border-radius: var(--radius);
	margin-block: var(--space-6);
}
.narrative-block__body figure figcaption {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin-top: var(--space-2);
}
.narrative-block__body blockquote {
	border-left: 3px solid var(--oxide);
	padding-left: var(--space-6);
	font-style: italic;
	color: var(--tannin);
	max-width: var(--measure);
}

/* === media-grid === */

.media-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 220px, 1fr ) );
	gap: var(--space-3);
	max-width: var(--container);
	margin: var(--space-8) auto;
	padding: 0 var(--space-6);
}
.media-grid__item {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--tideflat);
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s var(--ease);
}
.media-grid__item:hover { transform: translateY(-2px); }
.media-grid__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.media-grid__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--space-3) var(--space-3);
	background: linear-gradient( to top, rgba(43, 33, 24, 0.85), rgba(43, 33, 24, 0) );
	color: var(--paper);
	font-size: var(--text-sm);
	font-family: var(--font-body);
}

/* Lightbox overlay (built by components.js) */
.mv4-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(43, 33, 24, 0.92);
	z-index: 1000;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: var(--space-6);
	cursor: zoom-out;
}
.mv4-lightbox__img {
	max-width: 100%;
	max-height: 80vh;
	object-fit: contain;
	border-radius: var(--radius);
}
.mv4-lightbox__caption {
	color: var(--paper);
	font-family: var(--font-body);
	font-size: var(--text-base);
	margin-top: var(--space-4);
	max-width: 60ch;
	text-align: center;
}
.mv4-lightbox__close {
	position: absolute;
	top: var(--space-4);
	right: var(--space-6);
	background: transparent;
	border: 0;
	color: var(--paper);
	font-size: var(--text-2xl);
	cursor: pointer;
	padding: var(--space-2);
}
.mv4-lightbox__close:focus-visible { outline: 2px solid var(--oxide); outline-offset: 2px; }

/* === footer-trust === */

.footer-trust {
	max-width: var(--container);
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	color: var(--driftwood);
	font-size: var(--text-sm);
	line-height: var(--leading-normal);
}
.footer-trust__disclaimer {
	max-width: 70ch;
	margin: 0;
}
.footer-trust__operated {
	margin: 0;
}
.footer-trust__operator {
	color: var(--paper);
	font-weight: var(--weight-semibold);
}
.footer-trust__links {
	list-style: none;
	padding: 0;
	margin: var(--space-2) 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2) var(--space-4);
}
.footer-trust__links a {
	color: var(--tideflat);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.15s var(--ease), color 0.15s var(--ease);
}
.footer-trust__links a:hover {
	color: var(--paper);
	border-bottom-color: var(--oxide);
}

/* === conditions-strip === */

.conditions-strip {
	background: var(--tannin-deep);
	color: var(--paper);
	padding: var(--space-4) var(--space-6);
}
.conditions-strip__inner {
	max-width: var(--container);
	margin-inline: auto;
	display: flex;
	gap: var(--space-6);
	align-items: stretch;
	flex-wrap: wrap;
}
.conditions-strip__cells {
	flex: 1 1 auto;
	display: grid;
	grid-template-columns: repeat( auto-fit, minmax( 140px, 1fr ) );
	gap: var(--space-4) var(--space-6);
	align-items: center;
}
.conditions-strip__cell {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	min-width: 0;
}
.conditions-strip__cell--badge {
	align-items: flex-end;
}
.conditions-strip__key {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--driftwood);
}
.conditions-strip__val {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--weight-semibold);
	line-height: var(--leading-tight);
	color: var(--paper);
}
.conditions-strip__sub {
	display: block;
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-normal);
	color: var(--tideflat);
	margin-top: 2px;
}
.conditions-strip__badge {
	display: inline-block;
	padding: var(--space-2) var(--space-4);
	border-radius: 999px;
	font-family: var(--font-body);
	font-weight: var(--weight-bold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-size: var(--text-sm);
}
.conditions-strip__badge--go {
	background: var(--marsh);
	color: var(--paper);
}
.conditions-strip__badge--wait {
	background: #B58A2E;        /* warm amber — visually between marsh and oxide */
	color: var(--paper);
}
.conditions-strip__badge--no-go {
	background: var(--oxide);
	color: var(--paper);
}
.conditions-strip__cam {
	flex: 0 0 auto;
	width: 220px;
	aspect-ratio: 4 / 3;
	position: relative;
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--tannin);
	text-decoration: none;
}
.conditions-strip__cam img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.conditions-strip__cam-label {
	position: absolute;
	left: var(--space-2);
	bottom: var(--space-2);
	padding: 2px var(--space-2);
	background: rgba(43, 33, 24, 0.7);
	color: var(--paper);
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	border-radius: 2px;
}
@media (max-width: 720px) {
	.conditions-strip__cam { width: 100%; }
}

/* === map-embed === */

.map-embed {
	width: 100%;
	max-width: var(--container);
	margin: var(--space-8) auto;
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--tideflat);
}
.map-embed__canvas {
	width: 100%;
	height: 100%;
}
.map-embed .mapboxgl-popup-content {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	padding: var(--space-3) var(--space-4);
	border-radius: var(--radius);
	color: var(--color-text);
}
.map-embed .mapboxgl-popup-content a {
	color: var(--color-link);
	font-weight: var(--weight-semibold);
}

/* === nearby === */

.nearby {
	max-width: var(--container);
	margin: var(--space-12) auto;
	padding: 0 var(--space-6);
}
.nearby__heading {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--color-heading);
	margin-bottom: var(--space-6);
}
.nearby__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 220px, 1fr ) );
	gap: var(--space-4);
}
.nearby__card {
	display: flex;
	flex-direction: column;
	background: var(--paper);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.15s var(--ease), border-color 0.15s var(--ease);
}
.nearby__card:hover {
	transform: translateY(-2px);
	border-color: var(--oxide);
}
.nearby__thumb {
	aspect-ratio: 4 / 3;
	background-color: var(--tideflat);
	background-size: cover;
	background-position: center;
}
.nearby__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	padding: var(--space-3) var(--space-4);
}
.nearby__type {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tannin);
}
.nearby__title {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	color: var(--color-heading);
	line-height: var(--leading-snug);
}
.nearby__dist {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
}

/* === feedback-modal === */

/* Trigger button (inside footer-trust when show_feedback_trigger is true). */
.footer-trust__feedback {
	margin: var(--space-2) 0 0;
}
.footer-trust__feedback-btn {
	background: transparent;
	color: var(--paper);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	padding: var(--space-2) var(--space-4);
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
	font-size: var(--text-sm);
	cursor: pointer;
	transition: border-color 0.15s var(--ease), background 0.15s var(--ease), color 0.15s var(--ease);
}
.footer-trust__feedback-btn:hover {
	background: var(--oxide);
	border-color: var(--oxide);
	color: var(--paper);
}

/* Modal */
.feedback-modal[hidden] { display: none; }
.feedback-modal {
	position: fixed;
	inset: 0;
	z-index: 1100;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
}
.feedback-modal__scrim {
	position: absolute;
	inset: 0;
	background: rgba(43, 33, 24, 0.78);
	cursor: pointer;
}
.feedback-modal__dialog {
	position: relative;
	background: var(--paper);
	color: var(--color-text);
	width: 100%;
	max-width: 560px;
	max-height: 90vh;
	overflow: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	padding: var(--space-6) var(--space-6) var(--space-8);
}
.feedback-modal__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	margin-bottom: var(--space-6);
}
.feedback-modal__title {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--color-heading);
	margin: 0;
}
.feedback-modal__close {
	background: transparent;
	border: 0;
	color: var(--color-text-muted);
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	padding: var(--space-1) var(--space-2);
}
.feedback-modal__close:hover { color: var(--oxide); }

/* Ensure `hidden` always wins over the view containers' display rules. */
.feedback-modal [data-mv4-feedback-view][hidden] { display: none; }

.feedback-modal__choices {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.feedback-modal__choice {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	text-align: left;
	background: var(--tideflat);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	padding: var(--space-4) var(--space-6);
	cursor: pointer;
	transition: border-color 0.15s var(--ease), transform 0.15s var(--ease);
}
.feedback-modal__choice:hover {
	border-color: var(--oxide);
	transform: translateY(-1px);
}
.feedback-modal__choice-title {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: var(--weight-semibold);
	color: var(--color-heading);
}
.feedback-modal__choice-sub {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
}

.feedback-modal__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}
.feedback-modal__field {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}
.feedback-modal__label {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
	color: var(--color-text-muted);
}
.feedback-modal__field input,
.feedback-modal__field select,
.feedback-modal__field textarea {
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-text);
	background: var(--paper);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	padding: var(--space-3) var(--space-4);
	width: 100%;
	box-sizing: border-box;
}
.feedback-modal__field textarea { resize: vertical; }
.feedback-modal__field input:focus,
.feedback-modal__field select:focus,
.feedback-modal__field textarea:focus {
	outline: 2px solid var(--oxide);
	outline-offset: 1px;
	border-color: var(--oxide);
}

.feedback-modal__actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-3);
	margin-top: var(--space-2);
}
.feedback-modal__back {
	background: transparent;
	border: 0;
	color: var(--color-link);
	cursor: pointer;
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--weight-semibold);
}
.feedback-modal__back:hover { color: var(--color-link-hover); }
.feedback-modal__submit {
	background: var(--oxide);
	color: var(--paper);
	border: 0;
	border-radius: var(--radius);
	padding: var(--space-3) var(--space-6);
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
	cursor: pointer;
	transition: background 0.15s var(--ease);
}
.feedback-modal__submit:hover { background: #C26133; }
.feedback-modal__submit:disabled {
	opacity: 0.6;
	cursor: progress;
}

.feedback-modal__status {
	padding: var(--space-6);
	text-align: center;
	font-family: var(--font-body);
}
.feedback-modal__status--ok {
	color: var(--marsh);
}
.feedback-modal__status--err {
	color: var(--oxide);
}

/* === immersive === */

.immersive {
	max-width: var(--container);
	margin: var(--space-12) auto;
	padding: 0 var(--space-6);
}
.immersive__label {
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
	font-size: var(--text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tannin);
	margin-bottom: var(--space-3);
}
.immersive__frame {
	position: relative;
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--tideflat);
	aspect-ratio: 16 / 9;
}
.immersive__frame iframe,
.immersive__frame video,
.immersive__frame embed,
.immersive__frame object {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
.immersive__frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* === resources === */

.resources {
	max-width: var(--container);
	margin: var(--space-12) auto;
	padding: 0 var(--space-6);
}
.resources__heading {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--color-heading);
	margin-bottom: var(--space-4);
}
.resources__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}
.resources__item { margin: 0; }
.resources__link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
	padding: var(--space-3) var(--space-4);
	background: var(--tideflat);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	color: var(--color-text);
	text-decoration: none;
	transition: border-color 0.15s var(--ease), background 0.15s var(--ease);
}
.resources__link:hover {
	border-color: var(--oxide);
	background: var(--paper);
	color: var(--color-link-hover);
}
.resources__label {
	font-family: var(--font-body);
	font-weight: var(--weight-semibold);
}
.resources__arrow {
	color: var(--oxide);
	font-weight: var(--weight-bold);
}

/* === mv4-prevnext (used by single.php) === */

.mv4-prevnext {
	max-width: var(--container);
	margin: var(--space-12) auto;
	padding: 0 var(--space-6);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
}
.mv4-prevnext__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	padding: var(--space-4) var(--space-6);
	background: var(--tideflat);
	border: 1px solid var(--driftwood);
	border-radius: var(--radius);
	text-decoration: none;
	color: var(--color-text);
	transition: border-color 0.15s var(--ease), transform 0.15s var(--ease);
}
.mv4-prevnext__link--next {
	text-align: right;
}
.mv4-prevnext__link:hover {
	border-color: var(--oxide);
	transform: translateY(-1px);
}
.mv4-prevnext__direction {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tannin);
	font-weight: var(--weight-semibold);
}
.mv4-prevnext__title {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	color: var(--color-heading);
}

/* === site-header / nav === */
.mv4-skip-link { position: absolute; left: -9999px; top: auto; }
.mv4-skip-link:focus { left: 1rem; top: 1rem; background: var(--paper); color: var(--tannin-deep); padding: .5rem 1rem; z-index: 100; }
.mv4-site-header { background: var(--tannin-deep); color: var(--paper); position: sticky; top: 0; z-index: 50; }
.mv4-site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; max-width: 1200px; margin: 0 auto; padding: .75rem 1.25rem; }
.mv4-site-header__brand { color: var(--paper); text-decoration: none; font-family: var(--font-display); font-weight: 500; font-size: 1.0625rem; letter-spacing: .01em; }
.mv4-primary-nav__list { display: flex; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.mv4-primary-nav__list a { color: var(--paper); text-decoration: none; font-size: .9375rem; opacity: .85; }
.mv4-primary-nav__list a:hover, .mv4-primary-nav__list .current-menu-item > a { opacity: 1; border-bottom: 1px solid var(--oxide); }
.mv4-nav-toggle { display: none; background: transparent; border: 0; padding: .5rem; cursor: pointer; }
.mv4-nav-toggle__bar { display: block; width: 22px; height: 2px; background: var(--paper); margin: 4px 0; }
.mv4-main { display: block; }
.mv4-site-footer { background: var(--tannin-deep); color: var(--paper); padding: 2rem 1.25rem 1.5rem; }
.mv4-footer-nav { max-width: 1200px; margin: 0 auto 1rem; }
.mv4-footer-nav__list { display: flex; flex-wrap: wrap; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.mv4-footer-nav__list a { color: var(--paper); opacity: .8; font-size: .875rem; text-decoration: none; }
.mv4-footer-nav__list a:hover { opacity: 1; }
@media (max-width: 720px) {
    .mv4-nav-toggle { display: block; }
    .mv4-primary-nav { display: none; width: 100%; }
    .mv4-primary-nav.is-open { display: block; padding-top: .75rem; }
    .mv4-primary-nav__list { flex-direction: column; gap: .75rem; }
    .mv4-site-header__inner { flex-wrap: wrap; }
}

/* === buttons === */
.mv4-button { display: inline-block; padding: .65rem 1.25rem; border-radius: 999px; font-weight: 500; text-decoration: none; font-size: .9375rem; letter-spacing: .01em; transition: transform .15s; }
.mv4-button:hover { transform: translateY(-1px); }
.mv4-button--primary { background: var(--oxide); color: var(--paper); }
.mv4-button--ghost { background: transparent; color: var(--tannin-deep); border: 1px solid var(--tannin); }

/* === cpt-cards === */
.mv4-cpt-cards { padding: 4rem 1.25rem; max-width: 1200px; margin: 0 auto; }
.mv4-cpt-cards__heading { font-family: var(--font-display); font-size: clamp( 1.5rem, 3vw, 2rem ); margin: 0 0 2rem; color: var(--tannin-deep); }
.mv4-cpt-cards__grid { display: grid; grid-template-columns: repeat( auto-fit, minmax( 220px, 1fr ) ); gap: 1rem; }
.mv4-cpt-card { display: block; padding: 1.5rem; background: var(--paper); border: 1px solid var(--driftwood); border-radius: 6px; text-decoration: none; color: var(--tannin-deep); transition: border-color .15s; }
.mv4-cpt-card:hover { border-color: var(--oxide); }
.mv4-cpt-card__count { font-family: var(--font-display); font-size: 2.25rem; line-height: 1; color: var(--oxide); }
.mv4-cpt-card__label { font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; color: var(--tannin); margin: .5rem 0 .75rem; }
.mv4-cpt-card__blurb { font-size: .9375rem; margin: 0 0 1rem; color: var(--tannin-deep); }
.mv4-cpt-card__cta { color: var(--oxide); font-weight: 600; }

/* === ghost-fleet === */
.mv4-ghost-fleet { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; padding: 5rem 1.25rem; max-width: 1200px; margin: 0 auto; }
.mv4-ghost-fleet__headline { font-family: var(--font-display); font-size: clamp( 2rem, 4vw, 3rem ); line-height: 1.05; margin: 0 0 1.25rem; color: var(--tannin-deep); }
.mv4-ghost-fleet__lede { font-size: 1.0625rem; line-height: 1.55; color: var(--tannin-deep); margin: 0 0 1.5rem; max-width: 38ch; }
.mv4-ghost-fleet__image { width: 100%; padding-top: 75%; background-size: cover; background-position: center; border-radius: 4px; }
@media (max-width: 720px) { .mv4-ghost-fleet { grid-template-columns: 1fr; gap: 1.5rem; padding: 3rem 1.25rem; } }

/* === people-teaser === */
.mv4-people-teaser { background: var(--tideflat); padding: 5rem 1.25rem; text-align: center; }
.mv4-people-teaser__headline { font-family: var(--font-display); font-size: clamp( 1.75rem, 3.5vw, 2.5rem ); margin: 0 0 1rem; color: var(--tannin-deep); }
.mv4-people-teaser__lede { max-width: 60ch; margin: 0 auto 1.5rem; font-size: 1.0625rem; line-height: 1.6; color: var(--tannin-deep); }

/* === plan-teaser === */
.mv4-plan-teaser { padding: 4rem 1.25rem; max-width: 1200px; margin: 0 auto; }
.mv4-plan-teaser__headline { font-family: var(--font-display); font-size: clamp( 1.5rem, 3vw, 2rem ); margin: 0 0 1.5rem; color: var(--tannin-deep); }
.mv4-plan-teaser__list { list-style: none; margin: 0 0 1.5rem; padding: 0; display: grid; grid-template-columns: repeat( auto-fit, minmax( 240px, 1fr ) ); gap: 1rem; }
.mv4-plan-teaser__list li { padding: 1rem; background: var(--paper); border-left: 3px solid var(--oxide); }
.mv4-plan-teaser__list strong { display: block; font-family: var(--font-display); color: var(--tannin-deep); margin-bottom: .25rem; }
.mv4-plan-teaser__list span { font-size: .875rem; color: var(--tannin); }

/* === nearby-captures === */
.mv4-nearby-captures { padding: 4rem 1.25rem; max-width: 1200px; margin: 0 auto; }
.mv4-nearby-captures__heading { font-family: var(--font-display); font-size: clamp( 1.5rem, 3vw, 2rem ); margin: 0 0 .5rem; color: var(--tannin-deep); }
.mv4-nearby-captures__sub { color: var(--tannin); margin: 0 0 2rem; }
.mv4-nearby-captures__grid { display: grid; grid-template-columns: repeat( auto-fit, minmax( 260px, 1fr ) ); gap: 1.25rem; }
.mv4-nc-card { display: block; text-decoration: none; color: var(--tannin-deep); background: var(--paper); border: 1px solid var(--driftwood); border-radius: 6px; overflow: hidden; }
.mv4-nc-card__thumb { padding-top: 56.25%; background-size: cover; background-position: center; }
.mv4-nc-card__thumb--placeholder { background: linear-gradient( 135deg, var(--driftwood), var(--tideflat) ); }
.mv4-nc-card__title { padding: .75rem 1rem 0; font-family: var(--font-display); }
.mv4-nc-card__cta { padding: .25rem 1rem 1rem; font-size: .8125rem; color: var(--oxide); }

/* === map-embed-section (homepage variant) === */
.mv4-map-embed-section { padding: 4rem 1.25rem; max-width: 1200px; margin: 0 auto; }
.mv4-map-embed-section__heading { font-family: var(--font-display); font-size: clamp( 1.5rem, 3vw, 2rem ); margin: 0 0 1.5rem; color: var(--tannin-deep); }
.mv4-map-embed-section__cta { margin-top: 1.25rem; }
.mv4-map-embed { border-radius: 6px; overflow: hidden; background: var(--tideflat); }

/* === hero-story overrides (mv4-prefixed CTAs + subhead) === */
.mv4-hero-story__subhead { color: var(--paper); font-size: 1.0625rem; max-width: 42ch; margin: .5rem 0 1.25rem; text-shadow: 0 1px 4px rgba(0,0,0,.4); }
.mv4-hero-story__ctas { display: flex; gap: .75rem; flex-wrap: wrap; }
.mv4-button--on-dark { color: var(--paper); border-color: var(--paper); }

/* === page (generic) === */
.mv4-page { padding-bottom: 4rem; }
.mv4-page__hero { width: 100%; height: 50vh; min-height: 320px; background-size: cover; background-position: center; }
.mv4-page__header { max-width: 760px; margin: 3rem auto 1.5rem; padding: 0 1.25rem; }
.mv4-page__title { font-family: var(--font-display); font-size: clamp( 2rem, 4.5vw, 3.25rem ); line-height: 1.05; color: var(--tannin-deep); margin: 0; }

/* === explore page === */
.mv4-explore__lede { color: var(--tannin); margin: .75rem 0 0; }

/* === cpt-index === */
.mv4-cpt-index { max-width: 1200px; margin: 2rem auto 4rem; padding: 0 1.25rem; }
.mv4-cpt-index__controls { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.mv4-cpt-index__search { padding: .5rem .75rem; border: 1px solid var(--driftwood); border-radius: 4px; font-size: 1rem; min-width: 240px; background: var(--paper); color: var(--tannin-deep); }
.mv4-cpt-index__tabs { display: flex; gap: .5rem; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.mv4-cpt-index__tab { background: transparent; border: 1px solid var(--driftwood); padding: .4rem .9rem; border-radius: 999px; cursor: pointer; font-size: .875rem; color: var(--tannin-deep); }
.mv4-cpt-index__tab.is-active { background: var(--oxide); color: var(--paper); border-color: var(--oxide); }
.mv4-cpt-index__grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat( auto-fill, minmax( 220px, 1fr ) ); gap: 1rem; }
.mv4-cpt-index__card { display: block; text-decoration: none; color: var(--tannin-deep); }
.mv4-cpt-index__thumb { padding-top: 100%; background-color: var(--tideflat); background-size: cover; background-position: center; border-radius: 4px; }
.mv4-cpt-index__meta { font-size: .6875rem; letter-spacing: .12em; text-transform: uppercase; color: var(--tannin); margin-top: .5rem; }
.mv4-cpt-index__title { font-family: var(--font-display); font-size: 1.0625rem; line-height: 1.2; }

/* === section-landing === */
.mv4-section-landing { padding-bottom: 4rem; }
.mv4-section-landing__grid { list-style: none; padding: 0 1.25rem; margin: 2rem auto 0; max-width: 1200px; display: grid; grid-template-columns: repeat( auto-fit, minmax( 280px, 1fr ) ); gap: 1.5rem; }
.mv4-section-landing__card { display: block; text-decoration: none; color: var(--tannin-deep); background: var(--paper); border: 1px solid var(--driftwood); border-radius: 6px; overflow: hidden; transition: border-color .15s; }
.mv4-section-landing__card:hover { border-color: var(--oxide); }
.mv4-section-landing__thumb { padding-top: 56.25%; background-size: cover; background-position: center; background-color: var(--tideflat); }
.mv4-section-landing__title { font-family: var(--font-display); font-size: 1.25rem; margin: 1rem 1.25rem .5rem; }
.mv4-section-landing__excerpt { font-size: .9375rem; line-height: 1.5; margin: 0 1.25rem 1.25rem; color: var(--tannin); }
.mv4-land-ack { max-width: 760px; margin: 0 auto 2rem; padding: 1.25rem 1.5rem; background: var(--tideflat); border-left: 3px solid var(--oxide); border-radius: 0 4px 4px 0; }
.mv4-land-ack p { margin: 0; font-size: .9375rem; color: var(--tannin-deep); line-height: 1.6; }

/* === news === */
.mv4-news { max-width: 1000px; margin: 0 auto 4rem; padding: 0 1.25rem; }
.mv4-news__list { list-style: none; padding: 0; margin: 2rem 0 0; display: grid; gap: 1.5rem; }
.mv4-news__card { display: grid; grid-template-columns: 240px 1fr; gap: 1.5rem; text-decoration: none; color: var(--tannin-deep); background: var(--paper); border: 1px solid var(--driftwood); border-radius: 6px; overflow: hidden; transition: border-color .15s; }
.mv4-news__card:hover { border-color: var(--oxide); }
.mv4-news__thumb { background-size: cover; background-position: center; background-color: var(--tideflat); min-height: 180px; }
.mv4-news__body { padding: 1.25rem 1.5rem 1.25rem 0; }
.mv4-news__date { font-size: .8125rem; color: var(--tannin); letter-spacing: .04em; }
.mv4-news__title { font-family: var(--font-display); margin: .25rem 0 .5rem; font-size: 1.375rem; line-height: 1.2; }
.mv4-news__excerpt { margin: 0; font-size: .9375rem; line-height: 1.5; color: var(--tannin); }
.mv4-news__pagination { margin-top: 2rem; }
.mv4-news__empty { color: var(--tannin); }
@media (max-width: 720px) {
    .mv4-news__card { grid-template-columns: 1fr; }
    .mv4-news__thumb { min-height: 200px; }
    .mv4-news__body { padding: 0 1.25rem 1.25rem; }
}
