.sepia-mvp-hero-particles {
	--smh-bg: #050403;
	--smh-panel: rgba(18, 15, 12, 0.72);
	--smh-text: #f8f0e3;
	--smh-muted: #b8aa97;
	--smh-accent: #d6a85a;
	--smh-accent-2: #f2d49b;
	--smh-border: rgba(214, 168, 90, 0.2);
	--smh-glow: rgba(214, 168, 90, 0.24);
	position: relative;
	overflow: clip;
	width: 100%;
	min-height: 76vh;
	color: var(--smh-text);
	background:
		radial-gradient(circle at 68% 34%, rgba(214, 168, 90, 0.25), transparent 38%),
		radial-gradient(circle at 22% 76%, rgba(242, 212, 155, 0.15), transparent 34%),
		radial-gradient(circle at 50% 120%, rgba(214, 168, 90, 0.1), transparent 50%),
		linear-gradient(180deg, #0b0805 0%, var(--smh-bg) 50%, #050302 100%);
	border: 0;
	border-radius: 0;
	isolation: isolate;
}

.sepia-mvp-landing-stage {
	position: relative;
	margin: 0;
	padding: 0;
	background: #080604;
	color: #f8f0e3;
}

.sepia-mvp-scroll-wrap {
	width: min(1280px, calc(100% - 32px));
	margin: 0 auto;
	padding: 0 0 56px;
}

.sepia-mvp-hero-particles *,
.sepia-mvp-hero-particles *::before,
.sepia-mvp-hero-particles *::after {
	box-sizing: border-box;
}

.sepia-mvp-hero-particles::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.026) 1px, transparent 1px);
	background-size: 72px 72px;
	opacity: 0.28;
	z-index: -1;
}

.sepia-mvp-hero-particles::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -1px;
	left: 0;
	height: 190px;
	pointer-events: none;
	background: linear-gradient(180deg, transparent, #080604 76%, #080604);
	z-index: -1;
}

.sepia-mvp-hero-particles .smh-particles {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}

.sepia-mvp-hero-particles .smh-particle {
	position: absolute;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: rgba(242, 212, 155, 0.72);
	box-shadow: 0 0 22px rgba(214, 168, 90, 0.34);
	opacity: 0.36;
	will-change: transform;
	animation: smh-particle-drift 7.5s ease-in-out infinite;
	animation-delay: var(--smh-particle-delay, 0ms);
}

.sepia-mvp-hero-particles .smh-particle:nth-child(3n) {
	width: 3px;
	height: 3px;
	opacity: 0.46;
}

.sepia-mvp-hero-particles .smh-particle:nth-child(4n) {
	width: 9px;
	height: 9px;
	background: rgba(214, 168, 90, 0.32);
}

.sepia-mvp-hero-particles .smh-particle-1 {
	left: 9%;
	top: 18%;
}

.sepia-mvp-hero-particles .smh-particle-2 {
	left: 18%;
	top: 72%;
}

.sepia-mvp-hero-particles .smh-particle-3 {
	left: 28%;
	top: 28%;
}

.sepia-mvp-hero-particles .smh-particle-4 {
	left: 38%;
	top: 82%;
}

.sepia-mvp-hero-particles .smh-particle-5 {
	left: 48%;
	top: 16%;
}

.sepia-mvp-hero-particles .smh-particle-6 {
	left: 58%;
	top: 64%;
}

.sepia-mvp-hero-particles .smh-particle-7 {
	left: 66%;
	top: 24%;
}

.sepia-mvp-hero-particles .smh-particle-8 {
	left: 76%;
	top: 78%;
}

.sepia-mvp-hero-particles .smh-particle-9 {
	left: 86%;
	top: 18%;
}

.sepia-mvp-hero-particles .smh-particle-10 {
	left: 92%;
	top: 58%;
}

.sepia-mvp-hero-particles .smh-particle-11 {
	left: 14%;
	top: 46%;
}

.sepia-mvp-hero-particles .smh-particle-12 {
	left: 32%;
	top: 58%;
}

.sepia-mvp-hero-particles .smh-particle-13 {
	left: 44%;
	top: 42%;
}

.sepia-mvp-hero-particles .smh-particle-14 {
	left: 54%;
	top: 84%;
}

.sepia-mvp-hero-particles .smh-particle-15 {
	left: 70%;
	top: 46%;
}

.sepia-mvp-hero-particles .smh-particle-16 {
	left: 82%;
	top: 36%;
}

.sepia-mvp-hero-particles .smh-particle-17 {
	left: 24%;
	top: 88%;
}

.sepia-mvp-hero-particles .smh-particle-18 {
	left: 62%;
	top: 10%;
}

/* ─── Layout apilado hero ──────────────────────────────────────────── */

.sepia-mvp-hero-particles .smh-topbar {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1100px;
	margin: 0 auto;
	padding: clamp(20px, 3vw, 36px) clamp(18px, 4vw, 44px) 0;
}

.sepia-mvp-hero-particles .smh-eyebrow {
	color: var(--smh-accent-2);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 0;
}

.sepia-mvp-hero-particles .smh-topbar-brand {
	color: var(--smh-text);
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.sepia-mvp-hero-particles .smh-topbar-meta {
	color: var(--smh-muted);
	font-size: 0.72rem;
	letter-spacing: 0.06em;
}

.sepia-mvp-hero-particles .smh-hero-body {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	padding: clamp(24px, 4vw, 52px) clamp(18px, 4vw, 44px) 0;
}

.sepia-mvp-hero-particles .smh-headline {
	margin: 0;
	color: var(--smh-text);
	font-size: clamp(2.6rem, 6.5vw, 6rem);
	line-height: 0.93;
	letter-spacing: -0.02em;
	font-weight: 840;
}

.sepia-mvp-hero-particles .smh-hero-subnav {
	position: relative;
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	max-width: 1100px;
	margin: 0 auto;
	padding: clamp(16px, 2.5vw, 28px) clamp(18px, 4vw, 44px) 0;
	border-top: 1px solid rgba(214, 168, 90, 0.13);
	margin-top: clamp(20px, 3vw, 36px);
	margin-bottom: 40px;
}

.sepia-mvp-hero-particles .smh-hero-subnav span {
	flex: 1 1 auto;
	color: var(--smh-muted);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0 16px 0 0;
}

.sepia-mvp-hero-particles .smh-hero-footer {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 clamp(18px, 4vw, 44px) clamp(40px, 6vw, 72px);
}

.sepia-mvp-hero-particles .smh-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 0;
}

.sepia-mvp-hero-particles .smh-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 13px 22px;
	border: 1px solid var(--smh-border);
	border-radius: 999px;
	font-weight: 800;
	line-height: 1.1;
	text-decoration: none;
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.sepia-mvp-hero-particles .smh-button:hover,
.sepia-mvp-hero-particles .smh-button:focus-visible {
	transform: translateY(-1px);
}

.sepia-mvp-hero-particles .smh-button-primary {
	color: #170f07;
	background: linear-gradient(90deg, var(--smh-accent), var(--smh-accent-2));
	box-shadow: 0 0 36px var(--smh-glow);
}

.sepia-mvp-hero-particles .smh-button-secondary {
	color: var(--smh-text);
	background: rgba(255, 255, 255, 0.045);
}

.sepia-mvp-hero-particles .smh-microcopy {
	max-width: 560px;
	margin: 16px 0 0;
	color: var(--smh-muted);
	font-size: 0.9rem;
}


.sepia-mvp-hero-particles .smh-hero-visual-spacer {
	height: 480px;
}

/* ─── Hero character container (liquid mask) ──────────────────────── */

.sepia-mvp-hero-particles .smh-hero-char {
	position: relative;
	z-index: 1;
	width: clamp(260px, 30vw, 460px);
	aspect-ratio: 1;
	overflow: hidden;
	margin: clamp(16px, 3vw, 40px) auto clamp(24px, 4vw, 52px);
	background:
		radial-gradient(circle at 50% 42%, rgba(214, 168, 90, 0.22), transparent 38%),
		linear-gradient(145deg, #130f0b, #050403);
	border: 1px solid rgba(214, 168, 90, 0.2);
	border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	will-change: transform, border-radius, opacity;
	animation: sms-visual-liquid 10s ease-in-out infinite;
	transition: transform 60ms linear, opacity 60ms linear;
}

/* el sms-fallback dentro del hero hereda su layout centrado */
.sepia-mvp-hero-particles .smh-hero-char .sms-fallback {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 1;
}

@keyframes smh-particle-drift {

	0%,
	100% {
		translate: 0 0;
	}

	50% {
		translate: 0 -14px;
	}
}

@keyframes smh-bubble-breathe {

	0%,
	100% {
		translate: 0 0;
	}

	50% {
		translate: 0 -5px;
	}
}

@keyframes smh-liquid-blob {
	0% {
		border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	}

	25% {
		border-radius: 40% 60% 70% 30% / 50% 60% 30% 60%;
	}

	50% {
		border-radius: 70% 30% 50% 50% / 30% 30% 70% 70%;
	}

	75% {
		border-radius: 30% 70% 40% 60% / 60% 40% 60% 40%;
	}

	100% {
		border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	}
}

.sepia-mvp-hero-particles.smh-auto-motion .smh-bubble {
	animation: smh-bubble-breathe 6.5s ease-in-out infinite;
	animation-delay: var(--smh-float-delay, 0ms);
}

@media (max-width: 900px) {
	.sepia-mvp-hero-particles {
		min-height: auto;
	}

	.sepia-mvp-hero-particles .smh-topbar {
		padding-top: 18px;
	}

	.sepia-mvp-hero-particles .smh-topbar-brand {
		display: none;
	}

	.sepia-mvp-hero-particles .smh-headline {
		font-size: clamp(2.2rem, 10vw, 4.8rem);
		line-height: 0.95;
	}

	.sepia-mvp-hero-particles .smh-hero-subnav {
		gap: 8px;
	}

	.sepia-mvp-hero-particles .smh-hero-subnav span {
		flex: 1 1 40%;
		font-size: 0.68rem;
	}

	.sepia-mvp-hero-particles .smh-hero-char {
		width: clamp(180px, 52vw, 300px);
		margin: 16px auto 20px;
		animation: none;
		border-radius: 50% !important;
		transform: none !important;
		opacity: 1 !important;
	}
}

@media (prefers-reduced-motion: reduce) {

	.sepia-mvp-hero-particles .smh-particle,
	.sepia-mvp-hero-particles .smh-hv-glow,
	.sepia-mvp-hero-particles .smh-hv-ring,
	.sepia-mvp-hero-particles .smh-hv-orb,
	.sepia-mvp-hero-particles .smh-hv-core {
		animation: none;
	}

	.sepia-mvp-hero-particles .smh-button {
		transition: none;
	}
}

@media (max-width: 480px) {
	.sepia-mvp-hero-particles .smh-actions {
		display: grid;
	}

	.sepia-mvp-hero-particles .smh-button {
		width: 100%;
	}

	.sepia-mvp-hero-particles .smh-hero-visual-spacer {
		height: 180px;
	}
}

.sepia-mvp-scroll-story {
	--sms-bg: #050403;
	--sms-panel: rgba(18, 15, 12, 0.82);
	--sms-text: #f8f0e3;
	--sms-muted: #b8aa97;
	--sms-accent: #d6a85a;
	--sms-accent-2: #f2d49b;
	--sms-border: rgba(214, 168, 90, 0.24);
	--sms-glow: rgba(214, 168, 90, 0.28);
	--sms-radius: 22px;
	--sms-max: 1180px;
	position: relative;
	overflow: clip;
	color: var(--sms-text);
	background:
		radial-gradient(circle at 78% 18%, rgba(214, 168, 90, 0.14), transparent 34%),
		linear-gradient(180deg, #080604 0%, var(--sms-bg) 46%, #0d0906 100%);
	border: 1px solid rgba(214, 168, 90, 0.1);
	border-radius: 28px;
	font-family: inherit;
	isolation: isolate;
}

.sepia-mvp-scroll-story *,
.sepia-mvp-scroll-story *::before,
.sepia-mvp-scroll-story *::after {}

.sepia-mvp-scroll-story::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.026) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
	opacity: 0.34;
	z-index: -1;
}

.sms-global-track-wrapper::before,
.sms-global-track-wrapper::after {
	display: none !important;
}


.sepia-mvp-scroll-story .sms-shell {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.9fr);
	gap: clamp(28px, 5vw, 72px);
	max-width: var(--sms-max);
	margin: 0 auto;
	padding: clamp(34px, 5vw, 72px) clamp(18px, 4vw, 44px);
}

.sepia-mvp-scroll-story .sms-story {
	display: flex;
	flex-direction: column;
	gap: clamp(42px, 12vh, 128px);
	padding: clamp(10px, 3vh, 34px) 0 clamp(46px, 12vh, 120px);
}

.sepia-mvp-scroll-story .sms-scene {
	min-height: clamp(440px, 78vh, 780px);
	display: flex;
	flex-direction: column;
	justify-content: center;
	opacity: 0.42;
	transform: translateY(14px);
	transition: opacity 240ms ease, transform 240ms ease;
	scroll-margin-top: 120px;
}

.sepia-mvp-scroll-story .sms-scene.is-active {
	opacity: 1;
	transform: translateY(0);
}

.sepia-mvp-scroll-story .sms-eyebrow {
	margin: 0 0 14px;
	color: var(--sms-accent-2);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.sepia-mvp-scroll-story .sms-title {
	max-width: 720px;
	margin: 0;
	color: var(--sms-text);
	font-size: clamp(2rem, 4vw, 4.55rem);
	line-height: 0.98;
	letter-spacing: 0;
	font-weight: 760;
}

.sepia-mvp-scroll-story .sms-text {
	max-width: 650px;
	margin: 24px 0 0;
	color: var(--sms-muted);
	font-size: clamp(1.02rem, 1.55vw, 1.2rem);
	line-height: 1.72;
}

.sepia-mvp-scroll-story .sms-bullets {
	display: grid;
	gap: 10px;
	max-width: 620px;
	margin: 28px 0 0;
	padding: 0;
	list-style: none;
}

.sepia-mvp-scroll-story .sms-bullets li {
	position: relative;
	min-height: 42px;
	padding: 11px 14px 11px 42px;
	color: #eadfcc;
	background: rgba(255, 255, 255, 0.045);
	border: 1px solid rgba(214, 168, 90, 0.14);
	border-radius: 12px;
	line-height: 1.35;
}

.sepia-mvp-scroll-story .sms-bullets li::before {
	content: "";
	position: absolute;
	left: 16px;
	top: 50%;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--sms-accent);
	box-shadow: 0 0 18px var(--sms-glow);
	transform: translateY(-50%);
}

.sepia-mvp-scroll-story .sms-visual-track {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 10;
}

.sepia-mvp-scroll-story .sms-visual-sticky {
	position: sticky;
	top: clamp(20px, 7vh, 86px);
	display: flex;
	justify-content: center;
	align-items: flex-start;
	width: 100%;
	margin-top: var(--track-start, 580px);
	/* Dynamically calculated to sit below buttons */
}

.sepia-mvp-scroll-story .sms-visual-inner {
	position: relative;
	pointer-events: auto;
	width: clamp(280px, 35vw, 440px);
	transform: translateX(calc(var(--sms-visual-tx, 0) * 20vw));
	display: grid;
	gap: 16px;
	align-content: start;
	padding: 18px;
	background: linear-gradient(180deg, rgba(28, 22, 16, 0.88), rgba(9, 7, 5, 0.88));
	border: 1px solid var(--sms-border);
	border-radius: var(--sms-radius);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.38), 0 0 70px rgba(214, 168, 90, 0.08);
	backdrop-filter: blur(18px);
	will-change: transform;
	/* Smooth follow if JS updates progress */
	transition: transform 60ms linear;
	margin-top: -60px;
}

.sepia-mvp-scroll-story .sms-frame-wrap {
	position: relative;
	aspect-ratio: 1;
	min-height: 280px;
	overflow: hidden;
	background:
		radial-gradient(circle at 50% 42%, rgba(214, 168, 90, 0.22), transparent 38%),
		linear-gradient(145deg, #130f0b, #050403);
	border: 1px solid rgba(214, 168, 90, 0.2);
	border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	will-change: border-radius;
	animation: sms-visual-liquid 10s ease-in-out infinite;

}

.sepia-mvp-scroll-story .sms-canvas,
.sepia-mvp-scroll-story .sms-fallback {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.sepia-mvp-scroll-story .sms-canvas {
	z-index: 2;
	display: block;
	opacity: 1;
	/* Fixed: always visible since it loads asynchronously anyway */
	transition: opacity 180ms ease;
}

/* removed the .has-frame requirement entirely for canvas */

.sepia-mvp-scroll-story .sms-fallback {
	z-index: 1;
	display: grid;
	place-items: center;
	overflow: hidden;
}

.sepia-mvp-scroll-story.has-frame .sms-fallback {
	opacity: 0.16;
}

.sepia-mvp-scroll-story .sms-fallback-grid {
	position: absolute;
	inset: 12%;
	border: 1px solid rgba(214, 168, 90, 0.13);
	border-radius: 50%;
	background:
		linear-gradient(rgba(214, 168, 90, 0.08) 1px, transparent 1px),
		linear-gradient(90deg, rgba(214, 168, 90, 0.08) 1px, transparent 1px);
	background-size: 28px 28px;
	mask-image: radial-gradient(circle, #000 0 58%, transparent 72%);
	opacity: 0.72;
}

.sepia-mvp-scroll-story .sms-orbit {
	position: absolute;
	border: 1px solid rgba(214, 168, 90, 0.22);
	border-radius: 50%;
	box-shadow: inset 0 0 28px rgba(214, 168, 90, 0.08);
}

.sepia-mvp-scroll-story .sms-orbit-one {
	width: 70%;
	height: 70%;
}

.sepia-mvp-scroll-story .sms-orbit-two {
	width: 48%;
	height: 48%;
	transform: rotate(28deg);
}

.sepia-mvp-scroll-story .sms-avatar-core {
	position: relative;
	z-index: 2;
	display: grid;
	place-items: center;
	width: 34%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 30%, #f6dca8, #b98234 58%, #4e2d12);
	box-shadow: 0 0 48px rgba(214, 168, 90, 0.28);
}

.sepia-mvp-scroll-story .sms-avatar-ring {
	position: absolute;
	inset: -15%;
	border: 1px solid rgba(242, 212, 155, 0.38);
	border-radius: 50%;
}

.sepia-mvp-scroll-story .sms-avatar-mark {
	color: #160f08;
	font-size: clamp(2.2rem, 6vw, 4.4rem);
	font-weight: 850;
	line-height: 1;
}

.sepia-mvp-scroll-story .sms-hud {
	display: grid;
	gap: 14px;
	padding: 16px;
	background: rgba(255, 255, 255, 0.045);
	border: 1px solid rgba(214, 168, 90, 0.18);
	border-radius: 16px;
}

.sepia-mvp-scroll-story .sms-hud-top,
.sepia-mvp-scroll-story .sms-progress-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.sepia-mvp-scroll-story .sms-level {
	color: var(--sms-accent-2);
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
}

.sepia-mvp-scroll-story .sms-phase {
	color: var(--sms-muted);
	font-size: 0.88rem;
	text-align: right;
}

.sepia-mvp-scroll-story .sms-progress-track {
	flex: 1 1 auto;
	height: 8px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.09);
	border-radius: 999px;
}

.sepia-mvp-scroll-story .sms-progress-fill {
	display: block;
	width: 0;
	height: 100%;
	background: linear-gradient(90deg, var(--sms-accent), var(--sms-accent-2));
	border-radius: inherit;
	box-shadow: 0 0 20px var(--sms-glow);
	transition: width 180ms ease;
}

.sepia-mvp-scroll-story .sms-progress-value {
	min-width: 42px;
	color: var(--sms-accent-2);
	font-size: 0.8rem;
	font-weight: 760;
	text-align: right;
}

.sepia-mvp-scroll-story .sms-dots {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(14px, 1fr));
	gap: 8px;
}

.sepia-mvp-scroll-story .sms-dot {
	height: 4px;
	background: rgba(255, 255, 255, 0.13);
	border-radius: 999px;
	transition: background 180ms ease, box-shadow 180ms ease;
}

.sepia-mvp-scroll-story .sms-dot.is-active {
	background: var(--sms-accent);
	box-shadow: 0 0 14px var(--sms-glow);
}

@media (max-width: 900px) {
	.sepia-mvp-scroll-story {
		border-radius: 20px;
	}

	.sepia-mvp-scroll-story .sms-shell {
		display: block;
		padding: 18px 14px 44px;
	}

	.sepia-mvp-scroll-story .sms-visual-track {
		/* Keep it absolute like desktop so it spans the whole page */
		padding-top: 0;
	}

	.sepia-mvp-scroll-story .sms-visual-sticky {
		top: 10px;
		z-index: 100;
		/* Use the same calculated margin-top as desktop so it starts below buttons */
		margin-top: var(--track-start, 400px);
	}

	.sepia-mvp-scroll-story .sms-visual-inner {
		position: relative;
		top: auto;
		grid-template-columns: 96px minmax(0, 1fr);
		gap: 12px;
		align-items: center;
		padding: 10px;
		border-radius: 18px;
		box-shadow: 0 14px 36px rgba(0, 0, 0, 0.36);
		transform: none !important;
		width: auto;

	}

	.sepia-mvp-scroll-story .sms-frame-wrap {
		min-height: 0;
		width: 96px;
		height: 96px;
		border-radius: 18px;
		animation: none;
	}

	.sepia-mvp-scroll-story .sms-hud {
		gap: 10px;
		min-width: 0;
		padding: 10px;
		border-radius: 14px;
	}

	.sepia-mvp-scroll-story .sms-hud-top {
		align-items: flex-start;
	}

	.sepia-mvp-scroll-story .sms-level,
	.sepia-mvp-scroll-story .sms-phase {
		font-size: 0.72rem;
	}

	.sepia-mvp-scroll-story .sms-phase {
		max-width: 54%;
	}

	.sepia-mvp-scroll-story .sms-progress-track {
		height: 6px;
	}

	.sepia-mvp-scroll-story .sms-progress-value {
		min-width: 34px;
		font-size: 0.72rem;
	}

	.sepia-mvp-scroll-story .sms-dots {
		gap: 5px;
	}

	.sepia-mvp-scroll-story .sms-story {
		gap: 28px;
		padding: 0 0 18px;
	}

	.sepia-mvp-scroll-story .sms-scene {
		min-height: auto;
		padding: clamp(46px, 11vh, 86px) 4px;
		opacity: 0.72;
	}

	.sepia-mvp-scroll-story .sms-title {
		font-size: clamp(1.9rem, 10vw, 3.15rem);
		line-height: 1.02;
	}

	.sepia-mvp-scroll-story .sms-text {
		margin-top: 18px;
		font-size: 1rem;
		line-height: 1.68;
	}

	.sepia-mvp-scroll-story .sms-bullets {
		margin-top: 22px;
	}
}

@media (max-width: 480px) {
	.sepia-mvp-scroll-story .sms-visual-inner {
		grid-template-columns: 78px minmax(0, 1fr);
		margin-top: 0px;
	}

	.sepia-mvp-scroll-story .sms-frame-wrap {
		width: 78px;
		height: 78px;
	}

	.sepia-mvp-scroll-story .sms-hud {
		padding: 9px;
	}

	.sepia-mvp-scroll-story .sms-dots {
		display: none;
	}

	.sepia-mvp-scroll-story .sms-bullets li {
		padding-right: 12px;
	}
}

@keyframes sms-visual-liquid {
	0% {
		border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	}

	25% {
		border-radius: 40% 60% 70% 30% / 40% 70% 30% 60%;
	}

	50% {
		border-radius: 70% 30% 50% 50% / 30% 60% 70% 40%;
	}

	75% {
		border-radius: 30% 70% 40% 60% / 50% 40% 60% 50%;
	}

	100% {
		border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
	}
}

@media (prefers-reduced-motion: reduce) {

	.sepia-mvp-scroll-story .sms-scene,
	.sepia-mvp-scroll-story .sms-canvas,
	.sepia-mvp-scroll-story .sms-progress-fill,
	.sepia-mvp-scroll-story .sms-dot,
	.sepia-mvp-scroll-story .sms-visual-inner,
	.sepia-mvp-scroll-story .sms-frame-wrap {
		transition: none;
		animation: none;
		border-radius: var(--sms-radius);
	}
}
