.bekaa-route-story-shell {
	--bekaa-route-red: #ef2a32;
	--bekaa-route-ink: #151312;
	--bekaa-route-muted: #6f6964;
	--bekaa-route-quiet: #9b958f;
	--bekaa-route-line: rgba(33, 29, 25, 0.1);
	--bekaa-route-panel-width: 43vw;
	--bekaa-route-entry-gap: clamp(140px, 16vh, 220px);
	position: relative;
	left: 50%;
	width: 100vw;
	min-height: 320vh;
	margin-top: var(--bekaa-route-entry-gap);
	margin-bottom: var(--bekaa-route-map-overhang, 0px);
	margin-left: -50vw;
	overflow-x: clip;
	overflow-y: visible;
	background: #fff;
	color: var(--bekaa-route-ink);
	font-family: var(--bekaa-system-font, -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif);
}

.bekaa-route-story-shell *,
.bekaa-route-story-shell *::before,
.bekaa-route-story-shell *::after {
	box-sizing: border-box;
}

.bekaa-route-story-shell svg,
.bekaa-route-story-shell img {
	display: block;
}

body:not(.compose-mode) .mk-page-section.full_layout.bekaa-route-story-section-shell,
.mk-page-section.bekaa-route-story-section-shell {
	overflow-x: clip;
	overflow-y: visible;
}

.bekaa-route-story {
	position: sticky;
	top: var(--mk-theme-page-offset, 0px);
	min-height: calc(100vh - var(--mk-theme-page-offset, 0px));
	isolation: isolate;
	display: grid;
	grid-template-columns: minmax(0, var(--bekaa-route-panel-width)) minmax(0, 1fr);
	overflow: visible;
	background:
		linear-gradient(90deg, #fff 0%, #fff 35%, rgba(255, 255, 255, 0.9) 47%, rgba(255, 255, 255, 0.38) 58%, rgba(255, 255, 255, 0) 70%),
		#fff;
}

.bekaa-route-panel {
	position: relative;
	z-index: 4;
	min-height: calc(100vh - var(--mk-theme-page-offset, 0px));
	padding: clamp(42px, 5.8vh, 58px) 24px 34px clamp(72px, 5.45vw, 92px);
}

.bekaa-route-kicker {
	margin: 0 0 12px;
	color: var(--bekaa-route-ink);
	font-family: var(--bekaa-system-font, -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.18em;
	line-height: 1.3;
	text-transform: uppercase;
}

.bekaa-route-title {
	max-width: 420px;
	margin: 0;
	color: #020202;
	font-family: "gilda-display", "Gilda Display", Georgia, "Times New Roman", serif;
	line-height: 1;
	font-weight: 300;
	letter-spacing: 0;
	text-transform: none;
}

.bekaa-route-title > span {
	display: block;
	color: #020202;
	font-size: clamp(34px, 2.9vw, 40px);
	white-space: normal;
}

.bekaa-route-title > .is-italic {
	font-size: clamp(42px, 3.65vw, 50px);
	font-style: italic;
	font-weight: 500;
}

.bekaa-route-title .bekaa-heading-dot {
	color: var(--bekaa-route-red);
	font-style: normal;
}

.bekaa-route-metrics {
	display: flex;
	gap: 0;
	width: min(100%, 552px);
	margin: 28px 0 0;
	padding: 0;
	list-style: none;
	border: 1px solid rgba(229, 222, 215, 0.78);
	border-radius: 3px;
	background: rgba(255, 255, 255, 0.62);
	box-shadow: 0 8px 24px -16px rgba(20, 12, 8, 0.1);
}

.bekaa-route-metric {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	margin: 0;
	padding: 14px 16px;
	border-right: 1px solid rgba(229, 222, 215, 0.78);
	transition: background 0.35s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.bekaa-route-metric:last-child {
	border-right: 0;
}

.bekaa-route-metric:hover {
	background: rgba(255, 255, 255, 0.3);
}

.bekaa-route-metric__icon {
	flex: none;
	width: 20px;
	height: 20px;
	color: var(--bekaa-route-quiet);
	transition: color 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.bekaa-route-metric:hover .bekaa-route-metric__icon {
	color: var(--bekaa-route-red);
}

.bekaa-route-metric__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.bekaa-route-metric__value {
	display: block;
	overflow-wrap: anywhere;
	color: #221e1b;
	font-family: var(--bekaa-display, "Gilda Display", Georgia, "Times New Roman", serif);
	font-size: 14px;
	font-weight: 400;
	line-height: 1.15;
}

.bekaa-route-story-shell .bekaa-route-metric__value {
	color: #221e1b;
}

.bekaa-route-metric__label {
	display: block;
	color: var(--bekaa-route-quiet);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.18em;
	line-height: 1.3;
	text-transform: uppercase;
}

.bekaa-route-stop-list {
	--stack-card-height: 78px;
	--stack-card-step: 88px;
	--stack-list-height: 430px;
	position: relative;
	width: min(100%, 552px);
	height: var(--stack-list-height);
	margin: clamp(24px, 3.4vh, 34px) 0 0;
	padding: 0;
	list-style: none;
}

.bekaa-route-stop {
	position: absolute;
	z-index: var(--stack-z, 1);
	left: 0;
	right: 0;
	min-height: 0;
	height: var(--stack-card-height);
	display: grid;
	grid-template-columns: 58px minmax(0, 1fr) 18px;
	align-items: center;
	gap: 16px;
	padding: 0 20px;
	overflow: hidden;
	border: 1px solid rgba(229, 222, 215, 0.78);
	border-radius: 3px;
	background: rgba(255, 255, 255, 0.86);
	box-shadow: 0 16px 36px -24px rgba(20, 12, 8, 0.18), 0 1px 2px rgba(20, 12, 8, 0.03);
	opacity: var(--stack-opacity, 1);
	transform: translate3d(0, var(--stack-y, 0), 0) scale(var(--stack-scale, 1));
	transform-origin: 50% 100%;
	transition:
		background 0.55s cubic-bezier(0.16, 1, 0.3, 1),
		border-color 0.55s cubic-bezier(0.16, 1, 0.3, 1),
		box-shadow 0.55s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: auto;
}

@media (min-width: 981px) {
	.bekaa-route-story-shell.is-route-scroll-active .bekaa-route-stop {
		will-change: transform, opacity;
	}
}

.bekaa-route-stop::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 2px;
	background: var(--bekaa-route-red);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
}

.bekaa-route-stop-badge {
	appearance: none;
	position: relative;
	z-index: 1;
	width: 46px;
	aspect-ratio: 1;
	display: grid;
	place-items: center;
	padding: 0;
	border: 1px solid rgba(22, 20, 18, 0.14);
	border-radius: 50%;
	background: #fff;
	color: var(--bekaa-route-red);
	cursor: pointer;
	font-family: inherit;
	font-size: 14px;
	font-weight: 850;
	line-height: 1;
	transition:
		border-color 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
		background 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
		color 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
		box-shadow 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.bekaa-route-stop-badge:focus-visible {
	outline: 2px solid var(--bekaa-route-red);
	outline-offset: 4px;
}

.bekaa-route-stop-badge:disabled {
	cursor: default;
}

.bekaa-route-stop-title {
	display: block;
	margin: 0 0 3px;
	color: #221e1b;
	font-family: var(--bekaa-display, "Gilda Display", Georgia, "Times New Roman", serif);
	font-size: clamp(22px, 1.58vw, 27px);
	font-weight: 400;
	line-height: 1.07;
}

.bekaa-route-story-shell .bekaa-route-stop-title {
	color: #221e1b;
}

.bekaa-route-stop-copy {
	display: block;
	max-width: 390px;
	width: 100%;
	overflow: hidden;
	margin: 0;
	color: #746e68;
	font-family: var(--bekaa-system-font, -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif);
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.42;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.bekaa-route-stop-chevron {
	color: var(--bekaa-route-red);
	font-size: 25px;
	font-weight: 300;
	line-height: 1;
	transform: translateX(0) translateY(-1px);
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.bekaa-route-stop.is-active {
	border-color: rgba(239, 42, 50, 0.18);
	background: rgba(255, 255, 255, 0.97);
	box-shadow: 0 28px 50px -22px rgba(20, 12, 8, 0.22), 0 1px 3px rgba(20, 12, 8, 0.04);
}

.bekaa-route-stop.is-active::before {
	transform: scaleY(1);
}

.bekaa-route-stop.is-active .bekaa-route-stop-badge {
	border-color: var(--bekaa-route-red);
	background: var(--bekaa-route-red);
	color: #fff;
	box-shadow: 0 0 0 4px rgba(239, 42, 50, 0.12);
}

.bekaa-route-stop.is-active .bekaa-route-stop-title {
	color: var(--bekaa-route-red);
}

.bekaa-route-stop.is-active .bekaa-route-stop-chevron {
	transform: translateX(3px) translateY(-1px);
}

.bekaa-route-stop.is-complete:not(.is-active) {
	opacity: 0.52;
}

.bekaa-route-stop.is-complete:not(.is-active) .bekaa-route-stop-badge {
	border-color: rgba(239, 42, 50, 0.42);
	color: rgba(239, 42, 50, 0.74);
}

.bekaa-route-stop.is-complete:not(.is-active) .bekaa-route-stop-title {
	color: #5c5651;
}

.bekaa-route-stop.is-complete:not(.is-active) .bekaa-route-stop-copy {
	color: #9b958f;
}

.bekaa-route-stop.is-muted {
	opacity: 0.62;
}

.bekaa-route-stop.is-unrevealed {
	opacity: 0;
	pointer-events: none;
	transform: translate3d(0, var(--stack-y, 86px), 0) scale(var(--stack-scale, 0.985));
}

.bekaa-route-map-field {
	position: relative;
	z-index: 1;
	min-width: 0;
	min-height: calc(100vh - var(--mk-theme-page-offset, 0px));
	overflow: visible;
}

.bekaa-route-map-art {
	position: absolute;
	top: clamp(-185px, -15vh, -130px);
	right: clamp(-235px, -10vw, -130px);
	width: min(73vw, 1340px);
	aspect-ratio: var(--bekaa-route-map-ratio, 3813 / 3711);
}

.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-map-art {
	top: clamp(100px, 11.5vh, 148px);
	right: clamp(-154px, -6vw, -86px);
	width: min(82vw, 1700px);
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-map-art {
	top: clamp(0px, 3vh, 45px);
	right: 0;
	width: min(58vw, 1050px);
}

.bekaa-route-story[data-route-flight="moreton-stradbroke-islands"] .bekaa-route-map-art {
	top: clamp(140px, 15vh, 220px);
	right: auto;
	left: clamp(-220px, -10vw, -160px);
	width: min(62.05vw, 1139px);
}

.bekaa-route-story[data-route-flight="glasshouse-mountains"] .bekaa-route-map-art {
	top: clamp(46px, 7vh, 100px);
	right: clamp(-342px, -15.59vw, -168px);
	width: min(83.49vw, 1670px);
}

.bekaa-route-story[data-route-flight="glasshouse-mountains"] .bekaa-route-cloud--four {
	top: 47%;
	left: 11%;
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--one {
	top: 7%;
	left: 5%;
	width: 39%;
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--two {
	top: 20%;
	right: -4%;
	width: 34%;
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--three {
	top: 57%;
	left: -13%;
	width: 43%;
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--four {
	top: 75%;
	left: -16%;
	width: 46%;
}

.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--five {
	top: 78%;
	right: 12%;
	width: 34%;
}

.bekaa-route-map-image,
.bekaa-route-cloud-layer,
.bekaa-route-overlay {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.bekaa-route-map-image {
	z-index: 1;
	max-width: none;
	object-fit: cover;
	user-select: none;
}

.bekaa-route-cloud-layer {
	z-index: 2;
	overflow: hidden;
	pointer-events: none;
}

.bekaa-route-cloud {
	position: absolute;
	display: block;
	max-width: none;
	height: auto;
	opacity: 1;
	pointer-events: none;
	user-select: none;
	transform: translate3d(0, 0, 0);
	will-change: auto;
}

.bekaa-route-story-shell.is-route-scroll-active .bekaa-route-cloud {
	will-change: transform;
}

.bekaa-route-cloud--one {
	top: -8.093%;
	left: -1.215%;
	width: 33.414%;
}

.bekaa-route-cloud--two {
	top: 0.24%;
	right: 5.898%;
	width: 30.367%;
}

.bekaa-route-cloud--three {
	top: 19.427%;
	left: 35.837%;
	width: 33.99%;
}

.bekaa-route-cloud--four {
	top: 42.079%;
	left: 6.297%;
	width: 34.705%;
}

.bekaa-route-cloud--five {
	top: 57.824%;
	right: 5.249%;
	width: 26.873%;
}

.bekaa-route-overlay {
	z-index: 3;
	overflow: visible;
}

.bekaa-route-map-labels {
	pointer-events: none;
}

.bekaa-route-map-label-path {
	fill: none;
	stroke: none;
}

.bekaa-route-map-label {
	fill: #2a2420;
	stroke: none;
	font-family: "Gilda Display", "gilda-display", Georgia, "Times New Roman", serif;
	font-weight: 400;
	letter-spacing: 0.18em;
	dominant-baseline: central;
	text-rendering: geometricPrecision;
	pointer-events: none;
	user-select: none;
}

.bekaa-route-map-label--river {
	fill: #4a4440;
	font-style: italic;
	letter-spacing: 0.28em;
}

.bekaa-route-map-label--primary {
	fill: #332e28;
	letter-spacing: 0.18em;
}

.bekaa-route-map-label--secondary {
	fill: #4a4440;
	letter-spacing: 0.14em;
}

.bekaa-route-map-label--halo {
	fill: none;
	stroke: rgba(255, 255, 255, 0.94);
	stroke-linejoin: round;
	stroke-width: 8px;
	paint-order: stroke;
}

.bekaa-route-map-label--ink {
	stroke: rgba(42, 36, 32, 0.72);
	stroke-linejoin: round;
	stroke-width: 1.45px;
	paint-order: fill stroke;
}

.bekaa-route-path {
	fill: none;
	vector-effect: non-scaling-stroke;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.bekaa-route-path-underlay {
	stroke: rgba(255, 255, 255, 0.82);
	stroke-width: 8;
}

.bekaa-route-path-base {
	stroke: rgba(239, 42, 50, 0.18);
	stroke-width: 3.2;
}

.bekaa-route-path-active {
	stroke: var(--bekaa-route-red);
	stroke-width: 3.2;
}

.bekaa-route-dot {
	fill: var(--bekaa-route-red);
	stroke: #fff;
	stroke-width: 4;
	opacity: 1;
	vector-effect: non-scaling-stroke;
}

.bekaa-route-marker {
	opacity: 0.88;
	cursor: pointer;
	transition: opacity 170ms ease;
}

.bekaa-route-marker.is-navigation-disabled {
	cursor: default;
	pointer-events: none;
}

.bekaa-route-marker:focus {
	outline: none;
}

.bekaa-route-marker:focus-visible circle {
	stroke: var(--bekaa-route-red);
	stroke-width: 8;
}

.bekaa-route-marker circle {
	fill: rgba(255, 255, 255, 0.9);
	stroke: rgba(239, 42, 50, 0.6);
	stroke-width: 5;
}

.bekaa-route-marker text {
	fill: rgba(239, 42, 50, 0.82);
	font-family: var(--bekaa-system-font, -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif);
	font-size: 36px;
	font-weight: 850;
	line-height: 1;
	dominant-baseline: central;
	text-anchor: middle;
}

.bekaa-route-marker.is-visible {
	opacity: 1;
}

.bekaa-route-marker.is-complete:not(.is-active) circle {
	fill: rgba(255, 255, 255, 0.9);
	stroke: rgba(239, 42, 50, 0.6);
}

.bekaa-route-marker.is-complete:not(.is-active) text {
	fill: rgba(239, 42, 50, 0.82);
}

.bekaa-route-marker.is-muted {
	opacity: 0.58;
}

.bekaa-route-marker.is-complete:not(.is-active) {
	opacity: 0.88;
}

.bekaa-route-marker.is-active circle {
	fill: var(--bekaa-route-red);
	stroke: rgba(255, 255, 255, 0.94);
	stroke-width: 6;
}

.bekaa-route-marker.is-active text {
	fill: #fff;
}

@media (max-width: 1320px) and (min-width: 981px) {
	.bekaa-route-story-shell {
		--bekaa-route-panel-width: 43vw;
	}

	.bekaa-route-panel {
		padding-top: 34px;
		padding-right: 16px;
		padding-left: clamp(48px, 5vw, 70px);
	}

	.bekaa-route-metrics {
		max-width: 480px;
		margin-top: 22px;
	}

	.bekaa-route-metric {
		gap: 8px;
		padding: 11px 12px;
	}

	.bekaa-route-metric__value {
		font-size: 13px;
	}

	.bekaa-route-metric__label {
		font-size: 10px;
		line-height: 1.3;
	}

	.bekaa-route-stop-list {
		--stack-card-height: 74px;
		--stack-card-step: 82px;
		--stack-list-height: 402px;
		width: min(100%, 500px);
		margin-top: 22px;
	}

	.bekaa-route-stop {
		gap: 13px;
		padding: 0 16px;
	}

	.bekaa-route-stop-title {
		font-size: clamp(19px, 1.6vw, 23px);
	}

	.bekaa-route-stop-copy {
		font-size: 12px;
		line-height: 1.3;
	}

	.bekaa-route-map-art {
		top: -88px;
		right: -20vw;
		width: min(82vw, 1120px);
	}
}

@media (min-width: 981px) {
	.bekaa-route-metrics {
		width: fit-content;
		max-width: 100%;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-metric {
		flex: 0 0 auto;
		align-items: flex-start;
		gap: 0;
		padding: 0 24px 0 0;
		border-right: 0;
	}

	.bekaa-route-metric + .bekaa-route-metric {
		padding-left: 24px;
		border-left: 1px solid var(--bekaa-route-line);
	}

	.bekaa-route-metric:last-child {
		padding-right: 0;
	}

	.bekaa-route-metric:hover {
		background: transparent;
	}

	.bekaa-route-story-shell .bekaa-route-metric__icon {
		display: none;
	}

	.bekaa-route-metric__body {
		gap: 4px;
	}

	.bekaa-route-metric__value {
		font-size: 15px;
	}

	/* Desktop: strip card chrome — editorial typographic blocks */
	.bekaa-route-stop {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		height: auto;
		overflow: visible;
		padding: 20px 0 0 0;
		border: 0;
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-stop-copy {
		max-width: none;
		white-space: nowrap;
	}

	.bekaa-route-stop::before {
		display: none;
	}

	.bekaa-route-stop.is-active {
		border: 0;
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-stop.is-complete:not(.is-active) {
		opacity: 0.68;
	}

	/* Badge: small red numeral kicker, no circle */
	.bekaa-route-stop-badge {
		width: auto;
		aspect-ratio: auto;
		display: block;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--bekaa-route-red);
		font-size: 11px;
		font-weight: 700;
		letter-spacing: 0.06em;
		line-height: 1;
		margin: 0 0 8px;
		cursor: default;
	}

	.bekaa-route-stop.is-active .bekaa-route-stop-badge {
		border: 0;
		background: transparent;
		color: var(--bekaa-route-red);
		box-shadow: none;
	}

	.bekaa-route-stop.is-complete:not(.is-active) .bekaa-route-stop-badge {
		border: 0;
		color: var(--bekaa-route-red);
	}

	/* Chevron: hidden on desktop */
	.bekaa-route-stop-chevron {
		display: none;
	}

	.bekaa-route-marker circle,
	.bekaa-route-marker.is-complete:not(.is-active) circle {
		stroke: rgba(239, 42, 50, 0.38);
	}

	.bekaa-route-marker text,
	.bekaa-route-marker.is-complete:not(.is-active) text {
		fill: rgba(239, 42, 50, 0.62);
	}
}

@media (max-width: 1320px) and (min-width: 981px) {
	.bekaa-route-metric {
		padding-right: 16px;
	}

	.bekaa-route-metric + .bekaa-route-metric {
		padding-left: 16px;
	}

	.bekaa-route-metric__value {
		font-size: 13px;
	}
}

@media (max-width: 980px) {
	.bekaa-route-story-shell {
		--bekaa-route-panel-width: 100%;
		--bekaa-route-entry-gap: clamp(36px, 9vw, 56px);
		left: auto;
		width: 100%;
		min-height: auto;
		margin-left: 0;
		overflow: visible;
	}

	.bekaa-route-story {
		position: relative;
		top: auto;
		min-height: 0;
		display: flex;
		flex-direction: column;
		overflow: visible;
		background: #fff;
	}

	.bekaa-route-panel {
		order: 1;
		min-height: 0;
		padding: 48px 0 0;
	}

	.bekaa-route-title {
		max-width: 350px;
	}

	.bekaa-route-metrics {
		width: auto;
		max-width: none;
		margin: 22px 0 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-metric {
		padding: 12px 0;
		margin: 0;
	}

	.bekaa-route-story-shell .bekaa-route-metric__icon {
		display: none;
	}

	.bekaa-route-map-field {
		order: 2;
		left: 50%;
		width: 100vw;
		max-width: none;
		min-height: 0;
		margin-left: -50vw;
		overflow: visible;
		padding: 30px 0 0;
	}

	.bekaa-route-map-art {
		position: relative;
		top: auto;
		right: auto;
		left: 50%;
		width: clamp(560px, 200%, 760px);
		max-width: none;
		margin: 0 0 var(--bekaa-route-mobile-map-clearance, 0px);
		transform: translateX(-43.5%);
	}

	.bekaa-route-story[data-route-flight="brisbane-city-secrets"] .bekaa-route-map-art {
		width: clamp(560px, 150vw, 620px);
		transform: translateX(-41.5%);
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-map-art {
		--bekaa-route-mobile-map-clearance: 100px;
		width: clamp(650px, 165vw, 760px);
		transform: translateX(-59.6%);
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-map-art {
		--bekaa-route-mobile-map-clearance: 84px;
		top: 84px;
		width: clamp(650px, 167vw, 720px);
		transform: translateX(-50%);
	}

	.bekaa-route-story[data-route-flight="moreton-stradbroke-islands"] .bekaa-route-map-art {
		top: auto;
		right: auto;
		left: 50%;
		width: clamp(520px, 138vw, 600px);
		transform: translateX(-62%);
	}

	.bekaa-route-story[data-route-flight="glasshouse-mountains"] .bekaa-route-map-art {
		--bekaa-route-mobile-map-clearance: 112px;
		top: 112px;
		width: clamp(911px, 240.35vw, 1139px);
		transform: translateX(-49.1%);
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--one {
		top: 7%;
		left: -6%;
		width: 54%;
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--two {
		top: 27%;
		right: -14%;
		width: 48%;
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--three {
		top: 58%;
		left: -18%;
		width: 54%;
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--four {
		top: 74%;
		left: -24%;
		width: 58%;
	}

	.bekaa-route-story[data-route-flight="brisbane-gold-coast"] .bekaa-route-cloud--five {
		top: 78%;
		right: 4%;
		width: 44%;
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-cloud--one {
		top: -9%;
		left: -14%;
		width: 45%;
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-cloud--two {
		top: 4%;
		right: -11%;
		width: 38%;
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-cloud--three {
		top: 33%;
		left: 32%;
		width: 43%;
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-cloud--four {
		top: 49%;
		left: -10%;
		width: 42%;
	}

	.bekaa-route-story[data-route-flight="brisbane-city-highlights"] .bekaa-route-cloud--five {
		top: 68%;
		right: -8%;
		width: 34%;
	}

	.bekaa-route-cloud--one {
		top: -2.821%;
		left: -19.359%;
		width: 55.691%;
	}

	.bekaa-route-cloud--two {
		top: 43.544%;
		right: -7.097%;
		width: 46.443%;
	}

	.bekaa-route-cloud--three {
		top: 37.046%;
		left: 25.062%;
		width: 56.651%;
	}

	.bekaa-route-cloud--four {
		top: 52.973%;
		left: -14.44%;
		width: 53.793%;
	}

	.bekaa-route-cloud--five {
		top: 71.809%;
		right: -9.16%;
		width: 45.26%;
	}

	.bekaa-route-path-underlay {
		stroke: rgba(255, 255, 255, 0.74);
		stroke-width: 4.6;
	}

	.bekaa-route-path-base,
	.bekaa-route-path-active {
		stroke-width: 2.15;
	}

	.bekaa-route-path-active {
		stroke: rgba(239, 42, 50, 0.9);
	}

	.bekaa-route-map-label[data-label-priority="context"] {
		display: none;
	}

	.bekaa-route-map-label--primary,
	.bekaa-route-map-label--secondary,
	.bekaa-route-map-label--river {
		opacity: 0.9;
	}

	.bekaa-route-dot {
		display: none;
	}

	.bekaa-route-marker circle,
	.bekaa-route-marker.is-complete:not(.is-active) circle {
		fill: rgba(255, 255, 255, 0.86);
		stroke: rgba(239, 42, 50, 0.74);
		stroke-width: 5;
	}

	.bekaa-route-marker text,
	.bekaa-route-marker.is-complete:not(.is-active) text {
		fill: rgba(239, 42, 50, 0.9);
	}

	.bekaa-route-marker.is-active circle {
		fill: rgba(239, 42, 50, 0.92);
		stroke: rgba(255, 255, 255, 0.92);
	}

	.bekaa-route-marker.is-active text {
		fill: #fff;
	}

	.bekaa-route-marker.is-muted {
		opacity: 1;
	}

	.bekaa-route-stop-list {
		order: 3;
		width: auto;
		height: auto;
		margin: 28px 0 clamp(72px, 12svh, 112px);
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-stop {
		position: relative;
		left: auto;
		right: auto;
		z-index: 1;
		min-height: 0;
		height: auto;
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		padding: 24px 0;
		border: 0;
		border-top: 1px solid var(--bekaa-route-line);
		border-radius: 0;
		background: transparent;
		box-shadow: none;
		opacity: 1;
		transform: none;
		will-change: auto;
	}

	.bekaa-route-stop::before {
		display: none;
	}

	.bekaa-route-stop:first-child {
		border-top: 0;
	}

	.bekaa-route-stop.is-active {
		background: transparent;
		box-shadow: none;
	}

	.bekaa-route-stop.is-unrevealed {
		display: flex;
		opacity: 1;
		pointer-events: auto;
		transform: none;
	}

	.bekaa-route-stop.is-muted,
	.bekaa-route-stop.is-complete:not(.is-active) {
		opacity: 1;
	}

	.bekaa-route-stop-badge {
		width: auto;
		aspect-ratio: auto;
		display: block;
		place-items: unset;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--bekaa-route-red);
		font-size: 11px;
		font-weight: 700;
		letter-spacing: 0.06em;
		line-height: 1;
		margin: 0 0 10px;
		cursor: default;
	}

	.bekaa-route-stop.is-active .bekaa-route-stop-badge {
		background: transparent;
		border: 0;
		color: var(--bekaa-route-red);
		box-shadow: none;
	}

	.bekaa-route-stop.is-complete:not(.is-active) .bekaa-route-stop-badge {
		border: 0;
		color: var(--bekaa-route-red);
		opacity: 1;
	}

	.bekaa-route-stop-title {
		font-size: 24px;
	}

	.bekaa-route-stop-copy {
		max-width: none;
	}

	.bekaa-route-stop-chevron {
		display: none;
	}

	.bekaa-route-stop-copy {
		margin: 4px 0 0;
	}

	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item {
		opacity: 0;
		transform: translate3d(0, 10px, 0);
		transition:
			opacity 0.46s cubic-bezier(0.16, 1, 0.3, 1),
			transform 0.78s cubic-bezier(0.16, 1, 0.3, 1),
			background 0.55s cubic-bezier(0.16, 1, 0.3, 1),
			border-color 0.55s cubic-bezier(0.16, 1, 0.3, 1),
			box-shadow 0.55s cubic-bezier(0.16, 1, 0.3, 1);
		will-change: opacity, transform;
	}

	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item.is-visible,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item.is-visible,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item.is-visible,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item.is-visible,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item.bekaa-reveal-done {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}

	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item.bekaa-reveal-done,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item.bekaa-reveal-done {
		will-change: auto;
	}
}

@media (max-width: 640px) {
	.bekaa-route-metrics {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0;
	}

	.bekaa-route-metric {
		border-right: 0;
		border-bottom: 1px solid var(--bekaa-route-line);
	}

	.bekaa-route-metric:last-child {
		border-bottom: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.bekaa-route-cloud,
	.bekaa-route-stop,
	.bekaa-route-marker,
	.bekaa-route-path-active,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item {
		transition: none;
		will-change: auto;
	}

	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-kicker.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-title.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-metrics.reveal-item,
	html.bekaa-anim-js .bekaa-route-story-shell .bekaa-route-stop.reveal-item {
		opacity: 1;
		transform: none;
	}
}
