.ee-snap-page {
	height: 100vh;
	overflow-x: hidden;
	overflow-y: auto;
	scroll-behavior: smooth;
	scroll-snap-type: none;
}

body.ee-has-snap-page {
	scroll-behavior: smooth;
	scroll-snap-type: none;
}

html.ee-has-snap-page {
	scroll-behavior: smooth;
	scroll-snap-type: none;
}

html.ee-has-horizontal-snap,
body.ee-has-horizontal-snap {
	height: 100%;
	overflow: hidden;
}

.ee-snap-panel {
	min-height: 100vh;
	position: relative;
	overflow: hidden;
	scroll-snap-align: start;
	scroll-snap-stop: normal;
}

.ee-snap-panel > .e-con-inner {
	min-height: 100vh;
}

.ee-snap-page.ee-horizontal {
	max-width: none !important;
	width: 100%;
	height: 100vh;
	overflow-x: hidden !important;
	overflow-y: hidden !important;
}

.ee-snap-page.ee-horizontal .ee-horizontal-track {
	display: flex;
	flex: 0 0 auto;
	flex-wrap: nowrap;
	align-items: stretch;
	max-width: none !important;
	width: max-content !important;
	height: 100%;
	transform: translate3d(calc(var(--ee-active-panel, 0) * -100vw), 0, 0);
	transition: transform 700ms cubic-bezier(0.76, 0, 0.24, 1);
}

.ee-snap-page.ee-horizontal > .ee-snap-panel,
.ee-snap-page.ee-horizontal .ee-horizontal-track > .ee-snap-panel {
	flex: 0 0 100vw;
	min-width: 100vw;
	width: 100vw;
}

.ee-snap-page.ee-horizontal > .ee-snap-panel > .e-con-inner,
.ee-snap-page.ee-horizontal > .e-con-inner > .ee-snap-panel > .e-con-inner {
	width: 100%;
}

.ee-snap-panel.is-active {
	z-index: 1;
}

.ee-preset {
	background: #f7f7f5;
	color: #111;
}

.ee-preset .ee-kicker {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.ee-preset .ee-title {
	max-width: 720px;
	font-size: clamp(34px, 5vw, 78px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 0.96;
}

.ee-preset .ee-copy {
	max-width: 480px;
	font-size: clamp(14px, 1.2vw, 18px);
	line-height: 1.55;
}

.ee-preset .ee-small {
	font-size: 12px;
	line-height: 1.45;
}

.ee-preset .ee-image-frame {
	min-height: 220px;
	background-color: #ddd;
	background-image: linear-gradient(135deg, #eee, #aaa);
	background-position: center;
	background-size: cover;
}

.ee-preset .ee-number {
	position: absolute;
	right: 28px;
	top: 22px;
	padding: 4px 8px;
	background: #222;
	color: #fff;
	font-size: 10px;
	line-height: 1;
}

.ee-preset-cover .ee-image-frame {
	position: absolute;
	left: 50%;
	top: 42%;
	width: min(220px, 34vw);
	min-height: min(300px, 42vw);
	transform: translate(-50%, -50%);
}

.ee-preset-cover .ee-brand {
	position: absolute;
	left: 7vw;
	bottom: 8vh;
	font-size: clamp(28px, 5vw, 74px);
	font-weight: 600;
	letter-spacing: 0.16em;
}

.ee-preset-cover .ee-kicker {
	position: absolute;
	left: 7vw;
	top: 8vh;
}

.ee-preset-text .ee-title {
	position: absolute;
	left: 9vw;
	top: 14vh;
}

.ee-preset-text .ee-copy {
	position: absolute;
	left: 9vw;
	bottom: 16vh;
	columns: 2;
	column-gap: 56px;
	max-width: 850px;
}

.ee-preset-gallery .ee-image-frame {
	position: absolute;
	left: 0;
	top: 12vh;
	width: 42vw;
	min-height: 70vh;
}

.ee-preset-gallery .ee-title {
	position: absolute;
	left: 52vw;
	top: 26vh;
}

.ee-preset-gallery .ee-copy {
	position: absolute;
	left: 52vw;
	top: 43vh;
}

.ee-preset-triptych .ee-title {
	position: absolute;
	left: 8vw;
	top: 13vh;
	width: 36vw;
}

.ee-preset-triptych .ee-copy {
	position: absolute;
	left: 8vw;
	top: 45vh;
}

.ee-preset-triptych .ee-frame-1,
.ee-preset-triptych .ee-frame-2,
.ee-preset-triptych .ee-frame-3 {
	position: absolute;
	top: 30vh;
	width: 18vw;
	min-height: 36vh;
}

.ee-preset-triptych .ee-frame-1 {
	left: 55vw;
}

.ee-preset-triptych .ee-frame-2 {
	left: 75vw;
}

.ee-preset-triptych .ee-frame-3 {
	left: 65vw;
	top: 68vh;
	min-height: 20vh;
}

.ee-preset-toc .ee-title {
	position: absolute;
	left: 8vw;
	top: 12vh;
	font-size: clamp(30px, 4vw, 54px);
}

.ee-preset-toc .ee-list {
	position: absolute;
	left: 8vw;
	top: 30vh;
	width: min(680px, 70vw);
}

.ee-preset-toc .ee-list-row {
	display: grid;
	grid-template-columns: 44px 1fr auto;
	gap: 28px;
	align-items: center;
	padding: 18px 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.18);
}

.ee-preset-big-image .ee-image-frame {
	position: absolute;
	left: 8vw;
	top: 12vh;
	width: 84vw;
	min-height: 76vh;
}

.ee-preset-note .ee-title {
	position: absolute;
	right: 10vw;
	top: 16vh;
	width: 34vw;
	text-align: right;
}

.ee-preset-note .ee-image-frame {
	position: absolute;
	right: 10vw;
	bottom: 0;
	width: 38vw;
	min-height: 42vh;
}

.ee-preset-collage .ee-frame-1 {
	position: absolute;
	left: 8vw;
	top: 16vh;
	width: 28vw;
	min-height: 60vh;
}

.ee-preset-collage .ee-frame-2 {
	position: absolute;
	left: 40vw;
	top: 16vh;
	width: 42vw;
	min-height: 28vh;
}

.ee-preset-collage .ee-frame-3 {
	position: absolute;
	left: 47vw;
	top: 50vh;
	width: 30vw;
	min-height: 32vh;
}

.ee-preset-collage .ee-title {
	position: absolute;
	left: 82vw;
	top: 22vh;
	width: 120px;
	writing-mode: vertical-rl;
	font-size: clamp(24px, 3vw, 42px);
}

.ee-panel-nav {
	position: fixed;
	right: 24px;
	top: 50%;
	z-index: 999;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transform: translateY(-50%);
}

.ee-panel-nav button {
	width: 14px;
	height: 14px;
	padding: 0;
	border: 1px solid #111;
	border-radius: 999px;
	background: #fff;
	color: #111;
	cursor: pointer;
	opacity: 1;
	transition: none;
}

.ee-panel-nav button:hover,
.ee-panel-nav button:focus,
.ee-panel-nav button:active,
.ee-panel-nav button.is-active {
	border-color: #111;
	background: #111;
	color: #111;
	opacity: 1;
}

@media (max-width: 767px) {
	html.ee-has-snap-page,
	body.ee-has-snap-page {
		scroll-snap-type: none;
	}

	.ee-snap-page {
		height: auto;
		overflow: visible;
		scroll-snap-type: none;
	}

	.ee-snap-page.ee-horizontal {
		display: block;
		overflow: visible;
	}

	.ee-snap-page.ee-horizontal .ee-horizontal-track {
		display: block;
		width: auto;
		height: auto;
		transform: none;
		transition: none;
	}

	.ee-snap-page.ee-horizontal > .ee-snap-panel,
	.ee-snap-page.ee-horizontal > .e-con-inner > .ee-snap-panel {
		width: auto;
	}

	.ee-snap-panel,
	.ee-snap-panel > .e-con-inner {
		min-height: auto;
		scroll-snap-align: none;
	}

	.ee-panel-nav {
		display: none;
	}

	.ee-preset .ee-kicker,
	.ee-preset .ee-title,
	.ee-preset .ee-copy,
	.ee-preset .ee-brand,
	.ee-preset .ee-image-frame,
	.ee-preset .ee-list,
	.ee-preset-triptych .ee-frame-1,
	.ee-preset-triptych .ee-frame-2,
	.ee-preset-triptych .ee-frame-3,
	.ee-preset-collage .ee-frame-1,
	.ee-preset-collage .ee-frame-2,
	.ee-preset-collage .ee-frame-3 {
		position: relative;
		left: auto;
		right: auto;
		top: auto;
		bottom: auto;
		width: auto;
		max-width: none;
		margin: 24px;
		transform: none;
		text-align: left;
		writing-mode: initial;
	}

	.ee-preset .ee-copy {
		columns: initial;
	}
}

@media (prefers-reduced-motion: reduce) {
	.ee-snap-page {
		scroll-behavior: auto;
	}
}
