.iy-ms-page {
	--iy-ms-bg: #081222;
	--iy-ms-surface: #ffffff;
	--iy-ms-surface-alt: #f3f6fb;
	--iy-ms-text: #0f1726;
	--iy-ms-muted: #5d677a;
	--iy-ms-accent: #f4b93c;
	--iy-ms-accent-dark: #d79212;
	--iy-ms-radius: 24px;
	--iy-ms-shadow: 0 20px 50px rgba(3, 10, 20, 0.16);
	--iy-ms-max-width: 1180px;
	position: relative;
	overflow: clip;
	background:
		radial-gradient(circle at top left, rgba(244, 185, 60, 0.14), transparent 28%),
		radial-gradient(circle at top right, rgba(90, 140, 255, 0.09), transparent 24%),
		var(--iy-ms-bg);
	color: var(--iy-ms-text);
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	line-height: 1.6;
	padding-bottom: 0;
	overflow-x: clip;
}

.iy-ms-page,
.iy-ms-page * {
	box-sizing: border-box;
}

.iy-ms-page.iy-ms-style-default {
	--iy-ms-bg: #09111f;
	--iy-ms-surface: #ffffff;
	--iy-ms-surface-alt: #f2f5fa;
	--iy-ms-text: #0f1726;
	--iy-ms-muted: #5a6576;
	--iy-ms-accent: #f2ba41;
	--iy-ms-accent-dark: #cf8f12;
}

.iy-ms-page.iy-ms-style-exotic {
	--iy-ms-bg: #061815;
	--iy-ms-surface: #f7fbf7;
	--iy-ms-surface-alt: #eaf4ee;
	--iy-ms-text: #0d1a17;
	--iy-ms-muted: #51635d;
	--iy-ms-accent: #7fd36b;
	--iy-ms-accent-dark: #2d8e57;
}

.iy-ms-page.iy-ms-style-road_trip {
	--iy-ms-bg: #17130f;
	--iy-ms-surface: #fffaf4;
	--iy-ms-surface-alt: #f7eee5;
	--iy-ms-text: #201710;
	--iy-ms-muted: #6a5d52;
	--iy-ms-accent: #ff8a3d;
	--iy-ms-accent-dark: #c85f1e;
}

.iy-ms-page.iy-ms-style-premium {
	--iy-ms-bg: #07101f;
	--iy-ms-surface: #ffffff;
	--iy-ms-surface-alt: #eef2f8;
	--iy-ms-text: #101826;
	--iy-ms-muted: #5b6475;
	--iy-ms-accent: #c9a35c;
	--iy-ms-accent-dark: #8b6730;
}

.iy-ms-page.iy-ms-style-youth {
	--iy-ms-bg: #081524;
	--iy-ms-surface: #fefefe;
	--iy-ms-surface-alt: #eef6ff;
	--iy-ms-text: #0d1730;
	--iy-ms-muted: #55617c;
	--iy-ms-accent: #5cc7ff;
	--iy-ms-accent-dark: #1d79c0;
}

.iy-ms-page::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 20%),
		radial-gradient(circle at 50% 0, rgba(255, 255, 255, 0.08), transparent 32%);
	pointer-events: none;
}

.iy-ms-container {
	width: min(100%, var(--iy-ms-max-width));
	margin: 0 auto;
	padding-inline: clamp(1rem, 3vw, 2rem);
	position: relative;
	z-index: 1;
}

.iy-ms-narrow {
	max-width: 46rem;
}

.iy-ms-hero {
	position: relative;
	min-height: min(92vh, 920px);
	display: flex;
	align-items: flex-start;
	padding: clamp(4.5rem, 6vw, 7rem) 0 clamp(3rem, 5vw, 4.5rem);
	color: #fff;
}

.iy-ms-hero__media {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(5, 12, 24, 0.28), rgba(5, 12, 24, 0.78)),
		linear-gradient(135deg, rgba(22, 32, 52, 0.88), rgba(8, 17, 34, 0.98));
}

.iy-ms-hero__picture,
.iy-ms-hero__image {
	display: block;
	width: 100%;
	height: 100%;
}

.iy-ms-hero__image {
	object-fit: cover;
	object-position: center;
}

.iy-ms-hero__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(7, 13, 22, 0.12), rgba(7, 13, 22, 0.72)),
		linear-gradient(90deg, rgba(7, 13, 22, 0.7), rgba(7, 13, 22, 0.22));
}

.iy-ms-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	justify-items: center;
	gap: clamp(0.8rem, 1.8vw, 1.2rem);
}

.iy-ms-hero__content {
	max-width: 46rem;
	width: 100%;
	justify-self: start;
	color: #fff;
}

.iy-ms-brand-mark {
	display: flex;
	width: 100%;
	justify-content: center;
	align-items: center;
	padding-top: 0;
	margin-bottom: clamp(0.15rem, 0.6vw, 0.4rem);
}

.iy-ms-brand-mark__image {
	display: block;
	width: auto;
	max-width: min(320px, 72vw);
	max-height: clamp(56px, 6vw, 72px);
	height: auto;
	object-fit: contain;
	filter: drop-shadow(0 10px 18px rgba(3, 8, 16, 0.14));
}

.iy-ms-brand-mark__fallback {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	max-width: min(300px, 70vw);
	min-height: 0;
	padding: 0.15rem 0;
	color: rgba(255, 255, 255, 0.97);
	font-size: clamp(0.95rem, 1.7vw, 1.2rem);
	font-weight: 700;
	letter-spacing: 0.015em;
	text-transform: none;
	text-align: center;
}

.iy-ms-page .iy-ms-hero .iy-ms-eyebrow,
.iy-ms-page .iy-ms-hero .iy-ms-hero__title,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body p,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body li,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body a {
	color: #fff;
}

.iy-ms-page .iy-ms-hero .iy-ms-hero__body {
	color: rgba(255, 255, 255, 0.9);
}

.iy-ms-page .iy-ms-hero .iy-ms-hero__body p,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body li,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body a {
	color: inherit;
}

.iy-ms-eyebrow {
	margin: 0 0 0.75rem;
	font-size: 0.84rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: rgba(255, 255, 255, 0.82);
}

.iy-ms-hero__title,
.iy-ms-section__title,
.iy-ms-final-cta__title {
	margin: 0;
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.02;
}

.iy-ms-hero__title {
	font-size: clamp(2.8rem, 6vw, 5.8rem);
	max-width: 11.5ch;
	text-wrap: balance;
	color: #fff;
	text-shadow: 0 12px 28px rgba(4, 10, 20, 0.18);
}

.iy-ms-hero__body,
.iy-ms-section__body,
.iy-ms-final-cta__body {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.9);
}

.iy-ms-hero__body {
	margin-top: 1rem;
	max-width: 42rem;
}

.iy-ms-actions,
.iy-ms-section__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	margin-top: 1.5rem;
}

.iy-ms-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.25rem;
	padding: 0.85rem 1.25rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-size: 0.98rem;
	font-weight: 700;
	text-decoration: none;
	transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, color 180ms ease, border-color 180ms ease;
	box-shadow: 0 12px 26px rgba(0, 0, 0, 0.16);
	will-change: transform;
}

.iy-ms-btn span {
	position: relative;
	z-index: 1;
}

.iy-ms-btn--primary {
	background: linear-gradient(135deg, var(--iy-ms-accent), var(--iy-ms-accent-dark));
	color: #10131a;
}

.iy-ms-btn--secondary {
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(10px);
}

.iy-ms-page .iy-ms-btn--secondary {
	box-shadow: none;
}

.iy-ms-btn:hover,
.iy-ms-btn:focus-visible {
	transform: translateY(-2px);
	box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}

.iy-ms-section {
	padding: clamp(3.25rem, 6vw, 6.25rem) 0;
	position: relative;
	z-index: 1;
}

.iy-ms-section--positioning,
.iy-ms-section--gallery,
.iy-ms-section--faq {
	background: rgba(255, 255, 255, 0.02);
}

.iy-ms-section--mid-cta {
	padding-top: 0;
}

.iy-ms-section--summary {
	padding-top: clamp(1.4rem, 3vw, 2.4rem);
	padding-bottom: clamp(2rem, 4vw, 3.4rem);
}

.iy-ms-summary {
	border-radius: calc(var(--iy-ms-radius) + 4px);
	padding: clamp(1rem, 2.6vw, 1.15rem);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(246, 249, 253, 0.97)),
		linear-gradient(180deg, rgba(12, 24, 41, 0.03), rgba(12, 24, 41, 0));
	box-shadow: 0 18px 42px rgba(5, 12, 22, 0.14);
	border: 1px solid rgba(15, 23, 38, 0.08);
	color: var(--iy-ms-text);
	position: relative;
	overflow: hidden;
}

.iy-ms-summary::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, var(--iy-ms-accent), var(--iy-ms-accent-dark));
	opacity: 0.85;
}

.iy-ms-summary .iy-ms-eyebrow {
	color: #0c2330;
	margin-bottom: 0.7rem;
	font-size: clamp(1rem, 1.8vw, 1.18rem);
	font-weight: 800;
	letter-spacing: 0;
	text-transform: none;
}

.iy-ms-summary__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.75rem;
	min-width: 0;
	margin-top: 0.05rem;
}

.iy-ms-summary__item {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	min-width: 0;
	padding: 0.92rem 0.98rem;
	border-radius: 18px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(249, 251, 255, 0.96));
	border: 1px solid rgba(15, 23, 38, 0.08);
	box-shadow: 0 8px 18px rgba(7, 16, 28, 0.04);
}

.iy-ms-summary__label {
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	text-transform: none;
	color: #526172;
}

.iy-ms-summary__value {
	font-size: 1.03rem;
	font-weight: 800;
	line-height: 1.38;
	color: var(--iy-ms-text);
	overflow-wrap: anywhere;
}

.iy-ms-summary__secondary {
	font-size: 0.92rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--iy-ms-accent-dark);
	overflow-wrap: anywhere;
}

.iy-ms-section--final-cta {
	padding-bottom: clamp(4.5rem, 8vw, 7rem);
}

.iy-ms-section__title {
	font-size: clamp(1.9rem, 3vw, 3rem);
	color: inherit;
}

.iy-ms-section__body {
	margin-top: 0.9rem;
	color: var(--iy-ms-muted);
	font-size: 1.02rem;
}

.iy-ms-section__body--wide {
	max-width: 38rem;
}

.iy-ms-section-heading {
	margin-bottom: 1.5rem;
}

.iy-ms-card {
	border-radius: var(--iy-ms-radius);
	background: var(--iy-ms-surface);
	color: var(--iy-ms-text);
	box-shadow: var(--iy-ms-shadow);
	overflow: hidden;
}

.iy-ms-card__body {
	color: var(--iy-ms-muted);
}

.iy-ms-route-grid,
.iy-ms-review-grid {
	display: grid;
	gap: 1.2rem;
	min-width: 0;
}

.iy-ms-route-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.iy-ms-route-card__media,
.iy-ms-experience__media,
.iy-ms-gallery__item {
	position: relative;
	overflow: hidden;
	max-width: 100%;
}

.iy-ms-route-card__image,
.iy-ms-experience__image,
.iy-ms-gallery__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 220ms ease;
}

.iy-ms-route-card:hover .iy-ms-route-card__image,
.iy-ms-experience:hover .iy-ms-experience__image,
.iy-ms-gallery__item:hover .iy-ms-gallery__image {
	transform: scale(1.04);
}

.iy-ms-route-card__media {
	aspect-ratio: 16 / 10;
	background: var(--iy-ms-surface-alt);
}

.iy-ms-route-card__content {
	padding: 1.15rem 1.15rem 1.35rem;
	min-width: 0;
}

.iy-ms-route-card h3 {
	margin: 0 0 0.4rem;
	font-size: 1.15rem;
	line-height: 1.2;
}

.iy-ms-route-card__places {
	margin: 0 0 0.7rem;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--iy-ms-accent-dark);
}

.iy-ms-mid-cta {
	border-radius: calc(var(--iy-ms-radius) + 6px);
	padding: clamp(1.6rem, 4vw, 2.4rem);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.04)),
		linear-gradient(135deg, rgba(9, 17, 31, 0.96), rgba(12, 24, 41, 0.92));
	color: #fff;
	box-shadow: var(--iy-ms-shadow);
}

.iy-ms-mid-cta .iy-ms-section__title {
	color: #fff;
}

.iy-ms-mid-cta .iy-ms-btn--primary {
	color: #12151d;
}

.iy-ms-experience {
	display: grid;
	grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
	gap: 1.3rem;
	align-items: center;
	margin-top: 1.25rem;
	min-width: 0;
}

.iy-ms-experience:first-child {
	margin-top: 0;
}

.iy-ms-experience__media {
	border-radius: var(--iy-ms-radius);
	box-shadow: var(--iy-ms-shadow);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background: var(--iy-ms-surface-alt);
	min-width: 0;
}

.iy-ms-experience__content {
	padding: 0.25rem 0.25rem 0.25rem 0;
	min-width: 0;
}

.iy-ms-experience--reverse .iy-ms-experience__media {
	order: 2;
}

.iy-ms-experience--reverse .iy-ms-experience__content {
	order: 1;
	padding: 0.25rem 0 0.25rem 0.25rem;
}

.iy-ms-experience--card {
	grid-template-columns: 1fr;
	background: var(--iy-ms-surface);
	border-radius: calc(var(--iy-ms-radius) + 4px);
	padding: 1.1rem;
	box-shadow: var(--iy-ms-shadow);
	min-width: 0;
}

.iy-ms-experience--card .iy-ms-experience__media {
	aspect-ratio: 16 / 9;
}

.iy-ms-experience--card .iy-ms-experience__content,
.iy-ms-experience--dark .iy-ms-experience__content,
.iy-ms-experience--highlight .iy-ms-experience__content {
	padding: 0.25rem;
}

.iy-ms-experience--dark {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
	border-radius: calc(var(--iy-ms-radius) + 4px);
	padding: 1rem;
}

.iy-ms-experience--dark .iy-ms-experience__content {
	color: #fff;
}

.iy-ms-experience--dark .iy-ms-section__title,
.iy-ms-experience--dark .iy-ms-section__body,
.iy-ms-experience--dark .iy-ms-caption {
	color: rgba(255, 255, 255, 0.92);
}

.iy-ms-experience--highlight {
	background: linear-gradient(135deg, rgba(244, 185, 60, 0.22), rgba(255, 255, 255, 0.12));
	border-radius: calc(var(--iy-ms-radius) + 4px);
	padding: 1rem;
}

.iy-ms-caption {
	margin: 0.9rem 0 0;
	font-size: 0.94rem;
	font-weight: 700;
	color: var(--iy-ms-accent-dark);
}

.iy-ms-gallery {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.9rem;
	min-width: 0;
}

.iy-ms-gallery__item {
	border-radius: 20px;
	background: var(--iy-ms-surface);
	box-shadow: var(--iy-ms-shadow);
	min-width: 0;
}

.iy-ms-gallery__image {
	aspect-ratio: 1 / 1;
}

.iy-ms-gallery__caption {
	padding: 0.8rem 0.95rem 1rem;
	font-size: 0.94rem;
	color: var(--iy-ms-muted);
}

.iy-ms-review-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.iy-ms-review-card {
	padding: 1.15rem;
	border: 1px solid rgba(15, 23, 38, 0.08);
	min-width: 0;
}

.iy-ms-review-card__stars {
	display: flex;
	gap: 0.18rem;
	color: var(--iy-ms-accent-dark);
	font-size: 1rem;
}

.iy-ms-review-card__quote {
	margin: 0.9rem 0 1rem;
	color: var(--iy-ms-text);
	font-size: 0.98rem;
	overflow-wrap: anywhere;
}

.iy-ms-review-card__name {
	margin: 0;
	font-size: 0.92rem;
	font-weight: 700;
	color: var(--iy-ms-muted);
	overflow-wrap: anywhere;
}

.iy-ms-checklist {
	list-style: none;
	padding: 0;
	margin: 1.4rem 0 0;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.85rem;
}

.iy-ms-checklist__item {
	display: flex;
	align-items: flex-start;
	gap: 0.7rem;
	padding: 1rem 1rem 1rem 1.05rem;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.04);
	color: inherit;
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.iy-ms-checklist__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.6rem;
	height: 1.6rem;
	flex: 0 0 1.6rem;
	border-radius: 999px;
	background: var(--iy-ms-accent);
	color: #08111b;
	font-weight: 800;
}

.iy-ms-checklist__text {
	color: inherit;
}

.iy-ms-faq {
	display: grid;
	gap: 0.8rem;
	margin-top: 1.3rem;
}

.iy-ms-faq__item {
	border-radius: 20px;
	background: var(--iy-ms-surface);
	box-shadow: var(--iy-ms-shadow);
	overflow: hidden;
}

.iy-ms-faq__summary {
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.1rem 1.15rem;
	cursor: pointer;
	font-weight: 700;
}

.iy-ms-faq__summary::-webkit-details-marker {
	display: none;
}

.iy-ms-faq__chevron {
	display: inline-flex;
	width: 1.8rem;
	height: 1.8rem;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--iy-ms-surface-alt);
	color: var(--iy-ms-text);
	font-size: 1.1rem;
	flex: 0 0 1.8rem;
	transition: transform 180ms ease;
}

.iy-ms-faq__item[open] .iy-ms-faq__chevron {
	transform: rotate(45deg);
}

.iy-ms-faq__answer {
	padding: 0 1.15rem 1.15rem;
	color: var(--iy-ms-muted);
}

.iy-ms-faq__note {
	margin: 0.9rem 0 0;
	font-size: 0.92rem;
	color: var(--iy-ms-accent-dark);
}

.iy-ms-final-cta {
	border-radius: calc(var(--iy-ms-radius) + 6px);
	padding: clamp(1.7rem, 4vw, 2.5rem);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
		linear-gradient(135deg, #09111f, #13263d);
	color: #fff;
	box-shadow: var(--iy-ms-shadow);
}

.iy-ms-final-cta__title {
	font-size: clamp(2rem, 3.5vw, 3.25rem);
}

.iy-ms-final-cta__body {
	margin: 0.9rem 0 0;
	max-width: 44rem;
	color: rgba(255, 255, 255, 0.88);
}

.iy-ms-final-cta .iy-ms-btn--primary {
	margin-top: 1.35rem;
}

.iy-ms-sticky-cta {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 20;
	padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom));
	background: linear-gradient(180deg, rgba(7, 13, 22, 0), rgba(7, 13, 22, 0.82));
}

.iy-ms-sticky-cta__inner {
	display: flex;
	justify-content: center;
}

.iy-ms-page--has-sticky {
	padding-bottom: 0;
}

.iy-ms-page--has-sticky + .iy-ms-sticky-cta {
	display: flex;
}

.iy-ms-sticky-cta .iy-ms-btn {
	width: min(100%, 34rem);
}

@media (max-width: 1024px) {
	.iy-ms-sticky-cta {
		display: block;
	}

	.iy-ms-page--has-sticky {
		padding-bottom: 8.4rem;
	}
}

@media (max-width: 900px) {
	.iy-ms-route-grid,
	.iy-ms-review-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.iy-ms-experience {
		grid-template-columns: 1fr;
	}

	.iy-ms-experience--reverse .iy-ms-experience__media,
	.iy-ms-experience--reverse .iy-ms-experience__content {
		order: initial;
		padding: 0.25rem 0;
	}
}

@media (max-width: 767px) {
	.iy-ms-hero {
		min-height: 84vh;
		padding-top: 4.25rem;
	}

	.iy-ms-section--summary {
		padding-top: 1.5rem;
		padding-bottom: 1.5rem;
	}

	.iy-ms-summary {
		padding: 0.95rem;
	}

	.iy-ms-summary__grid {
		grid-template-columns: 1fr;
	}

	.iy-ms-summary__item {
		padding: 0.9rem 0.95rem;
	}

	.iy-ms-hero__title {
		font-size: clamp(2.25rem, 11vw, 3.5rem);
		max-width: 12ch;
	}

	.iy-ms-hero__body,
	.iy-ms-section__body,
	.iy-ms-final-cta__body {
		font-size: 0.98rem;
	}

	.iy-ms-route-grid,
	.iy-ms-review-grid,
	.iy-ms-checklist,
	.iy-ms-gallery {
		grid-template-columns: 1fr;
	}

	.iy-ms-actions,
	.iy-ms-section__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.iy-ms-btn {
		width: 100%;
	}

	.iy-ms-mid-cta .iy-ms-btn,
	.iy-ms-final-cta .iy-ms-btn {
		width: 100%;
	}

	.iy-ms-faq__summary {
		padding: 1rem;
	}

	.iy-ms-faq__answer {
		padding-inline: 1rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.iy-ms-page *,
	.iy-ms-page *::before,
	.iy-ms-page *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* Final polish overrides */
.iy-ms-page {
	min-height: 100vh;
}

.iy-ms-body {
	margin: 0;
	background: var(--iy-ms-bg);
	color: var(--iy-ms-text);
}

.iy-ms-page .iy-ms-hero {
	margin-top: -1px;
}

.iy-ms-page .iy-ms-route-card__content {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	padding: 1.35rem 1.25rem 1.55rem;
}

.iy-ms-page .iy-ms-route-card h3 {
	margin: 0;
	font-size: 1.3rem;
	line-height: 1.1;
	color: #102033;
}

.iy-ms-page .iy-ms-route-card__places {
	margin: 0;
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.55;
	color: var(--iy-ms-accent-dark);
}

.iy-ms-page .iy-ms-route-card .iy-ms-card__body {
	color: #39485b;
	font-size: 1rem;
	line-height: 1.72;
}

.iy-ms-page .iy-ms-experience__content {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	padding: 0.35rem 0.15rem 0.35rem 0;
}

.iy-ms-page .iy-ms-experience--card .iy-ms-experience__content,
.iy-ms-page .iy-ms-experience--dark .iy-ms-experience__content,
.iy-ms-page .iy-ms-experience--highlight .iy-ms-experience__content {
	padding: 0.35rem;
}

.iy-ms-page .iy-ms-experience__content .iy-ms-section__title {
	max-width: none;
	font-size: clamp(1.7rem, 2.8vw, 2.5rem);
	line-height: 1.08;
}

.iy-ms-page .iy-ms-experience__content .iy-ms-section__body {
	font-size: 1.02rem;
	line-height: 1.78;
}

.iy-ms-page .iy-ms-experience--dark .iy-ms-section__body {
	color: rgba(255, 255, 255, 0.95);
}

.iy-ms-page .iy-ms-experience--highlight {
	background:
		radial-gradient(circle at 0 0, rgba(255, 214, 120, 0.18), transparent 26%),
		linear-gradient(135deg, rgba(255, 248, 230, 0.99), rgba(255, 255, 255, 0.98));
	border: 1px solid rgba(243, 182, 63, 0.3);
}

.iy-ms-page .iy-ms-experience--dark .iy-ms-section__title,
.iy-ms-page .iy-ms-experience--dark .iy-ms-section__body,
.iy-ms-page .iy-ms-experience--dark .iy-ms-caption {
	color: rgba(255, 255, 255, 0.95);
}

.iy-ms-page .iy-ms-caption {
	font-size: 0.97rem;
	line-height: 1.55;
}

.iy-ms-page .iy-ms-review-card {
	padding: 1.35rem;
}

.iy-ms-page .iy-ms-review-card__stars {
	font-size: 1.05rem;
	letter-spacing: 0.08em;
}

.iy-ms-page .iy-ms-review-card__quote {
	font-size: 1rem;
	line-height: 1.72;
}

.iy-ms-page .iy-ms-review-card__name {
	font-size: 0.95rem;
}

.iy-ms-page .iy-ms-checklist__item {
	padding: 1.1rem 1.05rem;
	gap: 0.8rem;
}

.iy-ms-page .iy-ms-checklist__icon {
	font-size: 0.92rem;
}

.iy-ms-page .iy-ms-checklist__text {
	font-size: 1rem;
	line-height: 1.62;
}

.iy-ms-page .iy-ms-faq__summary {
	padding: 1.2rem 1.25rem;
	font-size: 1.02rem;
	line-height: 1.5;
	color: #162233;
}

.iy-ms-page .iy-ms-faq__chevron {
	font-size: 1.15rem;
	font-weight: 800;
}

.iy-ms-page .iy-ms-faq__answer {
	font-size: 1rem;
	line-height: 1.75;
}

.iy-ms-page .iy-ms-eyebrow {
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.92rem;
	font-weight: 650;
	line-height: 1.35;
	color: rgba(255, 255, 255, 0.86);
}

.iy-ms-page .iy-ms-section--summary .iy-ms-summary > .iy-ms-eyebrow {
	color: #0f1f2e !important;
}

.iy-ms-page .iy-ms-mid-cta,
.iy-ms-page .iy-ms-final-cta {
	display: grid;
	gap: 1rem;
}

.iy-ms-page .iy-ms-mid-cta .iy-ms-btn--primary,
.iy-ms-page .iy-ms-final-cta .iy-ms-btn--primary {
	margin-top: 0.4rem;
}

@media (min-width: 768px) {
	.iy-ms-page .iy-ms-mid-cta .iy-ms-btn--primary,
	.iy-ms-page .iy-ms-final-cta .iy-ms-btn--primary {
		width: auto;
		min-width: clamp(12rem, 18vw, 14rem);
		justify-self: start;
	}
}

.iy-ms-page .iy-ms-section__actions {
	margin-top: 1.2rem;
}

.iy-ms-page .iy-ms-actions {
	margin-top: 1.35rem;
}

@media (min-width: 768px) {
	.iy-ms-page .iy-ms-mid-cta,
	.iy-ms-page .iy-ms-final-cta {
		gap: 1.15rem;
	}
}

@media (max-width: 900px) {
	.iy-ms-brand-mark {
		margin-bottom: 0.15rem;
	}
}

@media (min-width: 768px) {
	.iy-ms-summary__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 768px) {
	.iy-ms-summary {
		padding-inline: clamp(1.1rem, 2vw, 1.35rem);
	}
}

@media (max-width: 540px) {
	.iy-ms-brand-mark__image {
		max-width: min(230px, 66vw);
		max-height: clamp(42px, 11vw, 56px);
	}

	.iy-ms-brand-mark__fallback {
		font-size: 0.98rem;
	}

	.iy-ms-page .iy-ms-mid-cta,
	.iy-ms-page .iy-ms-final-cta {
		gap: 0.95rem;
	}
}

@media (max-width: 767px) {
	.iy-ms-page .iy-ms-route-card__content,
	.iy-ms-page .iy-ms-review-card,
	.iy-ms-page .iy-ms-checklist__item,
	.iy-ms-page .iy-ms-faq__summary,
	.iy-ms-page .iy-ms-faq__answer,
	.iy-ms-page .iy-ms-gallery__caption {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.iy-ms-page .iy-ms-route-card h3 {
		font-size: 1.22rem;
	}

	.iy-ms-page .iy-ms-experience__content .iy-ms-section__title {
		font-size: clamp(1.55rem, 7vw, 2.15rem);
	}

	.iy-ms-page .iy-ms-experience__content .iy-ms-section__body,
	.iy-ms-page .iy-ms-route-card .iy-ms-card__body,
	.iy-ms-page .iy-ms-review-card__quote,
	.iy-ms-page .iy-ms-checklist__text,
	.iy-ms-page .iy-ms-faq__answer {
		font-size: 0.98rem;
		line-height: 1.72;
	}
}

/* Visual polish overrides */
.iy-ms-page {
	--iy-ms-bg: #07111e;
	--iy-ms-surface: rgba(255, 255, 255, 0.95);
	--iy-ms-surface-alt: rgba(244, 247, 252, 0.94);
	--iy-ms-text: #152033;
	--iy-ms-muted: #56657a;
	--iy-ms-accent: #f3b63f;
	--iy-ms-accent-dark: #c97f10;
	--iy-ms-shadow: 0 24px 54px rgba(8, 17, 32, 0.14);
	background:
		radial-gradient(circle at 18% 12%, rgba(243, 182, 63, 0.18), transparent 26%),
		radial-gradient(circle at 82% 6%, rgba(94, 140, 255, 0.14), transparent 24%),
		linear-gradient(180deg, #07111e 0%, #0a1526 42%, #f3f6fb 42%, #f7f9fc 100%);
}

.iy-ms-page.iy-ms-style-exotic {
	--iy-ms-bg: #051511;
	--iy-ms-surface: rgba(250, 253, 250, 0.96);
	--iy-ms-surface-alt: rgba(233, 245, 236, 0.96);
	--iy-ms-text: #12211d;
	--iy-ms-muted: #4e625c;
	--iy-ms-accent: #82d46d;
	--iy-ms-accent-dark: #2e8f58;
	background:
		radial-gradient(circle at 18% 12%, rgba(130, 212, 109, 0.18), transparent 26%),
		radial-gradient(circle at 80% 8%, rgba(63, 179, 130, 0.16), transparent 22%),
		linear-gradient(180deg, #051511 0%, #0d241d 42%, #f2faf4 42%, #f7fbf7 100%);
}

.iy-ms-page.iy-ms-style-road_trip {
	--iy-ms-bg: #17110d;
	--iy-ms-surface: rgba(255, 250, 244, 0.96);
	--iy-ms-surface-alt: rgba(247, 235, 224, 0.96);
	--iy-ms-text: #201711;
	--iy-ms-muted: #68584b;
	--iy-ms-accent: #ff8d45;
	--iy-ms-accent-dark: #c6611d;
	background:
		radial-gradient(circle at 18% 12%, rgba(255, 141, 69, 0.18), transparent 26%),
		radial-gradient(circle at 80% 8%, rgba(245, 180, 95, 0.14), transparent 22%),
		linear-gradient(180deg, #17110d 0%, #2a1b14 42%, #fff8f3 42%, #fffcf8 100%);
}

.iy-ms-page.iy-ms-style-premium {
	--iy-ms-bg: #07101f;
	--iy-ms-surface: rgba(255, 255, 255, 0.96);
	--iy-ms-surface-alt: rgba(239, 243, 249, 0.96);
	--iy-ms-text: #101826;
	--iy-ms-muted: #566274;
	--iy-ms-accent: #c8a25a;
	--iy-ms-accent-dark: #8b6630;
	background:
		radial-gradient(circle at 18% 12%, rgba(200, 162, 90, 0.16), transparent 26%),
		radial-gradient(circle at 80% 8%, rgba(114, 144, 255, 0.12), transparent 22%),
		linear-gradient(180deg, #07101f 0%, #101c31 42%, #f4f7fb 42%, #f8fafc 100%);
}

.iy-ms-page.iy-ms-style-youth {
	--iy-ms-bg: #081524;
	--iy-ms-surface: rgba(255, 255, 255, 0.96);
	--iy-ms-surface-alt: rgba(236, 246, 255, 0.96);
	--iy-ms-text: #0f1730;
	--iy-ms-muted: #55617b;
	--iy-ms-accent: #5cc7ff;
	--iy-ms-accent-dark: #1d79c0;
	background:
		radial-gradient(circle at 18% 12%, rgba(92, 199, 255, 0.2), transparent 26%),
		radial-gradient(circle at 80% 8%, rgba(100, 150, 255, 0.12), transparent 22%),
		linear-gradient(180deg, #081524 0%, #10223b 42%, #f3f8ff 42%, #f7fbff 100%);
}

.iy-ms-container {
	width: min(100%, 1240px);
	padding-inline: clamp(1rem, 2.5vw, 2rem);
}

.iy-ms-narrow {
	max-width: 58rem;
}

.iy-ms-page::before {
	background:
		radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.08), transparent 18%),
		radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.05), transparent 16%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.01), transparent 22%);
}

.iy-ms-hero {
	min-height: min(96vh, 1020px);
	padding: clamp(8.5rem, 12vw, 11rem) 0 clamp(4rem, 7vw, 5.5rem);
}

.iy-ms-hero::before,
.iy-ms-hero::after {
	content: "";
	position: absolute;
	inset: auto;
	border-radius: 999px;
	pointer-events: none;
}

.iy-ms-hero::before {
	top: 14%;
	right: 6%;
	width: 18rem;
	height: 18rem;
	background: radial-gradient(circle, rgba(243, 182, 63, 0.18), rgba(243, 182, 63, 0) 72%);
	filter: blur(10px);
}

.iy-ms-hero::after {
	left: -5rem;
	bottom: 14%;
	width: 22rem;
	height: 22rem;
	background: radial-gradient(circle, rgba(92, 199, 255, 0.14), rgba(92, 199, 255, 0) 72%);
	filter: blur(14px);
}

.iy-ms-hero__content {
	max-width: 50rem;
	padding: clamp(0.75rem, 2vw, 1.5rem) 0;
}

.iy-ms-hero__title {
	font-size: clamp(2.9rem, 5.6vw, 5.9rem);
	max-width: 10ch;
	text-wrap: balance;
}

.iy-ms-hero__body {
	margin-top: 1.1rem;
	font-size: 1.12rem;
	max-width: 43rem;
	color: rgba(255, 255, 255, 0.92);
}

.iy-ms-actions {
	margin-top: 1.8rem;
}

.iy-ms-btn {
	min-height: 3.45rem;
	padding: 0.9rem 1.35rem;
	letter-spacing: 0.01em;
}

.iy-ms-btn--primary {
	background: linear-gradient(135deg, #f8cb58 0%, var(--iy-ms-accent) 38%, var(--iy-ms-accent-dark) 100%);
	box-shadow: 0 18px 36px rgba(243, 182, 63, 0.24);
}

.iy-ms-btn--secondary {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.26);
}

/* Google reviews CTA: a visible, branded button on the light trust section
   (the default secondary style is white-on-translucent, made for dark areas). */
.iy-ms-page .iy-ms-btn[data-cta-position="reviews"] {
	gap: 0.6rem;
	background: #fff;
	color: var(--iy-ms-text);
	border-color: rgba(14, 20, 35, 0.14);
	box-shadow: 0 12px 30px rgba(12, 16, 28, 0.12);
	backdrop-filter: none;
}

.iy-ms-page .iy-ms-btn[data-cta-position="reviews"]::before {
	content: "";
	flex: 0 0 auto;
	width: 1.15rem;
	height: 1.15rem;
	background: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2048%2048%27%3E%3Cpath%20fill%3D%27%23EA4335%27%20d%3D%27M24%209.5c3.54%200%206.71%201.22%209.21%203.6l6.85-6.85C35.9%202.38%2030.47%200%2024%200%2014.62%200%206.51%205.38%202.56%2013.22l7.98%206.19C12.43%2013.72%2017.74%209.5%2024%209.5z%27%2F%3E%3Cpath%20fill%3D%27%234285F4%27%20d%3D%27M46.98%2024.55c0-1.57-.15-3.09-.38-4.55H24v9.02h12.94c-.58%202.96-2.26%205.48-4.78%207.18l7.73%206c4.51-4.18%207.09-10.36%207.09-17.65z%27%2F%3E%3Cpath%20fill%3D%27%23FBBC05%27%20d%3D%27M10.53%2028.59c-.48-1.45-.76-2.99-.76-4.59s.28-3.14.76-4.59l-7.98-6.19C.92%2016.46%200%2020.12%200%2024c0%203.88.92%207.54%202.56%2010.78l7.97-6.19z%27%2F%3E%3Cpath%20fill%3D%27%2334A853%27%20d%3D%27M24%2048c6.48%200%2011.93-2.13%2015.89-5.81l-7.73-6c-2.15%201.45-4.92%202.3-8.16%202.3-6.26%200-11.57-4.22-13.47-9.91l-7.98%206.19C6.51%2042.62%2014.62%2048%2024%2048z%27%2F%3E%3C%2Fsvg%3E") center / contain no-repeat;
}

.iy-ms-page .iy-ms-btn[data-cta-position="reviews"]:hover,
.iy-ms-page .iy-ms-btn[data-cta-position="reviews"]:focus-visible {
	border-color: rgba(14, 20, 35, 0.22);
	box-shadow: 0 18px 38px rgba(12, 16, 28, 0.18);
}

.iy-ms-section {
	padding: clamp(4.4rem, 7vw, 7.4rem) 0;
}

.iy-ms-section--positioning,
.iy-ms-section--route,
.iy-ms-section--trust,
.iy-ms-section--gallery,
.iy-ms-section--ideal,
.iy-ms-section--experience,
.iy-ms-section--faq {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 249, 252, 0.9));
	border-top: 1px solid rgba(14, 20, 35, 0.06);
	border-bottom: 1px solid rgba(14, 20, 35, 0.06);
}

.iy-ms-section--route .iy-ms-section-heading,
.iy-ms-section--trust .iy-ms-section-heading,
.iy-ms-section--gallery .iy-ms-section-heading {
	max-width: 52rem;
}

.iy-ms-section__title {
	color: #102033;
	line-height: 1.06;
}

.iy-ms-section__body {
	color: var(--iy-ms-muted);
	font-size: 1.04rem;
}

.iy-ms-section__body p:first-child {
	margin-top: 0;
}

.iy-ms-card,
.iy-ms-gallery__item,
.iy-ms-faq__item,
.iy-ms-review-card,
.iy-ms-checklist__item {
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(14, 20, 35, 0.08);
	box-shadow: 0 18px 42px rgba(12, 16, 28, 0.09);
}

.iy-ms-route-grid,
.iy-ms-review-grid {
	gap: 1.35rem;
}

.iy-ms-route-card {
	position: relative;
	display: flex;
	flex-direction: column;
}

.iy-ms-route-card__media,
.iy-ms-experience__media {
	background:
		linear-gradient(135deg, rgba(10, 17, 32, 0.98), rgba(22, 38, 62, 0.96));
}

.iy-ms-route-card__media--fallback,
.iy-ms-experience__media--fallback {
	min-height: 240px;
	padding: 1rem;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}

.iy-ms-route-card__media--fallback::before,
.iy-ms-experience__media--fallback::before {
	content: attr(data-fallback-label);
	display: inline-flex;
	max-width: 100%;
	padding: 0.7rem 0.9rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.95);
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	backdrop-filter: blur(8px);
}

.iy-ms-route-card__media--fallback::after,
.iy-ms-experience__media--fallback::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 22% 18%, rgba(243, 182, 63, 0.34), transparent 22%),
		radial-gradient(circle at 78% 28%, rgba(92, 199, 255, 0.2), transparent 18%),
		linear-gradient(135deg, rgba(10, 17, 32, 0.92), rgba(21, 40, 65, 0.88));
	pointer-events: none;
}

.iy-ms-route-card__media--fallback > *,
.iy-ms-experience__media--fallback > * {
	position: relative;
	z-index: 1;
}

.iy-ms-route-card__content {
	padding: 1.25rem 1.25rem 1.45rem;
}

.iy-ms-route-card h3 {
	font-size: 1.2rem;
	margin-bottom: 0.45rem;
}

.iy-ms-route-card__places {
	margin-bottom: 0.8rem;
	color: var(--iy-ms-accent-dark);
	letter-spacing: 0.02em;
}

.iy-ms-route-card .iy-ms-card__body {
	color: var(--iy-ms-muted);
	font-size: 0.98rem;
}

.iy-ms-mid-cta {
	position: relative;
	overflow: hidden;
	padding: clamp(2rem, 4vw, 2.8rem);
	background:
		radial-gradient(circle at 10% 0%, rgba(243, 182, 63, 0.18), transparent 22%),
		radial-gradient(circle at 90% 100%, rgba(92, 199, 255, 0.14), transparent 24%),
		linear-gradient(135deg, #0b1525, #11243b);
}

.iy-ms-mid-cta::after {
	content: "";
	position: absolute;
	inset: 1rem;
	border-radius: calc(var(--iy-ms-radius) + 2px);
	border: 1px solid rgba(255, 255, 255, 0.08);
	pointer-events: none;
}

.iy-ms-mid-cta .iy-ms-eyebrow,
.iy-ms-final-cta .iy-ms-eyebrow {
	color: rgba(255, 255, 255, 0.74);
}

.iy-ms-mid-cta .iy-ms-section__title,
.iy-ms-final-cta .iy-ms-final-cta__title {
	color: #fff;
}

.iy-ms-mid-cta .iy-ms-btn--primary,
.iy-ms-final-cta .iy-ms-btn--primary {
	color: #10131a;
}

.iy-ms-experience {
	gap: 1.6rem;
	align-items: stretch;
	margin-top: 1.5rem;
}

.iy-ms-experience__media {
	border-radius: calc(var(--iy-ms-radius) + 2px);
	overflow: hidden;
	aspect-ratio: 5 / 4;
	box-shadow: var(--iy-ms-shadow);
}

.iy-ms-experience__content {
	padding: 0.5rem 0.25rem;
}

.iy-ms-experience--text-only {
	grid-template-columns: minmax(0, 1fr);
	padding: 0.25rem 0;
}

.iy-ms-experience--text-only .iy-ms-experience__content {
	max-width: 52rem;
	padding-left: 0;
	padding-right: 0;
}

.iy-ms-experience__content .iy-ms-section__title {
	max-width: 16ch;
}

.iy-ms-experience--card {
	padding: 1.25rem;
}

.iy-ms-experience--card .iy-ms-experience__media {
	aspect-ratio: 16 / 9;
}

.iy-ms-experience--dark {
	background:
		radial-gradient(circle at 15% 0%, rgba(243, 182, 63, 0.08), transparent 24%),
		linear-gradient(135deg, #0b1525, #14233a);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.iy-ms-experience--dark .iy-ms-section__title,
.iy-ms-experience--dark .iy-ms-section__body,
.iy-ms-experience--dark .iy-ms-caption {
	color: rgba(255, 255, 255, 0.92);
}

.iy-ms-experience--highlight {
	background:
		radial-gradient(circle at 0 0, rgba(255, 214, 120, 0.16), transparent 26%),
		linear-gradient(135deg, rgba(255, 246, 220, 0.98), rgba(255, 255, 255, 0.96));
	border: 1px solid rgba(243, 182, 63, 0.28);
}

.iy-ms-experience--highlight .iy-ms-caption {
	color: #9b6b0d;
}

.iy-ms-caption {
	font-size: 0.96rem;
	letter-spacing: 0.01em;
}

.iy-ms-gallery {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.iy-ms-gallery--debug {
	grid-template-columns: minmax(0, 1fr);
	max-width: 26rem;
}

.iy-ms-gallery__item {
	display: flex;
	flex-direction: column;
	width: 100%;
	padding: 0;
	border: 0;
	background: var(--iy-ms-surface);
	color: inherit;
	text-align: left;
	cursor: pointer;
	overflow: hidden;
	appearance: none;
}

.iy-ms-gallery__item:focus-visible {
	outline: 3px solid rgba(22, 83, 63, 0.28);
	outline-offset: 4px;
}

.iy-ms-gallery__media {
	position: relative;
	display: block;
	overflow: hidden;
}

/* "+N remaining" overlay on the last visible preview tile. */
.iy-ms-gallery__more {
	position: absolute;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(8, 12, 20, 0.5);
	color: #fff;
	font-size: clamp(1.5rem, 4vw, 2.1rem);
	font-weight: 800;
	letter-spacing: 0.02em;
	pointer-events: none;
}

@media (min-width: 768px) {
	.iy-ms-gallery__more--desktop {
		display: flex;
	}
}

@media (max-width: 767px) {
	.iy-ms-gallery__more--mobile {
		display: flex;
	}
}

.iy-ms-gallery__image,
.iy-ms-gallery__placeholder {
	aspect-ratio: 1 / 1;
	width: 100%;
	display: block;
}

/* Preview teaser: show 3 thumbnails on desktop; the rest open in the viewer. */
.iy-ms-gallery__item:nth-child(n + 4) {
	display: none;
}

.iy-ms-gallery__placeholder {
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(circle at 20% 20%, rgba(243, 182, 63, 0.22), transparent 18%),
		radial-gradient(circle at 78% 28%, rgba(92, 199, 255, 0.16), transparent 16%),
		linear-gradient(135deg, #0a1525, #15283f);
}

.iy-ms-gallery__placeholder::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 28%),
		linear-gradient(135deg, rgba(255, 255, 255, 0.02), transparent 60%);
}

.iy-ms-gallery__placeholder-label {
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	z-index: 1;
	padding: 0.7rem 0.85rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	backdrop-filter: blur(8px);
}

.iy-ms-gallery__caption {
	display: block;
	padding: 0.95rem 1rem 1.1rem;
	font-size: 0.95rem;
	color: var(--iy-ms-muted);
}

.iy-ms-gallery-story[hidden] {
	display: none !important;
}

.iy-ms-gallery-story {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: block;
	padding: 0;
	background: rgba(5, 10, 18, 0.92);
	backdrop-filter: blur(14px);
	overflow: hidden;
	isolation: isolate;
}

.iy-ms-gallery-story__backdrop {
	position: absolute;
	inset: 0;
}

.iy-ms-gallery-story__panel {
	position: absolute;
	inset: 0;
	z-index: 1;
	width: 100vw;
	height: 100vh;
	height: 100dvh;
	display: block;
	border-radius: 0;
	overflow: hidden;
	background:
		radial-gradient(circle at 15% 0, rgba(243, 182, 63, 0.12), transparent 18%),
		linear-gradient(180deg, #070c12, #05090f);
	box-shadow: none;
}

.iy-ms-gallery-story__progress {
	position: absolute;
	top: max(0.32rem, env(safe-area-inset-top));
	left: max(0.32rem, env(safe-area-inset-left));
	right: max(0.32rem, env(safe-area-inset-right));
	z-index: 4;
	display: flex;
	align-items: stretch;
	gap: 0.16rem;
	padding: 0;
	background: transparent;
	overflow: hidden;
}

.iy-ms-gallery-story__segment {
	display: block;
	flex: 1 1 0;
	height: 1.75px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.16);
	overflow: hidden;
}

.iy-ms-gallery-story__segment-fill {
	display: block;
	width: 0;
	height: 100%;
	background: linear-gradient(90deg, #f3b63f, #59c37c);
}

.iy-ms-gallery-story__segment.is-complete .iy-ms-gallery-story__segment-fill {
	width: 100%;
	animation: none;
}

.iy-ms-gallery-story__segment.is-active .iy-ms-gallery-story__segment-fill {
	width: 0;
	animation: iy-ms-story-fill 5000ms linear forwards;
}

.iy-ms-gallery-story.is-paused .iy-ms-gallery-story__segment.is-active .iy-ms-gallery-story__segment-fill {
	animation-play-state: paused;
}

@keyframes iy-ms-story-fill {
	from {
		width: 0;
	}
	to {
		width: 100%;
	}
}

@media (prefers-reduced-motion: reduce) {
	.iy-ms-gallery-story__track {
		transition: none;
	}
}

.iy-ms-gallery-story__header {
	position: absolute;
	top: calc(max(0.32rem, env(safe-area-inset-top)) + 0.28rem);
	left: max(0.32rem, env(safe-area-inset-left));
	right: max(0.32rem, env(safe-area-inset-right));
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0;
	padding: 0;
	color: #fff;
}

.iy-ms-gallery-story__counter {
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.84);
}

.iy-ms-gallery-story__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	font-size: 1.28rem;
	line-height: 1;
	cursor: pointer;
}

.iy-ms-gallery-story__viewport {
	position: absolute;
	inset: 0;
	z-index: 2;
	overflow: hidden;
}

.iy-ms-gallery-story__track {
	display: flex;
	width: 100%;
	height: 100%;
	will-change: transform;
	transition: transform 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
	touch-action: pan-y;
}

.iy-ms-gallery-story.is-dragging .iy-ms-gallery-story__track {
	transition: none;
}

.iy-ms-gallery-story__slide {
	flex: 0 0 100%;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	min-width: 0;
	min-height: 0;
	overflow: hidden;
	background: #05090f;
}

.iy-ms-gallery-story__media {
	flex: 1;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.iy-ms-gallery-story__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	/* Keep the native image drag-and-drop from swallowing swipe gestures. */
	pointer-events: none;
	-webkit-user-drag: none;
	user-select: none;
}

.iy-ms-gallery-story__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: none;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	cursor: pointer;
	z-index: 6;
}

.iy-ms-gallery-story__nav::before {
	content: "";
	width: 0.65rem;
	height: 0.65rem;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
}

.iy-ms-gallery-story__nav--prev::before {
	transform: rotate(-135deg);
	margin-left: 0.2rem;
}

.iy-ms-gallery-story__nav--next::before {
	transform: rotate(45deg);
	margin-right: 0.2rem;
}

@media (min-width: 768px) {
	.iy-ms-gallery-story {
		display: grid;
		place-items: center;
	}

	.iy-ms-gallery-story__panel {
		width: 100%;
		height: 100%;
	}

	.iy-ms-gallery-story__progress,
	.iy-ms-gallery-story__header,
	.iy-ms-gallery-story__viewport {
		left: 50%;
		right: auto;
		transform: translateX(-50%);
		width: min(480px, calc((100vh - 2.5rem) * 0.5625), calc(100vw - 2rem));
	}

	.iy-ms-gallery-story__progress {
		top: max(0.35rem, env(safe-area-inset-top));
	}

	.iy-ms-gallery-story__header {
		top: calc(max(0.35rem, env(safe-area-inset-top)) + 0.24rem);
	}

	.iy-ms-gallery-story__viewport {
		top: 0;
		bottom: 0;
		height: 100%;
		align-items: center;
		justify-content: center;
	}

	.iy-ms-gallery-story__slide {
		width: 100%;
		height: 100%;
		max-height: calc(100vh - 1.5rem);
		aspect-ratio: 9 / 16;
		border-radius: 0;
		box-shadow: 0 34px 80px rgba(0, 0, 0, 0.44);
	}

	.iy-ms-gallery-story__nav {
		display: inline-flex;
	}

	.iy-ms-gallery-story__nav--prev {
		left: max(1rem, calc(50% - min(480px, calc((100vh - 2.5rem) * 0.5625), calc(100vw - 2rem)) / 2 - 3.5rem));
	}

	.iy-ms-gallery-story__nav--next {
		right: max(1rem, calc(50% - min(480px, calc((100vh - 2.5rem) * 0.5625), calc(100vw - 2rem)) / 2 - 3.5rem));
	}
}

.iy-ms-review-card {
	padding: 1.3rem;
	background:
		radial-gradient(circle at 12% 0, rgba(243, 182, 63, 0.08), transparent 20%),
		rgba(255, 255, 255, 0.96);
}

.iy-ms-review-card__stars {
	font-size: 1.02rem;
	letter-spacing: 0.06em;
}

.iy-ms-review-card__quote {
	margin-top: 1rem;
	font-size: 1rem;
	color: #1b2636;
}

.iy-ms-review-card__name {
	color: var(--iy-ms-muted);
}

.iy-ms-checklist {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.iy-ms-checklist__item {
	background:
		radial-gradient(circle at 12% 12%, rgba(243, 182, 63, 0.08), transparent 20%),
		rgba(255, 255, 255, 0.96);
	padding: 1.05rem 1rem;
	border-radius: 20px;
}

.iy-ms-checklist__icon {
	width: 1.75rem;
	height: 1.75rem;
	flex-basis: 1.75rem;
	background: linear-gradient(135deg, var(--iy-ms-accent), var(--iy-ms-accent-dark));
	color: #0f141d;
}

.iy-ms-faq {
	gap: 0.95rem;
	margin-top: 1.5rem;
}

.iy-ms-faq__item {
	overflow: hidden;
	border-radius: 22px;
}

.iy-ms-faq__summary {
	padding: 1.15rem 1.25rem;
	font-size: 1rem;
	color: #162233;
}

.iy-ms-faq__item summary:focus-visible {
	outline: 3px solid rgba(92, 199, 255, 0.45);
	outline-offset: 3px;
}

.iy-ms-faq__answer {
	padding: 0 1.25rem 1.15rem;
	color: var(--iy-ms-muted);
}

.iy-ms-faq__note {
	color: var(--iy-ms-accent-dark);
}

.iy-ms-final-cta {
	position: relative;
	overflow: hidden;
	padding: clamp(2rem, 4vw, 3rem);
	background:
		radial-gradient(circle at 8% 0%, rgba(243, 182, 63, 0.18), transparent 18%),
		radial-gradient(circle at 92% 100%, rgba(92, 199, 255, 0.16), transparent 20%),
		linear-gradient(135deg, #09111f, #12243b);
}

.iy-ms-final-cta__body {
	max-width: 48rem;
	font-size: 1.05rem;
}

.iy-ms-sticky-cta {
	background: linear-gradient(180deg, rgba(247, 249, 252, 0), rgba(6, 10, 18, 0.86));
}

.iy-ms-sticky-cta .iy-ms-btn {
	width: min(100%, 38rem);
}

@media (min-width: 1180px) {
	.iy-ms-route-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.iy-ms-gallery {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 1024px) {
	.iy-ms-hero {
		min-height: min(82vh, 760px);
		padding: clamp(3.25rem, 4.8vw, 4.75rem) 0 clamp(2.5rem, 4vw, 3.5rem);
	}

	.iy-ms-hero__inner {
		gap: 0.85rem;
	}

	.iy-ms-brand-mark {
		margin-bottom: 0.05rem;
	}

	.iy-ms-brand-mark__image {
		max-width: min(280px, 46vw);
		max-height: clamp(46px, 5vw, 60px);
	}

	.iy-ms-hero__content {
		max-width: 44rem;
	}

	.iy-ms-hero__title {
		font-size: clamp(2.2rem, 4.2vw, 3.35rem);
		max-width: 12ch;
	}

	.iy-ms-hero__body {
		max-width: 36rem;
		font-size: 1rem;
	}

	.iy-ms-route-grid,
	.iy-ms-review-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1rem;
	}

	.iy-ms-experience {
		grid-template-columns: 1fr;
		gap: 1rem;
		margin-top: 1rem;
	}

	.iy-ms-checklist {
		grid-template-columns: 1fr;
	}

	.iy-ms-gallery--debug {
		max-width: none;
	}

	.iy-ms-route-card__media {
		aspect-ratio: 4 / 3;
	}

	.iy-ms-route-card__image,
	.iy-ms-experience__image {
		object-position: center 28%;
	}

	.iy-ms-experience__media {
		aspect-ratio: 5 / 4;
	}
}

@media (max-width: 767px) {
	.iy-ms-page {
		background:
			radial-gradient(circle at 18% 10%, rgba(243, 182, 63, 0.14), transparent 24%),
			radial-gradient(circle at 82% 4%, rgba(92, 199, 255, 0.12), transparent 20%),
			linear-gradient(180deg, #07111e 0%, #0c1728 32%, #f3f6fb 32%, #f7f9fc 100%);
	}

	.iy-ms-hero {
		min-height: auto;
		padding: 4.25rem 0 3.25rem;
	}

	.iy-ms-hero__inner {
		gap: 1rem;
	}

	.iy-ms-hero__title {
		font-size: clamp(2.3rem, 12vw, 3.5rem);
		max-width: 11ch;
	}

	.iy-ms-hero__body {
		font-size: 1rem;
	}

	.iy-ms-actions,
	.iy-ms-section__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.iy-ms-btn {
		width: 100%;
	}

	.iy-ms-section {
		padding: 3.6rem 0;
	}

	.iy-ms-section__title {
		font-size: clamp(1.65rem, 7vw, 2.25rem);
	}

	.iy-ms-route-grid,
	.iy-ms-review-grid,
	.iy-ms-gallery {
		grid-template-columns: 1fr;
	}

	.iy-ms-experience {
		display: block;
	}

	.iy-ms-experience--text-only {
		gap: 0.85rem;
	}

	.iy-ms-experience--reverse .iy-ms-experience__media,
	.iy-ms-experience--reverse .iy-ms-experience__content {
		order: initial;
		padding: 0.5rem 0;
	}

	.iy-ms-experience__content .iy-ms-section__title {
		max-width: none;
		overflow-wrap: anywhere;
	}

	.iy-ms-route-card__media--fallback,
	.iy-ms-experience__media--fallback {
		min-height: 190px;
	}

	.iy-ms-route-card__content {
		padding-top: 1rem;
		padding-bottom: 1.15rem;
	}

	.iy-ms-review-card {
		padding-top: 1rem;
		padding-bottom: 1rem;
	}

	.iy-ms-route-card__content,
	.iy-ms-review-card,
	.iy-ms-checklist__item,
	.iy-ms-faq__summary,
	.iy-ms-faq__answer,
	.iy-ms-gallery__caption {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.iy-ms-page .iy-ms-experience__content {
		padding-top: 0.2rem;
		padding-bottom: 0.2rem;
	}

	.iy-ms-route-card__media,
	.iy-ms-experience__media {
		aspect-ratio: 16 / 10;
	}

	.iy-ms-route-card__image,
	.iy-ms-experience__image {
		object-position: center center;
	}

	.iy-ms-faq__summary {
		font-size: 0.98rem;
	}

	.iy-ms-final-cta,
	.iy-ms-mid-cta {
		padding: 1.5rem;
	}

	.iy-ms-sticky-cta {
		padding-inline: 0.85rem;
	}

	.iy-ms-gallery {
		grid-template-columns: 1fr;
	}

	.iy-ms-gallery__item:nth-child(n + 2) {
		display: none;
	}

	.iy-ms-gallery-story {
		padding: 0;
	}

	.iy-ms-gallery-story__panel {
		width: 100%;
		height: 100%;
		border-radius: 0;
	}

	.iy-ms-gallery-story__header {
		top: calc(max(0.4rem, env(safe-area-inset-top)) + 0.6rem);
		left: max(0.4rem, env(safe-area-inset-left));
		right: max(0.4rem, env(safe-area-inset-right));
		padding: 0;
	}

	.iy-ms-gallery-story__viewport {
		padding: 0;
	}
}

@media (max-width: 480px) {
	.iy-ms-hero {
		padding-top: 3.75rem;
		padding-bottom: 2.75rem;
	}

	.iy-ms-hero__inner {
		gap: 0.72rem;
	}

	.iy-ms-brand-mark {
		margin-bottom: 0;
	}

	.iy-ms-brand-mark__image {
		max-width: min(210px, 62vw);
		max-height: 48px;
	}

	.iy-ms-hero__title {
		font-size: clamp(2rem, 9.8vw, 3rem);
		max-width: 10.5ch;
	}

	.iy-ms-hero__body {
		max-width: 100%;
	}

	.iy-ms-route-card__content,
	.iy-ms-review-card,
	.iy-ms-checklist__item,
	.iy-ms-faq__summary,
	.iy-ms-faq__answer,
	.iy-ms-gallery__caption {
		padding-left: 0.9rem;
		padding-right: 0.9rem;
	}

	.iy-ms-final-cta,
	.iy-ms-mid-cta {
		padding: 1.25rem;
	}

	.iy-ms-page--has-sticky {
		padding-bottom: 7.9rem;
	}
}

/* Sticky CTA premium treatment */
.iy-ms-sticky-cta {
	padding: 0.62rem 0.85rem calc(0.62rem + env(safe-area-inset-bottom));
	background:
		linear-gradient(180deg, rgba(5, 10, 18, 0), rgba(5, 10, 18, 0.42)),
		linear-gradient(135deg, rgba(8, 17, 31, 0.76), rgba(10, 20, 34, 0.92));
	backdrop-filter: blur(16px);
	box-shadow: 0 -18px 34px rgba(5, 10, 18, 0.2);
	opacity: 0;
	transform: translateY(110%);
	transition: opacity 220ms ease, transform 220ms ease;
	pointer-events: none;
	will-change: opacity, transform;
}

.iy-ms-sticky-cta--visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.iy-ms-sticky-cta__inner {
	display: grid;
	gap: 0.45rem;
	justify-items: center;
}

.iy-ms-sticky-cta__microcopy {
	margin: 0;
	max-width: 38rem;
	color: rgba(255, 255, 255, 0.85);
	font-size: 0.72rem;
	line-height: 1.2;
	letter-spacing: 0.015em;
	text-align: center;
}

.iy-ms-sticky-cta .iy-ms-btn {
	width: min(100%, 38rem);
	min-height: 3.15rem;
	padding: 0.8rem 1.1rem;
	border-radius: 999px;
	box-shadow: 0 16px 30px rgba(0, 0, 0, 0.24);
	font-size: 0.96rem;
	font-weight: 800;
}

.iy-ms-page--has-sticky {
	padding-bottom: 9rem;
}

@media (max-width: 540px) {
	.iy-ms-sticky-cta {
		padding: 0.5rem 0.64rem calc(0.5rem + env(safe-area-inset-bottom));
	}

	.iy-ms-sticky-cta__microcopy {
		display: none;
	}

	.iy-ms-sticky-cta .iy-ms-btn {
		width: 100%;
		min-height: 2.95rem;
		padding: 0.74rem 0.95rem;
		font-size: 0.92rem;
	}

	.iy-ms-page--has-sticky {
		padding-bottom: 8rem;
	}
}

@media (max-width: 420px) {
	.iy-ms-sticky-cta {
		padding-inline: 0.55rem;
	}

	.iy-ms-page--has-sticky {
		padding-bottom: 7.6rem;
	}
}

/* Theme hardening: preserve white hero typography even if the active theme
 * applies stronger global heading/paragraph color rules. */
.iy-ms-page .iy-ms-hero .iy-ms-brand-mark__fallback,
.iy-ms-page .iy-ms-hero .iy-ms-eyebrow,
.iy-ms-page .iy-ms-hero .iy-ms-hero__title,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body p,
.iy-ms-page .iy-ms-hero .iy-ms-hero__body a {
	color: #ffffff !important;
}

.iy-ms-page .iy-ms-hero .iy-ms-hero__body a {
	text-decoration-color: rgba(255, 255, 255, 0.72);
}

/* Typography system: Manrope (headings/eyebrows/CTAs at 700/800, body/UI at 400/500) */
.iy-ms-page {
	--iy-ms-font-heading: "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
	--iy-ms-font-body: "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
	font-family: var(--iy-ms-font-body);
}

.iy-ms-hero__title,
.iy-ms-section__title,
.iy-ms-final-cta__title,
.iy-ms-eyebrow,
.iy-ms-btn,
.iy-ms-route-card h3 {
	font-family: var(--iy-ms-font-heading);
}

.iy-ms-hero__title,
.iy-ms-final-cta__title {
	font-weight: 800;
}

.iy-ms-section__title,
.iy-ms-route-card h3 {
	font-weight: 700;
}

.iy-ms-eyebrow,
.iy-ms-btn {
	font-weight: 700;
}

/* Variant shape personality (color variables already vary per .iy-ms-style-*; this layer varies shape/shadow) */
.iy-ms-page.iy-ms-style-default {
	--iy-ms-radius: 24px;
	--iy-ms-shadow: 0 24px 54px rgba(8, 17, 32, 0.14);
}

.iy-ms-page.iy-ms-style-exotic {
	--iy-ms-radius: 20px;
	--iy-ms-shadow: 0 20px 44px rgba(13, 33, 25, 0.16);
}

.iy-ms-page.iy-ms-style-road_trip {
	--iy-ms-radius: 12px;
	--iy-ms-shadow: 8px 14px 0 rgba(32, 23, 17, 0.18);
}

.iy-ms-page.iy-ms-style-premium {
	--iy-ms-radius: 8px;
	--iy-ms-shadow: 0 32px 70px rgba(8, 16, 31, 0.1);
}

.iy-ms-page.iy-ms-style-youth {
	--iy-ms-radius: 28px;
	--iy-ms-shadow: 0 22px 46px rgba(8, 21, 36, 0.16);
}

/* Premium: checklist icon becomes a thin ring instead of a filled circle */
.iy-ms-page.iy-ms-style-premium .iy-ms-checklist__icon {
	background: transparent;
	border: 2px solid var(--iy-ms-accent-dark);
	color: var(--iy-ms-accent-dark);
}

/* Road trip: slightly more angular eyebrow chip (no pill) */
.iy-ms-page.iy-ms-style-road_trip .iy-ms-eyebrow {
	border-radius: 4px;
}

/* Route cards: featured first stop */
.iy-ms-route-grid--featured {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	margin-bottom: 1.2rem;
}

.iy-ms-route-card--featured {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
	align-items: stretch;
}

.iy-ms-route-card--featured .iy-ms-route-card__media {
	aspect-ratio: auto;
	min-height: 320px;
}

.iy-ms-route-card--featured .iy-ms-route-card__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
	padding: clamp(1.5rem, 2vw, 2rem);
}

.iy-ms-route-card--featured h3 {
	font-size: clamp(1.6rem, 2.4vw, 2.1rem);
}

@media (max-width: 900px) {
	.iy-ms-route-card--featured {
		grid-template-columns: 1fr;
	}

	.iy-ms-route-card--featured .iy-ms-route-card__media {
		min-height: 220px;
	}

	.iy-ms-route-card--featured .iy-ms-route-card__content {
		padding: clamp(1rem, 3vw, 1.35rem);
	}
}

/* Scroll-reveal */
.iy-ms-reveal {
	opacity: 0;
	transform: translateY(10px);
	transition: opacity 400ms ease-out, transform 400ms ease-out;
}

.iy-ms-reveal--visible {
	opacity: 1;
	transform: translateY(0);
}

.iy-ms-no-reveal .iy-ms-reveal {
	opacity: 1;
	transform: none;
	transition: none;
}

@media (prefers-reduced-motion: reduce) {
	.iy-ms-reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* Summary section: stronger accent, equal vertical breathing room */
.iy-ms-section--summary {
	padding-top: clamp(2.2rem, 4vw, 3.4rem);
	padding-bottom: clamp(2.2rem, 4vw, 3.4rem);
}

.iy-ms-summary::before {
	height: 4px;
	opacity: 1;
}

/* FAQ smooth accordion.
   The height is animated in JS with the Web Animations API (see
   initFaqSmoothExpand): clicks are intercepted so the native <details>
   open state only flips when we say so, and an in-flight open/close is
   cancelled and reversed on the next click — so it can never get stuck
   half-open or desync the way a CSS/inline max-height transition does.
   These rules give the collapsed/expanded resting states; JS handles the
   motion between them. The .iy-ms-faq--js class is added by JS, so without
   it the items open/close natively. */
.iy-ms-faq__item.iy-ms-faq--js .iy-ms-faq__answer {
	overflow: hidden;
	max-height: 0;
	/* Only zero the vertical padding so the answer collapses fully; the
	   horizontal padding keeps flowing from the responsive rules so the
	   answer text stays aligned with its question at every breakpoint. */
	padding-top: 0;
	padding-bottom: 0;
}

.iy-ms-faq__item.iy-ms-faq--js .iy-ms-faq__answer-inner {
	min-width: 0;
	padding-bottom: 1.15rem;
}

.iy-ms-faq__item.iy-ms-faq--js[open] .iy-ms-faq__answer {
	max-height: none;
}

/* Desktop sticky CTA: same scroll-trigger behavior as mobile, more compact sizing */
.iy-ms-sticky-cta {
	display: block;
}

.iy-ms-page--has-sticky {
	padding-bottom: 8.4rem;
}

@media (min-width: 1025px) {
	.iy-ms-sticky-cta {
		padding: 0.55rem 1.5rem calc(0.55rem + env(safe-area-inset-bottom));
	}

	.iy-ms-sticky-cta__microcopy {
		display: none;
	}

	.iy-ms-sticky-cta .iy-ms-btn {
		width: auto;
		min-width: 16rem;
		min-height: 2.85rem;
		padding: 0.65rem 1.4rem;
		font-size: 0.92rem;
	}

	.iy-ms-page--has-sticky {
		padding-bottom: 0;
	}
}

/* Hero logo: pinned slim top bar, separated from headline content */
.iy-ms-hero__topbar {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 2;
	padding: clamp(1rem, 2vw, 1.5rem) 0;
}

.iy-ms-hero__topbar-inner {
	display: flex;
	justify-content: center;
}

.iy-ms-hero__topbar .iy-ms-brand-mark {
	margin-bottom: 0;
}

.iy-ms-hero__topbar .iy-ms-brand-mark__image {
	max-width: min(260px, 60vw);
	max-height: clamp(40px, 4vw, 56px);
}

.iy-ms-hero {
	padding-top: clamp(6.5rem, 9vw, 8.5rem);
}

@media (max-width: 767px) {
	.iy-ms-hero__topbar {
		padding: 0.85rem 0;
	}

	.iy-ms-hero__topbar .iy-ms-brand-mark__image {
		max-width: min(200px, 56vw);
		max-height: 40px;
	}

	.iy-ms-hero {
		padding-top: 5.5rem;
	}
}

@media (max-width: 480px) {
	.iy-ms-hero {
		padding-top: 4.5rem;
	}
}

/* Experience block: wide (full-bleed) variant */
.iy-ms-experience--wide {
	grid-template-columns: minmax(0, 1fr);
}

.iy-ms-experience--wide .iy-ms-experience__media {
	aspect-ratio: 16 / 7;
	order: 1;
}

.iy-ms-experience--wide .iy-ms-experience__content {
	order: 2;
	max-width: 52rem;
	padding: 1rem 0 0;
}

.iy-ms-experience--wide .iy-ms-section__title {
	max-width: none;
}

@media (max-width: 767px) {
	.iy-ms-experience--wide .iy-ms-experience__media {
		aspect-ratio: 16 / 10;
	}
}

@media (max-width: 767px) {
	.iy-ms-gallery-story__header {
		top: calc(max(0.28rem, env(safe-area-inset-top)) + 0.22rem);
		left: max(0.28rem, env(safe-area-inset-left));
		right: max(0.28rem, env(safe-area-inset-right));
		padding: 0;
	}

	.iy-ms-gallery-story__viewport {
		padding: 0;
	}
}

.iy-ms-gallery-story-open {
	overflow: hidden;
}
