/* ———————————————————————————————— */
/* Reset */
/* ———————————————————————————————— */
html, body {
	overflow-x: hidden;
	width: 100%;
}

img, svg {
	display: block;
	max-width: 100%;
	height: auto;
}

ul {
	list-style: none;
}

/* ———————————————————————————————— */
/* Fonts */
/* ———————————————————————————————— */

@font-face {
	font-family: "Megazoid Right";
	src:	url('../fonts/MegazoidLayersRight-Regular.woff2') format('woff2');
	font-display: block;
}

@font-face {
	font-family: "Megazoid Right Shade";
	src:	url('../fonts/MegazoidLayersRight-Shade.woff2') format('woff2');
	font-display: block;
}

@font-face {
	font-family: "Megazoid Regular";
	src:	url('../fonts/Megazoid-Regular.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Right Italic";
	src:	url('../fonts/MegazoidLayersRight-Italic.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Left";
	src:	url('../fonts/MegazoidLayersLeft-Regular.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Left Italic";
	src:	url('../fonts/MegazoidLayersLeft-Italic.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Fill";
	src:	url('../fonts/Megazoid-Fill.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Right Shade Italic";
	src:	url('../fonts/MegazoidLayersRight-ShadeItalic.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Left Shade";
	src:	url('../fonts/MegazoidLayersLeft-Shade.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Megazoid Left Shade Italic";
	src:	url('../fonts/MegazoidLayersLeft-ShadeItalic.woff2') format('woff2');
	font-display: swap;
}

@font-face {
	font-family: "Input Mono";
	src:	url('../fonts/Input.woff2') format('woff2');
	font-weight: 100 900;
	font-style: normal;
	font-display: swap;
	font-variation-settings: "MONO" 1;
}

@font-face {
	font-family: "Input Mono";
	src:	url('../fonts/Input.woff2') format('woff2');
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
	font-variation-settings: "MONO" 1;
}





/* ———————————————————————————————— */
/* Variables */
/* ———————————————————————————————— */
:root {
	--purple: 	#5F3694;
	--pink: 	#E4469B;
	--orange: 	#FF7F2E;
	--yellow:	#FFCB27;
	--green: 	#A7B716;
	--blue: 	#0297C2;
	--lt-blue:	#58CCED;
	--navy: 	#222351;
	--indigo: 	#2A104B;
	--cream: 	#F5F5EF;
	--red: 		#FF3D25;
	--teal: 	#107C72;
	--aqua: 	#61C9BB;
	--tan: 		#fbeed5;
	--text-ccc: #ccc;
	--text-666: #666;
	--text-333: #333;
	--text-222: #222;
	--text-000: #000;
	--text-fff:	#fff;

	/* Font stacks */
	--font-mega-regular: "Megazoid Regular";
	--font-mega-right: "Megazoid Right";
	--font-mega-left: "Megazoid Left";
	--font-mega-right-shade: "Megazoid Right Shade"; 
	--font-mega-left-shade: "Megazoid Left Shade";
	--font-mega-right-italic: "Megazoid Right Italic";
	--font-mega-left-italic: "Megazoid Left Italic";
	--font-mega-right-shade-italic: "Megazoid Right Shade Italic";
	--font-mega-left-shade-italic: "Megazoid Left Shade Italic";
	--font-mega-fill: "Megazoid Fill";
	--font-input-mono: "Input Mono", system-ui, "Segoe UI", "Roboto Mono", monospace;
}


/* ———————————————————————————————— */
/* Base */
/* ———————————————————————————————— */

body {
	position: relative;
  }
  
  .paper-overlay {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-repeat: repeat;
	background-image: url("../img/paper-overlay.jpg");
	mix-blend-mode: multiply;
	pointer-events: none;
	z-index: 100;
  }

#megazoid div, #megazoid span {
	display: block;
}

#megazoid section {
	margin: 0 auto;
	border: none;
	padding: 12rem 3rem 8rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	max-width: 100%;
}

@media screen and (max-width: 768px) {
	#megazoid section {
		padding: 2rem 2rem;
		min-height: auto !important;
	}
}

/* Are you ready header */
.are-you-ready {
    font-family: var(--font-mega-right) !important;
	font-variation-settings: "DPTH" 0;
    color: var(--text-222);
    font-size: clamp(6rem, 18vw, 24rem);
    line-height: 0.88;
    margin-bottom: 8rem;
    text-align: center;
	font-weight: normal;
}

@media screen and (max-width: 768px) {
    .are-you-ready {
        font-size: clamp(3rem, 15vw, 12rem);
        line-height: 1.05;
        margin-bottom: 1.5rem;
        padding: 0 0.5rem;
    }
}

/* Stylistic Sets Overrides */
#megazoid .ss09 {
	font-feature-settings: "ss09" 1;
}



/* ———————————————————————————————— */
/* hero */
/* ———————————————————————————————— */

#megazoid .hero {
	background: linear-gradient(
		46deg,
		var(--pink) 0%, var(--pink) 10%,
		var(--orange) 10%, var(--orange) 20%,
		var(--yellow) 20%, var(--yellow) 30%,
		var(--green) 30%, var(--green) 40%,
		var(--blue) 40%, var(--blue) 50%,
		var(--purple) 50%, var(--purple) 100%
	);
	background-size: cover;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	min-height: 90vh;
	padding: 2rem;
	position: relative;
}

#megazoid .hero-container {
	position: relative;
	width: fit-content;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
}

#megazoid .hero .hero-text {
	display: inline-block;
	position: relative;
	font-size: clamp(3rem, 14vw, 18rem);
	text-transform: none;
	letter-spacing: 0.02em;
	margin-bottom: clamp(0.5rem, 1vw, 1rem);
	text-align: center;
	perspective: 1000px;
	transform-style: preserve-3d;
	padding-left: clamp(1rem, 3vw, 4rem);
	padding: 3rem;
	margin: -3rem;
	opacity: 0;
	transition: opacity 0.3s ease;
}

/* Show hero text when fonts are loaded */
.fonts-loaded #megazoid .hero .hero-text {
	opacity: 1;
}

@keyframes depth-animation {
	0% { font-variation-settings: "DPTH" 0, "STRK" 0; }
	100% { font-variation-settings: "DPTH" -300, "STRK" 20; }
}

@keyframes shift-animation {
	0% { font-variation-settings: "DPTH" 0; }
	100% { font-variation-settings: "DPTH" -300; }
}

#megazoid .hero .hero-text .letter-wrapper {
	display: inline-block;
	position: relative;
	cursor: default;
}

#megazoid .hero .hero-text .letter-wrapper span {
	display: block;
	padding: 3rem;
	margin: -3rem;
}

/* Z-index layering for depth effect - d is highest, M is lowest */
#megazoid .hero .hero-text .letter-wrapper[data-letter="M"] { 
	z-index: 10; 
	margin-left: clamp(0.5rem, 2vw, 3rem);
}
#megazoid .hero .hero-text .letter-wrapper[data-letter="e"] { z-index: 20; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="g"] { z-index: 30; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="a"] { z-index: 40; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="z"] { z-index: 50; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="o"] { z-index: 60; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="i"] { z-index: 70; }
#megazoid .hero .hero-text .letter-wrapper[data-letter="d"] { z-index: 80; }

#megazoid .hero .hero-text .letter-wrapper .bot-layer {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	color: var(--text-000);
	font-family: var(--font-mega-right-shade);
	font-variation-settings: "DPTH" -300, "STRK" 20;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding-left: 0.3em;
	margin-left: -0.3em;
}

/* Mobile hero text layout */
#megazoid .hero-text-mobile {
	display: none;
	opacity: 0;
	transition: opacity 0.3s ease;
}

/* Show mobile hero text when fonts are loaded */
.fonts-loaded #megazoid .hero-text-mobile {
	opacity: 1;
}

#megazoid .hero-text-mobile .hero-line {
	display: flex;
	justify-content: center;
	align-items: center;
}

#megazoid .hero-text-mobile .hero-line .letter-wrapper {
	display: inline-block;
	position: relative;
	cursor: default;
}

#megazoid .hero-text-mobile .hero-line .letter-wrapper span {
	display: block;
}

/* Z-index layering for mobile depth effect - same as desktop */
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="M"] { 
	z-index: 10; 
	margin-left: clamp(0.5rem, 2vw, 3rem);
}
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="e"] { z-index: 20; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="g"] { z-index: 30; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="a"] { z-index: 40; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="z"] { z-index: 50; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="o"] { z-index: 60; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="i"] { z-index: 70; }
#megazoid .hero-text-mobile .hero-line .letter-wrapper[data-letter="d"] { z-index: 80; }

#megazoid .hero-text-mobile .hero-line .letter-wrapper .bot-layer {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	color: var(--text-000);
	font-family: var(--font-mega-right-shade);
	font-variation-settings: "DPTH" -300, "STRK" 40;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.5em;
	margin: -0.5em;
}

#megazoid .hero-text-mobile .hero-line .letter-wrapper .top-layer {
	position: relative;
	z-index: 2;
	color: white;
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" -300;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.5em;
	margin: -0.5em;
}

#megazoid .hero .hero-text .letter-wrapper .top-layer {
	position: relative;
	z-index: 2;
	color: white;
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" -300;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.3em;
	margin: -0.3em;
}



#megazoid .hero ul {
	list-style: none;
	display: flex;
	gap: clamp(0.7rem, 2vw, 3rem);
	margin: 0;
	padding: 0 0 1rem;
	line-height: 1;
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	justify-content: center;
}

#megazoid .hero ul li {
	margin: 0;
	padding: 0;
}

#megazoid .hero ul li a {
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" 0;
	font-size: clamp(0.875rem, 2vw, 3rem);
	text-transform: uppercase;
	color: var(--text-000);
	text-decoration: none;
	transition: color 0.2s ease, background 0.2s ease;
	letter-spacing: 0.04em;
	background: var(--text-fff);
	padding: 0.5rem 1.5rem;
	border-radius: 2rem;
	display: inline-block;
}

#megazoid .hero ul li a:hover {
	color: var(--text-fff);
	background: var(--indigo);
}

@media screen and (max-width: 768px) {
	#megazoid .hero {
		min-height: 75vh;
		height: 75vh;
	}
	
	/* Hide desktop hero text on mobile */
	#megazoid .hero .hero-text {
		display: none;
	}
	
	/* Show mobile hero text on mobile */
	#megazoid .hero-text-mobile {
		display: flex !important;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		font-size: clamp(6rem, 22vw, 16rem);
		letter-spacing: 0.02em;
		text-align: center;
		perspective: 1000px;
		transform-style: preserve-3d;
		line-height: 0.83;
		padding-left: 0.18em;
	}
	
	/* Ensure mobile hero text shows when fonts are loaded */
	.fonts-loaded #megazoid .hero-text-mobile {
		opacity: 1 !important;
	}

	#megazoid .hero-container {
		align-items: center;
		width: 100%;
	}

	#megazoid .hero ul {
		gap: 0.5rem;
		margin: 0;
		position: absolute;
		bottom: 1rem;
		left: 50%;
		transform: translateX(-50%);
		justify-content: center;
	}
	
	#megazoid .hero ul li a {
		font-size: clamp(1rem, 3vw, 1.5rem);
		padding: 0.5rem 1rem;
	}
}

/* ———————————————————————————————— */
/* overview */
/* ———————————————————————————————— */
#megazoid .overview,
#megazoid .overview p {
	background: var(--indigo);
	color: var(--cream);
	font-family: var(--font-mega-right);
	font-size: clamp(2.2rem, 8vw, 8rem);
	font-weight: normal;
	line-height: 1;
	font-variation-settings: "DPTH" 0;
}

#megazoid .overview-content {
	text-align: left;
}

#megazoid .overview p {
	padding: 0;
	margin: 0;
	text-align: left;
	max-width: 100%;
}

#megazoid .overview {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 0.7em clamp(2rem, 8vw, 10rem) 0.8em;
}

#megazoid .overview p + p {
	margin-top: 3rem;
}

@media screen and (max-width: 768px) {
	#megazoid .overview {
		padding: 1em clamp(0.75rem, 6vw, 3rem) 1em;
	}

	#megazoid .overview p + p {
		margin-top: 1.5rem;
	}
}


/* ———————————————————————————————— */
/* spec-upper-caps */
/* ———————————————————————————————— */
#megazoid .spec-upper-caps {
	background: var(--pink);
	font-family: var(--font-mega-right);
	color: var(--yellow);
	font-size: clamp(2.5rem, 12vw, 15rem);
	text-transform: uppercase;
	line-height: 1;
	text-align: center;
	padding: 0.7em 1rem 0.7em;
	font-variation-settings: "DPTH" 0;
}

/* ———————————————————————————————— */
/* spec-shades */
/* ———————————————————————————————— */
#megazoid .spec-shades {
	background: var(--yellow);
	font-size: clamp(2.5rem, 9vw, 11.25rem);
	line-height: 1.05;
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: clamp(2rem, 6vw, 2.9rem);
	padding: 1em 1rem 1em;
}

#megazoid .spec-shades .shade-right,
#megazoid .spec-shades .shade-left {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	flex: 0 1 auto;
}

#megazoid .spec-shades .shade-right {
	text-transform: uppercase;
}

#megazoid .spec-shades .layered-wrap {
	display: inline-block;
	position: relative;
	cursor: default;
}

#megazoid .spec-shades .layered-wrap span {
	display: block;
}

#megazoid .spec-shades .layered-wrap .bot-layer {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	color: var(--green);
	font-variation-settings: "DPTH" -300, "STRK" 40;
	transition: font-variation-settings 0.2s ease;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.5em;
	margin: -0.5em;
}

#megazoid .spec-shades .shade-right .layered-wrap .bot-layer {
	font-family: var(--font-mega-right-shade);
}

#megazoid .spec-shades .shade-left .layered-wrap .bot-layer {
	font-family: var(--font-mega-left-shade);
}

#megazoid .spec-shades .layered-wrap .top-layer {
	position: relative;
	z-index: 2;
	font-family: var(--font-mega-right);
	color: var(--text-fff);
	font-variation-settings: "DPTH" -300;
	transition: font-variation-settings 0.2s ease;
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.5em;
	margin: -0.5em;
}

#megazoid .spec-shades .shade-left .layered-wrap .top-layer {
	font-family: var(--font-mega-left);
}

#megazoid .spec-shades .layered-wrap:hover .bot-layer {
	font-variation-settings: "DPTH" 0, "STRK" 40;
}

#megazoid .spec-shades .layered-wrap:hover .top-layer {
	font-variation-settings: "DPTH" 0;
}

/* Shade-right words (top to bottom) */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(1) { z-index: 10; } /* Metric */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(2) { z-index: 20; } /* Return */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(3) { z-index: 30; } /* Phobia */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(4) { z-index: 40; } /* Dyadic */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(5) { z-index: 50; } /* Silicon */
#megazoid .spec-shades .shade-right .layered-wrap:nth-child(6) { z-index: 60; } /* Nebula */

/* Shade-left words (top to bottom) */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(1) { z-index: 10; } /* Angular */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(2) { z-index: 20; } /* Echelon */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(3) { z-index: 30; } /* Optimal */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(4) { z-index: 40; } /* Starship */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(5) { z-index: 50; } /* Diverge */
#megazoid .spec-shades .shade-left .layered-wrap:nth-child(6) { z-index: 60; } /* Isotopic */

@media (max-width: 768px) {
	#megazoid .spec-shades {
		flex-direction: column;
		gap: 2rem;
		align-items: center;
		font-size: clamp(4rem, 18vw, 16rem);
		padding: 0.7em 3rem 0.95em;
	}
	
	#megazoid .spec-shades .shade-right,
	#megazoid .spec-shades .shade-left {
		width: 100%;
		max-width: 95vw;
		align-items: center;
		text-align: center;
	}
}

/* ———————————————————————————————— */
/* history */
/* ———————————————————————————————— */
#megazoid .history {
	background: var(--cream);
	position: relative;
	padding: 8em 1rem 2em;
	padding-bottom: calc(44px + 27px + 16px + 8px + 4px + 2px + 1px + 6 * 10px + 96px);
}

#megazoid .history-container {
	max-width: clamp(70vw, 85vw, 1200px);
	margin: 0 auto;
}

#megazoid .history-grid {
	display: flex;
	flex-direction: column;
	gap: 2em;
}

#megazoid .history-row {
	display: grid;
	grid-template-columns: 1fr 1.25fr;
	gap: 3rem;
	align-items: start;
}

#megazoid .history-image {
	min-height: 0;
}

#megazoid .history-figure {
	margin: 0.5em 0 0 0;
}

#megazoid .history-figure img {
	max-width: 100%;
	height: auto;
	display: block;
}

#megazoid .history-figure .img-caption {
	font-family: var(--font-input-mono);
	font-size: clamp(0.875rem, 1.5vw, 1.0625rem);
	font-variation-settings: "wdth" 80, "wght" 300, "slnt" 0;
	line-height: 1.7;
	word-spacing: -0.05em;
	letter-spacing: -0.01em;
	color: var(--text-666);
	margin-top: 1rem;
	line-height: 1.4;
}

#megazoid .history .history-text p {
	font-family: var(--font-input-mono);
	font-size: clamp(0.875rem, 2.5vw, 1.125rem);
	font-variation-settings: "wdth" 80, "wght" 300, "slnt" 0;
	line-height: 1.7;
	word-spacing: -0.05em;
	letter-spacing: -0.01em;
	color: var(--text-222);
	margin: 0 0 1.5em 0;
}

#megazoid .history .history-text p .letter {
	background: var(--text-fff);
	display: inline;
	padding: 0 0.25em;
	border-radius: 0.2em;
	border: solid 1px var(--text-ccc);
}

#megazoid .history .history-text .first-word {
	text-transform: uppercase;
	display: inline;
	letter-spacing: 0.05em;
}

#megazoid .history .img-caption em {
	font-variation-settings: "wdth" 80, "wght" 300, "slnt" -8;
}

#megazoid .history-text p:last-child {
	margin-bottom: 0;
}

#megazoid .history .history-text p a {
	color: var(--text-222);
	text-decoration: underline;
	text-decoration-color: var(--pink);
	text-decoration-thickness: 0.08em;
	text-decoration-skip-ink: auto;
	text-underline-offset: 0.1em;
	transition: color 0.2s ease;
}

#megazoid .history .history-text p a:hover,
#megazoid .history .history-text p a:active {
	color: var(--pink);
	text-decoration: none;
}

#megazoid .history .layered-dropcap {
	position: relative;
	display: inline-block;
	font-size: 5.7em;
	float: left;
	line-height: 0.8;
	margin-right: 0.35em;
	margin-top: 0.21em;
	margin-left: -0.2em;
}

#megazoid .history .layered-dropcap .bot-layer {
	position: absolute;
	top: 0;
	left: 0;
	font-family: var(--font-mega-left-shade);
	color: var(--teal);
	z-index: 1;
	font-variation-settings: "DPTH" -300, "STRK" 20;
}

#megazoid .history .layered-dropcap .top-layer {
	position: relative;
	font-family: var(--font-mega-left);
	color: var(--aqua);
	z-index: 2;
	font-variation-settings: "DPTH" -300;
	transition: font-variation-settings 0.2s ease;
}

#megazoid .history .layered-dropcap .top-layer:hover {
	font-variation-settings: "DPTH" 0;
	cursor: default;
}

#megazoid .history-stripes-wrapper {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	pointer-events: none;
	--stripe-gap: 10px;
	height: calc(44px + 27px + 16px + 8px + 4px + 2px + 1px + 6 * var(--stripe-gap));
	overflow: hidden;
	z-index: 1;
}

#megazoid .history-stripes-wrapper .stripe {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100vw;
	background: var(--pink);
}

#megazoid .history-stripes-wrapper .stripe:nth-child(1) {
	height: 44px;
	bottom: 0;
}
#megazoid .history-stripes-wrapper .stripe:nth-child(2) {
	height: 27px;
	bottom: calc(44px + var(--stripe-gap));
}
#megazoid .history-stripes-wrapper .stripe:nth-child(3) {
	height: 16px;
	bottom: calc(44px + 27px + 2 * var(--stripe-gap));
}
#megazoid .history-stripes-wrapper .stripe:nth-child(4) {
	height: 8px;
	bottom: calc(44px + 27px + 16px + 3 * var(--stripe-gap));
}
#megazoid .history-stripes-wrapper .stripe:nth-child(5) {
	height: 4px;
	bottom: calc(44px + 27px + 16px + 8px + 4 * var(--stripe-gap));
}
#megazoid .history-stripes-wrapper .stripe:nth-child(6) {
	height: 2px;
	bottom: calc(44px + 27px + 16px + 8px + 4px + 5 * var(--stripe-gap));
}
#megazoid .history-stripes-wrapper .stripe:nth-child(7) {
	height: 1px;
	bottom: calc(44px + 27px + 16px + 8px + 4px + 2px + 6 * var(--stripe-gap));
}

@media screen and (min-width: 769px) {
	#megazoid .history-row {
		grid-template-areas: "image text";
	}
	
	#megazoid .history-row .history-image {
		grid-area: image;
	}
	
	#megazoid .history-row .history-text {
		grid-area: text;
	}
}

@media screen and (max-width: 768px) {
	#megazoid .history {
		padding-top: 4em;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
	}
	
	#megazoid .history-container {
		max-width: none;
	}
	
	#megazoid .history-row {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

/* ———————————————————————————————— */
/* spec-styles */
/* ———————————————————————————————— */
#megazoid .spec-styles {
	background: var(--navy);
	padding: 10px 0 0;
	text-align: center;
	position: relative;
	min-height: 150vh;
}

#megazoid .spec-styles-bg {
	position: relative;
	width: 100vw;
	height: 300px;
	background-image: url('../img/perspective-grid-bg.svg');
	background-size: 100% auto;
	background-position: top;
	background-repeat: no-repeat;
	pointer-events: none;
	margin-left: calc(-50vw + 50%);
}

#megazoid .spec-styles-bg::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url('../img/perspective-grid-bg.svg');
	background-size: 100% auto;
	background-position: top;
	background-repeat: no-repeat;
	opacity: 0.7;
	pointer-events: none;
}

#megazoid .spec-styles-bg::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 46%;
	background: linear-gradient(
		to top,
		var(--pink) 0%,
		var(--pink) 50%,
		transparent 100%
	);
	pointer-events: none;
}

#megazoid .spec-styles-wrapper {
	display: flex;
	flex-direction: column;
	text-align: left;
	gap: 5rem;
	align-items: center;
	max-width: 1200px;
	margin: 6rem auto 3rem;
}

#megazoid .spec-styles .style-lockup {
	display: grid;
	grid-template-rows: auto auto;
	grid-template-columns: 1fr;
	margin-bottom: 2rem;
	width: fit-content;
	row-gap: 2rem;
}

#megazoid .spec-styles .style-lockup .sample {
	font-family: var(--font-mega-right);
	color: var(--pink);
	font-size: clamp(4.2rem, 14vw, 15rem);
	line-height: 1;
	font-variation-settings: "DPTH" 0;
}

#megazoid .spec-styles .style-italic .sample {
	font-family: var(--font-mega-right-italic);
}

#megazoid .spec-styles .style-lockup .style-info {
	text-align: left;
	font-family: var(--font-input-mono);
	font-variation-settings: "wdth" 90;
	color: var(--cream);
	font-size: clamp(0.75rem, 2vw, 1.125rem);
	font-size: 0.875rem;
}

#megazoid .spec-styles .layered-wrap {
	position: relative;
}

#megazoid .spec-styles .layered-wrap .top-layer {
	position: relative;
	top: 0;
	left: 0;
	z-index: 2;
	color: var(--navy);
	color: rgb(21, 20, 51);
}

#megazoid .spec-styles .layered-wrap .bot-layer {
	position: absolute;
	top: 0;
	left: 0;
	/* margin-inline: auto; 
	width: fit-content; */
	z-index: 1;
	color: var(--pink);
}

#megazoid .spec-styles .style-shade-left .layered-wrap .top-layer,
#megazoid .spec-styles .style-shade-left .layered-wrap .bot-layer,
#megazoid .spec-styles .style-shade-right .layered-wrap .top-layer,
#megazoid .spec-styles .style-shade-right .layered-wrap .bot-layer {
	/* Hardware acceleration for smooth font variations */
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	/* Prevent clipping by adding padding/margin */
	padding: 0.55em;
	margin: -0.55em;
}

#megazoid .spec-styles .style-shade-left .layered-wrap .top-layer {
	left: clamp(-1rem, -4vw, -4rem);
	font-family: var(--font-mega-left);
	font-variation-settings: "DPTH" -300;
}

#megazoid .spec-styles .style-shade-left .layered-wrap .bot-layer {
	left: clamp(-1rem, -4vw, -4rem);
	font-family: var(--font-mega-left-shade);
	font-variation-settings: "DPTH" -300, "STRK" 20;
}

#megazoid .spec-styles .style-shade-right .layered-wrap .top-layer {
	left: clamp(0.65rem, 2.6vw, 2.6rem);
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" -300;
}

#megazoid .spec-styles .style-shade-right .layered-wrap .bot-layer {
	left: clamp(0.65rem, 2.6vw, 2.6rem);
	font-family: var(--font-mega-right-shade);
	font-variation-settings: "DPTH" -300, "STRK" 20;
}

#megazoid .spec-styles .style-fill .layered-wrap .top-layer {
	top: calc(-0.35rem - 0.5vw);
	left: calc(-0.35rem - 0.5vw);
	z-index: 2;
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" 0;
	color: transparent;
	-webkit-text-stroke: 0.125rem var(--cream);
	text-stroke: 0.125rem var(--cream);
	opacity: 0.5;
}

#megazoid .spec-styles .style-fill .layered-wrap .bot-layer {
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" 0;
	font-feature-settings: "ss19" 1;
}

/* Depth Slider Styles */
#megazoid .spec-styles .style-info-row {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	background: transparent;
	border: 1px solid transparent;
	/* border-radius: 0.5rem; */
	transition: background 0.3s ease;
	padding: 1rem;
	z-index: 10;
}

#megazoid .spec-styles .style-info-row:hover {
	background: rgba(21, 20, 51, 0.8);
}

#megazoid .spec-styles .link-control {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 0.5rem;
	margin-left: 1rem;
	flex-shrink: 0;
	min-width: 140px;
}

#megazoid .spec-styles .link-control label {
	display: flex;
	align-items: center;
	font-family: var(--font-input-mono);
	color: var(--cream);
	font-size: 0.875rem;
	cursor: pointer;
	white-space: nowrap;
	line-height: 1;
}

/* Safari-specific fixes for checkbox alignment */
@supports (-webkit-appearance: none) {
	#megazoid .spec-styles .link-control label {
		align-items: flex-start;
		padding-top: 2px;
	}
	
	#megazoid .spec-styles .link-control input[type="checkbox"] {
		margin-top: 1px;
	}
}

#megazoid .spec-styles .link-control input[type="checkbox"] {
	width: 16px;
	height: 16px;
	accent-color: var(--pink);
	cursor: pointer;
	vertical-align: middle;
	position: relative;
	top: -1px;
	margin-right: 0.5rem;
}

#megazoid .spec-styles .depth-slider {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 1rem;
	flex-shrink: 0;
}

#megazoid .spec-styles .slider-controls {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 1rem;
}

/* Stack checkbox below on smaller screens */
@media (max-width: 768px) {
	#megazoid .spec-styles .depth-slider {
		flex-direction: column-reverse;
		align-items: flex-start;
		gap: 0.5rem;
	}
	
	#megazoid .spec-styles .link-control {
		margin-left: 0;
		margin-top: 0;
		margin-bottom: 0.5rem;
		min-width: auto;
	}
	
	/* Keep the slider components in a row */
	#megazoid .spec-styles .slider-controls {
		flex-direction: row;
		align-items: center;
		gap: 1rem;
	}
}

#megazoid .spec-styles .depth-range {
	width: 200px;
	height: 2px;
	border-radius: 0;
	background: var(--purple);
	outline: none;
	transition: opacity 0.2s;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	flex-shrink: 0;
	min-width: 200px;
	max-width: 200px;
}

#megazoid .spec-styles .depth-slider label {
	font-family: var(--font-input-mono);
	color: var(--cream);
	font-size: 0.875rem;
	width: 3.5rem;
	text-align: left;
}

#megazoid .spec-styles .depth-value {
	font-family: var(--font-input-mono);
	color: var(--cream);
	font-size: 0.875rem;
	width: 3rem;
	flex-shrink: 0;
}

#megazoid .spec-styles .stroke-slider {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 1rem;
	flex-shrink: 0;
}

#megazoid .spec-styles .stroke-range {
	width: 200px;
	height: 2px;
	border-radius: 0;
	background: var(--purple);
	outline: none;
	transition: opacity 0.2s;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	flex-shrink: 0;
	min-width: 200px;
	max-width: 200px;
}

#megazoid .spec-styles .stroke-slider label {
	font-family: var(--font-input-mono);
	color: var(--cream);
	font-size: 0.875rem;
	width: 3.5rem;
	text-align: left;
}

#megazoid .spec-styles .stroke-value {
	font-family: var(--font-input-mono);
	color: var(--cream);
	font-size: 0.875rem;
}

#megazoid .spec-styles .depth-range:hover,
#megazoid .spec-styles .stroke-range:hover {
	opacity: 1;
}

#megazoid .spec-styles .depth-range::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 16px;
	height: 20px;
	background: var(--pink);
	cursor: pointer;
	border: none;
	border-radius: 0;
}

#megazoid .spec-styles .depth-range::-moz-range-thumb {
	width: 16px;
	height: 20px;
	background: var(--pink);
	cursor: pointer;
	border: none;
	border-radius: 0;
}

#megazoid .spec-styles .depth-range::-webkit-slider-track {
	width: 100%;
	height: 2px;
	background: rgba(255, 255, 255, 0.5);
	border: none;
	box-shadow: none;
}

#megazoid .spec-styles .depth-range::-moz-range-track {
	width: 100%;
	height: 2px;
	background: rgba(255, 255, 255, 0.5);
	border: none;
	box-shadow: none;
}

#megazoid .spec-styles .depth-range:hover::-webkit-slider-track {
	background: rgba(255, 255, 255, 1);
}

#megazoid .spec-styles .depth-range:hover::-moz-range-track {
	background: rgba(255, 255, 255, 1);
}

#megazoid .spec-styles .stroke-range::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 16px;
	height: 20px;
	background: var(--pink);
	cursor: pointer;
	border: none;
	border-radius: 0;
}

#megazoid .spec-styles .stroke-range::-moz-range-thumb {
	width: 16px;
	height: 20px;
	background: var(--pink);
	cursor: pointer;
	border: none;
	border-radius: 0;
}

#megazoid .spec-styles .stroke-range::-webkit-slider-track {
	width: 100%;
	height: 2px;
	background: rgba(255, 255, 255, 0.5);
	border: none;
	box-shadow: none;
}

#megazoid .spec-styles .stroke-range::-moz-range-track {
	width: 100%;
	height: 2px;
	background: rgba(255, 255, 255, 0.5);
	border: none;
	box-shadow: none;
}

#megazoid .spec-styles .stroke-range:hover::-webkit-slider-track {
	background: rgba(255, 255, 255, 1);
}

#megazoid .spec-styles .stroke-range:hover::-moz-range-track {
	background: rgba(255, 255, 255, 1);
}


@media screen and (min-width: 768px) {
	#megazoid .spec-styles-bg {
		height: 400px;
	}
}

@media screen and (min-width: 1200px) {
	#megazoid .spec-styles-bg {
		height: 600px;
	}
}

@media screen and (max-width: 768px) {
	#megazoid .spec-styles-bg::after {
		height: 30%;
	}
	
	#megazoid .spec-styles-bg {
		height: clamp(190px, 30vw, 260px);
	}
	
	#megazoid .spec-styles .style-lockup .style-info {
		text-align: center;
	}
	
	#megazoid .spec-styles .style-lockup {
		row-gap: 1rem;
	}
	
	#megazoid .spec-styles-wrapper {
		margin: 2rem auto 2rem;
		gap: 3em;
	}

	#megazoid .spec-styles .style-shade-left .layered-wrap .top-layer,
	#megazoid .spec-styles .style-shade-left .layered-wrap .bot-layer {
		left: clamp(0.01rem, -4vw, -4rem);
	}
		
	#megazoid .spec-styles .style-shade-right .layered-wrap .top-layer,
	#megazoid .spec-styles .style-shade-right .layered-wrap .bot-layer {
		left: clamp(1rem, 2.6vw, 2.6rem);
	}
}

#megazoid .spec-styles-stripes-wrapper {
	width: 100vw;
	pointer-events: none;
	--stripe-gap: 10px;
	height: calc(10px + 27px + 16px + 8px + 4px + 2px + 1px + 5 * var(--stripe-gap));
	overflow: hidden;
}

#megazoid .spec-styles-stripes-wrapper .stripe {
	width: 100vw;
	background: var(--pink);
	margin-bottom: 10px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(1) {
	height: 27px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(2) {
	height: 16px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(3) {
	height: 8px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(4) {
	height: 4px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(5) {
	height: 2px;
}

#megazoid .spec-styles-stripes-wrapper .stripe:nth-child(6) {
	height: 1px;
}

/* ———————————————————————————————— */
/* spec-regular-paragraph-1 */
/* ———————————————————————————————— */
#megazoid .spec-regular-paragraph-1 {
	background: var(--pink);
	padding: 1em 1rem 6em clamp(2rem, 4vw, 5rem);
	text-align: left;
	overflow: hidden;
}

#megazoid .spec-regular-paragraph-1 .layered-text .bot-layer {
	position: absolute;
	z-index: 1;
	font-family: var(--font-mega-right);
	color: var(--purple);
	opacity: 0.7;
	font-variation-settings: "DPTH" 100;
}

#megazoid .spec-regular-paragraph-1 .layered-text .top-layer {
	position: relative;
	z-index: 2;
	font-family: var(--font-mega-right);
	color: var(--cream);
	font-variation-settings: "DPTH" 0;
	transition: font-variation-settings 0.3s ease;
}

#megazoid .spec-regular-paragraph-1 .layered-text {
	position: relative;
	font-family: var(--font-mega-right);
	color: var(--cream);
	font-size: clamp(2rem, 8vw, 12rem);
	line-height: 1.1;
	cursor: default;
}

#megazoid .spec-regular-paragraph-1 .layered-text:hover .top-layer {
	font-variation-settings: "DPTH" -100;
}

#megazoid .spec-regular-paragraph-1 .layered-text span {
	display: block;
	width: 35em;
}

@media screen and (max-width: 768px) {
	#megazoid .spec-regular-paragraph-1 {
		padding: 1em 2rem 3em 2rem;
	}

	#megazoid .spec-regular-paragraph-1 .layered-text {
		font-size: clamp(2.8rem, 12vw, 9rem);
	}
}



/* ———————————————————————————————— */
/* letter-field */
/* ———————————————————————————————— */
#megazoid .letter-field {
	background: var(--tan);
	padding: 0 0.25rem 0;
	text-align: center;
}

#megazoid .animated-letter-field {
	margin-top: -1px;
	max-width: 100%;
	width: auto !important;
	display: block;
}

#megazoid .animated-letter-field svg {
	width: 100%;
	height: auto;
	display: block;
}

/* Initial state for all letters - hidden and moved down */
#megazoid .animated-letter-field .letter-letter-1,
#megazoid .animated-letter-field .letter-letter-2,
#megazoid .animated-letter-field .letter-letter-3,
#megazoid .animated-letter-field .letter-letter-4,
#megazoid .animated-letter-field .letter-letter-5,
#megazoid .animated-letter-field .letter-letter-6,
#megazoid .animated-letter-field .letter-letter-7,
#megazoid .animated-letter-field .letter-letter-8,
#megazoid .animated-letter-field .letter-letter-9,
#megazoid .animated-letter-field .letter-letter-10,
#megazoid .animated-letter-field .letter-letter-11,
#megazoid .animated-letter-field .letter-letter-12,
#megazoid .animated-letter-field .letter-letter-13,
#megazoid .animated-letter-field .letter-letter-14,
#megazoid .animated-letter-field .letter-letter-15,
#megazoid .animated-letter-field .letter-letter-16,
#megazoid .animated-letter-field .letter-letter-17,
#megazoid .animated-letter-field .letter-letter-18,
#megazoid .animated-letter-field .letter-letter-19,
#megazoid .animated-letter-field .letter-letter-20,
#megazoid .animated-letter-field .letter-letter-21,
#megazoid .animated-letter-field .letter-letter-22,
#megazoid .animated-letter-field .letter-letter-23,
#megazoid .animated-letter-field .letter-letter-24,
#megazoid .animated-letter-field .letter-letter-25,
#megazoid .animated-letter-field .letter-letter-26,
#megazoid .animated-letter-field .letter-letter-27,
#megazoid .animated-letter-field .letter-letter-28,
#megazoid .animated-letter-field .letter-letter-29,
#megazoid .animated-letter-field .letter-letter-30 {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

/* Animated state - visible and in position */
#megazoid .animated-letter-field .letter-letter-1.animate,
#megazoid .animated-letter-field .letter-letter-2.animate,
#megazoid .animated-letter-field .letter-letter-3.animate,
#megazoid .animated-letter-field .letter-letter-4.animate,
#megazoid .animated-letter-field .letter-letter-5.animate,
#megazoid .animated-letter-field .letter-letter-6.animate,
#megazoid .animated-letter-field .letter-letter-7.animate,
#megazoid .animated-letter-field .letter-letter-8.animate,
#megazoid .animated-letter-field .letter-letter-9.animate,
#megazoid .animated-letter-field .letter-letter-10.animate,
#megazoid .animated-letter-field .letter-letter-11.animate,
#megazoid .animated-letter-field .letter-letter-12.animate,
#megazoid .animated-letter-field .letter-letter-13.animate,
#megazoid .animated-letter-field .letter-letter-14.animate,
#megazoid .animated-letter-field .letter-letter-15.animate,
#megazoid .animated-letter-field .letter-letter-16.animate,
#megazoid .animated-letter-field .letter-letter-17.animate,
#megazoid .animated-letter-field .letter-letter-18.animate,
#megazoid .animated-letter-field .letter-letter-19.animate,
#megazoid .animated-letter-field .letter-letter-20.animate,
#megazoid .animated-letter-field .letter-letter-21.animate,
#megazoid .animated-letter-field .letter-letter-22.animate,
#megazoid .animated-letter-field .letter-letter-23.animate,
#megazoid .animated-letter-field .letter-letter-24.animate,
#megazoid .animated-letter-field .letter-letter-25.animate,
#megazoid .animated-letter-field .letter-letter-26.animate,
#megazoid .animated-letter-field .letter-letter-27.animate,
#megazoid .animated-letter-field .letter-letter-28.animate,
#megazoid .animated-letter-field .letter-letter-29.animate,
#megazoid .animated-letter-field .letter-letter-30.animate {
	opacity: 1;
	transform: translateY(0);
}

/* Animation timing is now handled by JavaScript based on scroll position */

/* ———————————————————————————————— */
/* calculator */
/* ———————————————————————————————— */
#megazoid .calculator {
	background: linear-gradient(
		to top,
		var(--pink) 0%,
		var(--pink) 11.11%,
		var(--orange) 11.11%,
		var(--orange) 22.22%,
		var(--yellow) 22.22%,
		var(--yellow) 33.33%,
		var(--green) 33.33%,
		var(--green) 44.44%,
		var(--blue) 44.44%,
		var(--blue) 55.56%,
		var(--tan) 55.56%,
		var(--tan) 100%
	);
	padding: 2rem 1rem 8rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: clamp(-25rem, -35vw, -40rem);
	min-height: 100vh;
}

@media screen and (max-width: 768px) {
	#megazoid .calculator {
		margin-top: clamp(-5rem, -15vw, -10rem);
	}
}

#megazoid .calculator-container {
	background: #DAD6CC;
	border-radius: clamp(2.25rem, 6vw, 3rem);
	box-shadow: 0.5625rem 0.75rem 2.25rem 0px #0003, 0 0 0 0.5625rem #fff inset;
	padding: clamp(1.6875rem, 4.5vw, 3rem) clamp(1.3125rem, 3.75vw, 2.25rem);
	width: fit-content;
	max-width: clamp(26.25rem, 105vw, 36rem);
	display: flex;
	flex-direction: column;
	align-items: center;
	border: 0.5625rem solid #d1d1cb;
	position: relative;
}

#megazoid .calc-header {
	width: 100%;
	text-align: right;
	display: flex;
	justify-content: flex-end;
}

#megazoid .calc-header img {
	width: 40%;
}

#megazoid .display {
	background: linear-gradient(135deg, #303135, #28282A);
	border: clamp(0.1875rem, 0.375vw, 0.25rem) solid #888572;
	border-radius: clamp(0.5rem, 1vw, 0.75rem);
	color: #4ff6ff;
	font-family: var(--font-mega-right);
	font-size: clamp(2rem, 5vw, 4.5rem);
	max-width: 100%;
	min-width: 0;
	height: clamp(3.75rem, 9vw, 6rem);
	min-height: clamp(3.75rem, 9vw, 6rem);
	max-height: clamp(3.75rem, 9vw, 6rem);
	margin: 0;
	text-align: right;
	line-height: clamp(3.375rem, 8vw, 5.5rem);
	padding: 0 clamp(0.75rem, 1.5vw, 1.25rem);
	box-shadow: 0 0.1875rem 0.75rem #0002 inset;
	letter-spacing: 0.1875rem;
	overflow-x: auto;
	overflow-y: hidden;
	white-space: nowrap;
	cursor: default;
	box-sizing: border-box;
	flex-shrink: 0;
	flex-basis: auto;
	font-variation-settings: "DPTH" 0;
}

#megazoid .display::-webkit-scrollbar {
	display: none;
}

#megazoid .display {
	scrollbar-width: none; /* Firefox */
	-ms-overflow-style: none; /* Internet Explorer 10+ */
}

#megazoid .calculator-wrapper {
	display: flex;
	flex-direction: column;
	gap: clamp(1.125rem, 3vw, 2rem);
	align-items: center;
	width: fit-content;
	max-width: calc(100vw - 2rem);
	background: #DCD8CD;
	padding: clamp(1.5rem, 3vw, 2.5rem);
	border-radius: clamp(1rem, 2vw, 1.5rem);
	border-right: clamp(0.25rem, 0.5vw, 0.5rem) solid #B8B4A9;
	border-bottom: clamp(0.25rem, 0.5vw, 0.5rem) solid #B8B4A9;
	box-shadow: clamp(0.25rem, 0.5vw, 0.5rem) clamp(0.25rem, 0.5vw, 0.5rem) clamp(0.5rem, 1vw, 1rem) rgba(0, 0, 0, 0.3);
	margin: 0 1rem;
}

#megazoid .calc-header,
#megazoid .display,
#megazoid .button-wrapper {
	width: calc(5 * clamp(3rem, 8vw, 6.5rem) + 4 * clamp(0.125rem, 0.5vw, 0.375rem) + 2 * clamp(1rem, 2vw, 2rem) + clamp(0.125rem, 0.25vw, 0.25rem) * 2);
	box-sizing: border-box;
}

#megazoid .calculator .button-wrapper {
	background: linear-gradient(135deg, #303135, #28282A);
	border: clamp(0.1875rem, 0.375vw, 0.25rem) solid #888572;
	padding: clamp(0.75rem, 2vw, 1.5rem) clamp(1.25rem, 2.5vw, 2rem);
	border-radius: clamp(0.5rem, 1vw, 0.75rem);
	display: flex;
	gap: clamp(0.75rem, 2vw, 1.5rem);
	justify-content: center;
}

#megazoid .calculator .left-panel {
	display: grid;
	grid-template-columns: repeat(3, clamp(3rem, 8vw, 6.5rem));
	grid-template-rows: repeat(4, clamp(3rem, 8vw, 6.5rem));
	gap: clamp(0.125rem, 0.5vw, 0.375rem) clamp(0.125rem, 0.5vw, 0.375rem);
}

#megazoid .calculator #btn-7 { grid-row: 1; grid-column: 1; }
#megazoid .calculator #btn-8 { grid-row: 1; grid-column: 2; }
#megazoid .calculator #btn-9 { grid-row: 1; grid-column: 3; }
#megazoid .calculator #btn-4 { grid-row: 2; grid-column: 1; }
#megazoid .calculator #btn-5 { grid-row: 2; grid-column: 2; }
#megazoid .calculator #btn-6 { grid-row: 2; grid-column: 3; }
#megazoid .calculator #btn-1 { grid-row: 3; grid-column: 1; }
#megazoid .calculator #btn-2 { grid-row: 3; grid-column: 2; }
#megazoid .calculator #btn-3 { grid-row: 3; grid-column: 3; }
#megazoid .calculator #btn-0 {
	width: clamp(5.5rem, 13vw, 11.125rem) !important;
	height: clamp(2rem, 5vw, 4.5rem) !important;
	border-radius: clamp(1rem, 2.5vw, 2.25rem) !important;
}

#megazoid .calculator #btn-0::before {
	border-radius: 0.5rem !important;
}


#megazoid .calculator #btn-dot {
	grid-row: 4;
	grid-column: 3;
}

#megazoid .calculator .right-panel {
	display: grid;
	grid-template-columns: repeat(2, clamp(3rem, 8vw, 6.5rem));
	grid-template-rows: repeat(4, clamp(3rem, 8vw, 6.5rem));
	gap: clamp(0.125rem, 0.5vw, 0.375rem) clamp(0.125rem, 0.5vw, 0.375rem);
}

#megazoid .calculator #btn-plus { grid-row: 1; grid-column: 1; }
#megazoid .calculator #clear { grid-row: 1; grid-column: 2; }
#megazoid .calculator #btn-minus { grid-row: 2; grid-column: 1; }
#megazoid .calculator #btn-percent { grid-row: 2; grid-column: 2; }
#megazoid .calculator #btn-multiply { grid-row: 3; grid-column: 1; }
#megazoid .calculator #btn-divide { grid-row: 4; grid-column: 2; }
#megazoid .calculator #result {
	grid-row: 3 / span 2 !important;
	grid-column: 2 !important;
	width: clamp(2rem, 5vw, 4.5rem) !important;
	height: clamp(5.5rem, 13vw, 11.125rem) !important;
	border-radius: clamp(1rem, 2.5vw, 2.25rem) !important;
	font-size: clamp(1.5rem, 4vw, 3.3rem) !important;
	background: linear-gradient(-20deg, #2F86CF, #1A72B2);
	color: #fff;
	box-shadow: clamp(-0.375rem, -0.75vw, -0.5rem) clamp(-0.375rem, -0.75vw, -0.5rem) clamp(0.5rem, 1vw, 0.75rem) rgba(255, 255, 255, 0.95), clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.5rem, 1vw, 0.75rem) clamp(0.03125rem, 0.0625vw, 0.0625rem) rgba(0, 0, 0, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	border-color: #5A9CD8;
}

#megazoid .calculator .btn-base.tall {
	grid-row: 3 / span 2 !important;
	grid-column: 2 !important;
	width: auto !important;
	height: auto !important;
}

#megazoid .calculator #result::before {
	background: #3ba8e6 !important;
	border-radius: 0.5rem !important;
}

#megazoid .calculator .btn {
	font-family: var(--font-mega-right);
	font-size: clamp(1.25rem, 2.5vw, 3rem);
	font-weight: normal;
	border: clamp(0.125rem, 0.25vw, 0.1875rem) solid #D3D0CB;
	border-radius: 50%;
	background: linear-gradient(135deg, #94999a, #F1EEE9);
	position: relative;
	box-shadow: clamp(-0.375rem, -0.75vw, -0.5rem) clamp(-0.375rem, -0.75vw, -0.5rem) clamp(0.5rem, 1vw, 0.75rem) rgba(255, 255, 255, 0.95), clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.5rem, 1vw, 0.75rem) clamp(0.03125rem, 0.0625vw, 0.0625rem) rgba(0, 0, 0, 0.2);
	color: #232629;
	cursor: pointer;
	transition: background 0.15s, box-shadow 0.15s, color 0.15s;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 80%;
	width: 80%;
	box-sizing: border-box;
	margin: auto;
	padding: 0.125rem 0 0 0;
	text-decoration: none;
	text-transform: none;
	letter-spacing: normal;
	line-height: 1;
	vertical-align: middle;
}

#megazoid .calculator .btn img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#megazoid .calculator #btn-dot img {
	object-position: bottom center;
}

#megazoid .calculator .btn-base {
	background: linear-gradient(to right, #D3D0CB, #959DA0);
	border-radius: 0.5rem;
	padding: 0.125rem;
	display: flex;
	align-items: center;
	justify-content: center;
	height: auto;
	width: auto;
	overflow: hidden;
}

#megazoid .calculator .btn-base.wide {
	grid-row: 4 !important;
	grid-column: 1 / span 2 !important;
	width: auto !important;
	height: auto !important;
}

#megazoid .calculator .btn.clear {
	background: linear-gradient(135deg, #D43D2D, #FC676B);
	color: #fff;
	box-shadow: clamp(-0.375rem, -0.75vw, -0.5rem) clamp(-0.375rem, -0.75vw, -0.5rem) clamp(0.5rem, 1vw, 0.75rem) rgba(255, 255, 255, 0.95), clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.5rem, 1vw, 0.75rem) clamp(0.03125rem, 0.0625vw, 0.0625rem) rgba(0, 0, 0, 0.2);
	border-color: #D84D4A;
}

#megazoid .calculator .btn.percent {
	background: linear-gradient(135deg, #E8AA2B, #F9CD62);
	color: #fff;
	box-shadow: clamp(-0.375rem, -0.75vw, -0.5rem) clamp(-0.375rem, -0.75vw, -0.5rem) clamp(0.5rem, 1vw, 0.75rem) rgba(255, 255, 255, 0.95), clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.5rem, 1vw, 0.75rem) clamp(0.03125rem, 0.0625vw, 0.0625rem) rgba(0, 0, 0, 0.2);
	border-color: #F9CD62;
}

#megazoid .calculator .btn.operator {
	background: linear-gradient(135deg, #0a0a13, #111029);
	color: #fff;
	box-shadow: clamp(-0.375rem, -0.75vw, -0.5rem) clamp(-0.375rem, -0.75vw, -0.5rem) clamp(0.5rem, 1vw, 0.75rem) rgba(255, 255, 255, 0.95), clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.375rem, 0.75vw, 0.5rem) clamp(0.5rem, 1vw, 0.75rem) clamp(0.03125rem, 0.0625vw, 0.0625rem) rgba(0, 0, 0, 0.2);
}

/* Remove default button outline */
#megazoid .calculator .btn:focus {
	outline: none;
}

/* Press effect */
#megazoid .calculator .btn-base:active {
	transform: translate(2px, 2px);
}

#megazoid .calculator #btn-dot {
	font-size: clamp(1.875rem, 4.5vw, 3rem);
}


/* ———————————————————————————————— */
/* spec-italics */
/* ———————————————————————————————— */
#megazoid .spec-italics {
	background: var(--purple);
	padding: 6em 1rem 6.5em clamp(2rem, 4vw, 5rem);
	text-align: left;
	overflow: hidden;
}

#megazoid .spec-italics .layered-text {
	position: relative;
	font-family: var(--font-mega-right-italic);
	color: var(--lt-blue);
	font-size: clamp(2rem, 8vw, 12rem);
	line-height: 1.1;
	cursor: default;
}

#megazoid .spec-italics .layered-text:hover .bot-layer {
	font-variation-settings: "DPTH" -150;
}

#megazoid .spec-italics .layered-text span {
	display: block;
	width: 40em;
}

#megazoid .spec-italics .layered-text .bot-layer {
	position: absolute;
	z-index: 1;
	line-height: 1.1;
	color: var(--navy);
	opacity: 0.5;
	font-family: var(--font-mega-right-italic);
	font-variation-settings: "DPTH" 150;
	transition: font-variation-settings 0.3s ease;
}

#megazoid .spec-italics .layered-text .top-layer {
	position: relative;
	z-index: 2;
	font-family: var(--font-mega-right-italic);
	font-variation-settings: "DPTH" 0;
}

@media screen and (max-width: 768px) {
	#megazoid .spec-italics {
		padding: 3em 2rem 3em clamp(2rem, 4vw, 5rem);
	}
	
	#megazoid .spec-italics .layered-text {
		font-size: clamp(2.8rem, 12vw, 9rem);
	}

	#megazoid .spec-italics .layered-text span {
		display: block;
		width: 30em;
	}
}

/* ———————————————————————————————— */
/* spec-roadway */
/* ———————————————————————————————— */
#megazoid .spec-roadway {
	background: var(--yellow);
	padding: 3em 0.5rem 3em;
	text-align: center;
}

#megazoid .spec-roadway img {
	max-width: 100%;
	height: auto;
}

@media screen and (max-width: 768px) {
	#megazoid .spec-roadway {
		padding: 2em 0 2em;
	}
}


/* ———————————————————————————————— */
/* spec-lowercase */
/* ———————————————————————————————— */
#megazoid .spec-lowercase {
	background: var(--blue);
	font-family: var(--font-mega-right);
	color: var(--text-fff);
	font-size: clamp(2.5rem, 12vw, 15rem);
	line-height: 1;
	text-align: center;
	padding: 0.7em 1rem 0.6em;
	font-variation-settings: "DPTH" 0;
}

#megazoid .spec-lowercase-content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}


/* ———————————————————————————————— */
/* opentype */
/* ———————————————————————————————— */
#megazoid .opentype {
	background: var(--cream);
	padding: 0;
	text-align: center;
}

#megazoid .opentype-container {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(30rem, 1fr));
	width: 100%;
	gap: 1px;
	background: var(--text-ccc);
}

#megazoid .opentype-block {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	padding: 3rem 2rem;
	background: var(--cream);
	box-sizing: border-box;
	transition: background 0.3s ease;
}

#megazoid .opentype-block .style-eg {
	font-family: var(--font-mega-right);
	font-size: clamp(3rem, 8vw, 6rem);
	line-height: 1;
	margin-bottom: 1.5rem;
	text-align: left;
	font-feature-settings: normal;
	transition: font-feature-settings 0.3s ease;
	font-variation-settings: "DPTH" 0;
}

#megazoid .opentype-block .style-set {
	font-family: var(--font-input-mono);
	font-size: clamp(0.875rem, 1.5vw, 1.125rem);
	color: var(--text-222);
	line-height: 1.4;
	font-weight: normal;
	text-align: left;
}

#megazoid .opentype-block:hover,
#megazoid .opentype-block.active {
	background: white;
}

/* Stylistic Set 1 */
#megazoid .opentype-block:nth-child(1):hover .style-eg {
	font-feature-settings: "ss01" 1;
}

/* Stylistic Set 2 */
#megazoid .opentype-block:nth-child(2):hover .style-eg {
	font-feature-settings: "ss02" 1;
}

/* Stylistic Set 3 */
#megazoid .opentype-block:nth-child(3):hover .style-eg {
	font-feature-settings: "ss03" 1;
}

/* Stylistic Set 4 */
#megazoid .opentype-block:nth-child(4):hover .style-eg {
	font-feature-settings: "ss04" 1;
}

/* Stylistic Set 5 */
#megazoid .opentype-block:nth-child(5):hover .style-eg {
	font-feature-settings: "ss05" 1;
}

/* Stylistic Set 6 */
#megazoid .opentype-block:nth-child(6):hover .style-eg {
	font-feature-settings: "ss06" 1;
}

/* Stylistic Set 7 */
#megazoid .opentype-block:nth-child(7):hover .style-eg {
	font-feature-settings: "ss07" 1;
}

/* Stylistic Set 8 */
#megazoid .opentype-block:nth-child(8):hover .style-eg {
	font-feature-settings: "ss08" 1;
}

/* Stylistic Set 9 */
#megazoid .opentype-block:nth-child(9):hover .style-eg {
	font-feature-settings: "ss09" 1;
}

/* Stylistic Set 10 */
#megazoid .opentype-block:nth-child(10):hover .style-eg {
	font-feature-settings: "ss10" 1;
}

/* Stylistic Set 11 */
#megazoid .opentype-block:nth-child(11):hover .style-eg {
	font-feature-settings: "ss11" 1;
}

/* Stylistic Set 12 */
#megazoid .opentype-block:nth-child(12):hover .style-eg {
	font-feature-settings: "ss12" 1;
}

/* Touch/JS: activate same effects via an .active class */
#megazoid .opentype-block:nth-child(1).active .style-eg { font-feature-settings: "ss01" 1; }
#megazoid .opentype-block:nth-child(2).active .style-eg { font-feature-settings: "ss02" 1; }
#megazoid .opentype-block:nth-child(3).active .style-eg { font-feature-settings: "ss03" 1; }
#megazoid .opentype-block:nth-child(4).active .style-eg { font-feature-settings: "ss04" 1; }
#megazoid .opentype-block:nth-child(5).active .style-eg { font-feature-settings: "ss05" 1; }
#megazoid .opentype-block:nth-child(6).active .style-eg { font-feature-settings: "ss06" 1; }
#megazoid .opentype-block:nth-child(7).active .style-eg { font-feature-settings: "ss07" 1; }
#megazoid .opentype-block:nth-child(8).active .style-eg { font-feature-settings: "ss08" 1; }
#megazoid .opentype-block:nth-child(9).active .style-eg { font-feature-settings: "ss09" 1; }
#megazoid .opentype-block:nth-child(10).active .style-eg { font-feature-settings: "ss10" 1; }
#megazoid .opentype-block:nth-child(11).active .style-eg { font-feature-settings: "ss11" 1; }
#megazoid .opentype-block:nth-child(12).active .style-eg { font-feature-settings: "ss12" 1; }

@media screen and (max-width: 768px) {
	#megazoid .opentype-block {
		width: 100%;
	}
	
	#megazoid .opentype-block .style-eg {
		font-size: clamp(4rem, 12vw, 8rem);
	}
}

/* ———————————————————————————————— */
/* spec-regular-paragraph-2 */
/* ———————————————————————————————— */
#megazoid .spec-regular-paragraph-2 {
	background: var(--purple);
	padding: 0;
	text-align: left;
	overflow: hidden;
	text-transform: uppercase;
}

#megazoid .spec-regular-paragraph-2 .layered-text {
	position: relative;
	font-family: var(--font-mega-right);
	font-size: clamp(2rem, 8vw, 12rem);
	line-height: 1.3;
	margin: 0em 0 -0.4em -0.1em;
	cursor: default;
}

#megazoid .spec-regular-paragraph-2 .layered-text span {
	display: block;
	width: 35em;
}

#megazoid .spec-regular-paragraph-2 .layered-text .bot-layer {
	position: absolute;
	font-family: var(--font-mega-right-shade);
	color: var(--navy);
	opacity: 0.5;
	font-variation-settings: "DPTH" -500;
	transition: all 0.3s ease;
}

#megazoid .spec-regular-paragraph-2 .layered-text .top-layer {
	position: relative;
	z-index: 2;
	font-family: var(--font-mega-right);
	color: var(--pink);
	font-variation-settings: "DPTH" 0;
	transition: all 0.3s ease;
}

#megazoid .spec-regular-paragraph-2 .layered-text:hover .top-layer {
	font-variation-settings: "DPTH" -500;
}

@media screen and (max-width: 768px) {
	#megazoid .spec-regular-paragraph-2 {
		padding: 0;
	}
	
	#megazoid .spec-regular-paragraph-2 .layered-text {
		font-size: clamp(2.8rem, 12vw, 9rem);
		margin: -0.5em 0 -0.4em -0.1em;
	}

	#megazoid .spec-regular-paragraph-2 .layered-text span {
		max-width: 32em;
	}
}

/* ———————————————————————————————— */
/* spec-thankyou */
/* ———————————————————————————————— */
#megazoid .spec-thankyou {
	background: #eee;
	padding: clamp(3rem, 8vw, 10rem) 1rem;
	text-align: center;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

#megazoid .spec-thankyou span {
	display: block;
	font-family: var(--font-mega-right);
	font-size: clamp(3.3rem, 12vw, 16rem);
	line-height: 0.9;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: transparent;
	-webkit-text-stroke: clamp(0.125rem, 0.5vw, 0.25rem) var(--pink);
	text-stroke: clamp(0.125rem, 0.5vw, 0.25rem) var(--pink);
	font-variation-settings: "DPTH" 0;
}

#megazoid .spec-thankyou span:first-child {
}

#megazoid .spec-thankyou span:last-child {
	color: var(--pink);
	-webkit-text-stroke: none;
	text-stroke: none;
}



/* ———————————————————————————————— */
/* spec-breakout */
/* ———————————————————————————————— */

#megazoid .spec-breakout {
	background-color: var(--navy);
	padding: clamp(1rem, 2vw, 3rem) 2rem clamp(8rem, 12vw, 16rem);
	text-align: center;
	min-height: 10vh;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	transition: min-height 0.3s ease-out;
	width: 100%;
	box-sizing: border-box;
}

#megazoid .spec-breakout-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 2.3rem;
	min-height: 50vh;
	width: 100%;
	text-align: center;
}

@media screen and (min-width: 500px) {
	#megazoid .spec-breakout-text {
		gap: 3rem;
	}
}

@media screen and (min-width: 600px) {
	#megazoid .spec-breakout-text {
		gap: 3.5rem;
	}
}

@media screen and (min-width: 768px) {
	#megazoid .spec-breakout-text {
		gap: 4.5rem;
		min-height: 100vh;
	}
}

@media screen and (min-width: 1000px) {
	#megazoid .spec-breakout-text {
		gap: 6rem;
	}
}

@media screen and (min-width: 1200px) {
	#megazoid .spec-breakout-text {
		gap: clamp(6em, 9vw, 13em);
	}
}

#megazoid .spec-breakout-text .super-word,
#megazoid .spec-breakout-text .breakout-word {
	position: relative;
	width: 100%;
}

#megazoid .spec-breakout-text span {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%);
	font-family: var(--font-mega-right);
	font-variation-settings: "DPTH" 0;
	text-transform: uppercase;
	line-height: 0.9;
	white-space: nowrap;
	font-feature-settings: "ss19" 1;
}

#megazoid .spec-breakout-text .super-word .layer-1,
#megazoid .spec-breakout-text .breakout-word .layer-1 {
	font-feature-settings: normal;
}

/* SUPER moving up */
#megazoid .spec-breakout-text .super-word .layer-1 {
	color: var(--yellow);
	font-size: clamp(3rem, 14vw, 30rem);
	position: absolute;
	z-index: 6;
	transform: translateX(-50%);
}

#megazoid .spec-breakout-text .super-word .layer-2 {
	color: var(--orange);
	font-size: clamp(2.5rem, 13.4vw, 27rem);
	z-index: 4;
	transform: translateX(-50%) translateY(calc(-50% - 7.5vw));
}

#megazoid .spec-breakout-text .super-word .layer-3 {
	color: var(--red);
	font-size: clamp(2.2rem, 12.9vw, 24rem);
	z-index: 3;
	transform: translateX(-50%) translateY(calc(-50% - 5vw));
}

#megazoid .spec-breakout-text .super-word .layer-4 {
	color: var(--lt-blue);
	font-size: clamp(1.9rem, 12.45vw, 21rem);
	z-index: 2;
	transform: translateX(-50%) translateY(calc(-50% - 2.5vw));
}

#megazoid .spec-breakout-text .super-word .layer-5 {
	color: var(--blue);
	font-size: clamp(1.6rem, 12vw, 18rem);
	z-index: 1;
	transform: translateX(-50%) translateY(calc(-50% - 0vw));
}

/* BREAKOUT moving down */
#megazoid .spec-breakout-text .breakout-word .layer-1 {
	color: var(--yellow);
	font-size: clamp(3rem, 14vw, 30rem);
	position: absolute;
	z-index: 5;
	transform: translateX(-50%);
}

#megazoid .spec-breakout-text .breakout-word .layer-2 {
	color: var(--orange);
	font-size: clamp(2.5rem, 13.4vw, 27rem);
	z-index: 4;
	transform: translateX(-50%) translateY(calc(-50% + 7.5vw));
}

#megazoid .spec-breakout-text .breakout-word .layer-3 {
	color: var(--red);
	font-size: clamp(2.2rem, 12.9vw, 24rem);
	z-index: 3;
	transform: translateX(-50%) translateY(calc(-50% + 5vw));
}

#megazoid .spec-breakout-text .breakout-word .layer-4 {
	color: var(--lt-blue);
	font-size: clamp(1.9rem, 12.45vw, 21rem);
	z-index: 2;
	transform: translateX(-50%) translateY(calc(-50% + 2.5vw));
}

#megazoid .spec-breakout-text .breakout-word .layer-5 {
	color: var(--blue);
	font-size: clamp(1.6rem, 12vw, 18rem);
	z-index: 1;
	transform: translateX(-50%) translateY(calc(-50% + 0vw));
}


/* ———————————————————————————————— */
/* characters */
/* ———————————————————————————————— */
#megazoid .characters {
	background: var(--cream);
	padding: 1px;
	text-align: center;
	position: relative;
}

#megazoid .characters-container {
	width: 100%;
}

#megazoid .characters-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(clamp(60px, 8vw, 120px), 1fr));
	gap: 0;
	justify-content: center;
	width: 100%;
}

#megazoid .char-square {
	display: flex;
	aspect-ratio: 1;
	align-items: center;
	justify-content: center;
	font-family: var(--font-mega-regular);
	font-size: clamp(24px, 4vw, 60px);
	color: var(--text-222);
	background: var(--cream);
	transition: all 0.2s ease;
	cursor: pointer;
	border: 1.5px solid var(--pink);
	box-sizing: border-box;
	margin: -1px;
	font-variation-settings: "DPTH" 0;
}

#megazoid .char-square:hover {
	background: var(--text-222);
	color: var(--text-fff);
	opacity: 1;
}

#megazoid .char-square.active {
	background: var(--pink);
	color: var(--text-fff);
	opacity: 1;
}

#megazoid .char-square:hover::after {
	content: attr(data-char);
	position: fixed;
	top: 50vh;
	left: 50vw;
	transform: translate(-50%, -50%);
	font-family: var(--font-mega-regular);
	font-size: 80vh;
	color: var(--pink);
    mix-blend-mode: multiply;
	z-index: 10;
	pointer-events: none;
	line-height: 1;
	overflow: visible;
	white-space: nowrap;
	padding: 0.25em;
	font-variation-settings: "DPTH" 0;
}

/* Disable hover on touch devices */
@media (hover: none) and (pointer: coarse) {
	#megazoid .char-square:hover::after {
		display: none;
	}
}

/* Touch devices: show big preview when active */
@media (hover: none) and (pointer: coarse) {
    #megazoid .char-square.active::after {
        content: attr(data-char);
        position: fixed;
        top: 50vh;
        left: 50vw;
        transform: translate(-50%, -50%);
        font-family: var(--font-mega-regular);
        font-size: 80vw;
        color: var(--pink);
        mix-blend-mode: multiply;
        z-index: 10;
        pointer-events: none;
        line-height: 1;
        overflow: visible;
        white-space: nowrap;
        padding: 0.25em;
        display: block;
        font-variation-settings: "DPTH" 0;
    }
}

@media screen and (max-width: 768px) {
	#megazoid .characters-grid {
		grid-template-columns: repeat(auto-fit, minmax(clamp(60px, 8vw, 100px), 1fr));
	}
	
	#megazoid .char-square {
		font-size: clamp(32px, 4vw, 60px);
	}
	
	#megazoid .char-square:hover::after {
		font-size: 80vw;
	}
}

/* ———————————————————————————————— */
/* credits */
/* ———————————————————————————————— */
#megazoid .credits {
	background: var(--indigo);
	padding: clamp(3rem, 6vw, 6rem) clamp(2rem, 4vw, 5rem);
	text-align: left;
	color: var(--text-fff);
}

#megazoid .credits p {
	font-family: var(--font-mega-right);
	font-size: clamp(1.5rem, 4vw, 4rem);
	line-height: 1.2;
	letter-spacing: 0.01em;
	margin: 0 0 2.5rem 0;
	max-width: 60em;
	z-index: 10;
	font-variation-settings: "DPTH" 0;
}

#megazoid .credits p:last-child {
	margin-bottom: 0;
}

#megazoid .credits a {
	position: relative;
	color: var(--yellow);
	text-decoration: none;
	transition: color 0.3s ease;
}

#megazoid .credits a:hover {
	color: var(--orange);
}

@media screen and (max-width: 768px) {
	#megazoid .credits {
		padding: 2rem 1rem;
	}
	
	#megazoid .credits p {
		font-size: clamp(1.75rem, 5vw, 2.5rem);
		margin: 0 0 2rem 0;
	}

}