	/* Landing page template: self-contained, no runtime dependency on the Astra header. */
	body.landing-route-template .site-header,
	body.landing-route-template .ast-primary-header-bar,
	body.landing-route-template .main-header-bar,
	body.landing-route-template .ast-mobile-header-wrap {
		display: none !important;
	}

	body.landing-route-template .site-footer {
		display: none !important;
	}

	body.landing-route-template {
		background:
			radial-gradient(circle at 10% 10%, rgba(var(--color-primary), 0.12), transparent 26%),
			radial-gradient(circle at 88% 4%, rgba(255, 184, 0, 0.10), transparent 18%),
			linear-gradient(180deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0) 18%),
			#edf6ee;
	}

	body.landing-route-template .site-content {
		padding-top: 0 !important;
	}

	body.landing-route-template .content-area,
	body.landing-route-template .site-content .ast-container {
		max-width: none;
		padding: 0;
	}

	.landing-route {
		position: relative;
		isolation: isolate;
		/* Mirror the palette used by the landing mock so all gradient layers resolve. */
		--color-primary-rgb: 20, 112, 120;
		--color-primary-hover-rgb: 26, 118, 166;
		--color-primary-dark-rgb: 13, 77, 83;
		--color-accent-rgb: 255, 184, 0;
		--color-hero-grad-start-rgb: 20, 112, 120;
		--color-hero-grad-end-rgb: 190, 223, 226;
		--color-bg-rgb: 237, 246, 238;
		--color-white-rgb: 253, 253, 253;
		--color-border-rgb: 229, 231, 235;
		--color-text-body-rgb: 71, 85, 105;
		--color-text-muted-rgb: 100, 116, 139;
		--color-text-dark-rgb: 15, 23, 42;
		--color-primary: var(--color-primary-rgb);
		--color-primary-hover: var(--color-primary-hover-rgb);
		--color-primary-dark: var(--color-primary-dark-rgb);
		--color-accent: var(--color-accent-rgb);
		--color-bg: var(--color-bg-rgb);
		--color-white: var(--color-white-rgb);
		--color-border: var(--color-border-rgb);
		--color-text-body: var(--color-text-body-rgb);
		--color-text-muted: var(--color-text-muted-rgb);
		--color-text-dark: var(--color-text-dark-rgb);
		--radius-lg: 24px;
		--radius-md: 16px;
		--ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
		--ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
		--ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
		--motion-duration-fast: 180ms;
		--motion-duration-base: 420ms;
		--motion-duration-hero: 680ms;
		--motion-offset-base: 16px;
		--motion-offset-hero: 24px;
		--shadow: 0 16px 44px rgba(15, 23, 42, 0.08);
		color: rgb(var(--color-text-dark));
		font-family: "Google Sans Flex", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
		line-height: 1.5;
		padding-bottom: 96px;
	}

	html.landing-route-motion .landing-route .landing-motion {
		opacity: 0;
		transform: translate3d(0, var(--motion-offset, var(--motion-offset-base)), 0);
		filter: blur(4px);
		transition:
			opacity var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quint),
			transform var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quint),
			filter var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quart);
		will-change: transform, opacity, filter;
	}

	html.landing-route-motion .landing-route .landing-motion.is-inview {
		opacity: 1;
		transform: none;
		filter: none;
	}

	html.landing-route-motion .landing-route .landing-motion--hero {
		--motion-offset: var(--motion-offset-hero);
		--motion-duration: var(--motion-duration-hero);
	}

	html.landing-route-motion .landing-route .landing-motion--panel {
		--motion-duration: var(--motion-duration-base);
	}

	html.landing-route-motion .landing-route .landing-motion--stagger > * {
		opacity: 0;
		transform: translate3d(0, var(--motion-offset, var(--motion-offset-base)), 0);
		filter: blur(3px);
		transition:
			opacity var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quint),
			transform var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quint),
			filter var(--motion-duration, var(--motion-duration-base)) var(--ease-out-quart);
		transition-delay: var(--reveal-delay, 0ms);
		will-change: transform, opacity, filter;
	}

	html.landing-route-motion .landing-route .landing-motion--stagger.is-inview > * {
		opacity: 1;
		transform: none;
		filter: none;
	}

	html.landing-route-motion--reduced .landing-route .landing-motion,
	html.landing-route-motion--reduced .landing-route .landing-motion--stagger > * {
		opacity: 1;
		transform: none;
		filter: none;
		transition: none;
	}

	.landing-shell {
		width: min(1180px, calc(100% - 32px));
		margin: 0 auto;
	}

	.landing-topbar {
		position: absolute;
		inset: 0 0 auto 0;
		z-index: 40;
		padding: 16px 0 0;
		pointer-events: none;
	}

	

	.landing-topbar__inner {
		display: flex;
		align-items: center;
		gap: 16px;
		padding: 12px 18px;
		border-radius: 999px;
		border: 1px solid rgba(255, 255, 255, 0.64);
		background: linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.32));
		box-shadow: 0 16px 36px rgba(15, 23, 42, 0.10);
		backdrop-filter: blur(16px) saturate(145%);
		-webkit-backdrop-filter: blur(16px) saturate(145%);
		pointer-events: auto;
	}

	.landing-topbar__brand {
		flex: 0 0 auto;
		display: flex;
		align-items: center;
		min-width: 0;
	}

	.landing-topbar__logo {
		display: inline-flex;
		align-items: center;
		color: rgb(var(--color-text-dark));
	}

	.landing-topbar__logo .custom-logo-link,
	.landing-topbar__logo .landing-topbar__site-name {
		display: inline-flex;
		align-items: center;
		text-decoration: none;
		color: inherit;
	}

	.landing-topbar__logo img {
		display: block;
		max-height: 44px;
		width: auto;
	}

	.landing-topbar__site-name {
		font-size: 18px;
		font-weight: 800;
		letter-spacing: -0.03em;
	}

	.landing-topbar__nav {
		flex: 1 1 auto;
		display: flex;
		justify-content: center;
		min-width: 0;
	}

	.landing-topbar__menu {
		display: flex;
		align-items: center;
		gap: 22px;
		margin: 0;
		padding: 0;
		list-style: none;
		flex-wrap: wrap;
	}

	.landing-topbar__menu > li {
		display: flex;
	}

	.landing-topbar__menu a {
		display: inline-flex;
		align-items: center;
		min-height: 36px;
		padding: 0;
		color: rgb(var(--color-text-dark));
		font-weight: 700;
		text-decoration: none;
		transition: color 0.18s ease, opacity 0.18s ease;
	}

	.landing-topbar__menu a:hover,
	.landing-topbar__menu a:focus-visible {
		color: rgb(var(--color-primary));
	}

	.landing-topbar__actions {
		display: flex;
		align-items: center;
		gap: 10px;
		flex: 0 0 auto;
	}

	.landing-topbar__action {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 40px;
		padding: 0 16px;
		border-radius: 999px;
		font-size: 14px;
		font-weight: 800;
		text-decoration: none;
		transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
	}

	.landing-topbar__action:hover,
	.landing-topbar__action:focus-visible {
		transform: translateY(-1px);
	}

	.landing-topbar__action--primary {
		background: linear-gradient(135deg, rgb(var(--color-primary)), rgb(var(--color-primary-hover)));
		color: #fff;
		box-shadow: 0 10px 20px rgba(var(--color-primary), 0.18);
	}

	.landing-topbar__action--phone {
		background: rgba(255, 255, 255, 0.82);
		color: rgb(var(--color-primary-dark));
		border: 1px solid rgba(var(--color-primary), 0.18);
	}

	.landing-topbar__phone-icon {
		margin-right: 8px;
		font-size: 14px;
	}

	.landing-topbar__mobile {
		position: relative;
		display: none;
		align-items: center;
		justify-content: flex-end;
		flex: 0 0 auto;
		margin-left: auto;
		overflow: visible;
	}

	.landing-topbar__mobile-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 46px;
		height: 46px;
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.86);
		border: 1px solid rgba(var(--color-primary), 0.16);
		box-shadow: 0 10px 18px rgba(15, 23, 42, 0.08);
		list-style: none;
		cursor: pointer;
	}

	.landing-topbar__mobile-toggle::-webkit-details-marker {
		display: none;
	}

	.landing-topbar__mobile-toggle span {
		display: block;
		width: 18px;
		height: 2px;
		border-radius: 999px;
		background: rgb(var(--color-primary-dark));
	}

	.landing-topbar__mobile-toggle span + span {
		margin-top: 4px;
	}

	.landing-topbar__mobile-panel {
		position: absolute;
		top: calc(100% + 10px);
		right: 0;
		left: 0;
		padding: 16px;
		border-radius: 24px;
		border: 1px solid rgba(var(--color-border), 0.95);
		background: rgba(255, 255, 255, 0.96);
		box-shadow: 0 20px 40px rgba(15, 23, 42, 0.14);
		backdrop-filter: blur(14px);
		-webkit-backdrop-filter: blur(14px);
	}

	.landing-topbar__mobile-panel .landing-topbar__menu {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}

	.landing-topbar__mobile-panel .landing-topbar__menu a {
		font-size: 15px;
	}

	.landing-topbar__mobile-actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 10px;
		margin-top: 16px;
	}

	.landing-button {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 44px;
		padding: 12px 18px;
		border-radius: 999px;
		border: 1px solid transparent;
		font-weight: 700;
		text-decoration: none;
		transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
	}

	.landing-button:hover {
		transform: translateY(-1px);
	}

	.landing-button--primary {
		background: linear-gradient(135deg, rgb(var(--color-primary)), rgb(var(--color-primary-hover)));
		color: #fff;
		box-shadow: 0 12px 24px rgba(var(--color-primary), 0.16);
	}

	.landing-button--ghost {
		background: #fff;
		color: rgb(var(--color-primary));
		border-color: rgba(var(--color-primary), 0.22);
	}

	.landing-hero {
		position: relative;
		overflow: hidden;
		padding: 0 0 32px;
	}

	.landing-hero__media {
		position: absolute;
		inset: 0;
		z-index: 0;
		pointer-events: none;
		overflow: hidden;
	}

	.landing-hero__picture {
		display: block;
		width: 100%;
		height: 100%;
	}

	.landing-hero__image {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center center;
		transform: scale(1.03);
		filter: saturate(0.98) contrast(1.02);
	}

	.landing-hero__media::before {
		content: "";
		position: absolute;
		inset: 0;
		background:
			linear-gradient(90deg, rgba(237, 246, 238, 0.98) 0%, rgba(237, 246, 238, 0.9) 28%, rgba(237, 246, 238, 0.6) 54%, rgba(237, 246, 238, 0.18) 72%, rgba(237, 246, 238, 0.04) 100%),
			linear-gradient(180deg, rgba(15, 23, 42, 0.08), rgba(15, 23, 42, 0.14));
		z-index: 1;
		pointer-events: none;
	}

	.landing-hero__grid {
		position: relative;
		z-index: 1;
		display: grid;
		grid-template-columns: minmax(0, 1.02fr) minmax(350px, 0.98fr);
		gap: 28px;
		align-items: start;
		padding-top: clamp(88px, 8vw, 124px);
	}

	.landing-kicker {
		display: inline-flex;
		align-items: center;
		gap: 10px;
		padding: 8px 14px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.12);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 800;
		letter-spacing: 0.08em;
		text-transform: uppercase;
	}

	.landing-hero h1 {
		margin: 16px 0 16px;
		font-size: clamp(2rem, 4vw, 3.75rem);
		line-height: 1.04;
		letter-spacing: -0.05em;
		color: rgb(var(--color-text-dark));
		text-wrap: balance;
		text-shadow: 0 1px 0 rgba(255, 255, 255, 0.18);
	}

	.hero-headline__highlight {
		display: inline-block;
		padding: 0.08em 0.18em 0.12em;
		background: linear-gradient(180deg, rgba(42, 170, 138, 0.98), rgba(30, 154, 124, 0.98));
		color: #fff;
		box-decoration-break: clone;
		-webkit-box-decoration-break: clone;
		text-shadow: none;
	}

	.landing-deck {
		margin: 0;
		max-width: 640px;
		color: rgb(var(--color-text-body));
		font-size: 1.05rem;
		line-height: 1.72;
	}

	.booking-route-content {
		padding: 28px 0 0;
	}

	.booking-route-content__box {
		padding: 20px 18px;
	}

	.booking-route-content__text {
		color: rgb(var(--color-text-body));
		font-size: 1rem;
		line-height: 1.72;
		overflow: hidden;
	}

	.booking-route-content__text[data-collapsed="true"] {
		display: -webkit-box;
		-webkit-line-clamp: 10;
		line-clamp: 10;
		-webkit-box-orient: vertical;
	}

	.booking-route-content__toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 44px;
		margin-top: 14px;
		padding: 0 16px;
		border: 1px solid rgba(var(--color-primary), 0.22);
		border-radius: 999px;
		background: rgb(var(--color-primary));
		color: #fff;
		font-weight: 700;
		cursor: pointer;
		transition: transform 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
	}

	.booking-route-content__toggle:hover,
	.booking-route-content__toggle:focus-visible {
		transform: translateY(-1px);
		background: rgb(var(--color-primary-dark));
		box-shadow: 0 10px 22px rgba(var(--color-primary), 0.18);
	}

	.booking-route-content__toggle:focus-visible {
		outline: 2px solid rgba(var(--color-accent), 0.9);
		outline-offset: 2px;
	}

	.landing-pills {
		display: flex;
		flex-wrap: wrap;
		gap: 12px;
		margin: 22px 0 24px;
		padding: 0;
		list-style: none;
	}

	.landing-pills li {
		display: inline-flex;
		align-items: center;
		gap: 8px;
		padding: 10px 14px;
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.84);
		border: 1px solid rgba(var(--color-border), 0.85);
		box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
	}

	.landing-pills strong {
		font-size: 14px;
	}

	.hero__summary {
		border-radius: 24px;
		padding: 18px;
		background: rgba(255, 255, 255, 0.72);
		border: 1px solid rgba(var(--color-border), 0.88);
		box-shadow: var(--shadow);
	}

	.summary-strip {
		display: grid;
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 12px;
	}

	.summary-card {
		border-radius: 18px;
		padding: 14px 12px;
		background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(var(--color-bg-rgb), 0.92));
		border: 1px solid rgba(var(--color-border), 0.88);
	}

	.summary-card .label {
		display: block;
		font-size: 12px;
		font-weight: 700;
		color: rgb(var(--color-text-muted));
		text-transform: uppercase;
		letter-spacing: 0.08em;
	}

	.summary-card .value {
		margin-top: 10px;
		font-size: 1.15rem;
		font-weight: 800;
		letter-spacing: -0.03em;
		color: rgb(var(--color-text-dark));
	}

	.summary-note {
		margin-top: 16px;
		padding: 16px 16px 0;
		color: rgb(var(--color-text-body));
		line-height: 1.7;
	}

	.booking {
		border-radius: 28px;
		padding: 22px;
		background: rgba(255, 255, 255, 0.88);
		border: 1px solid rgba(var(--color-border), 0.96);
		box-shadow: var(--shadow);
		backdrop-filter: blur(12px);
	}

	.booking__header {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
		gap: 16px;
		margin-bottom: 18px;
	}

	.route-badge {
		display: inline-flex;
		align-items: center;
		padding: 7px 12px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.12);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 800;
		letter-spacing: 0.08em;
		text-transform: uppercase;
	}

	.route-direction {
		display: flex;
		flex-wrap: wrap;
		gap: 8px;
		margin-bottom: 12px;
	}

	.route-direction__chip {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 38px;
		padding: 8px 12px;
		border-radius: 999px;
		border: 1px solid rgba(var(--color-border), 0.96);
		background: rgba(255, 255, 255, 0.96);
		color: rgb(var(--color-text-dark));
		font-size: 12px;
		font-weight: 800;
		letter-spacing: 0;
		white-space: nowrap;
		cursor: pointer;
		transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
	}

	.route-direction__chip:hover {
		transform: translateY(-1px);
	}

	.route-direction__chip.is-active {
		background: rgba(var(--color-primary), 0.12);
		border-color: rgba(var(--color-primary), 0.28);
		color: rgb(var(--color-primary-dark));
		box-shadow: 0 10px 24px rgba(var(--color-primary), 0.08);
	}

	.booking h2 {
		margin: 10px 0 6px;
		font-size: 1.5rem;
		line-height: 1.15;
		letter-spacing: -0.03em;
	}

	.booking p {
		margin: 0;
		color: rgb(var(--color-text-body));
	}

	.booking__price {
		min-width: 130px;
		text-align: right;
	}

	.booking__price span {
		display: block;
		font-size: 12px;
		font-weight: 700;
		color: rgb(var(--color-text-muted));
		text-transform: uppercase;
		letter-spacing: 0.08em;
	}

	.booking__price strong {
		display: block;
		margin-top: 8px;
		font-size: 1.55rem;
		letter-spacing: -0.04em;
		color: rgb(var(--color-primary-dark));
	}

	form#lead-form {
		margin: 0;
	}

	.field {
		margin-bottom: 14px;
	}

	.field label {
		display: block;
		margin-bottom: 8px;
		font-size: 14px;
		font-weight: 700;
		color: rgb(var(--color-text-dark));
	}

	.field input,
	.field select,
	.field textarea {
		width: 100%;
		min-height: 48px;
		padding: 12px 14px;
		border-radius: 14px;
		border: 1px solid rgba(var(--color-border), 1);
		background: #fff;
		color: rgb(var(--color-text-dark));
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
	}

	.field textarea {
		min-height: 120px;
		resize: vertical;
	}

	.grid-2 {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 12px;
	}

	.booking__dynamic {
		margin-top: 4px;
	}

	.booking__seat-types {
		margin-top: 8px;
		padding: 14px;
		border-radius: 18px;
		background: linear-gradient(180deg, rgba(var(--color-bg-rgb), 0.48), rgba(255, 255, 255, 0.92));
		border: 1px solid rgba(var(--color-border), 0.9);
	}

	.booking__seat-types-header {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		margin-bottom: 12px;
	}

	.booking__seat-types-title {
		font-size: 0.92rem;
		font-weight: 800;
		letter-spacing: 0.08em;
		text-transform: uppercase;
		color: rgb(var(--color-text-muted));
	}

	.booking__seat-types-grid {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 12px;
	}

	.booking__seat-type {
		background-color: rgb(var(--color-white));
	}

	.booking__seat-type:hover {
		border-color: rgba(var(--color-primary), 0.28);
		background: linear-gradient(180deg, rgba(var(--color-primary), 0.06), rgba(var(--color-accent), 0.05));
		transform: translateY(-1px);
	}

	.booking__seat-type.is-selected {
		border-color: rgba(var(--color-primary), 0.42);
		background: linear-gradient(180deg, rgba(var(--color-primary), 0.16), rgba(var(--color-accent), 0.05));

		box-shadow: 0 10px 22px rgba(var(--color-primary), 0.08);
	}

	.booking__seat-type:focus-visible,
	.booking__time-chip:focus-visible {
		outline: 2px solid rgba(var(--color-primary), 0.5);
		outline-offset: 2px;
	}

	.booking__seat-text {
		display: flex;
		flex-direction: column;
		min-width: 0;
	}

	.booking__seat-text strong {
		font-size: 12px;
		line-height: 1.14;
		color: rgb(var(--color-text-dark));
		text-transform: uppercase;
		letter-spacing: 0.05em;
	}

	.booking__seat-price {
		margin-top: 4px;
		font-size: var(--text-md) !important;
		font-weight: 700;
		color: rgb(var(--color-accent));
	}

	.booking__time-field {
		margin-bottom: 14px;
	}

	.booking__time-select {
		width: 100%;
		min-height: 48px;
		padding: 12px 16px;
		border-radius: 16px;
		border: 1px solid rgba(var(--color-border), 0.96);
		background: rgba(255, 255, 255, 0.98);
		color: rgb(var(--color-text-dark));
		font: inherit;
		font-weight: 700;
		box-shadow: 0 10px 24px rgba(var(--color-primary), 0.04);
		appearance: none;
		-webkit-appearance: none;
		-moz-appearance: none;
		background-image:
			linear-gradient(45deg, transparent 50%, rgb(var(--color-text-dark)) 50%),
			linear-gradient(135deg, rgb(var(--color-text-dark)) 50%, transparent 50%),
			linear-gradient(to right, transparent, transparent);
		background-position:
			calc(100% - 20px) calc(50% - 2px),
			calc(100% - 14px) calc(50% - 2px),
			100% 0;
		background-size: 6px 6px, 6px 6px, 2.5em 100%;
		background-repeat: no-repeat;
		padding-right: 48px;
	}

	.booking__time-select:focus {
		outline: none;
		border-color: rgba(var(--color-primary), 0.35);
		box-shadow: 0 0 0 4px rgba(var(--color-primary), 0.10);
	}

	.booking__seat-type {
		min-height: 70px;
		padding: 10px;
		grid-template-columns: 36px minmax(0, 1fr);
		gap: 8px;
		border-radius: 12px;
	}

	.booking__seat-icon {
		width: 36px;
		height: 26px;
		font-size: 10px;
	}

	.booking__seat-text strong {
		font-size: 11px;
		letter-spacing: 0.03em;
	}

	.booking__seat-price {
		font-size: 11px;
		margin-top: 4px;
	}

	.booking__actions {
		display: grid;
		gap: 10px;
		margin-top: 16px;
	}

	.button--block {
		width: 100%;
	}

	.status {
		margin-top: 12px;
		min-height: 24px;
		font-size: 14px;
		font-weight: 600;
		color: rgb(var(--color-primary-dark));
	}

	.section {
		padding: 24px 0 0;
	}

	.section__head {
		text-align: center;
		max-width: 860px;
		margin: 0 auto 22px;
	}

	.section__head .landing-kicker {
		margin-bottom: 14px;
	}

	.section__head h2 {
		margin: 0 0 14px;
		font-size: clamp(1.6rem, 2.6vw, 2.3rem);
		line-height: 1.12;
		letter-spacing: -0.04em;
	}

	.section__head p {
		margin: 0;
		color: rgb(var(--color-text-body));
	}

	.section__intro--narrow {
		max-width: 720px;
		margin-left: auto;
		margin-right: auto;
	}

	.section__head--compact {
		max-width: 760px;
		margin: 0;
		text-align: left;
	}

	.section__head--compact .landing-kicker {
		margin-bottom: 12px;
	}

	.section__head--compact h2 {
		margin-bottom: 10px;
	}

	.section__head--compact .section__intro--narrow {
		margin-left: 0;
		margin-right: 0;
	}

	.route-gallery {
		margin-top: 18px;
	}

	.route-gallery__preview {
		display: grid;
		grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.78fr);
		grid-template-rows: repeat(2, minmax(150px, 1fr));
		gap: 12px;
		min-height: 390px;
	}

	.route-gallery__tile {
		position: relative;
		display: block;
		width: 100%;
		height: 100%;
		padding: 0;
		border: 1px solid rgba(var(--color-border), 0.92);
		border-radius: 26px;
		overflow: hidden;
		background: rgba(255, 255, 255, 0.92);
		box-shadow: 0 12px 26px rgba(15, 23, 42, 0.06);
		cursor: pointer;
		transition:
			transform 180ms var(--ease-out-quart),
			box-shadow 180ms var(--ease-out-quart),
			border-color 180ms var(--ease-out-quart);
	}

	.route-gallery__tile:hover {
		transform: translateY(-2px);
		border-color: rgba(var(--color-primary), 0.24);
		box-shadow: 0 18px 34px rgba(15, 23, 42, 0.10);
	}

	.route-gallery__tile:focus-visible {
		outline: 3px solid rgba(var(--color-accent), 0.82);
		outline-offset: 3px;
	}

	.route-gallery__tile--1 {
		grid-column: 1;
		grid-row: 1 / span 2;
	}

	.route-gallery__tile--2 {
		grid-column: 2;
		grid-row: 1;
	}

	.route-gallery__tile--3 {
		grid-column: 2;
		grid-row: 2;
	}

	.route-gallery__tile img {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
		transform: scale(1.001);
	}

	.route-gallery__shade {
		position: absolute;
		inset: 0;
		background:
			linear-gradient(180deg, rgba(15, 23, 42, 0.02), rgba(15, 23, 42, 0.22)),
			linear-gradient(90deg, rgba(15, 23, 42, 0.10), transparent 46%);
		pointer-events: none;
	}

	.route-gallery__badge,
	.route-gallery__more {
		position: absolute;
		z-index: 1;
		display: inline-flex;
		align-items: center;
		gap: 8px;
		border-radius: 999px;
		backdrop-filter: blur(12px) saturate(145%);
		-webkit-backdrop-filter: blur(12px) saturate(145%);
	}

	.route-gallery__badge {
		top: 14px;
		left: 14px;
		min-height: 32px;
		padding: 0 12px;
		background: rgba(255, 255, 255, 0.88);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 800;
		letter-spacing: 0.02em;
	}

	.route-gallery__more {
		right: 14px;
		bottom: 14px;
		flex-direction: column;
		align-items: flex-start;
		padding: 10px 12px;
		background: rgba(15, 23, 42, 0.78);
		color: rgb(var(--color-white));
		box-shadow: 0 12px 24px rgba(15, 23, 42, 0.18);
	}

	.route-gallery__more-count {
		font-size: 1.15rem;
		font-weight: 900;
		line-height: 1;
		letter-spacing: -0.04em;
	}

	.route-gallery__more-label {
		font-size: 12px;
		font-weight: 700;
		opacity: 0.88;
	}

	.route-gallery--empty {
		padding: 20px;
		border-radius: 26px;
		border: 1px dashed rgba(var(--color-border), 0.9);
		background: linear-gradient(180deg, rgba(var(--color-bg-rgb), 0.36), rgba(255, 255, 255, 0.92));
	}

	.route-gallery__empty {
		max-width: 620px;
		margin: 0 auto;
		padding: 24px;
		text-align: center;
	}

	.route-gallery__empty-kicker {
		display: inline-flex;
		align-items: center;
		margin-bottom: 10px;
		padding: 7px 12px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.10);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 800;
		letter-spacing: 0.08em;
		text-transform: uppercase;
	}

	.route-gallery__empty h3 {
		margin: 0 0 10px;
		font-size: 1.35rem;
		letter-spacing: -0.03em;
	}

	.route-gallery__empty p {
		margin: 0;
		color: rgb(var(--color-text-body));
		line-height: 1.7;
	}

	.route-gallery-modal {
		position: fixed;
		inset: 0;
		z-index: 9999;
		display: none;
		align-items: center;
		justify-content: center;
		padding: 18px;
		background: rgba(7, 12, 20, 0.82);
		backdrop-filter: blur(16px);
		-webkit-backdrop-filter: blur(16px);
	}

	.route-gallery-modal[aria-hidden="false"] {
		display: flex;
	}

	.route-gallery-modal__dialog {
		width: min(1120px, 100%);
		max-height: min(92vh, 980px);
		display: grid;
		grid-template-rows: auto minmax(0, 1fr) auto;
		border-radius: 30px;
		background: rgba(255, 255, 255, 0.97);
		border: 1px solid rgba(255, 255, 255, 0.6);
		box-shadow: 0 32px 70px rgba(15, 23, 42, 0.28);
		overflow: hidden;
	}

	.route-gallery-modal__head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 16px;
		padding: 18px 18px 0;
	}

	.route-gallery-modal__meta {
		display: flex;
		flex-direction: column;
		gap: 4px;
		min-width: 0;
	}

	.route-gallery-modal__meta strong {
		font-size: 1rem;
		line-height: 1.2;
		letter-spacing: -0.02em;
	}

	.route-gallery-modal__meta span {
		color: rgb(var(--color-text-muted));
		font-size: 13px;
		font-weight: 700;
	}

	.route-gallery-modal__close,
	.route-gallery-modal__nav,
	.route-gallery-modal__thumb {
		border: none;
	}

	.route-gallery-modal__close,
	.route-gallery-modal__nav {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-width: 44px;
		min-height: 44px;
		padding: 0;
		border-radius: 999px;
		background: rgba(var(--color-bg-rgb), 0.78);
		color: rgb(var(--color-text-dark));
		box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
		cursor: pointer;
		transition: transform 180ms var(--ease-out-quart), background 180ms var(--ease-out-quart), box-shadow 180ms var(--ease-out-quart);
	}

	.route-gallery-modal__close:hover,
	.route-gallery-modal__nav:hover {
		transform: translateY(-1px);
		background: rgba(var(--color-primary), 0.10);
	}

	.route-gallery-modal__close:focus-visible,
	.route-gallery-modal__nav:focus-visible,
	.route-gallery-modal__thumb:focus-visible {
		outline: 3px solid rgba(var(--color-accent), 0.88);
		outline-offset: 2px;
	}

	.route-gallery-modal__close {
		font-size: 1.85rem;
		line-height: 1;
	}

	.route-gallery-modal__stage {
		position: relative;
		margin: 16px 18px 0;
		border-radius: 26px;
		overflow: hidden;
		background:
			linear-gradient(180deg, rgba(var(--color-bg-rgb), 0.74), rgba(15, 23, 42, 0.12)),
			rgb(15, 23, 42);
	}

	.route-gallery-modal__image {
		display: block;
		width: 100%;
		height: min(68vh, 680px);
		object-fit: contain;
		background: rgba(15, 23, 42, 0.94);
	}

	.route-gallery-modal__nav {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		z-index: 2;
		font-size: 2rem;
	}

	.route-gallery-modal__nav--prev {
		left: 14px;
	}

	.route-gallery-modal__nav--next {
		right: 14px;
	}

	.route-gallery-modal__thumbs {
		display: flex;
		gap: 10px;
		overflow-x: auto;
		padding: 14px 18px 18px;
	}

	.route-gallery-modal__thumb {
		flex: 0 0 auto;
		width: 82px;
		height: 58px;
		padding: 0;
		border-radius: 14px;
		overflow: hidden;
		background: rgba(var(--color-bg-rgb), 0.72);
		opacity: 0.48;
		cursor: pointer;
		transition: opacity 180ms var(--ease-out-quart), transform 180ms var(--ease-out-quart), box-shadow 180ms var(--ease-out-quart);
	}

	.route-gallery-modal__thumb:hover {
		transform: translateY(-1px);
		opacity: 0.76;
	}

	.route-gallery-modal__thumb.is-active {
		opacity: 1;
		box-shadow: 0 0 0 2px rgba(var(--color-primary), 0.28);
	}

	.route-gallery-modal__thumb img {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

	body.route-gallery-open {
		overflow: hidden;
	}

	.benefits {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 16px;
	}

	.benefit {
		position: relative;
		overflow: hidden;
		min-height: 230px;
		padding: 22px 22px 26px;
		border-radius: 22px;
		background-image:
			linear-gradient(180deg, rgba(237, 246, 238, 0.18) 0%, rgba(237, 246, 238, 0.82) 72%, rgba(237, 246, 238, 0.96) 100%),
			var(--benefit-bg, none);
		background-size: cover, cover;
		background-position: center center, center center;
		background-repeat: no-repeat, no-repeat;
		border: 1px solid rgba(var(--color-border), 0.9);
		box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
	}

	.benefit::before {
		content: '';
		position: absolute;
		inset: 0;
		background: linear-gradient(180deg, rgba(var(--color-accent),0.1), rgba(var(--color-primary-dark), 0.4));
		pointer-events: none;
	}

	.benefit > * {
		position: relative;
		z-index: 1;
	}

	.benefit__icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 42px;
		height: 42px;
		border-radius: 14px;
		background: rgba(var(--color-primary), 0.12);
		color: rgb(var(--color-primary-dark));
		font-weight: 800;
	}

	.benefit h3 {
		margin: 14px 0 10px;
		font-size: 1.05rem;
	}

	.benefit p {
		margin: 0;
		color: rgba(255, 255, 255, 0.92);
		line-height: 1.68;
		/* max-width: 18ch; */
		text-shadow: 0 1px 2px rgba(15, 23, 42, 0.24);
	}

	.benefit h3 {
		color: #fff;
		text-shadow: 0 1px 2px rgba(15, 23, 42, 0.28);
	}

	.benefit__icon {
		background: rgba(255, 255, 255, 0.86);
		box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
	}

	.benefit:hover {
		transform: translateY(-2px) scale(1.01);
		transition: transform 0.22s ease, box-shadow 0.22s ease;
	}

	.timeline {
		padding: 20px;
		border-radius: 22px;
		background: linear-gradient(180deg, rgba(var(--color-primary), 0.08), rgba(255, 255, 255, 0.96));
		border: 1px solid rgba(var(--color-border), 0.88);
	}

	.timeline h3 {
		margin: 0 0 10px;
		font-size: 1.15rem;
	}

	.timeline__meta {
		display: flex;
		flex-wrap: wrap;
		gap: 8px 10px;
		align-items: center;
		margin-top: 12px;
	}

	.timeline__route-pill {
		display: inline-flex;
		align-items: center;
		min-height: 34px;
		padding: 0 13px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.12);
		border: 1px solid rgba(var(--color-primary), 0.18);
		color: rgb(var(--color-primary-dark));
		font-size: 0.92rem;
		font-weight: 700;
		letter-spacing: -0.01em;
		flex: 0 0 auto;
		white-space: nowrap;
	}

	.section__intro--inline [data-reverse-route-button] {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 34px;
		padding: 0 13px;
		border-radius: 999px;
		border: 1px solid rgba(var(--color-primary), 0.18);
		background: rgba(var(--color-white), 0.88);
		color: rgb(var(--color-text-dark));
		font-size: 0.92rem;
		font-weight: 800;
		letter-spacing: -0.01em;
		line-height: 1;
		cursor: pointer;
		white-space: nowrap;
		flex: 0 0 auto;
		transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
	}

	.section__intro--inline [data-reverse-route-button]:hover:not(:disabled) {
		transform: translateY(-1px);
		background: rgba(var(--color-white), 0.98);
		border-color: rgba(var(--color-primary), 0.26);
	}

	.section__intro--inline [data-reverse-route-button].is-active {
		background: rgba(var(--color-primary), 0.18);
		border-color: rgba(var(--color-primary), 0.34);
		color: rgb(var(--color-primary-dark));
		box-shadow: 0 10px 20px rgba(var(--color-primary), 0.10);
	}

	.section__intro--inline [data-reverse-route-button]:focus-visible {
		outline: 2px solid rgba(var(--color-primary), 0.55);
		outline-offset: 2px;
	}

	.timeline__chips {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		gap: 10px;
		margin: 16px 0 20px;
	}

	.chip {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-width: 68px;
		height: 38px;
		padding: 0 12px;
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.94);
		border: 1px solid rgba(var(--color-border), 0.9);
		font-weight: 700;
	}

	.booking__time-chip--timeline {
		color: rgb(var(--color-text-dark));
		cursor: pointer;
		transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
	}

	.booking__time-chip--timeline:hover {
		transform: translateY(-1px);
		border-color: rgba(var(--color-primary), 0.28);
		background: rgba(var(--color-white), 1);
		color: rgb(var(--color-primary-dark));
	}

	.booking__time-chip--timeline.is-active {
		background: linear-gradient(180deg, rgba(var(--color-primary), 0.16), rgba(var(--color-primary), 0.08));
		border-color: rgba(var(--color-primary), 0.32);
		color: rgb(var(--color-primary-dark));
		box-shadow: 0 10px 22px rgba(var(--color-primary), 0.10);
	}

	.timeline__empty {
		display: inline-flex;
		align-items: center;
		min-height: 38px;
		padding: 0 14px;
		border-radius: 999px;
		border: 1px dashed rgba(var(--color-border), 1);
		background: rgba(255, 255, 255, 0.72);
		color: rgb(var(--color-text-muted));
		font-size: 14px;
		font-weight: 600;
	}

	.seat-prices {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 16px;
		margin-top: 22px;
	}

	.seat-price-card {
		padding: 20px;
		border-radius: 22px;
		background: rgba(255, 255, 255, 0.92);
		border: 1px solid rgba(var(--color-border), 0.92);
		box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
	}

	.seat-price-card__icon {
		display: none;
		align-items: center;
		justify-content: center;
		width: 42px;
		height: 42px;
		border-radius: 14px;
		background: rgba(var(--color-primary), 0.12);
		font-size: 20px;
	}

	.seat-price-card h3 {
		margin: 14px 0 6px;
		font-size: 1.05rem;
	}

	.seat-price-card p {
		margin: 0;
		color: rgb(var(--color-text-muted));
		font-size: 14px;
	}

	.seat-price-card strong {
		display: block;
		margin-top: 14px;
		font-size: 1.55rem;
		color: rgb(var(--color-primary-dark));
		letter-spacing: -0.04em;
	}

	.route-card-grid {
		margin-top: 20px;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
	}

	.route-card-tile {
		position: relative;
		min-height: 240px;
		border-radius: 24px;
		overflow: hidden;
		border: 1px solid rgba(var(--color-border), 0.92);
		background: #dfeee2;
		box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
	}

	.route-card-tile__media {
		position: absolute;
		inset: 0;
		z-index: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		transform: scale(1.01);
		transition: transform 0.35s ease, filter 0.35s ease;
	}

	.route-card-tile::before {
		content: "";
		position: absolute;
		inset: 0;
		z-index: 0;
		background:
			linear-gradient(90deg, rgba(var(--color-primary), 0.55) 0%, rgba(var(--color-primary), 0.22) 28%, rgba(var(--color-primary), 0.04) 55%, rgba(255, 255, 255, 0) 72%),
			linear-gradient(135deg, rgba(var(--color-primary), 0.18) 0%, rgba(var(--color-hero-grad-end-rgb), 0.08) 42%, rgba(15, 23, 42, 0.22) 100%),
			linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(15, 23, 42, 0.12));
	}

	.route-card-tile::after {
		content: "";
		position: absolute;
		inset: 0;
		z-index: 0;
		background:
			linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, rgba(15, 23, 42, 0.08) 42%, rgba(15, 23, 42, 0.42) 100%),
			radial-gradient(circle at 20% 18%, rgba(var(--color-accent-rgb), 0.12), transparent 28%);
		mix-blend-mode: normal;
	}

	.route-card-tile:hover .route-card-tile__media {
		transform: scale(1.06);
		filter: saturate(1.06);
	}

	.route-card-tile__inner {
		position: relative;
		z-index: 1;
		height: 100%;
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		padding: 18px;
		color: #fff;
		text-shadow: 0 1px 2px rgba(15, 23, 42, 0.22);
	}

	.route-card-tile__badge {
		display: inline-flex;
		align-items: center;
		align-self: flex-start;
		padding: 7px 11px;
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.16);
		border: 1px solid rgba(255, 255, 255, 0.22);
		font-size: 11px;
		font-weight: 800;
		letter-spacing: 0.12em;
		text-transform: uppercase;
	}

	.route-card-tile__content {
		margin-top: auto;
		padding-top: 20px;
		transition: transform 0.28s ease;
	}

	.route-card-tile__content h3 {
		margin: 0 0 8px;
		font-size: 1.18rem;
		letter-spacing: -0.03em;
		color: rgb(var(--color-white));
	}

	.route-card-tile__meta {
		display: flex;
		flex-wrap: wrap;
		gap: 8px 12px;
		font-size: 13px;
		color: rgba(255, 255, 255, 0.86);
	}

	.route-card-tile__price {
		margin-top: 12px;
		font-size: 1.45rem;
		font-weight: 800;
		letter-spacing: -0.04em;
	}

	.route-card-tile__button {
		margin-top: 16px;
		width: 100%;
		opacity: 0;
		transform: translateY(10px);
		pointer-events: none;
		transition: opacity 0.22s ease, transform 0.22s ease, background 0.22s ease, color 0.22s ease;
		background: rgba(255, 255, 255, 0.96);
		color: rgb(var(--color-text-dark));
	}

	.route-card-tile:hover .route-card-tile__button,
	.route-card-tile:focus-within .route-card-tile__button {
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}

	.route-card-tile:hover .route-card-tile__content,
	.route-card-tile:focus-within .route-card-tile__content {
		transform: translateY(-6px);
	}

	.stop-lists {
		margin-top: 22px;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
	}

	.stop-tabs {
		margin-top: 18px;
		display: inline-flex;
		flex-wrap: wrap;
		gap: 8px;
		padding: 6px;
		border-radius: 18px;
		background: rgba(var(--color-bg-rgb), 0.48);
		border: 1px solid rgba(var(--color-border), 0.82);
	}

	.stop-tabs__tab {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 40px;
		padding: 0 14px;
		border: 0;
		border-radius: 12px;
		background: transparent;
		color: rgb(var(--color-text-dark));
		font-size: 13px;
		font-weight: 800;
		cursor: pointer;
		transition: background 180ms var(--ease-out-quart), color 180ms var(--ease-out-quart), box-shadow 180ms var(--ease-out-quart);
	}

	.stop-tabs__tab:hover {
		background: rgba(255, 255, 255, 0.92);
	}

	.stop-tabs__tab.is-active {
		background: rgba(var(--color-primary), 0.12);
		color: rgb(var(--color-primary-dark));
		box-shadow: 0 8px 18px rgba(var(--color-primary), 0.08);
	}

	.stop-panels {
		margin-top: 14px;
	}

	.stop-panel[hidden] {
		display: none;
	}

	.stop-map-panel {
		padding: 2px 0 0;
	}

	#diem-don-tra [data-test-map-root] {
		width: 100%;
	}

	#diem-don-tra [data-test-map-canvas] {
		height: clamp(300px, 42vw, 380px) !important;
	}

	.stop-list-card {
		padding: 20px;
		border-radius: 22px;
		background: rgba(255, 255, 255, 0.92);
		border: 1px solid rgba(var(--color-border), 0.92);
		box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
	}

	.stop-list-card h3 {
		margin: 0 0 8px;
		font-size: 1.1rem;
	}

	.stop-list-card p {
		margin: 0 0 14px;
		color: rgb(var(--color-text-muted));
		font-size: 14px;
	}

	.stop-list-card[data-stop-kind] h3 {
		display: flex;
		align-items: center;
		gap: 10px;
	}

	.stop-list {
		display: flex;
		flex-direction: column;
		gap: 10px;
	}

	.stop-list__empty {
		padding: 14px 16px;
		border-radius: 16px;
		border: 1px dashed rgba(var(--color-border), 0.95);
		background: rgba(var(--color-bg-rgb), 0.32);
		color: rgb(var(--color-text-muted));
		font-size: 14px;
		font-weight: 600;
	}

	.stop-item {
		display: flex;
		align-items: flex-start;
		gap: 12px;
		padding: 12px 14px;
		border-radius: 16px;
		background: linear-gradient(180deg, rgba(var(--color-bg-rgb), 0.44), rgba(255, 255, 255, 0.96));
		border: 1px solid rgba(var(--color-border), 0.85);
	}

	.stop-item__index {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 30px;
		height: 30px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.12);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 800;
		flex: 0 0 auto;
	}

	.stop-item__body {
		min-width: 0;
		flex: 1 1 auto;
	}

	.stop-item__title {
		font-weight: 800;
		color: rgb(var(--color-text-dark));
		line-height: 1.4;
	}

	.stop-item__address {
		margin-top: 4px;
		color: rgb(var(--color-text-body));
		font-size: 13px;
		line-height: 1.5;
	}

	.stop-item__meta {
		margin-top: 4px;
		display: flex;
		flex-wrap: wrap;
		gap: 6px;
	}

	.stop-pill {
		display: inline-flex;
		align-items: center;
		padding: 4px 8px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.08);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 700;
	}

	.stop-pill--link {
		padding: 0;
		background: transparent;
	}

	.stop-map-link {
		display: inline-flex;
		align-items: center;
		min-height: 24px;
		padding: 4px 8px;
		border-radius: 999px;
		background: rgba(var(--color-primary), 0.08);
		color: rgb(var(--color-primary-dark));
		font-size: 12px;
		font-weight: 700;
		text-decoration: none;
		transition: background 0.18s ease, transform 0.18s ease, color 0.18s ease;
	}

	.stop-map-link:hover {
		transform: translateY(-1px);
		background: rgba(var(--color-primary), 0.14);
		color: rgb(var(--color-primary-dark));
	}

	.stop-item--default {
		border-color: rgba(var(--color-primary), 0.28);
		box-shadow: 0 12px 24px rgba(var(--color-primary), 0.08);
	}

	.policy {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
	}

	.policy__panel {
		padding: 22px;
		border-radius: 24px;
		background: rgba(255, 255, 255, 0.9);
		border: 1px solid rgba(var(--color-border), 0.92);
		box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
	}

	.policy__panel h3 {
		margin: 0 0 14px;
		font-size: 1.15rem;
	}

	.policy__list {
		margin: 0;
		padding-left: 18px;
		color: rgb(var(--color-text-body));
	}

	.policy__list li+li {
		margin-top: 12px;
	}

	.policy__steps .step+.step {
		margin-top: 14px;
		padding-top: 14px;
		border-top: 1px solid rgba(var(--color-border), 0.82);
	}

	.policy__steps strong {
		display: block;
		margin-bottom: 4px;
		color: rgb(var(--color-text-dark));
	}

	.policy__steps span {
		color: rgb(var(--color-text-body));
	}

	.refund {
		margin-top: 16px;
		padding: 24px;
		border-radius: 24px;
		background: linear-gradient(135deg, rgba(var(--color-primary), 0.08), rgba(255, 255, 255, 0.96));
		border: 1px solid rgba(var(--color-border), 0.88);
	}

	.refund h3 {
		margin: 8px 0 12px;
		font-size: 1.2rem;
	}

	.refund p {
		margin: 0;
		color: rgb(var(--color-text-body));
	}

	.refund p+p {
		margin-top: 10px;
	}



	@media (max-width: 1024px) {

		.landing-hero__grid,
		.policy,
		.seat-prices,
		.route-card-grid,
		.stop-lists {
			grid-template-columns: 1fr;
		}

		.summary-strip,
		.benefits {
			grid-template-columns: repeat(2, minmax(0, 1fr));
		}

		.booking__header {
			flex-direction: column;
		}

		.booking__price {
			text-align: left;
		}

		.route-gallery__preview {
			min-height: 340px;
		}
	}

	@media (max-width: 760px) {
		.landing-shell {
			width: min(1180px, calc(100% - 20px));
		}

	

		.landing-topbar {
			padding-top: 10px;
		}

		.landing-topbar__inner {
			border-radius: 24px;
			padding: 10px 12px;
			gap: 10px;
			justify-content: space-between;
		}

		.landing-topbar__nav,
		.landing-topbar__actions {
			display: none;
		}

		.landing-topbar__mobile {
			display: flex;
			position: relative;
		}

		.landing-topbar__mobile-panel {
			left: auto;
			right: 0;
			width: min(320px, calc(100vw - 24px));
			min-width: 240px;
			padding: 14px;
		}

		.landing-topbar__mobile-toggle {
			width: 42px;
			height: 42px;
		}

		.landing-hero {
			padding: 0 0 24px;
		}

		.landing-hero__image {
			object-position: center top;
			transform: scale(1.06);
		}

		.grid-2,
		.benefits,
		.seat-prices,
		.route-card-grid,
		.stop-lists {
			grid-template-columns: 1fr;
		}

		.landing-hero h1 {
			font-size: clamp(1.8rem, 10vw, 2.8rem);
		}

		.landing-hero__grid {
			padding-top: 84px;
		}

		.summary-strip {
			display: grid;
			grid-template-columns: repeat(2, minmax(0, 1fr));
			gap: 10px;
		}

		.stop-tabs {
			width: 100%;
		}

		.stop-tabs__tab {
			flex: 1 1 auto;
		}

		#diem-don-tra [data-test-map-canvas] {
			height: 280px !important;
		}

		.summary-card {
			padding: 12px 10px;
		}

		.summary-card .label {
			font-size: 11px;
			letter-spacing: 0.06em;
		}

		.summary-card .value {
			margin-top: 8px;
			font-size: 1rem;
		}

		.booking__seat-types-grid {
			grid-template-columns: repeat(2, minmax(0, 1fr));
			gap: 10px;
		}

		.booking__seat-type {
			min-height: 62px;
			padding: 10px 11px 9px;
			grid-template-columns: minmax(0, 1fr);
			gap: 4px;
			border-radius: 12px;
		}

		.booking__seat-type[data-seat-type="double"] {
			grid-column: 1 / -1;
		}

		.benefit {
			min-height: 200px;
		}

		.booking__seat-text strong {
			font-size: 11px;
			letter-spacing: 0.04em;
		}

		.booking__seat-price {
			font-size: 11px;
			margin-top: 3px;
		}

		.timeline {
			padding: 16px;
		}

		.timeline__meta {
			margin-top: 10px;
		}

		.timeline__route-pill {
			width: 100%;
			justify-content: center;
		}

		.timeline__chips {
			gap: 8px;
			margin: 14px 0 18px;
		}

		.booking__time-chip--timeline,
		.timeline__empty {
			min-height: 40px;
		}

		.booking-route-content {
			padding-top: 22px;
		}

		.booking-route-content__box {
			padding: 16px 14px;
			border-radius: 18px;
		}

		.route-gallery {
			margin-top: 14px;
		}

		.route-gallery__preview {
			grid-template-columns: 1fr 1fr;
			grid-template-rows: auto auto;
			gap: 10px;
			min-height: unset;
		}

		.route-gallery__tile {
			min-height: 140px;
			border-radius: 18px;
		}

		.route-gallery__tile--1 {
			grid-column: 1 / -1;
			grid-row: auto;
			min-height: 220px;
		}

		.route-gallery__tile--2,
		.route-gallery__tile--3 {
			grid-column: auto;
			grid-row: auto;
		}

		.route-gallery__badge {
			top: 10px;
			left: 10px;
			min-height: 28px;
			padding: 0 10px;
			font-size: 11px;
		}

		.route-gallery__more {
			right: 10px;
			bottom: 10px;
			padding: 9px 10px;
		}

		.route-gallery__more-count {
			font-size: 1.05rem;
		}

		.route-gallery-modal {
			padding: 12px;
		}

		.route-gallery-modal__dialog {
			border-radius: 24px;
			max-height: 94vh;
		}

		.route-gallery-modal__head {
			padding: 14px 14px 0;
		}

		.route-gallery-modal__stage {
			margin: 12px 14px 0;
			border-radius: 20px;
		}

		.route-gallery-modal__image {
			height: min(64vh, 560px);
		}

		.route-gallery-modal__nav {
			min-width: 42px;
			min-height: 42px;
			font-size: 1.8rem;
		}

		.route-gallery-modal__nav--prev {
			left: 8px;
		}

		.route-gallery-modal__nav--next {
			right: 8px;
		}

		.route-gallery-modal__thumbs {
			padding: 12px 14px 14px;
		}

		.section {
			padding-top: 18px;
		}
	}

	@media (prefers-reduced-motion: reduce) {
		html.landing-route-motion .landing-route .landing-motion,
		html.landing-route-motion .landing-route .landing-motion--stagger > * {
			animation: none !important;
			transition: none !important;
			transform: none !important;
			filter: none !important;
			opacity: 1 !important;
		}

		.route-card-tile::before {
			transition: none !important;
		}

		.route-gallery__tile,
		.route-gallery-modal__close,
		.route-gallery-modal__nav,
		.route-gallery-modal__thumb {
			transition: none !important;
		}

	}

	</style>
