*,
*::after,
*::before {
	box-sizing: border-box;
}

:root {
	font-size: 16px;

	/* Layout */
	--page-padding-x: 1.5rem;
	--page-padding-y: 1.5rem;
	--page-padding: var(--page-padding-y) var(--page-padding-x);

	--font-body: "Montserrat", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-heading: "Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
	--color-primary: #003150;
	--color-primary-rgb: 0, 49, 80;
	--color-black: #000000;
	--color-white: #ffffff;

	--color-text: var(--color-primary);
	--color-muted: rgba(var(--color-primary-rgb), 0.72);
	--color-bg: var(--color-white);
	--color-surface: var(--color-white);
	--color-link: var(--color-primary);
	--color-link-hover: #001d31;
	--color-accent: var(--color-primary);
	--color-bg-1: #f7f9fb;
	--color-bg-2: #eff3f6;
	--color-bg-3: #e7eef2;
	--color-bg-4: #fbfcfd;
	--color-bg-5: #f1f5f8;
	--color-bg-6: #e9f0f5;

	--focus-ring: rgba(var(--color-primary-rgb), 0.55);
}

body {
	margin: 0;
	color: var(--color-text);
	background-color: var(--color-bg);
	font-family: var(--font-body);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	width: 100%;
	overflow-x: hidden;
}

.cursor-trail {
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100vh;
	pointer-events: none;
	z-index: 3500;
	mix-blend-mode: normal;
	opacity: 0;
	transition: opacity 220ms ease;
}

body.is-presenting .cursor-trail {
	opacity: 0.85;
}

body.theme-dark.is-presenting .cursor-trail {
	mix-blend-mode: screen;
}

/* Slides deck (horizontal) */
.wrap.slides {
	/* Match StickySections (demo-2) look, scoped to slides only */
	--color-text: #000;
	--color-muted: rgba(0,0,0,0.65);
	--color-bg: #e1e1e1;
	--color-link: rgba(0,0,0,0.6);
	--color-link-hover: #000;
	--color-bg-1: #9d9d9d;
	--color-bg-2: #c7c7c7;
	--color-bg-3: var(--color-bg-1);
	--color-bg-4: var(--color-bg-2);
	--color-bg-5: var(--color-bg-1);
	--color-bg-6: var(--color-bg-2);

	position: relative;
	width: 100vw;
	height: 100vh;
	overflow: hidden;
	isolation: isolate;
	background: var(--color-bg);
	color: var(--color-text);
}

.wrap.slides .slides-track {
	position: relative;
	z-index: 1;
	height: 100%;
	display: flex;
	flex-wrap: nowrap;
	will-change: transform;
}

	.wrap.slides .slide.content--grid {
		width: 100vw;
		height: 100vh;
		flex: 0 0 100vw;
		padding: var(--page-padding);
	background: var(--color-bg-1);
	position: relative;
	font-family: "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-variation-settings: normal;

	display: grid;
	overflow: hidden;
	grid-column-gap: 5vw;
	grid-row-gap: 2vh;
	align-content: center;
	grid-template-areas: 'content-img' 'content-title' 'content-text';
	justify-items: center;
		text-align: center;
	}

	.wrap.slides .slide--shift-down {
		padding-top: calc(var(--page-padding-y) + 6vh);
	}

	.wrap.slides .content__img {
		grid-area: content-img;
		width: 50%;
		max-width: 300px;
		height: auto;
}

.wrap.slides .content__img--large {
	width: 60%;
	height: auto;
}

.wrap.slides .content__img--3d {
	display: block;
	aspect-ratio: 1 / 1;
	border-radius: 999px;
	pointer-events: none;
	filter: drop-shadow(0 28px 52px rgba(0,0,0,0.18));
}

.wrap.slides .content__heading {
	grid-area: content-title;
	display: grid;
	gap: 0.55rem;
}

.wrap.slides .content__heading .content__title {
	grid-area: auto;
}

.wrap.slides .content__title,
.wrap.slides .slide h1,
.wrap.slides .slide h2,
.wrap.slides .slide h3 {
	grid-area: content-title;
	letter-spacing: -0.02em;
	text-transform: none;
	line-height: 1.05;
	font-weight: 600;
	font-size: clamp(2.25rem, 6vw, 5rem);
	margin: 0;
	font-family: "Clash Display", "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-variation-settings: normal;
	max-width: 22ch;
	text-wrap: balance;
}

.wrap.slides .content__title i {
	font-style: normal;
	font-weight: 400;
}

.wrap.slides .content__title-thin {
	font-weight: 300;
}

	.wrap.slides .content__subline {
		margin: 0;
		max-width: 34ch;
		font-size: clamp(1.35rem, 2.1vw, 2.15rem);
		line-height: 1.18;
		letter-spacing: -0.01em;
		font-weight: 400;
		color: var(--color-muted);
		font-family: "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
		text-wrap: balance;
	}

.wrap.slides .content__subline i {
	font-style: normal;
	font-weight: inherit;
}

	.wrap.slides .content__text {
		grid-area: content-text;
		margin: 0;
		max-width: 500px;
		font-size: clamp(1.02rem, 1.1vw, 1.18rem);
	text-align: center;
	line-height: 1.5;
	padding: 0 1rem;
	backface-visibility: hidden;
		color: var(--color-muted);
		font-family: "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	}

	.wrap.slides .content__text strong {
		font-weight: 700;
		color: var(--color-text);
	}

	.wrap.slides .content__text .content__text-rest {
		font-weight: 400;
		color: var(--color-muted);
	}

	.wrap.slides .content__bullets {
		margin: 0;
		padding-left: 1.05rem;
		display: grid;
	gap: 0.55rem;
	text-align: left;
}

.wrap.slides .content__bullets li {
	margin: 0;
}

.wrap.slides .slide.bg-1 { background: var(--color-bg-1); }
.wrap.slides .slide.bg-2 { background: var(--color-bg-2); }
.wrap.slides .slide.bg-3 { background: var(--color-bg-3); }
.wrap.slides .slide.bg-4 { background: var(--color-bg-4); }
.wrap.slides .slide.bg-5 { background: var(--color-bg-5); }
.wrap.slides .slide.bg-6 { background: var(--color-bg-6); }

@media screen and (min-width: 63em) {
	.wrap.slides .slide.content--grid {
		grid-template-areas: 'content-img content-title' '. content-text';
		grid-template-columns: 30% 1fr;
		grid-template-rows: auto auto;
		justify-items: start;
		text-align: left;
		align-items: center;
	}

	.wrap.slides .content__img--large {
		width: 160%;
	}

	.wrap.slides .content__img--left {
		justify-self: end;
	}

	.wrap.slides .content__heading {
		align-self: center;
	}

	.wrap.slides .content__title {
		align-self: center;
	}

	.wrap.slides .content__text {
		padding: 0;
		text-align: left;
	}

	.wrap.slides .content__text--left {
		align-self: start;
	}
}

.demo-2, 
.demo-4,
.demo-6,
.demo-8,
.demo-10,
.demo-12,
.demo-14 {
	--color-text: var(--color-primary);
	--color-muted: rgba(var(--color-primary-rgb), 0.72);
	--color-bg: var(--color-white);
	--color-link: var(--color-primary);
	--color-link-hover: #001d31;
	--color-bg-1: #f7f9fb;
	--color-bg-2: #eff3f6;
	--color-bg-3: #e7eef2;
	--color-bg-4: #fbfcfd;
	--color-bg-5: #f1f5f8;
	--color-bg-6: #e9f0f5;
}

.theme-dark {
	--color-text: #f5f6f7;
	--color-muted: rgba(255,255,255,0.72);
	--color-bg: #0f1217;
	--color-surface: #151a22;
	--color-link: rgba(255,255,255,0.7);
	--color-link-hover: #ffffff;
	--color-bg-1: #111722;
	--color-bg-2: #151d29;
	--color-bg-3: var(--color-bg-1);
	--color-bg-4: var(--color-bg-2);
	--color-bg-5: var(--color-bg-1);
	--color-bg-6: var(--color-bg-2);
	--focus-ring: rgba(255,255,255,0.78);
}

.site-nav {
	position: fixed;
	top: 14px;
	left: 14px;
	right: 14px;
	z-index: 4100;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	pointer-events: none;
	color: var(--color-text);
}

.site-nav__left,
.site-nav__right {
	display: flex;
	align-items: center;
	gap: 10px;
}

.site-nav__left {
	pointer-events: auto;
	transition: opacity 180ms ease, transform 180ms ease;
}

body.is-presenting .site-nav__left {
	opacity: 0;
	transform: translateY(-10px);
	pointer-events: none;
}

.site-nav__btn {
	pointer-events: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 38px;
	min-width: 38px;
	padding: 0 12px;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.18);
	background: rgba(255,255,255,0.86);
	backdrop-filter: blur(12px);
	color: currentColor;
	cursor: pointer;
	font-weight: 650;
	font-size: 0.85rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: transform 160ms ease, border-color 160ms ease, opacity 160ms ease;
}

.theme-dark .site-nav__btn {
	border-color: rgba(255,255,255,0.22);
	background: rgba(15,18,23,0.72);
}

.site-nav__btn:hover {
	transform: translateY(-1px);
	border-color: rgba(var(--color-primary-rgb), 0.34);
}

.theme-dark .site-nav__btn:hover {
	border-color: rgba(255,255,255,0.38);
}

.site-nav__btn:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

.site-nav__btn--theme {
	padding: 0 10px;
	width: 38px;
}

.site-nav__icon {
	display: block;
}

.site-nav__icon--sun {
	display: none;
}

.theme-dark .site-nav__icon--sun {
	display: block;
}

.theme-dark .site-nav__icon--moon {
	display: none;
}

.site-nav__right {
	pointer-events: none;
	gap: 12px;
}

.site-nav__logo {
	display: block;
	height: 26px;
	width: auto;
	opacity: 0.95;
	filter: drop-shadow(0 10px 24px rgba(0,0,0,0.14));
}

.theme-dark .site-nav__logo {
	filter: brightness(0) invert(1) drop-shadow(0 14px 30px rgba(0,0,0,0.38));
}

body.is-presenting .site-nav__logo {
	filter: grayscale(1) brightness(0) drop-shadow(0 10px 24px rgba(0,0,0,0.14));
}

.site-nav__divider {
	width: 1px;
	height: 20px;
	background: rgba(0,0,0,0.28);
}

.theme-dark .site-nav__divider {
	background: rgba(255,255,255,0.28);
}

.demo-9 {
	--color-bg-1: #2f251e;
	--color-bg-2: #43392f;
	--color-bg-3: #18130e;
	--color-bg-4: var(--color-bg-1);
	--color-bg-5: var(--color-bg-2);
	--color-bg-6: var(--color-bg-3);
}

.demo-10 {
	--color-bg-1: #9d9d9d;
	--color-bg-2: #c7c7c7;
	--color-bg-3: #7c7c7c;
	--color-bg-4: var(--color-bg-1);
	--color-bg-5: var(--color-bg-2);
	--color-bg-6: var(--color-bg-3);
}

/* Page Loader */
.js .loading::before,
.js .loading::after {
	content: '';
	position: fixed;
	z-index: 5000;
}

.js .loading::before {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-bg);
}

.js .loading::after {
	top: 50%;
	left: 50%;
	width: 60px;
	height: 60px;
	margin: -30px 0 0 -30px;
	border-radius: 50%;
	opacity: 0.4;
	background: var(--color-link);
	animation: loaderAnim 0.7s linear infinite alternate forwards;
}

@keyframes loaderAnim {
	to {
		opacity: 1;
		transform: scale3d(0.5,0.5,1);
	}
}

a {
	text-decoration: none;
	color: var(--color-link);
	outline: none;
	cursor: pointer;
}

a:hover {
	color: var(--color-link-hover);
	outline: none;
}

/* Better focus styles from https://developer.mozilla.org/en-US/docs/Web/CSS/:focus-visible */
a:focus {
	/* Provide a fallback style for browsers
	 that don't support :focus-visible */
	outline: none;
}

a:focus:not(:focus-visible) {
	/* Remove the focus indicator on mouse-focus for browsers
	 that do support :focus-visible */
	outline: none;
}

a:focus-visible {
	/* Draw a very noticeable focus style for
	 keyboard-focus on browsers that do support
	 :focus-visible */
	outline: 2px solid var(--focus-ring);
	outline-offset: 3px;
}

.unbutton {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font: inherit;
	cursor: pointer;
}

.unbutton:focus {
	outline: none;
}

.frame {
	padding: var(--page-padding);
	position: relative;
	display: grid;
	z-index: 1000;
	width: 100%;
	grid-row-gap: 1rem;
	grid-column-gap: 2rem;
	justify-items: start;
	text-transform: uppercase;
	font-size: 12px;
}

.frame--header {
	height: 100%;
	z-index: 3000;
	background-size: auto 80%;
	background-position: 120% 50%;
	background-repeat: no-repeat;
	grid-template-areas: 'title' 'prev' 'back' 'sub' 'sponsor' 'demos' 'heading';
}

.frame--footer {
	grid-template-areas: 'credits' 'author';
	align-content: end;
}

.frame #cdawrap {
  justify-self: start;
}

.frame a {
  pointer-events: auto;
}

.frame__title {
  grid-area: title;
  font-size: inherit;
  margin: 0;
}

.frame__back {
  grid-area: back;
  justify-self: start;
}

.frame__prev {
  grid-area: prev;
  justify-self: start;
}

.frame__sub {
  grid-area: sub;
}

.frame__demos {
	grid-area: demos;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	align-self: start;
	flex-wrap: wrap;
	background: var(--color-bg);
	border: 1px solid;
	padding: 1rem;
	border-radius: 10px;
}

.frame__demos > * {
	width: 2rem;
	display: block;
	flex: none;
	text-decoration: none;
	border-radius: 50%;
	aspect-ratio: 1;
	border: 1px solid var(--color-link-hover);
	display: grid;
	place-items: center;
	padding-top: 0.2em;
	background: var(--color-bg);
}

.frame__demos > span {
	filter: invert(100%);
}

.frame__demos::before {
	content: "Variations:";
}

.frame__heading {
	grid-area: heading;
	align-self: center;
	justify-self: start;
	width: min-content;
	display: flex;
	flex-direction: column;
	margin-top: 10vh;
}

.frame__heading h2 {
	margin: 0;
	line-height: 0.9;
	text-transform: none;
	margin-left: -0.01em;
	font-size: clamp(2.5rem,12vw,7rem);
	letter-spacing: -0.03em;
	font-family: var(--font-heading);
	font-weight: 600;
}

i {
	font-style: normal;
}

.frame__heading p {
		margin: 0;
}

.frame__credits {
	grid-area: credits;
}

.frame__author {
	display: flex;
	gap: 1.5rem;
	grid-area: author;
}

/* Hero kickoff section */
.hero {
	padding: clamp(3rem, 6vw, 6rem) var(--page-padding-x);
	background: linear-gradient(
		135deg,
		rgba(var(--color-primary-rgb), 0.16) 0%,
		rgba(var(--color-primary-rgb), 0.06) 55%,
		var(--color-bg) 100%
	);
	color: var(--color-text);
	border-bottom: 1px solid rgba(0,0,0,0.05);
}

.hero--kickoff {
	display: flex;
	align-items: center;
	justify-content: center;
}

.content--grid.hero--kickoff {
	display: flex;
}

.hero__inner {
	max-width: 960px;
	margin: 0 auto;
	display: grid;
	gap: 1.25rem;
	justify-items: center;
	text-align: center;
}

.hero__logos {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: center;
}

.hero__logo {
	height: 42px;
	width: auto;
}

.hero__logo--hilton {
	height: 52px;
}

.theme-dark .hero__logo {
	filter: brightness(0) invert(1);
}

.hero__divider {
	width: 1px;
	height: 32px;
	background: rgba(0,0,0,0.1);
	display: inline-block;
}

.hero__eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.85rem;
	color: rgba(var(--color-primary-rgb), 0.65);
}

.hero__title {
	margin: 0;
	font-size: clamp(2.6rem, 6vw, 4rem);
	letter-spacing: -0.02em;
	line-height: 1.12;
	font-family: var(--font-heading);
	font-weight: 600;
}

.hero__lede {
	margin: 0;
	max-width: 780px;
	font-size: 1.08rem;
	line-height: 1.6;
	color: var(--color-muted);
}

.hero__actions {
	display: flex;
	gap: 0.9rem;
	flex-wrap: wrap;
	margin-top: 0.75rem;
	justify-content: center;
}

.hero__actions--left {
	justify-content: flex-start;
}

.hero__actions--stacked {
	flex-direction: column;
	align-items: flex-start;
}

.hero__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.85rem 1.6rem;
	border-radius: 12px;
	border: 1px solid transparent;
	background: var(--color-primary);
	color: var(--color-white);
	font-weight: 600;
	letter-spacing: 0.01em;
	transition: transform 180ms ease, box-shadow 200ms ease, border-color 180ms ease, background 180ms ease;
}

.hero__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 30px rgba(0,0,0,0.08);
}

.hero__cta:focus-visible {
	outline: 2px solid var(--focus-ring);
	outline-offset: 3px;
}

.hero__cta--ghost {
	background: transparent;
	color: var(--color-primary);
	border-color: rgba(var(--color-primary-rgb), 0.18);
}

.hero__cta--ghost:hover {
	background: rgba(var(--color-primary-rgb), 0.06);
	box-shadow: none;
}

.content.hero--immersive {
	min-height: 100vh;
	width: 100%;
	position: relative;
	overflow: hidden;
	isolation: isolate;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: flex-start;
	padding: clamp(3rem, 7vw, 6rem);
	padding-bottom: clamp(5rem, 18vh, 12rem);
	background:
		radial-gradient(600px 600px at 18% 28%, rgba(var(--color-primary-rgb), 0.14), transparent 55%),
		radial-gradient(700px 700px at 82% 6%, rgba(var(--color-primary-rgb), 0.08), transparent 60%),
		linear-gradient(140deg, var(--color-white) 0%, #f7fafc 45%, #eef4f8 100%);
	color: #fff;
	border-bottom: none;
}

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

.hero__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	pointer-events: none;
}

.hero__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero--immersive::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(var(--color-primary-rgb), 0.05) 0%, transparent 38%, rgba(0,0,0,0.03) 100%);
	pointer-events: none;
	z-index: 1;
}

.hero__inner--immersive {
	position: relative;
	z-index: 2;
	width: min(600px, 100%);
	margin: 0;
	display: grid;
	gap: 1.1rem;
	text-align: left;
	align-items: start;
	justify-items: start;
}

.hero--immersive .hero__lede {
	color: currentColor;
	opacity: 0.78;
}

.hero__meta {
	margin: 0;
	font-size: 0.82rem;
	letter-spacing: 0.01em;
	opacity: 0.65;
}

.hero--immersive .hero__meta {
	color: currentColor;
	opacity: 0.7;
}

.hero--immersive .hero__cta--ghost {
	background: rgba(255, 255, 255, 0.95);
	color: #003150;
	border-color: rgba(255, 255, 255, 0.55);
}

.hero--immersive .hero__cta--ghost:hover {
	background: rgba(255, 255, 255, 0.9);
	box-shadow: none;
}

/* Pinned showcase (GSAP image reveal) */
.pinned-showcase {
	width: 100%;
	background: linear-gradient(180deg, rgba(var(--color-primary-rgb), 0.03) 0%, transparent 38%);
	scroll-margin-top: 90px;
}

.pinned-showcase__layout {
	display: flex;
	width: 100%;
}

.pinned-showcase__steps {
	position: relative;
	width: 56%;
	z-index: 1;
}

.pinned-showcase__step {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 4vw, 3rem);
	gap: 0.65rem;
}

.pinned-showcase__num {
	font-family: var(--font-body);
	font-weight: 650;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-size: 0.85rem;
	color: rgba(var(--color-primary-rgb), 0.65);
}

.pinned-showcase__title {
	margin: 0;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: clamp(2.1rem, 4.2vw, 3.35rem);
	letter-spacing: -0.02em;
	line-height: 1.05;
	color: var(--color-text);
	text-wrap: balance;
}

.pinned-showcase__subtitle {
	margin: 0;
	max-width: 38ch;
	font-family: var(--font-body);
	font-size: 1.05rem;
	line-height: 1.55;
	color: var(--color-text);
	opacity: 0.65;
}

.pinned-showcase__cta {
	margin-top: 1.2rem;
	width: fit-content;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.7rem 1.15rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.18);
	background: rgba(var(--color-primary-rgb), 0.03);
	color: var(--color-primary);
	font-family: var(--font-body);
	font-size: 0.82rem;
	font-weight: 650;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: transform 160ms ease, background 200ms ease, border-color 200ms ease;
}

.pinned-showcase__cta:hover {
	transform: translateY(-1px);
	background: rgba(var(--color-primary-rgb), 0.06);
	border-color: rgba(var(--color-primary-rgb), 0.28);
}

.pinned-showcase__cta:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

.pinned-showcase__mobile-image {
	display: none;
	width: min(520px, 100%);
	margin-top: 1.2rem;
	border-radius: 22px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.12);
	box-shadow: 0 26px 60px rgba(var(--color-primary-rgb), 0.12);
	object-fit: cover;
}

.pinned-showcase__media {
	width: 44%;
}

.pinned-showcase__sticky {
	position: sticky;
	top: 0;
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(2rem, 4vw, 3rem);
}

.pinned-showcase__frame {
	width: min(560px, 100%);
	aspect-ratio: 4 / 3;
	position: relative;
	border-radius: 28px;
	overflow: hidden;
	border: 1px solid rgba(var(--color-primary-rgb), 0.12);
	box-shadow: 0 30px 70px rgba(var(--color-primary-rgb), 0.14);
	background: var(--color-surface);
}

.pinned-showcase__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border-radius: inherit;
	overflow: hidden;
	opacity: 0;
	filter: blur(6px);
	transform: scale(1.01);
	transition: opacity 420ms var(--cubicbz, ease), filter 420ms var(--cubicbz, ease), transform 420ms var(--cubicbz, ease);
	will-change: opacity, filter, transform;
}

.pinned-showcase__image.is-active {
	opacity: 1;
	filter: blur(0px);
	transform: scale(1);
}

.pinned-showcase__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (prefers-reduced-motion: reduce) {
	.pinned-showcase__image {
		transition: none;
		filter: none;
		transform: none;
	}
}

@media (max-width: 56em) {
	.pinned-showcase__layout {
		flex-direction: column;
	}

	.pinned-showcase__steps {
		width: 100%;
	}

	.pinned-showcase__media {
		display: none;
	}

	.pinned-showcase__step {
		min-height: auto;
		padding-top: clamp(3rem, 8vw, 4.5rem);
		padding-bottom: clamp(3rem, 8vw, 4.5rem);
	}

	.pinned-showcase__mobile-image {
		display: block;
	}
}

.content.services {
	width: 100%;
	padding: clamp(3rem, 7vw, 6rem) clamp(1.5rem, 4vw, 3rem);
	background: linear-gradient(180deg, rgba(0,49,80,0.02) 0%, transparent 35%);
	color: inherit;
	position: relative;
	z-index: 1;
	display: block;
	gap: 2rem;
}

.services__header {
	width: min(1100px, 100%);
	margin: 0 auto 1.5rem auto;
	display: grid;
	gap: 0.5rem;
	text-align: left;
}

.services__lede {
	max-width: 720px;
	padding: 0;
}

.service-cards {
	width: min(1100px, 100%);
	margin: 0 auto;
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.service-card {
	background: var(--color-surface);
	border: 1px solid rgba(var(--color-primary-rgb), 0.1);
	border-radius: 16px;
	padding: 1.2rem 1.35rem;
	box-shadow: 0 18px 40px rgba(var(--color-primary-rgb), 0.1);
	display: grid;
	gap: 0.75rem;
	align-content: space-between;
	min-height: 220px;
}

.service-card__body {
	display: grid;
	gap: 0.35rem;
}

.service-card__cta {
	align-self: end;
	justify-content: flex-start;
	width: fit-content;
}

.theme-dark .service-card {
	background: #151a22;
	border-color: rgba(255,255,255,0.08);
	box-shadow: 0 18px 40px rgba(0,0,0,0.28);
}

.content {
	padding: var(--page-padding);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
}

.content--perspective {
	perspective-origin: 50% 0%;
	perspective: 1000px;
}

.text-large {
	font-size: clamp(1.5rem,5vw,3rem);
	max-width: 900px;
	margin: 0 0 0.85em 0;
	line-height: 1.2;
	font-family: var(--font-heading);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--color-text);
}

.content--sticky {
	width: 100vw;
	position: sticky;
	top: 0;
	--offset: 0px;
	top: var(--offset);
	height: calc(100vh - var(--offset));
	padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 4vw, 3rem);
}

.content--grid,
.content--grid .content__inner {
	display: grid;
	overflow: hidden;
	grid-column-gap: 5vw;
	grid-row-gap: 2vh;
	align-content: center;
	grid-template-areas: 'content-img' 'content-title' 'content-text';
	justify-items: center;
	gap: 1rem;
	align-items: center;
	text-align: center;
	padding: 0 clamp(2rem, 4vw, 3rem);
}

.content--grid:has(.content__inner) {
	display: block;
	padding: 0;
}

.content__inner {
	width: 100%;
	height: 100%;
	border-radius: 0 0 2rem 2rem;
}

.content--sticky.content--grid {
	background: var(--color-surface);
	border-radius: 24px;
	box-shadow: 0 26px 70px rgba(var(--color-primary-rgb), 0.12);
	border: 1px solid rgba(var(--color-primary-rgb), 0.12);
}

.content--highlight {
	background: linear-gradient(180deg, rgba(var(--color-primary-rgb), 0.06) 0%, rgba(var(--color-primary-rgb), 0.02) 100%);
	color: var(--color-text);
	padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 4vw, 3rem);
}

.content--card {
	display: flex;
	flex-direction: column;
	height: 80vh;
	width: 95vw;
	max-width: 500px;
	aspect-ratio: 0.8;
	top: 10vh;
	margin: auto;
	border-radius: 14px;
	gap: 3vh;
	text-align: center;
	margin-bottom: 5vh;
}

.content--card .content__title {
	font-size: clamp(1.5rem,4vw,3.5rem);
}

.content--card .content__title i {
	display: block;
}

.content--half {
	display: flex;
	flex-direction: column;
	gap: 3vh;
	text-align: center;
}

.content--half:nth-child(odd) {
	margin-left: auto;
}

.content__img {
	grid-area: content-img;
	width: 50%;
	max-width: 300px;
	height: auto;
}

.content__img--large {
	width: 60%;
	height: auto;
}

.content__img--small {
	height: 35%;
	width: auto;
}

.spacer {
	margin-top: 20vh;
}

.content__title {
	grid-area: content-title;
	letter-spacing: -0.02em;
	text-transform: none;
	line-height: 1.06;
	font-weight: 600;
	font-size: clamp(2rem,6vw,4.5rem);
	margin: 0;
	font-family: var(--font-heading);
	color: var(--color-text);
	text-wrap: balance;
}

.content__text {
	margin: 0;
	max-width: 500px;
	grid-area: content-text;
	text-align: center;
	line-height: 1.5;
	padding: 0 1rem;
	backface-visibility: hidden;
	color: var(--color-muted);
}

.content__text--narrow {
	max-width: 300px;
}

.content__eyebrow {
	margin: 0;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 0.9rem;
	color: var(--color-link);
}

.theme-dark .content__eyebrow {
	color: rgba(255,255,255,0.7);
}

.content__kicker {
	margin: 0 0 0.35rem 0;
	font-weight: 700;
	letter-spacing: 0.01em;
}

.content__block {
	grid-column: 1 / -1;
	display: grid;
	gap: 0.35rem;
	align-items: start;
	text-align: left;
	max-width: 760px;
}

.foundation-grid {
	grid-column: 1 / -1;
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	width: 100%;
	max-width: 1080px;
}

.foundation-card {
	background: rgba(255,255,255,0.78);
	border: 1px solid rgba(0,0,0,0.06);
	border-radius: 18px;
	padding: 1.2rem 1.4rem;
	box-shadow: 0 14px 35px rgba(0,0,0,0.06);
	display: grid;
	gap: 0.3rem;
}

.foundation-card--wide {
	grid-column: 1 / -1;
}

.theme-dark .foundation-card {
	background: rgba(23,27,34,0.85);
	border-color: rgba(255,255,255,0.08);
	box-shadow: 0 14px 35px rgba(0,0,0,0.35);
}

.content__logos {
	position: absolute;
	top: 14px;
	right: 14px;
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 6px 10px;
	background: rgba(255,255,255,0.8);
	border: 1px solid rgba(0,0,0,0.06);
	backdrop-filter: blur(10px);
	border-radius: 12px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.08);
	pointer-events: none;
}

.content__logo {
	height: 28px;
	width: auto;
	pointer-events: none;
}

.content__logo--hilton {
	height: 34px;
}

.theme-dark .content__logos {
	background: rgba(18,20,26,0.7);
	border-color: rgba(255,255,255,0.08);
}

.theme-dark .content__logo {
	filter: brightness(0) invert(1);
}

.content__list {
	margin: 0;
	padding-left: 1.2rem;
	display: grid;
	gap: 0.25rem;
	color: inherit;
}

.content--intro {
	padding-top: 25vh;
	padding-bottom: 25vh;
	z-index: 2;
}

.content--outro {
	padding-top: 50vh;
	padding-bottom: 30vh;
}

.content--break {
	min-height: 140vh;
}

.scroll-break {
	min-height: 8vh;
	background: #e1e1e1;
	margin: 0;
}

.embed-section {
	gap: 1rem;
	text-align: center;
}

.embed-section__subline {
	margin: 0;
	max-width: 42ch;
	font-size: 1.05rem;
	line-height: 1.6;
	color: var(--color-muted);
}

.embed-frame {
	width: min(1100px, 100%);
	aspect-ratio: 16 / 9;
	max-height: 80vh;
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 24px 60px rgba(var(--color-primary-rgb), 0.12);
	border: 1px solid rgba(var(--color-primary-rgb), 0.14);
}

.embed-frame iframe {
	width: 100%;
	height: 100%;
	border: none;
	border-radius: 18px;
}

.theme-dark .embed-frame {
	border-color: rgba(255,255,255,0.08);
	box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}

.booking-section {
	gap: 1.25rem;
	scroll-margin-top: 90px;
	min-height: 100vh;
	background: linear-gradient(
		180deg,
		rgba(var(--color-primary-rgb), 0.03) 0%,
		rgba(var(--color-primary-rgb), 0.02) 45%,
		var(--color-bg) 100%
	);
}

.booking-wrapper {
	width: min(1100px, 100%);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
	text-align: left;
}

.booking-wrapper .content__title,
.booking-wrapper .content__text {
	grid-area: auto;
	padding: 0;
	text-align: left;
	max-width: 72ch;
}

.booking-wrapper .content__title {
	font-size: clamp(2.1rem, 4.4vw, 3.35rem);
	line-height: 1.1;
}

.booking-flow {
	width: min(1100px, 100%);
	display: grid;
	gap: 1rem;
	margin-top: 1rem;

	--booking-surface: rgba(255,255,255,0.92);
	--booking-surface-muted: rgba(var(--color-primary-rgb), 0.03);
	--booking-border: rgba(0,0,0,0.08);
	--booking-shadow: 0 18px 44px rgba(0,0,0,0.06);
	--booking-shadow-soft: 0 12px 30px rgba(0,0,0,0.05);
}

.booking-body {
	width: 100%;
	display: grid;
	gap: 1.25rem;
}

.booking-sidebar {
	align-self: start;
}

.booking-sidebar__card {
	border-radius: 18px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface);
	box-shadow: var(--booking-shadow);
	padding: 1.15rem 1.2rem;
	display: grid;
	gap: 0.85rem;
}

.booking-sidebar__top {
	display: grid;
	gap: 0.25rem;
}

.booking-sidebar__kicker {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.78rem;
	color: var(--color-muted);
}

.booking-sidebar__provider {
	margin: 0;
	font-weight: 600;
	letter-spacing: 0.01em;
}

.booking-sidebar__list {
	margin: 0;
	display: grid;
	grid-template-columns: 110px 1fr;
	column-gap: 0.9rem;
	row-gap: 0.45rem;
}

.booking-sidebar__list dt {
	font-size: 0.92rem;
	color: var(--color-muted);
}

.booking-sidebar__list dd {
	margin: 0;
	font-weight: 500;
}

.booking-sidebar__note {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.55;
	color: var(--color-muted);
}

.booking-stepper {
	width: 100%;
	display: flex;
	gap: 0.55rem;
	align-items: center;
	overflow-x: auto;
	padding-bottom: 0.25rem;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.booking-stepper::-webkit-scrollbar {
	display: none;
}

.booking-stepper__item {
	flex: 0 0 auto;
	min-width: min(220px, 90vw);
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.7rem 0.85rem;
	border-radius: 14px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface);
	color: inherit;
	text-align: left;
	box-shadow: var(--booking-shadow-soft);
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
	min-height: 62px;
	scroll-snap-align: start;
}

.booking-stepper__item:hover:not(:disabled) {
	transform: translateY(-1px);
	border-color: rgba(var(--color-primary-rgb), 0.22);
	box-shadow: var(--booking-shadow);
}

.booking-stepper__item:focus-visible {
	outline: 2px solid var(--focus-ring);
	outline-offset: 3px;
}

.booking-stepper__item:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	box-shadow: none;
}

.booking-stepper__item.is-active {
	border-color: rgba(var(--color-primary-rgb), 0.42);
	background: rgba(var(--color-primary-rgb), 0.06);
}

.booking-stepper__item.is-complete {
	border-color: rgba(var(--color-primary-rgb), 0.2);
}

.booking-stepper__num {
	width: 34px;
	height: 34px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	background: rgba(var(--color-primary-rgb), 0.07);
	color: var(--color-primary);
}

.booking-stepper__item.is-complete .booking-stepper__num {
	background: rgba(var(--color-primary-rgb), 0.12);
}

.booking-stepper__text {
	display: grid;
	gap: 0.1rem;
	min-width: 0;
}

.booking-stepper__label {
	font-weight: 600;
	font-size: 0.78rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(var(--color-primary-rgb), 0.64);
}

.booking-stepper__meta {
	font-size: 0.98rem;
	font-weight: 600;
	color: var(--color-text);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.booking-stage {
	position: relative;
	display: grid;
}

.booking-stage__inner {
	grid-area: 1 / 1;
	border-radius: 18px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface);
	box-shadow: var(--booking-shadow);
	padding: clamp(1.1rem, 2.2vw, 1.6rem);
	display: grid;
	gap: 1.15rem;
	transform-origin: 50% 30%;
	transition: opacity 220ms ease, filter 220ms ease, transform 220ms ease;
}

.booking-stage__inner.is-entering {
	opacity: 0;
	filter: blur(4px);
	transform: translateY(8px) scale(0.995);
}

.booking-stage__inner.is-exiting {
	opacity: 0;
	filter: blur(4px);
	transform: translateY(-8px) scale(0.995);
	pointer-events: none;
}

.booking-stage__header {
	display: grid;
	gap: 0.4rem;
}

.booking-stage__title {
	margin: 0;
	font-family: var(--font-heading);
	font-size: clamp(1.5rem, 2.2vw, 2rem);
	letter-spacing: -0.01em;
	line-height: 1.15;
}

.booking-stage__title:focus {
	outline: 2px solid rgba(var(--color-primary-rgb), 0.35);
	outline-offset: 4px;
	border-radius: 10px;
}

.booking-stage__description {
	margin: 0;
	max-width: 70ch;
	line-height: 1.6;
	color: var(--color-muted);
}

.booking-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 0.85rem;
}

.booking-card {
	display: grid;
	gap: 0.45rem;
	padding: 1rem 1.05rem;
	border-radius: 16px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface);
	box-shadow: var(--booking-shadow-soft);
	color: inherit;
	text-align: left;
	transition: transform 180ms ease, border-color 180ms ease, box-shadow 200ms ease, background 180ms ease;
}

.booking-card:hover {
	transform: translateY(-2px);
	border-color: rgba(var(--color-primary-rgb), 0.2);
	box-shadow: var(--booking-shadow);
	background: var(--booking-surface-muted);
}

.booking-card:focus-visible {
	outline: 2px solid rgba(var(--color-primary-rgb), 0.38);
	outline-offset: 3px;
}

.booking-card__row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.75rem;
}

.booking-card__title {
	font-weight: 700;
	letter-spacing: 0.01em;
	font-size: 1.05rem;
}

.booking-card__meta {
	font-size: 0.92rem;
	color: var(--color-muted);
}

.booking-card__price {
	font-weight: 700;
	color: var(--color-text);
	white-space: nowrap;
}

.booking-card__desc {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.55;
	color: var(--color-muted);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

.booking-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.booking-tag {
	display: inline-flex;
	align-items: center;
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
	background: rgba(var(--color-primary-rgb), 0.06);
	border: 1px solid rgba(var(--color-primary-rgb), 0.1);
	color: var(--color-primary);
	font-size: 0.82rem;
	letter-spacing: 0.01em;
}

.booking-service-layout {
	display: grid;
	gap: 1rem;
}

.booking-cards--services {
	align-content: start;
}

.booking-aside {
	border-radius: 16px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface-muted);
	padding: 1rem 1.1rem;
}

.booking-aside__title {
	margin: 0;
	font-size: 0.95rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--color-muted);
}

.booking-aside__list {
	margin: 0.75rem 0 0;
	padding-left: 1.1rem;
	display: grid;
	gap: 0.4rem;
	color: var(--color-muted);
}

.booking-time-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(84px, 1fr));
	gap: 0.55rem;
	margin-top: 0.5rem;
}

.booking-time {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.55rem 0.7rem;
	border-radius: 999px;
	border: 1px solid var(--booking-border);
	background: rgba(255,255,255,0.94);
	color: inherit;
	font-weight: 600;
	transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.booking-time:hover {
	transform: translateY(-1px);
	border-color: rgba(var(--color-primary-rgb), 0.32);
}

.booking-time:focus-visible {
	outline: 2px solid var(--focus-ring);
	outline-offset: 3px;
}

.theme-dark .booking-time {
	background: rgba(255,255,255,0.06);
	border-color: rgba(255,255,255,0.14);
	color: rgba(255,255,255,0.92);
}

.theme-dark .booking-time:hover {
	border-color: rgba(255,255,255,0.22);
}

.booking-time.is-selected {
	background: rgba(var(--color-primary-rgb), 0.1);
	border-color: rgba(var(--color-primary-rgb), 0.38);
	color: var(--color-primary);
}

.booking-actions--flow {
	justify-content: flex-end;
	gap: 0.6rem;
}

.booking-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.85rem 1.35rem;
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,0.12);
	background: transparent;
	color: var(--color-primary);
	font-weight: 600;
	letter-spacing: 0.01em;
	transition: transform 180ms ease, box-shadow 200ms ease, border-color 180ms ease, background 180ms ease;
}

.booking-action:hover:not(:disabled) {
	transform: translateY(-2px);
	background: rgba(var(--color-primary-rgb), 0.06);
}

.booking-action:focus-visible {
	outline: 2px solid var(--focus-ring);
	outline-offset: 3px;
}

.booking-action:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.booking-summary {
	border-radius: 16px;
	border: 1px solid var(--booking-border);
	background: var(--booking-surface-muted);
	padding: 1rem 1.1rem;
}

.booking-summary__lead {
	margin: 0;
	color: var(--color-muted);
	line-height: 1.6;
}

.booking-summary__list {
	margin: 0;
	display: grid;
	grid-template-columns: 150px 1fr;
	row-gap: 0.45rem;
	column-gap: 1rem;
}

.booking-summary__list dt {
	font-weight: 600;
	color: var(--color-muted);
}

.booking-summary__list dd {
	margin: 0;
}

.booking-error {
	margin: 0;
	color: #b42318;
	background: rgba(255, 107, 107, 0.12);
	border: 1px solid rgba(255, 107, 107, 0.28);
	padding: 0.75rem 0.9rem;
	border-radius: 14px;
}

.theme-dark .booking-flow {
	--booking-surface: rgba(21,26,34,0.92);
	--booking-surface-muted: rgba(255,255,255,0.06);
	--booking-border: rgba(255,255,255,0.1);
	--booking-shadow: 0 18px 52px rgba(0,0,0,0.55);
	--booking-shadow-soft: 0 14px 36px rgba(0,0,0,0.5);
}

.theme-dark .booking-stepper__meta,
.theme-dark .booking-card__desc,
.theme-dark .booking-card__meta,
.theme-dark .booking-stage__description,
.theme-dark .booking-summary__lead,
.theme-dark .booking-aside__list {
	color: rgba(255,255,255,0.72);
}

.theme-dark .booking-stepper__label {
	color: rgba(255,255,255,0.62);
}

.theme-dark .booking-stepper__num,
.theme-dark .booking-tag,
.theme-dark .booking-time.is-selected {
	color: #ffffff;
	background: rgba(255,255,255,0.12);
	border-color: rgba(255,255,255,0.12);
}

.theme-dark .booking-stepper__item:hover:not(:disabled),
.theme-dark .booking-card:hover {
	border-color: rgba(255,255,255,0.18);
}

.theme-dark .booking-action {
	border-color: rgba(255,255,255,0.14);
	color: rgba(255,255,255,0.92);
}

.theme-dark .booking-action:hover:not(:disabled) {
	background: rgba(255,255,255,0.08);
}

@media (prefers-reduced-motion: reduce) {
	.booking-stage__inner {
		transition: none;
	}

	.booking-card,
	.booking-stepper__item,
	.booking-time,
	.booking-action,
	.hero__cta {
		transition: none;
	}
}

@media screen and (min-width: 60em) {
	.booking-stepper__item {
		flex: 1 1 0;
		min-width: 0;
	}
}

@media screen and (min-width: 63em) {
	.booking-body {
		grid-template-columns: 1fr minmax(260px, 340px);
		align-items: start;
	}

	.booking-sidebar {
		position: sticky;
		top: 110px;
	}

	.booking-service-layout {
		grid-template-columns: 1fr minmax(260px, 320px);
		align-items: start;
	}
}

.booking-form {
	width: min(900px, 100%);
	display: grid;
	gap: 1rem;
	margin-top: 1rem;
}

.booking-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
}

.booking-field {
	display: grid;
	gap: 0.35rem;
	text-align: left;
	color: inherit;
}

.booking-field span {
	font-size: 0.9rem;
	letter-spacing: 0.01em;
	color: var(--color-muted);
}

.theme-dark .booking-field span {
	color: rgba(255,255,255,0.75);
}

.booking-field input,
.booking-field select,
.booking-field textarea {
	width: 100%;
	border-radius: 12px;
	border: 1px solid var(--booking-border, rgba(var(--color-primary-rgb), 0.15));
	padding: 0.75rem 0.9rem;
	font-size: 1rem;
	font-family: inherit;
	background: var(--booking-surface, rgba(255,255,255,0.96));
	color: inherit;
	box-shadow: 0 10px 24px rgba(0,0,0,0.05);
	transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

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

.booking-field input:focus,
.booking-field select:focus,
.booking-field textarea:focus {
	outline: none;
	border-color: rgba(var(--color-primary-rgb), 0.42);
	box-shadow: 0 14px 32px rgba(0,0,0,0.08);
	background: rgba(255,255,255,0.98);
}

.theme-dark .booking-field input,
.theme-dark .booking-field select,
.theme-dark .booking-field textarea {
	background: var(--booking-surface, rgba(21,26,34,0.9));
	border-color: var(--booking-border, rgba(255,255,255,0.08));
	box-shadow: 0 10px 28px rgba(0,0,0,0.45);
}

.booking-field--full {
	grid-column: 1 / -1;
}

.booking-actions {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	align-items: center;
}

.bg-1 { background: var(--color-bg-1); }
.bg-2 { background: var(--color-bg-2); }
.bg-3 { background: var(--color-bg-3); }
.bg-4 { background: var(--color-bg-4); }
.bg-5 { background: var(--color-bg-5); }
.bg-6 { background: var(--color-bg-6); }

@media screen and (min-width: 63em) {
	body {
		--page-padding-y: 2rem;
		--page-padding-x: 3rem;
	}
	.frame--header {
		height: 100vh;
		grid-template-columns: auto auto auto 1fr 1fr;
		grid-template-rows: auto 1fr auto;
		align-content: space-between;
		grid-template-areas: 'title back prev sub sponsor' 'heading heading heading heading heading' 'demos demos demos demos demos';
	}
	.frame__heading {
		margin-top: 0;
	}
	.frame__heading h2 {
		white-space: nowrap;
	}
	.frame__heading p {
		margin: 0 0 0 auto;
	}
	.content--grid .content__title {
		align-self: end;
	}
	.frame__demos {
		position: fixed;
		bottom: 2rem;
	}
	.frame--footer {
		padding-bottom: 0;
		grid-template-areas: 'credits ...' '... author';
		grid-template-columns: 1fr 1fr;
		grid-template-rows: auto 6rem;
	}
	.frame__author {
		align-self: center;
	}
	.frame #cdawrap {
		max-width: 300px;
		text-align: right;
	}
	.frame #cdawrap, 
	.frame__author,
	.frame__sub {
		justify-self: end;
	}
	.content--grid,
	.content--grid .content__inner {
		grid-template-areas: 'content-img content-title' 'content-img content-text';
		grid-template-columns: 30% 1fr;
		justify-items: start;
	}
	.content__img--large {
		width: 160%;
	}
	.content__img--left {
		justify-self: end;
	}
.content__text--left {
	text-align: left;
	align-self: start;
}
	.content--card {
		width: 50vw;
	}
	.content--half {
		width: 50%;
	}
}

/* Offers page */
.page-angebote {
	--color-text: #2c241d;
	--color-muted: rgba(44, 36, 29, 0.68);
	--color-bg: #f7f1ea;
	--color-surface: #fff9f3;
	--color-link: #2c241d;
	--color-link-hover: #1f1914;
	--color-primary-rgb: 44, 36, 29;

	--offers-hero-text: #f5f7fa;
	--offers-hero-muted: rgba(238, 242, 246, 0.78);

	--offers-page-bg:
		radial-gradient(circle at 20% 20%, rgba(170, 140, 110, 0.22), rgba(247, 241, 234, 0) 55%),
		radial-gradient(circle at 80% 75%, rgba(140, 120, 95, 0.18), rgba(247, 241, 234, 0) 60%),
		linear-gradient(180deg, #f8f2ec 0%, #f3ebe1 45%, #eee4d8 100%);
	--offers-vignette-bg:
		radial-gradient(circle at 50% 40%, rgba(8, 10, 12, 0.05), rgba(4, 5, 7, 0.6) 70%),
		linear-gradient(180deg, rgba(8, 10, 12, 0.25), rgba(4, 5, 7, 0.85));
	--offers-section-one-bg:
		radial-gradient(900px 700px at 12% 18%, rgba(190, 160, 130, 0.22), transparent 65%),
		radial-gradient(800px 600px at 88% 76%, rgba(210, 190, 170, 0.25), transparent 70%),
		linear-gradient(180deg, #f6efe6 0%, #f2e7db 55%, #ede2d5 100%);
	--offers-section-two-bg:
		radial-gradient(900px 700px at 85% 20%, rgba(180, 170, 160, 0.2), transparent 65%),
		radial-gradient(700px 500px at 18% 80%, rgba(200, 185, 170, 0.22), transparent 70%),
		linear-gradient(180deg, #f4f1ee 0%, #eee9e3 55%, #e7e1da 100%);
	--offers-section-three-bg:
		radial-gradient(900px 700px at 12% 18%, rgba(210, 185, 140, 0.22), transparent 62%),
		radial-gradient(800px 600px at 82% 78%, rgba(200, 170, 130, 0.22), transparent 70%),
		linear-gradient(180deg, #f7efe3 0%, #f1e5d6 55%, #ebdfcf 100%);
	--offers-section-retainer-bg:
		radial-gradient(900px 700px at 15% 20%, rgba(185, 160, 135, 0.24), transparent 65%),
		radial-gradient(800px 650px at 85% 80%, rgba(205, 185, 165, 0.26), transparent 70%),
		linear-gradient(180deg, #f5f0ea 0%, #efe7de 55%, #e8dfd4 100%);
	--offers-section-compare-bg:
		radial-gradient(800px 600px at 18% 25%, rgba(190, 175, 160, 0.2), transparent 65%),
		linear-gradient(180deg, #f3f0ec 0%, #ece6df 60%, #e5ded6 100%);
	--offers-panel-border: rgba(44, 36, 29, 0.14);
	--offers-panel-shadow: 0 24px 60px rgba(20, 16, 12, 0.12);
	--offers-panel-bg:
		linear-gradient(160deg, rgba(255, 255, 255, 0.88), rgba(235, 225, 215, 0.6)),
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.6), transparent 65%);
	--offers-panel-bg-cool:
		linear-gradient(160deg, rgba(225, 232, 238, 0.75), rgba(230, 220, 210, 0.55)),
		radial-gradient(circle at 25% 18%, rgba(255, 255, 255, 0.55), transparent 68%);
	--offers-panel-bg-gold:
		linear-gradient(160deg, rgba(235, 218, 185, 0.78), rgba(230, 216, 200, 0.55)),
		radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.6), transparent 68%);
	--offers-card-border: rgba(44, 36, 29, 0.14);
	--offers-card-shadow: 0 24px 55px rgba(20, 16, 12, 0.12);
	--offers-card-bg:
		linear-gradient(160deg, rgba(255, 255, 255, 0.86), rgba(235, 225, 215, 0.55)),
		radial-gradient(circle at 25% 20%, rgba(255, 255, 255, 0.55), transparent 70%);
	--offers-card-focus-border: rgba(44, 36, 29, 0.22);
	--offers-card-focus-shadow: 0 28px 70px rgba(20, 16, 12, 0.18);
	--offers-card-focus-bg:
		linear-gradient(160deg, rgba(220, 232, 245, 0.8), rgba(230, 220, 210, 0.55)),
		radial-gradient(circle at 25% 18%, rgba(255, 255, 255, 0.6), transparent 70%);

	min-height: 100vh;
	overflow-x: hidden;
	background: var(--offers-page-bg);
	color: var(--color-text);
}

.page-angebote.theme-dark {
	--color-text: #eef2f6;
	--color-muted: rgba(238, 242, 246, 0.7);
	--color-bg: #060504;
	--color-surface: #0f141a;
	--color-link: #e8edf2;
	--color-link-hover: #ffffff;
	--color-primary-rgb: 232, 238, 245;

	--offers-hero-text: #f5f7fa;
	--offers-hero-muted: rgba(238, 242, 246, 0.78);

	--offers-page-bg:
		radial-gradient(circle at 20% 20%, rgba(90, 70, 50, 0.18), rgba(6, 5, 4, 0) 55%),
		radial-gradient(circle at 80% 75%, rgba(60, 45, 35, 0.22), rgba(6, 5, 4, 0) 60%),
		linear-gradient(180deg, #080705 0%, #060504 45%, #030202 100%);
	--offers-vignette-bg:
		radial-gradient(circle at 50% 40%, rgba(8, 10, 12, 0.1), rgba(4, 5, 7, 0.82) 68%),
		linear-gradient(180deg, rgba(8, 10, 12, 0.35), rgba(4, 5, 7, 0.95));
	--offers-section-one-bg:
		radial-gradient(900px 700px at 12% 18%, rgba(160, 120, 85, 0.32), transparent 65%),
		radial-gradient(800px 600px at 88% 76%, rgba(70, 50, 35, 0.42), transparent 70%),
		linear-gradient(180deg, #0a0806 0%, #070604 55%, #050403 100%);
	--offers-section-two-bg:
		radial-gradient(900px 700px at 85% 20%, rgba(120, 110, 100, 0.28), transparent 65%),
		radial-gradient(700px 500px at 18% 80%, rgba(80, 70, 60, 0.32), transparent 70%),
		linear-gradient(180deg, #090808 0%, #070707 55%, #050505 100%);
	--offers-section-three-bg:
		radial-gradient(900px 700px at 12% 18%, rgba(200, 170, 120, 0.28), transparent 62%),
		radial-gradient(800px 600px at 82% 78%, rgba(110, 85, 55, 0.36), transparent 70%),
		linear-gradient(180deg, #0b0907 0%, #080706 55%, #050403 100%);
	--offers-section-retainer-bg:
		radial-gradient(900px 700px at 15% 20%, rgba(150, 120, 90, 0.28), transparent 65%),
		radial-gradient(800px 650px at 85% 80%, rgba(90, 70, 55, 0.35), transparent 70%),
		linear-gradient(180deg, #0a0908 0%, #070605 55%, #050403 100%);
	--offers-section-compare-bg:
		radial-gradient(800px 600px at 18% 25%, rgba(120, 110, 100, 0.22), transparent 65%),
		linear-gradient(180deg, #080808 0%, #060606 60%, #050505 100%);
	--offers-panel-border: rgba(255, 255, 255, 0.12);
	--offers-panel-shadow: 0 30px 70px rgba(0, 0, 0, 0.35);
	--offers-panel-bg:
		linear-gradient(160deg, rgba(255, 255, 255, 0.08), rgba(20, 18, 16, 0.2)),
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08), transparent 65%);
	--offers-panel-bg-cool:
		linear-gradient(160deg, rgba(180, 190, 200, 0.16), rgba(18, 18, 18, 0.2)),
		radial-gradient(circle at 25% 18%, rgba(140, 150, 160, 0.18), transparent 68%);
	--offers-panel-bg-gold:
		linear-gradient(160deg, rgba(220, 190, 140, 0.18), rgba(24, 18, 14, 0.2)),
		radial-gradient(circle at 18% 18%, rgba(220, 190, 140, 0.2), transparent 68%);
	--offers-card-border: rgba(255, 255, 255, 0.12);
	--offers-card-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
	--offers-card-bg:
		linear-gradient(160deg, rgba(255, 255, 255, 0.06), rgba(12, 12, 12, 0.2)),
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08), transparent 70%);
	--offers-card-focus-border: rgba(255, 255, 255, 0.22);
	--offers-card-focus-shadow: 0 30px 80px rgba(0, 0, 0, 0.38);
	--offers-card-focus-bg:
		linear-gradient(160deg, rgba(160, 180, 200, 0.18), rgba(12, 12, 12, 0.2)),
		radial-gradient(circle at 25% 18%, rgba(180, 200, 220, 0.18), transparent 70%);
}

.offers-page {
	position: relative;
	min-height: 100vh;
	color: inherit;
}

.offers-hero {
	position: relative;
	width: 100vw;
	height: 100vh;
	overflow: hidden;
	color: var(--offers-hero-text);
}

.offers-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
}

.offers-vignette {
	position: absolute;
	inset: 0;
	background: var(--offers-vignette-bg);
	opacity: 1;
	pointer-events: none;
	transition: opacity 120ms linear;
	z-index: 1;
}

.offers-overlay {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	text-align: center;
	padding: clamp(2rem, 6vh, 4rem) var(--page-padding-x);
	opacity: 0;
	transform: translate3d(0, 0, 0) scale(1);
	transition: opacity 200ms ease, transform 200ms ease;
	pointer-events: none;
	z-index: 2;
	color: var(--offers-hero-text);
}

.offers-overlay__inner {
	max-width: 60ch;
	display: grid;
	gap: 1.2rem;
}

.offers-overlay__eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.34em;
	font-size: 0.72rem;
	color: var(--offers-hero-muted);
	margin: 0;
}

.offers-overlay__title {
	margin: 0;
	font-size: clamp(2.2rem, 5vw, 4.4rem);
	letter-spacing: -0.02em;
	font-weight: 600;
	line-height: 1.05;
	font-family: "Clash Display", "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.offers-overlay__copy {
	margin: 0;
	font-size: clamp(1.05rem, 1.3vw, 1.25rem);
	line-height: 1.5;
	color: var(--offers-hero-muted);
}

.offers-overlay__micro {
	margin: 0;
	font-size: 0.8rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--offers-hero-muted);
}

.offers-fallback {
	position: absolute;
	inset: 0;
	display: none;
	place-items: center;
	background: rgba(5, 6, 8, 0.92);
	color: var(--offers-hero-muted);
	font-size: 1rem;
	letter-spacing: 0.01em;
	text-align: center;
	padding: 1rem;
}

.offers-fallback:not([hidden]) {
	display: grid;
}

.offers-list {
	position: relative;
	z-index: 1;
	background: none;
	padding: 0;
}

.offers-section {
	--section-accent: 160, 125, 90;
	position: relative;
	min-height: 100vh;
	display: grid;
	align-items: center;
	padding: clamp(4rem, 12vh, 8rem) var(--page-padding-x);
	overflow: hidden;
}

.offers-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		linear-gradient(120deg, rgba(255, 255, 255, 0.04), rgba(0, 0, 0, 0) 45%),
		radial-gradient(600px 500px at 20% 20%, rgba(var(--section-accent), 0.28), transparent 70%);
	opacity: 0.9;
	pointer-events: none;
}

.offers-section__inner {
	position: relative;
	z-index: 1;
	max-width: 1120px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: clamp(2rem, 6vw, 4rem);
	align-items: center;
}

.offers-section__inner--wide {
	max-width: 1200px;
}

.offers-section__content {
	display: grid;
	gap: 1.1rem;
}

.offers-section--reverse .offers-section__content {
	order: 2;
}

.offers-section--reverse .offers-panel {
	order: 1;
}

.offers-section--one {
	--section-accent: 178, 140, 96;
	background: var(--offers-section-one-bg);
}

.offers-section--two {
	--section-accent: 120, 110, 100;
	background: var(--offers-section-two-bg);
}

.offers-section--three {
	--section-accent: 178, 140, 96;
	background: var(--offers-section-one-bg);
}

.offers-section--compare {
	--section-accent: 150, 145, 140;
	--compare-accent: 210, 170, 120;
	background: var(--offers-section-compare-bg);
}

.offers-section--compare .offers-section__inner {
	grid-template-columns: 1fr;
	row-gap: clamp(2rem, 5vw, 3rem);
	align-items: start;
}

.offers-section--compare .offers-compare__intro {
	max-width: none;
	justify-self: center;
	text-align: center;
}

.offers-section--compare .offers-title {
	overflow-wrap: break-word;
}

.offers-section--retainer {
	--section-accent: 165, 135, 105;
	background: var(--offers-section-retainer-bg);
}

.offers-section--retainer .offers-section__inner {
	grid-template-columns: minmax(260px, 1fr) minmax(0, 1.4fr);
	align-items: start;
}

.offers-eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.32em;
	font-size: 0.72rem;
	color: rgba(var(--color-primary-rgb), 0.65);
}

.offers-title {
	margin: 0;
	font-size: clamp(2.1rem, 4.6vw, 3.8rem);
	line-height: 1.08;
	letter-spacing: -0.02em;
	font-family: "Clash Display", "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.offers-copy {
	margin: 0;
	max-width: 56ch;
	color: var(--color-muted);
	font-size: clamp(1rem, 1.2vw, 1.15rem);
	line-height: 1.6;
}

.offers-price {
	font-size: 1.05rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(var(--color-primary-rgb), 0.78);
}

.offers-features {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.6rem;
	color: rgba(var(--color-primary-rgb), 0.7);
	font-size: 0.98rem;
}

.offers-features li {
	position: relative;
	padding-left: 1.1rem;
}

.offers-features li::before {
	content: '+';
	position: absolute;
	left: 0;
	top: 0;
	color: rgba(var(--color-primary-rgb), 0.45);
}

.offers-section--one .offers-price {
	font-size: 1.4rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: none;
	color: rgba(var(--color-primary-rgb), 0.88);
}

.offers-section--one .offers-features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	color: rgba(var(--color-primary-rgb), 0.72);
	font-size: 0.85rem;
}

.offers-section--one .offers-features li {
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.2);
	background: rgba(var(--color-primary-rgb), 0.08);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	white-space: nowrap;
}

.offers-section--one .offers-features li::before {
	content: none;
}

.offers-section--two .offers-price {
	font-size: 1.4rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: none;
	color: rgba(var(--color-primary-rgb), 0.88);
}

.offers-section--two .offers-features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	color: rgba(var(--color-primary-rgb), 0.72);
	font-size: 0.85rem;
}

.offers-section--two .offers-features li {
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.2);
	background: rgba(var(--color-primary-rgb), 0.08);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	white-space: nowrap;
}

.offers-section--two .offers-features li::before {
	content: none;
}

.offers-section--three .offers-price {
	font-size: 1.4rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: none;
	color: rgba(var(--color-primary-rgb), 0.88);
}

.offers-section--three .offers-features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	color: rgba(var(--color-primary-rgb), 0.72);
	font-size: 0.85rem;
}

.offers-section--three .offers-features li {
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.2);
	background: rgba(var(--color-primary-rgb), 0.08);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	white-space: nowrap;
}

.offers-section--three .offers-features li::before {
	content: none;
}

.offers-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem 1.6rem;
	font-size: 0.9rem;
	color: rgba(var(--color-primary-rgb), 0.55);
}

.offers-panel {
	border-radius: 26px;
	padding: 2.2rem;
	border: 1px solid var(--offers-panel-border);
	background: var(--offers-panel-bg);
	box-shadow: var(--offers-panel-shadow);
	display: grid;
	gap: 1.1rem;
}

.offers-panel--cool {
	background: var(--offers-panel-bg-cool);
}

.offers-panel--gold {
	background: var(--offers-panel-bg-gold);
}

.offers-panel__kicker {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.26em;
	font-size: 0.72rem;
	color: rgba(var(--color-primary-rgb), 0.6);
}

.offers-panel__title {
	margin: 0;
	font-size: 1.5rem;
	letter-spacing: -0.01em;
}

.offers-panel__list {
	margin: 0;
	padding-left: 1.1rem;
	display: grid;
	gap: 0.6rem;
	color: rgba(var(--color-primary-rgb), 0.7);
	font-size: 0.95rem;
}

.offers-panel__note {
	margin: 0;
	color: rgba(var(--color-primary-rgb), 0.55);
	font-size: 0.92rem;
}

.offers-compare__intro {
	max-width: 62ch;
	display: grid;
	gap: 1rem;
}

.subscription-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.6rem;
	align-items: stretch;
}

.subscription-stack {
	display: grid;
	gap: 0.8rem;
}

.offers-section--retainer .subscription-grid {
	grid-template-columns: repeat(2, minmax(260px, 1fr));
	overflow-x: auto;
	padding-bottom: 0.4rem;
}

.subscription-card {
	border-radius: 26px;
	padding: 2.2rem;
	border: 1px solid var(--offers-card-border);
	background: var(--offers-card-bg);
	box-shadow: var(--offers-card-shadow);
	display: grid;
	gap: 0.9rem;
}

.subscription-card--focus {
	border-color: var(--offers-card-focus-border);
	background: var(--offers-card-focus-bg);
	box-shadow: var(--offers-card-focus-shadow);
}

.subscription-card__kicker {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.26em;
	font-size: 0.7rem;
	color: rgba(var(--color-primary-rgb), 0.6);
}

.subscription-card__title {
	margin: 0;
	font-size: 1.5rem;
	letter-spacing: -0.01em;
}

.subscription-card__price {
	margin: 0;
	font-size: 0.95rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(var(--color-primary-rgb), 0.72);
}

.offers-section--retainer .subscription-card__price {
	text-transform: none;
	letter-spacing: 0.08em;
}

.subscription-card__list {
	margin: 0;
	padding-left: 1.1rem;
	display: grid;
	gap: 0.55rem;
	color: rgba(var(--color-primary-rgb), 0.68);
	font-size: 0.95rem;
}

.subscription-card__note {
	margin: 0;
	color: rgba(var(--color-primary-rgb), 0.55);
	font-size: 0.88rem;
}

.subscription-note,
.subscription-boundaries {
	margin: 0;
	max-width: 72ch;
	font-size: 0.82rem;
	color: rgba(var(--color-primary-rgb), 0.55);
}

.subscription-note {
	margin-top: 1rem;
}

.subscription-boundaries {
	margin-top: 0.5rem;
	color: rgba(var(--color-primary-rgb), 0.48);
}

.comparison-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
}

.comparison-card-wrap {
	position: relative;
	display: grid;
	align-content: start;
}

.comparison-stack {
	display: grid;
	gap: 1rem;
}

.offers-section--compare .comparison-grid {
	grid-template-columns: repeat(3, minmax(260px, 1fr));
	overflow-x: visible;
	padding-bottom: 0;
	align-items: stretch;
}

.comparison-card {
	position: relative;
	border-radius: 24px;
	padding: 2rem;
	border: 1px solid var(--offers-card-border);
	background: var(--offers-card-bg);
	box-shadow: var(--offers-card-shadow);
	display: grid;
	gap: 1rem;
	height: 100%;
}

.comparison-card--focus {
	border-color: var(--offers-card-focus-border);
	box-shadow: var(--offers-card-focus-shadow);
	background: var(--offers-card-focus-bg);
}

.comparison-card__title {
	margin: 0;
	font-size: 1.3rem;
	letter-spacing: -0.01em;
}

.comparison-card__price {
	margin: 0;
	font-size: 0.92rem;
	letter-spacing: 0.08em;
	text-transform: none;
	color: rgba(var(--color-primary-rgb), 0.78);
}

.comparison-card__promise {
	margin: 0;
	font-size: 0.92rem;
	color: rgba(var(--color-primary-rgb), 0.62);
}

.comparison-rows {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.6rem;
	font-size: 0.92rem;
	color: rgba(var(--color-primary-rgb), 0.65);
}

.comparison-row {
	display: flex;
	justify-content: space-between;
	gap: 0.8rem;
}

.comparison-label {
	color: rgba(var(--color-primary-rgb), 0.6);
}

.comparison-value {
	color: rgba(var(--color-primary-rgb), 0.85);
	font-weight: 600;
}

.comparison-value--included {
	color: rgba(var(--compare-accent), 0.95);
}

.comparison-value--optional {
	color: rgba(var(--color-primary-rgb), 0.75);
	font-weight: 500;
}

.comparison-value--none {
	color: rgba(var(--color-primary-rgb), 0.45);
	font-weight: 500;
}

.comparison-chips {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: 0.78rem;
	color: rgba(var(--color-primary-rgb), 0.72);
}

.comparison-chips li {
	padding: 0.3rem 0.7rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--color-primary-rgb), 0.2);
	background: rgba(var(--color-primary-rgb), 0.08);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	white-space: nowrap;
}

.comparison-card__badge {
	position: absolute;
	top: -1.2rem;
	left: 0;
	z-index: 2;
	justify-self: start;
	align-self: start;
	padding: 0.3rem 0.6rem;
	border-radius: 999px;
	border: 1px solid rgba(var(--compare-accent), 0.5);
	background: rgba(var(--compare-accent), 0.16);
	color: rgba(var(--compare-accent), 0.95);
	text-transform: uppercase;
	letter-spacing: 0.24em;
	font-size: 0.6rem;
}

.comparison-note {
	margin: 0;
	font-size: 0.82rem;
	color: rgba(var(--color-primary-rgb), 0.55);
	max-width: 80ch;
}

.comparison-netnote {
	margin: 0;
	font-size: 0.78rem;
	color: rgba(var(--color-primary-rgb), 0.5);
	justify-self: end;
	text-align: right;
}

.offers-netnote {
	margin: 0;
	grid-column: 1 / -1;
	justify-self: end;
	text-align: right;
	font-size: 0.78rem;
	color: rgba(var(--color-primary-rgb), 0.5);
}

.subscription-netnote {
	margin: 0;
	justify-self: end;
	text-align: right;
	font-size: 0.78rem;
	color: rgba(var(--color-primary-rgb), 0.5);
}

@media (max-width: 700px) {
	.comparison-card-wrap--signature {
		order: 1;
	}

	.comparison-card--tour {
		order: 2;
	}

	.comparison-card--core {
		order: 3;
	}
}

@media (max-width: 900px) {
	.offers-section {
		padding: clamp(3rem, 10vh, 6rem) var(--page-padding-x);
	}

	.offers-section--reverse .offers-section__content,
	.offers-section--reverse .offers-panel {
		order: initial;
	}

	.offers-section--compare .offers-section__inner {
		grid-template-columns: 1fr;
	}

	.offers-section--compare .offers-compare__intro {
		max-width: 100%;
	}
}

.offers-list__inner {
	max-width: 1100px;
	margin: 0 auto;
	display: grid;
	gap: 3rem;
}

.offers-list__header {
	display: grid;
	gap: 0.85rem;
}

.offers-list__eyebrow {
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.28em;
	font-size: 0.72rem;
	color: rgba(238, 242, 246, 0.6);
}

.offers-list__title {
	margin: 0;
	font-size: clamp(2rem, 3.6vw, 3.4rem);
	line-height: 1.1;
	letter-spacing: -0.02em;
	font-family: "Clash Display", "Satoshi", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.offers-list__copy {
	margin: 0;
	max-width: 60ch;
	color: var(--color-muted);
	font-size: 1.05rem;
	line-height: 1.55;
}

.offers-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.6rem;
}

.offer-card {
	display: grid;
	gap: 1.2rem;
	padding: 1.8rem;
	border-radius: 24px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
		radial-gradient(circle at top, rgba(255, 255, 255, 0.12), rgba(5, 6, 8, 0) 70%);
	box-shadow: 0 30px 60px rgba(0, 0, 0, 0.35);
}

.offer-card--featured {
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 35px 80px rgba(0, 0, 0, 0.45);
	background:
		linear-gradient(135deg, rgba(150, 175, 210, 0.18), rgba(10, 12, 16, 0.2)),
		radial-gradient(circle at 30% 20%, rgba(200, 220, 255, 0.16), rgba(5, 6, 8, 0) 70%);
}

.offer-card__header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 1rem;
}

.offer-card__title {
	margin: 0;
	font-size: 1.3rem;
	letter-spacing: -0.01em;
}

.offer-card__price {
	font-size: 0.95rem;
	color: rgba(238, 242, 246, 0.75);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.offer-card__lede {
	margin: 0;
	color: rgba(238, 242, 246, 0.7);
	font-size: 1rem;
	line-height: 1.5;
}

.offer-card__list {
	margin: 0;
	padding-left: 1.1rem;
	display: grid;
	gap: 0.5rem;
	color: rgba(238, 242, 246, 0.68);
	font-size: 0.95rem;
}

.offers-list__note {
	margin: 0;
	color: rgba(238, 242, 246, 0.55);
	font-size: 0.95rem;
	letter-spacing: 0.01em;
}

.page-angebote .site-nav__btn {
	border-color: rgba(var(--color-primary-rgb), 0.22);
	background: rgba(255, 255, 255, 0.78);
	color: var(--color-text);
	backdrop-filter: blur(12px);
}

.page-angebote .site-nav__logo {
	filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.24));
}

.page-angebote .site-nav__divider {
	background: rgba(var(--color-primary-rgb), 0.28);
}

.page-angebote.theme-dark .site-nav__btn {
	border-color: rgba(255, 255, 255, 0.2);
	background: rgba(8, 10, 12, 0.6);
	color: var(--color-text);
}

.page-angebote.theme-dark .site-nav__logo {
	filter: brightness(0) invert(1) drop-shadow(0 14px 30px rgba(0, 0, 0, 0.38));
}

.page-angebote.theme-dark .site-nav__divider {
	background: rgba(255, 255, 255, 0.32);
}

.page-angebote .cursor-trail {
	opacity: 0.85;
}

.page-angebote.theme-dark .cursor-trail {
	mix-blend-mode: screen;
}
