:root {
  --display-font: "Satoshi", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --body-font: "Author", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}


:root {
	--bg: #191815;
	--text: #ffffe3;
	--accent: #1dccd2;
	--on-accent: #191815;
	--surface-1: #201f1b;
	--surface-2: #23221e;
	--hairline: #2b2924
}

.theme-psyk {
	--section-bg: linear-gradient(180deg, var(--ink-950), var(--ink-900));
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--orange-600);
	--btn-grad-b: var(--orange-700);
	--btn-on: #111015;
	--ghost-fg: var(--teal-500)
}

.theme-psyk .about-hero-card {
	--card-bg: var(--paper-50);
	--card-fg: var(--fg-on-light)
}

body,
html {
	background: var(--bg);
	color: var(--text)
}

:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 4px;
	border-radius: 12px
}

body.modal-open {
	padding-right: var(--sbw, 0)
}

a {
	color: var(--accent);
	text-decoration: underline;
	text-underline-offset: 3px
}

a:hover {
	text-decoration-thickness: 2px
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-weight: 700;
	border-radius: 16px;
	padding: .75rem 1.1rem
}

.btn-primary {
	background: var(--accent);
	color: var(--on-accent);
	box-shadow: 0 2px 0 rgba(0, 0, 0, .4)
}

.btn-primary:hover {
	filter: brightness(.96)
}

.media-placeholder {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: var(--accent);
	font-weight: 800;
	letter-spacing: .03em;
	border: 1px dashed var(--accent);
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(29, 204, 210, .15), transparent 60%), var(--surface-2);
	z-index: 0
}

.image-container img,
.video-container video {
	z-index: 1;
	position: absolute;
	inset: 0
}

#about,
#contact,
#image-slideshow,
#services {
	padding-block: clamp(2.5rem, 6vw, 5rem)
}

body {
	font-weight: 400;
	font-style: normal;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	overflow-x: hidden
}

body a {
	color: #1dccd2;
	text-decoration: none
}

body a:hover {
	color: #ffffe3
}

#logo {
	position: fixed;
	top: 20px;
	right: 20px;
	z-index: 200;
	height: 125px
}

.video-container {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	background: #191815;
	overflow: hidden
}

.video-container video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover
}

#video-slideshow {
	position: relative;
	width: 100%;
	background: #191815;
	overflow: hidden
}

.slideshow-container {
	position: relative;
	width: 100%
}

.slideshow-video {
	display: none;
	width: 100%;
	position: relative
}

.slideshow-video.active {
	display: block
}

.slideshow-text {
	position: absolute;
	bottom: 2rem;
	left: 4rem;
	z-index: 5;
	background: var(--bg);
	color: var(--text);
	padding: 1rem 2rem;
	border-radius: 12px
}

.slideshow-text h2 {
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 2.5rem;
	margin: 0 0 .5rem
}

.slideshow-text p {
	font-family: Satoshi, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.5rem;
	margin: 0
}

.slideshow-next,
.slideshow-prev {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: #191815;
	color: #ffffe3;
	border: none;
	font-size: 2rem;
	padding: .5rem 1rem;
	cursor: pointer;
	z-index: 10;
	transition: background .3s
}

.slideshow-next:hover,
.slideshow-prev:hover {
	background: rgba(255, 255, 255, .7);
	color: #000
}

.slideshow-prev {
	left: 1rem
}

.slideshow-next {
	right: 1rem
}

.slideshow-dots {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: .5rem;
	z-index: 5
}

.slideshow-dots .dot {
	width: 10px;
	height: 10px;
	background: rgba(255, 255, 255, .5);
	border-radius: 50%;
	cursor: pointer;
	transition: background .3s
}

.slideshow-dots .dot.active {
	background: var(--accent)
}

.slideshow-dots .dot:hover {
	background: #ffffe3
}

#about {
	min-height: 40vh;
	background-image: url(https://psyklabs.io/assets/img2025/PsykLabs_Contact_inv.png);
	background-position: right 10px bottom 30px;
	background-size: 70% auto;
	background-repeat: no-repeat;
	background-color: #191815
}

#about .container {
	position: relative;
	text-align: left;
	padding: 0;
	min-height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-start
}

#about h2 {
	width: 60%;
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3rem;
	margin-bottom: 1rem;
	color: #ffffe3;
	line-height: 1.2
}

#about p {
	width: 60%;
	font-family: neue-haas-grotesk-display, sans-serif;
	font-weight: 400;
	font-style: normal;
	text-align: left;
	font-size: 1.7rem;
	line-height: 1.5;
	margin: 0 0 1rem;
	color: #ffffe3
}

.parallax-container {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	text-align: left;
	background: linear-gradient(to top, #191815, rgba(0, 0, 0, 0));
	padding: 4rem;
	z-index: 2;
	box-sizing: border-box
}

.text-overlay {
	position: relative;
	z-index: 1;
	color: #ffffe3;
	text-align: left;
	width: 70%
}

.text-overlay h2 {
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3rem;
	margin-bottom: 1.5rem
}

.text-overlay p {
	font-family: Satoshi, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.7rem;
	line-height: 1.5;
	margin-bottom: 1rem
}

.text-overlay a {
	color: var(--accent);
	text-decoration: none
}

.text-overlay a:hover {
	color: #ffffe3
}

#assets {
	background-image: url(https://psyklabs.io/assets/images/fortnite-island_bg.jpg);
	background-position: top;
	background-size: cover;
	color: #ffffe3;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	z-index: 1;
	min-height: 70vh
}

.assets-container {
	width: 100%;
	text-align: center;
	margin: 0 auto;
	padding-top: 8rem;
	padding-bottom: 8rem;
	padding-left: 4rem;
	padding-right: 4rem;
	z-index: 2;
	box-sizing: border-box
}

.assets-overlay {
	width: 100%;
	text-align: center;
	font-size: 2rem;
	color: var(--off-white)
}

.assets-overlay h2 {
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3rem
}

.assets-overlay p {
	font-family: Satoshi, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.7rem;
	line-height: 1.5
}

.assets-overlay a {
	color: var(--accent);
	text-decoration: none
}

.assets-overlay a:hover {
	color: #ffffe3
}

footer {
	background-color: #191815;
	color: #ffffe3;
	padding: 6rem;
	text-align: center
}

footer a {
	color: #ffffe3;
	text-decoration: none
}

footer a:hover {
	text-decoration: underline
}

.social-icon {
	width: 40px;
	height: 40px;
	margin: 0 10px
}

footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center
}

footer li {
	margin: 0 10px
}

#bottom-nav {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 100;
	display: flex;
	flex-direction: column
}

.nav-background {
	width: 100%;
	background-color: var(--ink-950);
	height: 100%;
	position: absolute
}

.nav-items {
	border-top: 1px solid #1dccd2;
	display: flex;
	justify-content: flex-end;
	padding: 1rem;
	z-index: 1
}

#bottom-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 2rem
}

#bottom-nav li {
	display: inline-block
}

#bottom-nav a {
	font-family: Satoshi, sans-serif;
	font-weight: 300;
	font-style: normal;
	color: #ffffe3;
	font-size: 1.1rem;
	text-decoration: none;
	transition: color .3s
}

#bottom-nav a:hover {
	color: var(--accent)
}

.sound-toggle {
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 10;
	background: #191815;
	color: #ffffe3;
	border: none;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	font-size: 20px;
	cursor: pointer
}

.sound-toggle:hover {
	background: rgba(255, 255, 255, .7);
	color: #000
}

#mobile-nav {
	display: none;
	position: fixed;
	bottom: 0;
	width: 100%;
	background-color: #191815;
	color: #ffffe3;
	z-index: 1000;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem;
	box-sizing: border-box;
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-size: 1.2rem
}

#mobile-nav .nav-left {
	text-align: left;
	flex: 1
}

#mobile-nav .nav-right {
	text-align: right;
	flex: 1;
	display: flex;
	justify-content: flex-end
}

#menu-toggle {
	background: 0 0;
	border: none;
	color: var(--off-white);
	font-size: 1.2rem;
	cursor: pointer;
	font-weight: 700;
	padding: 0;
	margin: 0
}

#mobile-menu-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--ink-950);
	color: var(--off-white);
	z-index: 2000;
	justify-content: center;
	align-items: center
}

#mobile-menu-overlay.active {
	display: flex
}

#mobile-menu-overlay .menu-content {
	text-align: center
}

#mobile-menu-overlay a {
	display: block;
	font-family: Satoshi, sans-serif;
	font-weight: 300;
	font-size: 2rem;
	color: var(--off-white);
	text-decoration: none;
	margin: 1rem 0;
	transition: color .3s ease
}

#mobile-menu-overlay a:hover {
	color: var(--accent)
}

#menu-close {
	margin-top: 2rem;
	background: 0 0;
	border: none;
	color: var(--off-white);
	font-size: 1.2rem;
	cursor: pointer;
	font-weight: 700
}

.scroll-down {
	position: absolute;
	top: 1rem;
	left: 1rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 30px;
	height: 50px;
	border: 2px solid var(--accent);
	border-radius: 25px;
	opacity: .7;
	animation: fadeIn 2s ease-in-out infinite;
	z-index: 6;
	pointer-events: none
}

@keyframes fadeIn {

	0%,
	100% {
		opacity: .7
	}

	50% {
		opacity: 1
	}
}

@keyframes scrollDownDot {
	0% {
		transform: translateY(0)
	}

	50% {
		transform: translateY(10px)
	}

	100% {
		transform: translateY(0)
	}
}

.play-btn {
	display: block;
	width: 90%;
	margin: 0 auto 1.5rem;
	padding: 1rem 0;
	text-align: center;
	text-decoration: none;
	font-weight: 800;
	border-radius: .6rem;
	color: var(--text);
	border: 1px solid var(--accent)
}

.play-btn:hover {
	background: var(--accent);
	color: #ffffe3;
	text-decoration: none
}

.slideshow-container {
	overflow: hidden
}

.slides {
	display: flex;
	transition: transform .5s ease-in-out
}

.slideshow-video {
	flex: 0 0 100%;
	width: 100%;
	display: block
}

.slideshow-video.active {
	display: block
}

.slideshow-container {
	overflow: hidden
}

.slides {
	display: flex;
	transition: transform .5s ease-in-out
}

.slideshow-video {
	flex: 0 0 100%;
	width: 100%;
	display: block
}

.slideshow-video.active {
	display: block
}

.slideshow-sound-toggle {
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 10;
	background: #191815;
	color: #ffffe3;
	border: none;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	font-size: 20px;
	cursor: pointer;
	transition: background .3s, color .3s
}

.slideshow-sound-toggle:hover {
	background: rgba(255, 255, 255, .7);
	color: #000
}

#mobile-nav {
	display: none;
	position: fixed;
	bottom: 0;
	width: 100%;
	background-color: var(--ink-950);
	color: #fff;
	z-index: 1000;
	justify-content: space-between;
	align-items: center;
	padding: 1rem;
	box-sizing: border-box;
	font-family: "Neue Haas Grotesk", Helvetica, Arial, sans-serif;
	font-weight: 700;
	font-size: 1.2rem
}

#bottom-nav {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 100;

	display: flex;
	flex-direction: column
}

#image-slideshow {
	position: relative;
	width: 100%;
	background: #000;
	overflow: hidden
}

.image-container {
	position: relative;
	weight: 100%;
	padding-top: 56.25%;
	background: #000;
	overflow: hidden
}

.image-container img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover
}

.slideshow-slide {
	flex: 0 0 100%;
	width: 100%;
	display: block
}

.slideshow-container {
	overflow: hidden
}

.slides {
	display: flex;
	transition: transform .5s ease-in-out
}

.slideshow-video {
	flex: 0 0 100%;
	width: 100%;
	display: block
}

.slideshow-video.active {
	display: block
}

#image-slideshow {
	position: relative;
	width: 100%;
	background: #191815;
	overflow: hidden
}

.image-container {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	background: #000;
	overflow: hidden
}

.image-container img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover
}

.slideshow-slide {
	background: var(--ink-950);
	flex: 0 0 100%;
	width: 100%;
	display: block;
	position: relative
}

.slideshow-text {
	position: absolute;
	bottom: 2rem;
	left: 4rem;
	z-index: 5;
	background: var(--bg);
	color: var(--text);
	padding: 1rem 2rem;
	border-radius: 12px
}

#services {
	min-height: 40vh;
	background-color: #191815;
	background-image: none;
	background-position: right 10px bottom 30px;
	background-size: 70% auto;
	background-repeat: no-repeat
}

#services .container {
	position: relative;
	text-align: left;
	padding: 0;
	min-height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-start
}

#services h2 {
	width: 60%;
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3rem;
	margin-bottom: 1rem;
	color: var(--off-white);
	line-height: 1.2
}

#services p {
	width: 60%;
	font-family: neue-haas-grotesk-display, sans-serif;
	font-weight: 400;
	font-style: normal;
	text-align: left;
	font-size: 1.7rem;
	line-height: 1.5;
	margin: 0 0 1rem;
	color: var(--off-white)
}

#image-slideshow .slideshow-text,
#video-slideshow .slideshow-text {
	display: none !important
}

.info-section .card {
	background: var(--surface-1);
	border: 1px solid var(--hairline);
	border-radius: 20px;
	padding: 1.25rem
}

.info-section .measure {
	max-width: 72ch
}

.info-section ul {
	line-height: 1.65
}

.content-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 2rem
}

.measure {
	max-width: 72ch
}

.feature-card {
	background: var(--surface-1);
	border: 1px solid var(--hairline);
	border-radius: 20px;
	padding: 2rem;
	box-shadow: 0 1px 0 rgba(0, 0, 0, .35)
}

.pill {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	border-radius: 999px;
	border: 1px solid var(--hairline)
}

.eyebrow {
	font-size: .85rem;
	letter-spacing: .18em;
	text-transform: uppercase;
	opacity: .85
}

.info-section {
	padding-block: clamp(2.5rem, 2vw, 5.5rem);
	padding-bottom: 0;
}

#image-slideshow {
	padding-block: 0 !important
}

#artwork-info h2,
#worlds-info h2 {
	font-family: var(--display-font);
	font-weight: 700;
	letter-spacing: .5px;
	font-style: normal;
	font-size: 3rem;
	margin-bottom: 1rem;
	line-height: 1
}

#artwork-info li,
#artwork-info p,
#worlds-info li,
#worlds-info p {
	font-family: var(--body-font);
	font-weight: 400;
	font-style: normal;
	font-size: 1.7rem;
	line-height: 1.5
}

#video-slideshow {
	padding-block: 0 !important
}

#about {
	background-image: none !important;
	background-color: var(--bg)
}

.display-title {
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	line-height: 1.1;
	font-size: clamp(2.5rem, 6vw, 5rem);
	margin: .25rem 0 1rem
}

#about,
#services {
	background-image: none !important;
	background-color: var(--ink-950);
	padding-block: clamp(2.5rem, 6vw, 5.5rem)
}

#about h2,
#about p,
#services h2,
#services p {
	width: auto !important;
	max-width: none
}

#about .feature-card .measure,
#services .feature-card .measure {
	max-width: 72ch
}

#about .feature-card p,
#artwork-info li,
#artwork-info p,
#services .feature-card p,
#worlds-info li,
#worlds-info p {
	font-size: clamp(1.05rem, .5vw + .95rem, 1.35rem);
	line-height: 1.6
}

:root {
	--display-font: "Satoshi", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--body-font: "Author", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--ink-950: #050505;
	--ink-900: #151317;
	--sand-300: #E6C9A0;
	--paper-50: #FFF3DE;
	--orange-700: #E94A19;
	--orange-600: #FF5A21;
	--teal-500: #14D6D6;
	--fg-on-dark: #FFF7F0;
	--fg-on-light: #0E0B0D;
	--nf-shadow: 0 18px 60px rgba(0, 0, 0, .35);
	--off-white: #F4F6F8
}

body,
html {
	font-family: var(--body-font)
}

h1,
h2,
h3 {
	font-family: var(--display-font);
	font-weight: 700;
	letter-spacing: .5px;
	line-height: .95
}

a:not(.btn) {
	text-decoration: underline;
	text-underline-offset: 3px
}

a:not(.btn):hover {
	text-decoration-thickness: 2px
}

.section-theme {
	position: relative;
	background: var(--section-bg, var(--ink-950));
	color: var(--section-fg, var(--fg-on-dark))
}

.section-theme-white {
	position: relative;
	background: var(--section-bg, var(--ink-950));
	color: var(--ink-950, var(--fg-on-dark))
}

.section-theme .btn.btn-primary {
	background: linear-gradient(180deg, var(--btn-grad-a, var(--orange-600)), var(--btn-grad-b, var(--orange-700)));
	color: var(--btn-on, #111015);
	border: 0
}

.theme-psyk-orange {
	--section-bg: linear-gradient(180deg, #FF6A2A, #E94A19);
	--section-fg: var(--fg-on-light);
	--btn-grad-a: var(--ink-950);
	--btn-grad-b: #242128;
	--btn-on: #fff;
	--ghost-fg: #111015
}

.theme-violet {
	--section-bg: #653BBF;
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--sand-300);
	--btn-grad-b: var(--sand-300);
	--btn-on: #0E0B0D;
	--ghost-fg: #FFF7F0
}

.theme-psyk-orange-soft {
	--section-bg: linear-gradient(180deg, #C86C4A, #A44A2E);
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--sand-300);
	--btn-grad-b: var(--sand-300);
	--btn-on: #0E0B0D;
	--ghost-fg: #FFF7F0
}

.theme-violet-soft {
	--section-bg: linear-gradient(180deg, #8A6FBF, #5E4FA8);
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--sand-300);
	--btn-grad-b: var(--sand-300);
	--btn-on: #0E0B0D;
	--ghost-fg: #FFF7F0
}

.theme-ink-soft {
	--section-bg: var(--ink-950);
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--orange-600);
	--btn-grad-b: var(--orange-700);
	--btn-on: #111015;
	--ghost-fg: var(--teal-500)
}

.theme-off-white {
	--section-bg: var(--off-white);
	--section-fg: var(--fg-on-dark);
	--btn-grad-a: var(--orange-600);
	--btn-grad-b: var(--orange-700);
	--btn-on: #111015;
	--ghost-fg: var(--teal-500)
}

.about-hero-card {
	--card-bg: #ffffe3;
	--card-fg: #111015;
	--card-border: rgba(0, 0, 0, .08);
	width: 100%;
	background: var(--off-white);
	color: var(--card-fg);
	border-radius: var(--card-radius);
	border: 1px solid var(--off-white);
	overflow: hidden
}

.about-media {
	margin: 0;
	background: var(--off-white);
	display: grid;
	place-items: center
}

.about-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 4/3
}

.about-copy {
	padding: clamp(1rem, 3vw, 2rem);
	display: grid;
	align-content: center;
	gap: .9rem
}

.about-copy h2 {
	margin: 0
}

.about-copy .lead {
	font-weight: 600
}

.about-actions {
	display: flex;
	gap: .75rem;
	margin-top: .25rem
}

.about-copy .eyebrow.pill {
	padding: .4rem .6rem;
	background: var(--off-white);
	color: #111015;
	border-color: rgba(0, 0, 0, .12)
}

.theme-ink-soft #worlds-info .about-hero-card,
.theme-psyk #worlds-info .about-hero-card {
	--card-bg: var(--paper-50);
	--card-fg: var(--fg-on-light);
	--card-border: rgba(0, 0, 0, .10)
}

#worlds-info .about-actions .btn {
	text-decoration: none;
	border-radius: 14px;
	box-shadow: none;
	outline: 0
}

#worlds-info .about-actions .btn:hover {
	filter: brightness(1.03);
	transform: translateY(-1px)
}

#worlds-info .about-actions .btn:focus,
#worlds-info .about-actions .btn:focus-visible {
	outline: 0;
	box-shadow: none
}

#worlds-feed .wf-card {
	--card-bg: var(--ink-950);
	--card-fg: var(--off-white);
	--card-bd: rgba(255, 255, 255, .12);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(320px, 48%);
	gap: 1rem;
	padding: 1rem;
	background: var(--card-bg);
	color: var(--card-fg);
	border: 1px solid var(--card-bd);
	border-radius: 20px
}

#worlds-feed .wf-copy {
	padding: clamp(1rem, 2.5vw, 1.5rem);
	display: grid;
	align-content: start;
	gap: .5rem
}

#worlds-feed .wf-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
	font-size: .78rem;
	padding: .4rem .6rem;
	border-radius: 999px;
	margin-bottom: .75rem;
	background: var(--off-white);
	color: #111015;
	border-color: rgba(0, 0, 0, .12)
}

#worlds-feed .wf-media {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	background: #111
}

#worlds-feed .wf-media img,
#worlds-feed .wf-media video {
	width: 100%;
	height: 100%;
	display: block;
	aspect-ratio: 16/9;
	object-fit: cover
}

#worlds-feed .wf-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-top: 1rem
}

#worlds-feed .wf-feature {
	position: relative;
	background: var(--off-white);
	border: 1px solid var(--off-white);
	border-radius: 16px;
	padding: 2.2rem 1rem 1rem;
	transition: transform .18s ease, box-shadow .18s ease
}

#worlds-feed .wf-feature:hover {
	transform: translateY(-3px) rotate(-.25deg);
	box-shadow: 0 14px 28px rgba(0, 0, 0, .25)
}

#worlds-feed .wf-feature h3 {
	font-family: var(--body-font);
	font-weight: 700;
	margin: .15rem 0 .45rem;
	font-size: 1.08rem;
	color: var(--section-fg, #fff7f0)
}

#worlds-feed .wf-feature p {
	margin: 0;
	opacity: .9;
	font-family: var(--body-font)
}

#worlds-feed .wf-feature::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 6px;
	border-radius: 0 0 16px 16px;
	background: var(--flair, #ffd500);
	opacity: .95
}

#worlds-feed .wf-feature[data-flair=teal] {
	--flair: #1dccd2
}

#worlds-feed .wf-feature[data-flair=violet] {
	--flair: #A885F2
}

#worlds-feed .wf-feature[data-flair=orange] {
	--flair: var(--orange-600, #FF5A21)
}

:root {
  --h2-size: clamp(1.9rem, 4.8vw, 3rem);
  --h2-lh: .93;
  --h3-size: clamp(1.10rem, 1.4vw, 1.45rem);

  /* Bigger body + lead */
  --lead-size: clamp(1.15rem, 1.10vw + 0.95rem, 1.45rem);
  --body-size: clamp(1.10rem, 0.95vw + 0.85rem, 1.30rem);

  --eyebrow-size: .78rem;
}



#artwork-info h2,
#assets-modelling h2,
#lab-feed h2,
#services h2,
#trailers h2,
#worlds-feed h2,
#worlds-info .about-copy h2 {
	font-family: var(--display-font);
	font-weight: 700;
	letter-spacing: .8px;
	line-height: var(--h2-lh);
	font-size: var(--h2-size);
	margin: .25rem 0 .35rem
}

#artwork-info .lead,
#assets-modelling .lead,
#lab-feed .lead,
#services .lead,
#services p.measure,
#trailers .lead,
#worlds-feed .lead,
#worlds-info .about-copy p {
	font-family: var(--body-font);
	font-size: var(--lead-size);
	line-height: 1.5;
	opacity: .95
}

.copy-stack>p {
	margin: 0 0 .75rem
}

.copy-stack>p:last-child {
	margin-bottom: 0
}

#worlds-feed .wf-feature h3 {
	font-family: var(--body-font);
	font-weight: 700;
	font-size: var(--h3-size);
	line-height: 1.25;
	margin: .15rem 0 .45rem
}

#worlds-feed .wf-feature p {
	font-family: var(--body-font);
	font-size: var(--body-size);
	line-height: 1.5
}

#artwork-info .eyebrow.pill,
#assets-modelling .eyebrow.pill,
#lab-feed .eyebrow.pill,
#services .eyebrow.pill,
#trailers .eyebrow.pill,
#worlds-feed .eyebrow.pill,
#worlds-info .eyebrow.pill {
	font-family: var(--body-font);
	font-weight: 700;
	font-size: var(--eyebrow-size);
	letter-spacing: .06em
}

#worlds-info {
	position: relative
}

#assets {
	position: relative
}

#assets {
	position: relative
}

#video-slideshow {
	position: relative
}

#video-slideshow {
	position: relative;
	z-index: 0
}

#assets .assets-overlay h2 {
	font-family: var(--display-font);
	font-weight: 700;
	letter-spacing: .5px;
	line-height: 1
}

#assets .assets-overlay p {
	font-family: var(--body-font);
	text-align: center;
	margin-inline: auto
}

#contact {
	padding: 5rem 0;
	background-image: url(assets/images/Eqlipse_Psyk_labs.jpg);
	background-position: center;
	background-size: auto;
	background-repeat: no-repeat;
	color: #ffffe3;
	position: relative;
	z-index: 1
}

#contact .container {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
	background-color: rgba(0, 0, 0, .5);
	padding: 2rem;
	border-radius: 10px;
	z-index: 2
}

#contact h2 {
	font-family: Satoshi, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3rem;
	margin-bottom: 2rem
}

#contact p {
	font-family: Satoshi, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1.7rem;
	line-height: 1.5
}

#contact form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem
}

#contact input,
#contact textarea {
	font-family: Satoshi, sans-serif;
	padding: 1rem;
	font-size: 1rem;
	border: 1px solid #ccc;
	border-radius: 5px;
	width: 100%;
	box-sizing: border-box;
	resize: vertical
}

#contact button {
	padding: 1rem 2rem;
	font-size: 1.2rem;
	border: none;
	cursor: pointer;
	border-radius: 12px;
	transition: filter .2s ease;
	background: var(--accent);
	color: var(--on-accent);
	box-shadow: 0 2px 0 rgba(0, 0, 0, .4)
}

#contact button:hover {
	filter: brightness(.96)
}

#contact {
	padding: 5rem 0;
	background-image: url(assets/images/Eqlipse_Psyk_labs.jpg);
	background-attachment: auto;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	color: #ffffe3;
	position: relative;
	z-index: 1;
	background-color: var(--bg)
}

#contact {
	background: var(--ink-950);
	color: var(--fg-on-dark);
	background-image: none;
	padding-block: clamp(2.5rem, 6vw, 5.5rem)
}

#contact .contact-card {
	--card-fg: var(--fg-on-dark);
	--card-bd: var(--hairline);
	--card-pad: clamp(1rem, 2.5vw, 1.5rem);
	--card-radius: 28px;
	--visual-h: clamp(120px, 18vw, 180px);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(340px, 48%);
	gap: 1.25rem;
	padding: var(--card-pad);
	position: relative;
	background: var(--ink-950);
	color: var(--card-fg);
	border: 1px solid var(--card-bd);
	border-radius: var(--card-radius)
}

#contact .contact-copy {
	display: grid;
	align-content: start;
	gap: .6rem;
	padding: var(--card-pad);
	padding-bottom: calc(var(--visual-h) + var(--card-pad))
}

#contact .contact-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .18em;
	font-weight: 700;
	font-size: .8rem;
	padding: .4rem .75rem;
	border-radius: 999px;
	background: var(--hairline);
	border: 1px solid var(--hairline);
	color: var(--fg-on-dark);
	opacity: .85
}

#contact h2 {
	font-family: var(--display-font);
	color: var(--text);
	margin: 0
}

#contact .measure {
	max-width: 72ch
}

#contact .contact-form {
	display: grid;
	align-content: start;
	gap: 1rem;
	padding: var(--card-pad)
}

#contact .contact-form .field {
	display: grid;
	gap: .35rem
}

#contact .contact-form label {
	font: 700 .9rem/1 var(--body-font);
	opacity: .85
}

#contact .contact-form input,
#contact .contact-form textarea {
	font: 400 1rem/1.4 var(--body-font);
	padding: .9rem 1rem;
	width: 100%;
	box-sizing: border-box;
	border-radius: 12px;
	background: var(--hairline);
	border: 1px solid var(--hairline);
	color: var(--fg-on-dark)
}

#contact .contact-form input::placeholder,
#contact .contact-form textarea::placeholder {
	opacity: .7
}

#contact .contact-form input:focus,
#contact .contact-form textarea:focus {
	background: var(--hairline);
	outline: 2px solid var(--accent);
	outline-offset: 2px;
	border-color: transparent
}

#contact .btn.btn-primary {
	align-self: start
}

#contact .contact-visual {
	position: absolute;
	left: var(--card-pad);
	bottom: var(--card-pad);
	margin: 0;
	width: min(46%, 320px);
	height: var(--visual-h);
	background: var(--ink-950);
	border: 1px solid var(--hairline);
	border-radius: 16px;
	overflow: hidden
}

#contact .contact-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block
}

#contact {
	background: var(--ink-950);
	color: var(--fg-on-dark);
	background-image: none;
	padding-block: clamp(2.5rem, 0, 5.5rem)
}

#contact .contact-card {
	--card-fg: var(--fg-on-dark);
	--card-bd: var(--hairline);
	--card-pad: clamp(1rem, 2.5vw, 1.5rem);
	--card-radius: 28px;
	--visual-h: clamp(120px, 18vw, 180px);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(340px, 48%);
	gap: 1.25rem;
	padding: var(--card-pad);
	position: relative;
	background: var(--ink-950);
	color: var(--soft-white);
	border: 1px solid var(--ink-950);
	border-radius: var(--card-radius)
}

#contact .contact-copy {
	display: grid;
	align-content: start;
	gap: .6rem;
	padding: var(--card-pad);
	padding-bottom: clamp(0, calc(var(--visual-h) - var(--card-pad)), 400px)
}

#contact .contact-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .18em;
	font-weight: 700;
	font-size: .8rem;
	padding: .4rem .75rem;
	border-radius: 999px;
	background: var(--hairline);
	border: 1px solid var(--hairline);
	color: var(--fg-on-dark);
	opacity: .85
}

#contact h2 {
	font-family: var(--display-font);
	color: var(--off-white);
	margin: 0
}

#contact .measure {
	max-width: 72ch
}

#contact .contact-form {
	display: grid;
	align-content: start;
	gap: 1rem;
	padding: var(--card-pad)
}

#contact .contact-form .field {
	display: grid;
	gap: .35rem
}

#contact .contact-form label {
	font: 700 .9rem/1 var(--body-font);
	opacity: .85
}

#contact .contact-form input,
#contact .contact-form textarea {
	font: 400 1rem/1.4 var(--body-font);
	padding: .9rem 1rem;
	width: 100%;
	box-sizing: border-box;
	border-radius: 12px;
	background: var(--hairline);
	border: 1px solid var(--hairline);
	color: var(--fg-on-dark)
}

#contact .contact-form input::placeholder,
#contact .contact-form textarea::placeholder {
	opacity: .7
}

#contact .contact-form input:focus,
#contact .contact-form textarea:focus {
	background: var(--hairline);
	outline: 2px solid var(--accent);
	outline-offset: 2px;
	border-color: transparent
}

#contact .btn.btn-primary {
	align-self: start
}

#contact .contact-visual {
	position: absolute;
	left: var(--card-pad);
	bottom: 0;
	margin: 0;
	width: min(46%, 320px);
	height: var(--visual-h);
	background: var(--ink-950);
	border: 1px solid var(--hairline);
	border-radius: 16px;
	overflow: hidden
}

#contact .contact-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block
}

#contact .contact-card {
	--visual-h: clamp(140px, 20vw, 220px)
}

#contact .contact-visual {
	border: 0
}

#contact .contact-visual img {
	object-fit: contain;
	width: 100%;
	height: 100%;
	display: block
}

footer {
	background-color: var(--ink-950);
	color: var(--text);
	padding: 2rem 6rem 4rem;
	text-align: center;
	margin-top: 0
}

footer a {
	color: inherit
}

#about,
#image-slideshow,
#services {
	padding-block: clamp(2.5rem, 6vw, 5rem)
}

#contact {
	padding-top: 2rem;
	padding-bottom: 1rem
}

#image-slideshow {
	position: relative;
	z-index: 0
}

#image-slideshow::after,
#image-slideshow::before {
	transform: scaleX(-1);
	transform-origin: 50% 50%
}

.nf-modal {
	--nf-dialog-bg: var(--surface-1);
	--nf-dialog-fg: var(--fg-on-dark);
	--nf-media-bg: var(--ink-950)
}

.nf-modal[hidden] {
	display: none
}

.nf-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: grid;
	place-items: center
}

.nf-modal::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .55);
	backdrop-filter: blur(3px)
}

.nf-dialog {
	position: relative;
	z-index: 1;
	width: min(1100px, 92vw);
	padding: clamp(12px, 2vw, 20px);
	border-radius: 18px;
	background: var(--nf-dialog-bg);
	color: var(--nf-dialog-fg);
	display: grid;
	grid-template-columns: minmax(340px, 46%) 1fr;
	gap: clamp(16px, 2.4vw, 28px);
	box-shadow: var(--nf-shadow)
}

.nf-dialog .nf-media {
	align-self: stretch;
	background: var(--nf-media-bg);
	border-radius: 14px;
	overflow: hidden;
	display: grid;
	place-items: center;
	min-height: clamp(320px, 48vh, 540px)
}

.nf-dialog .nf-media img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	background: var(--nf-media-bg)
}

.nf-close {
	position: absolute;
	top: .5rem;
	right: .5rem;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: #111;
	color: #fff;
	border: 0;
	font-size: 22px;
	line-height: 1;
	cursor: pointer
}

.nf-close:focus-visible {
	outline: 3px dashed #000;
	outline-offset: 4px
}

#worlds-info {
	padding-top: 1.25rem
}

#video-slideshow .video-container {
	position: relative
}

#video-slideshow .media-placeholder {
	pointer-events: none
}

#video-slideshow .slides,
#video-slideshow .slideshow-video {
	pointer-events: auto
}

#video-slideshow .slideshow-sound-toggle {
	position: absolute;
	right: 12px;
	bottom: 75px;
	z-index: 999;
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, .45);
	background: rgba(0, 0, 0, .55);
	color: #fff;
	font-size: 18px;
	line-height: 1;
	cursor: pointer
}

#video-slideshow .slideshow-video:not(.active) .slideshow-sound-toggle {
	pointer-events: none;
	opacity: .6
}

@media (max-width:839px) {
	#worlds-info {
		padding-top: .25rem
	}
}

@media (max-width:520px) {
	.nf-modal {
		overflow: auto
	}

	.nf-modal .nf-dialog {
		width: 100vw;
		max-width: 100vw;
		min-width: 0;
		margin-inline: auto;
		box-sizing: border-box;
		padding: 1rem max(12px, env(safe-area-inset-right)) 1rem max(12px, env(safe-area-inset-left));
		display: grid;
		grid-template-columns: 1fr;
		justify-items: stretch;
		gap: 12px
	}

	.nf-modal .nf-dialog .nf-media {
		width: 100%;
		min-height: 0;
		height: auto;
		margin: 0
	}

.nf-modal .nf-dialog .nf-media img,
.nf-modal .nf-dialog .nf-media video {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

	.nf-modal .nf-close {
		top: calc(10px + env(safe-area-inset-top));
		right: calc(10px + env(safe-area-inset-right))
	}

	#hero {
		padding-inline: .5rem
	}
}

@media screen and (max-width:480px) {
	.slideshow-text {
		position: absolute;
		bottom: 2rem;
		left: 4rem;
		z-index: 5;
		background: var(--bg);
		color: var(--text);
		padding: 1rem 2rem;
		border-radius: 12px
	}

	.slideshow-text h2 {
		font-size: 1.5rem
	}

	.slideshow-text p {
		font-size: 1rem
	}

	.slideshow-next,
	.slideshow-prev {
		font-size: 1.5rem;
		padding: .3rem .8rem
	}

	.slideshow-dots {
		bottom: .5rem
	}

	.slideshow-dots .dot {
		width: 8px;
		height: 8px
	}

	#logo {
		height: 40px;
		top: 10px;
		right: 10px
	}

	#about {
		background-size: 35% auto;
		padding: 2rem;
		background-image: none
	}

	#about h2 {
		font-size: 2rem;
		width: 100%
	}

	#about p {
		font-size: 1rem;
		width: 100%
	}

	.parallax-container {
		padding: 2rem
	}

	.text-overlay {
		width: 100%
	}

	.text-overlay h2 {
		font-size: 2rem
	}

	.text-overlay p {
		font-size: 1rem
	}

	#assets {
		min-height: 40vh
	}

	.assets-container {
		padding: 2rem
	}

	.assets-overlay {
		width: 100%
	}

	.assets-overlay h2 {
		font-size: 2rem
	}

	.assets-overlay p {
		font-size: 1rem
	}

	#contact {
		background-size: auto 100%;
		background-position: center center;
		background-attachment: scroll
	}

	#contact h2 {
		font-size: 2rem
	}

	#contact p {
		font-size: 1rem
	}

	#contact input,
	#contact textarea {
		padding: .6rem;
		font-size: .8rem
	}

	#contact button {
		padding: 1rem 2rem;
		font-size: 1.2rem;
		border: none;
		cursor: pointer;
		border-radius: 12px;
		transition: filter .2s ease;
		background: var(--accent);
		color: var(--on-accent);
		box-shadow: 0 2px 0 rgba(0, 0, 0, .4)
	}

	.scroll-down {
		display: none
	}

	#services h2 {
		font-size: 2rem
	}

	#services p {
		font-size: 1rem
	}

	#artwork-info h2,
	#worlds-info h2 {
		font-size: 2rem
	}

	#artwork-info li,
	#artwork-info p,
	#worlds-info li,
	#worlds-info p {
		font-size: 1rem
	}
}

@media (max-width:375px) {
	.nf-modal .nf-dialog {
		padding: .85rem max(10px, env(safe-area-inset-right)) .85rem max(10px, env(safe-area-inset-left));
		gap: 10px
	}

	#video-slideshow .slideshow-sound-toggle {
		bottom: 10px
	}

	.assets-container,
	.content-container {
		padding: .5rem
	}

	#worlds-info {
		padding-top: .25rem
	}
}

@media (min-width:376px) and (max-width:520px) {

	.assets-container,
	.content-container {
		padding: .5rem
	}

	#video-slideshow .slideshow-sound-toggle {
		bottom: 15px
	}
}

@media (min-width:521px) and (max-width:839px) {
	#video-slideshow .slideshow-sound-toggle {
		bottom: 20px
	}
}

@media screen and (min-width:769px) and (max-width:1315px) {
	#about h2 {
		font-size: 3rem;
		width: 65%
	}

	#about p {
		font-size: 1.5rem;
		width: 65%;
		line-height: 1.4
	}

	.text-overlay {
		width: 100%
	}

	.text-overlay h2 {
		font-size: 3rem
	}

	.text-overlay p {
		font-size: 1.5rem;
		line-height: 1.4
	}

	#assets {
		min-height: 50vh
	}

	.assets-container {
		padding: 2rem
	}

	.assets-overlay {
		width: 100%
	}

	.assets-overlay h2 {
		font-size: 3rem
	}

	.assets-overlay p {
		font-size: 1.5rem;
		line-height: 1.4
	}

	#contact h2 {
		font-size: 3rem
	}

	#contact p {
		font-size: 1.5rem;
		line-height: 1.4
	}

	#contact {
		background-size: cover;
		background-position: left center
	}
}

@media (min-width:768px) {
	.opacity-90 {
		opacity: .9
	}
}

@media screen and (min-width:769px) {
	#mobile-nav {
		display: none
	}

	#bottom-nav {
		display: flex
	}
}

@media screen and (max-width:768px) {
	#mobile-nav {
		display: flex
	}

	#bottom-nav {
		display: none
	}

	#services {
		padding: 2rem;
		min-height: auto;
		background-image: none;
		background-position: right top;
		background-size: 25% auto
	}

	#services h2,
	#services p {
		width: 100%
	}

	#services h2 {
		font-size: 2.5rem
	}

	#services p {
		font-size: 1.2rem;
		line-height: 1.4
	}

	#about {
		padding: 2rem;
		min-height: auto;
		background-size: 25% auto;
		background-position: right top
	}

	#about h2 {
		font-size: 2.5rem;
		width: 100%
	}

	#about p {
		font-size: 1.2rem;
		width: 100%;
		line-height: 1.4
	}

	#artwork-info h2,
	#worlds-info h2 {
		font-size: 2.5rem
	}

	#artwork-info li,
	#artwork-info p,
	#worlds-info li,
	#worlds-info p {
		font-size: 1.2rem;
		line-height: 1.4
	}

	.parallax-container {
		padding: 2rem
	}

	.text-overlay {
		width: 100%
	}

	.text-overlay h2 {
		font-size: 2.5rem
	}

	.text-overlay p {
		font-size: 1.2rem;
		line-height: 1.4
	}

	#assets {
		min-height: 50vh
	}

	.assets-container {
		padding: 2rem
	}

	.assets-overlay {
		width: 100%
	}

	.assets-overlay h2 {
		font-size: 2.5rem
	}

	.assets-overlay p {
		font-size: 1.2rem;
		line-height: 1.4
	}

	#logo {
		height: 60px;
		top: 15px;
		right: 15px
	}

	#about {
		background-image: none
	}

	.slideshow-text {
		position: absolute;
		bottom: 2rem;
		left: 4rem;
		z-index: 5;
		background: var(--bg);
		color: var(--text);
		padding: 1rem 2rem;
		border-radius: 12px
	}

	.slideshow-text h2 {
		font-size: 2rem
	}

	.slideshow-text p {
		font-size: 1.2rem
	}

	.slideshow-next,
	.slideshow-prev {
		font-size: 1.8rem;
		padding: .4rem 1rem
	}

	#contact {
		background-size: 100%;
		background-attachment: scroll;
		background-position: center
	}

	#contact .container {
		padding: 1.5rem
	}

	#contact h2 {
		font-size: 2.5rem
	}

	#contact p {
		font-size: 1.2rem;
		line-height: 1.4
	}

	#contact input,
	#contact textarea {
		padding: .8rem;
		font-size: .9rem
	}

	#contact button {
		padding: 1rem 2rem;
		font-size: 1.2rem;
		border: none;
		cursor: pointer;
		border-radius: 12px;
		transition: filter .2s ease;
		background: var(--accent);
		color: var(--on-accent);
		box-shadow: 0 2px 0 rgba(0, 0, 0, .4)
	}

	#contact {
		background-size: auto 100%;
		background-position: center center;
		background-attachment: scroll
	}

	#about,
	#services {
		padding: 0
	}
}

@media (min-width:900px) {
	#contact .contact-visual {
		bottom: var(--card-pad)
	}

	#contact .contact-copy {
		padding-bottom: var(--visual-h)
	}

	#contact .btn.btn-primary {
		margin-bottom: 0
	}
}

@media screen and (min-width:1800px) {
	#services {
		padding: 6rem
	}

	#services h2 {
		font-size: 4.5rem
	}

	#services p {
		font-size: 2rem;
		line-height: 1.6
	}

	#artwork-info h2,
	#worlds-info h2 {
		font-size: 4.5rem
	}

	#artwork-info li,
	#artwork-info p,
	#worlds-info li,
	#worlds-info p {
		font-size: 2rem;
		line-height: 1.6
	}

	.slideshow-text {
		position: absolute;
		bottom: 2rem;
		left: 4rem;
		z-index: 5;
		background: var(--bg);
		color: var(--text);
		padding: 1rem 2rem;
		border-radius: 12px
	}

	.slideshow-text h2 {
		font-size: 3.5rem
	}

	.slideshow-text p {
		font-size: 2rem
	}

	.slideshow-next,
	.slideshow-prev {
		font-size: 2.5rem;
		padding: .7rem 1.5rem
	}

	#about {
		padding: 6rem
	}

	#about .container {
		justify-content: flex-start
	}

	#about h2 {
		font-size: 4.5rem
	}

	#about p {
		font-size: 2rem;
		line-height: 1.6
	}

	.parallax-container {
		justify-content: flex-start
	}

	.text-overlay {
		width: 100%
	}

	.text-overlay h2 {
		font-size: 4.5rem
	}

	.text-overlay p {
		font-size: 2rem;
		line-height: 1.6
	}

	#assets {
		min-height: 40vh
	}

	.assets-container {
		justify-content: flex-start
	}

	.assets-overlay {
		width: 100%
	}

	.assets-overlay h2 {
		font-size: 4.5rem
	}

	.assets-overlay p {
		font-size: 2rem;
		line-height: 1.6
	}

	#contact h2 {
		font-size: 4.5rem
	}

	#contact p {
		font-size: 2rem;
		line-height: 1.6
	}

	#contact {
		background-size: cover;
		background-position: left center
	}
}

@media screen and (max-width:768px) {
	#contact {
		background-size: auto 100%;
		background-position: center center;
		background-attachment: scroll
	}
}

#hero .hero-media {
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: 0;
	pointer-events: none
}

#hero {
	position: relative;
	isolation: isolate;
	overflow: visible;
	min-height: min(92vh, 960px);
	color: (--off-white)
}

#hero .hero-video,
#hero video {
	-webkit-mask: none !important;
	-webkit-mask-image: none !important;
	mask: none !important;
	mask-image: none !important;
	filter: none !important
}

#hero .hero-video,
#hero video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0
}

@media screen and (min-width:1800px) {
	#hero .hero-media {
		bottom: -110px
	}
}

#hero::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
	background: linear-gradient(90deg, rgba(0, 0, 0, .72) 0, rgba(0, 0, 0, .56) 18%, rgba(0, 0, 0, .38) 36%, rgba(0, 0, 0, .2) 54%, rgba(0, 0, 0, .1) 68%, rgba(0, 0, 0, 0) 78%), linear-gradient(180deg, rgba(0, 0, 0, .35) 0, rgba(0, 0, 0, 0) 28%)
}

:root {
	--section-gutter: clamp(16px, 5vw, 80px)
}

#hero .hero-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	margin-left: var(--section-gutter);
	margin-right: var(--section-gutter);
	padding-top: clamp(96px, 18vh, 240px);
	padding-bottom: clamp(48px, 14vh, 160px);
	max-width: 64rem;
	gap: 1rem
}

#hero .hero-card,
#hero .hero-content,
#hero .hero-copy,
#hero [class*=card] {
	background: 0 0 !important;
	backdrop-filter: none !important;
	border: 0 !important;
	box-shadow: none !important
}

#hero .h1,
#hero h1 {
	color: var(--off-white)
}

@media (max-width:768px) {
	#hero::after {
		background: linear-gradient(180deg, rgba(0, 0, 0, .72) 0, rgba(0, 0, 0, .55) 35%, rgba(0, 0, 0, 0) 75%)
	}

	#hero .hero-content {
		margin-left: var(--section-gutter);
		margin-right: var(--section-gutter);
		padding-top: clamp(80px, 25vh, 180px)
	}
}

@supports (padding:max(env(safe-area-inset-left), 0px)) {
	#hero .hero-content {
		margin-left: max(var(--section-gutter), env(safe-area-inset-left));
		margin-right: max(var(--section-gutter), env(safe-area-inset-right))
	}
}

#hero,
#hero .hero-content {
	font-size: 1rem
}

:root {
	--display-hero: var(--display-xxl, clamp(1.75rem, 5.5vw, 4.5rem));
	--display-hero-lh: var(--display-line, 1.05)
}

#hero .h1,
#hero h1 {
	font-size: var(--display-hero);
	line-height: var(--display-hero-lh);
	letter-spacing: .02em;
	font-weight: 800;
	margin: 0 0 .5em
}

#hero [class*=display-],
#hero h1[class*=text-] {
	font-size: inherit !important;
	line-height: inherit !important
}

#hero {
	display: grid
}

#hero .hero-content {
	align-self: end;
	padding-top: 0;
	padding-bottom: clamp(48px, 14vh, 160px)
}

#hero .cta,
#hero [class*=cta] {
	padding-top: 0 !important;
	margin-top: 0 !important
}

#hero {
	display: grid
}

#hero .hero-content {
	align-self: end;
	padding-top: 0;
	padding-bottom: clamp(24px, 8vh, 88px);
	gap: .5rem
}

#hero h1 {
	margin: 0 0 .25em
}

#hero .cta,
#hero [class*=cta] {
	padding-top: 0 !important;
	margin-top: .25rem !important
}

#hero .cta[class*=mt-],
#hero .cta[class*=pt-] {
	padding-top: 0 !important;
	margin-top: 0 !important
}

@media (max-width:768px) {
	#hero .hero-content {
		padding-top: 0;
		padding-bottom: clamp(16px, 6vh, 15px)
	}
}

#hero {
	--display-hero: clamp(2.25rem, 7.5vw, 4.5rem)
}

@media (max-width:768px) {
	#hero {
		--display-hero: clamp(2.375rem, 8.5vw, 3.25rem)
	}
}

@media (max-width:380px) {
	#hero {
		--display-hero: clamp(2.25rem, 9.5vw, 3rem)
	}
}

#hero::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -1px;
	transform: translateX(-50%) scaleY(-1);
	width: 100vw;
	height: clamp(56px, 10vw, 140px);
	background: var(--hero-divider-fill, var(--off-white));
	-webkit-mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
	mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
	pointer-events: none;
	z-index: 2
}



/* HERO lead text under headline */
#hero .hero-lead {
  font-family: var(--body-font);
  font-size: var(--lead-size);
  line-height: 1.6;
  max-width: 46rem;
  color: var(--off-white);
  opacity: 0.96;
  margin: 0;
}




#worlds-info {
	position: relative;
	isolation: isolate;
	padding: 0;
	aspect-ratio: 2760/1152;
	min-height: 60vh;
	overflow: hidden;
	color: var(--off-white);
	 background-image: url("assets/img2025/poster/sam-fouracre-prospector-key-art-01.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

#worlds-info .worlds-bg-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
	opacity: 0;                      /* start hidden */
	transition: opacity 0.4s ease;   /* smooth fade */
}

#worlds-info .worlds-bg-video.is-ready {
	opacity: 1;
}

#worlds-info::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none
}

#worlds-info .content-container {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	align-items: center
}

#worlds-info .about-hero-card {
	background: 0 0;
	border: 0;
	box-shadow: none;
	color: var(--off-white)
}

#worlds-info .about-copy {
	grid-column: 2/-1;
	max-width: 34rem
}

#hero::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -1px;
	transform: translateX(-50%) scaleY(-1);
	width: 100vw;
	height: clamp(56px, 10vw, 140px);
	background: var(--hero-divider-fill, var(--off-white));
	-webkit-mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
	mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
	pointer-events: none;
	z-index: 2
}

#worlds-info {
	position: relative;
	isolation: isolate;
	padding: 0;
	margin-top: -80px;
	z-index: 1;
	aspect-ratio: 2760/1152;
	min-height: 60vh;
	overflow: hidden;
	color: var(--ink-950);
	-webkit-mask-image: url(assets/masks/worlds_torn_top.svg);
	mask-image: url(assets/masks/worlds_torn_top.svg);
	-webkit-mask-size: cover;
	mask-size: cover;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: top center;
	mask-position: top center;
	display: flex;
	flex-direction: column;
	 justify-content: flex-end;   /* or flex-start / space-between depending on taste */
			/* New: use the poster as a proper background */
	background-color: #050509;
	background-image: url("assets/img2025/poster/novus-tower-ue5-environment-psyk-labs-sam-fouracre-.jpg");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	
		
}





#worlds-info .about-media {
	position: absolute;
	inset: 0;
	margin: 0;
	padding: 0;
	z-index: 0
}

#worlds-info .about-media video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
	display: block
}




#worlds-info .content-container {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	align-items: center;
	padding: clamp(3rem, 8vh, 5rem) 2rem 2.5rem
}

#worlds-info .about-hero-card {
	background: 0 0;
	border: 0;
	box-shadow: none;
	color: var(--off-white)
}

#hero::before {
	content: none
}

#worlds-info .about-hero-card {
	width: 100%
}

#worlds-info .about-copy {
	width: 60%;
	max-width: none;
	margin-left: auto;
	padding: 0;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: .75rem
}

#worlds-info .about-copy-panel {
	padding: 1.25rem 1.75rem;
	border-radius: 24px;
	background: rgba(255, 255, 255, .66);
	backdrop-filter: blur(6px);
	color: #111015
}

#worlds-info .about-copy-panel h2 {
	margin: .4rem 0 .5rem
}

#worlds-info .about-copy-panel .body {
	margin: 0
}

#worlds-info .about-actions {
	margin-top: .5rem
}

@media (max-width:940px) {
	#worlds-info .about-copy {
		width: 100%;
		margin-left: 0
	}
}

@media (max-width:940px) {
	#worlds-info {
		aspect-ratio: auto;
		min-height: auto
	}

	#worlds-info .content-container {
		height: auto;
		align-items: center;
		justify-content: center;
		padding: clamp(2.5rem, 7vh, 4rem) var(--section-gutter)
	}

	#worlds-info .about-hero-card {
		display: block;
		max-width: 44rem;
		margin: 0 auto
	}

	#worlds-info .about-copy {
		width: 100%;
		max-width: 40rem;
		margin: 0 auto
	}
}

@media (max-width:900px) {
	#worlds-info .content-container {
		display: flex;
		justify-content: center;
		align-items: center
	}

	#worlds-info .about-hero-card {
		grid-template-columns: 1fr;
		max-width: 44rem;
		margin: 0 auto
	}

	#worlds-info .about-copy {
		width: 100%;
		max-width: 40rem;
		margin: 0 auto
	}

	#worlds-info {
		-webkit-mask-position: top center;
		mask-position: top center
	}
}

@media (max-width:520px) {


	#worlds-info .about-copy-panel {
		padding: 1rem 1.25rem;
		border-radius: 20px
	}
}

@media (max-width:940px) {
	#worlds-info {
		aspect-ratio: auto;
		min-height: 70vh
	}
}

@media (max-width:375px) {
	#worlds-info {
		-webkit-mask-position: top center;
		mask-position: top center
	}
}

@media (min-width:376px) and (max-width:520px) {
	#worlds-info {
		-webkit-mask-position: top center;
		mask-position: top center
	}
}

@media (max-width:940px) {
	#worlds-info {
		aspect-ratio: auto;
		min-height: 70vh
	}

	#worlds-info .content-container {
		align-items: flex-end
	}

	#worlds-info .about-hero-card {
		display: block
	}

	#worlds-info .about-copy {
		grid-column: 1/-1;
		max-width: 100%;
		padding-top: 2rem
	}
}

@media (min-width:940px)  {
	#worlds-info {
		aspect-ratio: auto;
		min-height: 75vh
	}
}

#worlds-feed .wf-feature {
	--card-bd: rgba(255, 255, 255, .12);
	position: relative;
	background: var(--ink-950);
	border: 1px solid var(--card-bd);
	border-radius: 16px;
	padding: 0;
	overflow: hidden;
	transition: transform .18s ease, box-shadow .18s ease
}

#worlds-feed .wf-feature:hover {
	transform: translateY(-3px) rotate(-.25deg);
	box-shadow: 0 14px 28px rgba(0, 0, 0, .25)
}

#worlds-feed .wf-feature .wf-thumb {
	display: block;
	border: 0;
	margin: 0;
	padding: 0;
	background: 0 0;
	width: 100%;
	cursor: pointer
}

#worlds-feed .wf-feature img {
	display: block;
	width: 100%;
	height: auto
}

.nf-dialog--image-only {
	display: block;
	box-sizing: border-box;
	margin-inline: auto;
	padding: clamp(12px, 2vw, 20px);
	border-radius: 18px;
	background: var(--ink-950);
	color: var(--nf-dialog-fg);
	box-shadow: var(--nf-shadow);
	width: min(100vw, calc((100vh - 120px) * 16 / 9));
	max-width: 100vw
}

.nf-dialog--image-only .nf-media {
	border-radius: 14px;
	overflow: hidden;
	background: var(--nf-media-bg);
	display: block;
	aspect-ratio: 16/9
}

.nf-dialog--image-only .nf-media img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain
}

#assets-modelling .wf-card {
	--card-bg: var(--ink-950);
	--card-fg: var(--off-white);
	--card-bd: rgba(255, 255, 255, .12);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(320px, 48%);
	gap: 1rem;
	padding: 1rem;
	background: var(--card-bg);
	color: var(--card-fg);
	border: 1px solid var(--card-bd);
	border-radius: 20px
}

#assets-modelling .wf-copy {
	padding: clamp(1rem, 2.5vw, 1.5rem);
	display: grid;
	align-content: start;
	gap: .5rem
}

#assets-modelling .wf-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
	font-size: .78rem;
	padding: .4rem .6rem;
	border-radius: 999px;
	margin-bottom: .75rem;
	background: var(--off-white);
	color: #111015;
	border-color: rgba(0, 0, 0, .12)
}

#assets-modelling .wf-media {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	background: #111
}

#assets-modelling .wf-media img,
#assets-modelling .wf-media video {
	width: 100%;
	height: 100%;
	display: block;
	aspect-ratio: 1/1;
	object-fit: cover
}

#assets-modelling .wf-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-top: 1rem
}

#assets-modelling .wf-feature {
	--card-bd: rgba(255, 255, 255, .12);
	position: relative;
	background: var(--ink-950);
	border: 1px solid var(--card-bd);
	border-radius: 16px;
	padding: 0;
	overflow: hidden;
	transition: transform .18s ease, box-shadow .18s ease
}

#assets-modelling .wf-feature:hover {
	transform: translateY(-3px) rotate(-.25deg);
	box-shadow: 0 14px 28px rgba(0, 0, 0, .25)
}

#assets-modelling .wf-feature::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 6px;
	border-radius: 0 0 16px 16px;
	background: var(--flair, #ffd500);
	opacity: .95
}

#assets-modelling .wf-feature[data-flair=teal] {
	--flair: #1dccd2
}

#assets-modelling .wf-feature[data-flair=violet] {
	--flair: #A885F2
}

#assets-modelling .wf-feature[data-flair=orange] {
	--flair: var(--orange-600, #FF5A21)
}

#assets-modelling .wf-feature .wf-thumb {
	display: block;
	border: 0;
	margin: 0;
	padding: 0;
	background: 0 0;
	width: 100%;
	cursor: pointer
}

#assets-modelling .wf-feature img {
	display: block;
	width: 100%;
	height: auto
}

#trailers .wf-card {
	--card-bg: var(--ink-950);
	--card-fg: var(--off-white);
	--card-bd: rgba(255, 255, 255, .12);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(320px, 48%);
	gap: 1rem;
	padding: 1rem;
	background: var(--card-bg);
	color: var(--card-fg);
	border: 1px solid var(--card-bd);
	border-radius: 20px
}

#trailers .wf-copy {
	padding: clamp(1rem, 2.5vw, 1.5rem);
	display: grid;
	align-content: start;
	gap: .5rem
}

#trailers .wf-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
	font-size: .78rem;
	padding: .4rem .6rem;
	border-radius: 999px;
	margin-bottom: .75rem;
	background: var(--off-white);
	color: #111015;
	border-color: rgba(0, 0, 0, .12)
}

#trailers .wf-media {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	background: #111;
	aspect-ratio: 16/9
}

#trailers .wf-media img,
#trailers .wf-media video {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover
}

#trailers .wf-features {
	margin-top: 1rem
}

#trailers .trailers-video {
	position: relative;
	max-width: min(100%, 1920px);
	margin-inline: auto;
	border-radius: 16px;
	overflow: hidden;
	background: var(--ink-950);
	aspect-ratio: 16/9
}

#trailers .trailers-video video {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover
}

#lab-feed .wf-card {
	--card-bg: var(--ink-950);
	--card-fg: var(--off-white);
	--card-bd: rgba(255, 255, 255, .12);
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(320px, 48%);
	gap: 1rem;
	padding: 1rem;
	background: var(--card-bg);
	color: var(--card-fg);
	border: 1px solid var(--card-bd);
	border-radius: 20px
}

#lab-feed .wf-copy {
	padding: clamp(1rem, 2.5vw, 1.5rem);
	display: grid;
	align-content: start;
	gap: .5rem
}

#lab-feed .wf-copy .eyebrow.pill {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
	font-size: .78rem;
	padding: .4rem .6rem;
	border-radius: 999px;
	margin-bottom: .75rem;
	background: var(--off-white);
	color: #111015;
	border-color: rgba(0, 0, 0, .12)
}

#lab-feed .wf-media {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	background: #111;
	aspect-ratio: 16/9
}

#lab-feed .wf-media img,
#lab-feed .wf-media video {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover
}

#lab-feed .wf-lab-games-heading {
	margin-top: 2rem;
	margin-bottom: .75rem
}

#lab-feed .wf-lab-games-heading h3 {
	font-family: var(--display-font, var(--body-font));
	font-size: 1.25rem
}

#lab-feed .wf-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-top: 1rem
}

#lab-feed .wf-feature {
	--card-bd: rgba(255, 255, 255, .12);
	position: relative;
	background: var(--ink-950);
	border: 1px solid var(--card-bd);
	border-radius: 16px;
	overflow: hidden;
	padding: 0;
	aspect-ratio: 16/9;
	transition: transform .18s ease, box-shadow .18s ease
}

#lab-feed .wf-feature:hover {
	transform: translateY(-3px) rotate(-.25deg);
	box-shadow: 0 14px 28px rgba(0, 0, 0, .25)
}

#lab-feed .wf-feature::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 6px;
	border-radius: 0 0 16px 16px;
	background: var(--flair, #ffd500);
	opacity: .95
}

#lab-feed .wf-feature[data-flair=teal] {
	--flair: #1dccd2
}

#lab-feed .wf-feature[data-flair=violet] {
	--flair: #A885F2
}

#lab-feed .wf-feature[data-flair=orange] {
	--flair: var(--orange-600, #FF5A21)
}

#lab-feed .wf-feature .wf-thumb {
	display: block;
	border: 0;
	margin: 0;
	padding: 0;
	background: 0 0;
	width: 100%;
	height: 100%;
	cursor: pointer;
	text-decoration: none
}

#lab-feed .wf-feature img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover
}

@media (max-width:980px) {
	#hero {
		padding-inline: 2rem;
		padding-bottom: 2rem
	}

	#hero .hero-card {
		box-sizing: border-box;
		position: static;
		right: auto;
		bottom: auto;
		width: 100%;
		max-width: none;
		margin: 0;
		text-align: center;
		box-shadow: none
	}
}

@media (max-width:940px) {
	#worlds-info .about-media {
		padding: clamp(8px, 2vw, 16px)
	}

	#worlds-info .about-media img {
		object-fit: contain;
		width: 100%;
		height: auto;
		aspect-ratio: 16/9;
		max-height: min(52vh, 420px)
	}

	.about-hero-card {
		grid-template-columns: 1fr
	}

	.about-media img {
		aspect-ratio: 16/9
	}
}

@media (max-width:900px) {

	#assets-modelling .wf-card,
	#assets-modelling .wf-features,
	#lab-feed .wf-card,
	#lab-feed .wf-features,
	#trailers .wf-card,
	#trailers .wf-features,
	#worlds-feed .wf-card,
	#worlds-feed .wf-features {
		grid-template-columns: 1fr
	}

	#contact .contact-card {
		grid-template-columns: 1fr
	}

	#contact .contact-visual {
		position: static;
		width: 100%;
		height: auto;
		margin-top: 1rem;
		border-radius: 16px
	}

	#contact .contact-copy {
		padding-bottom: var(--card-pad)
	}

	footer {
		padding: 2rem 1.25rem 4rem
	}
}

.wide-video-section {
	width: 100%;
	margin: 0;
	padding-block: clamp(2.5rem, 2vw, 5.5rem);
	padding-bottom: 0;
	padding-inline: 0;
	background: var(--ink-950)
}

.wide-video-section video {
	display: block;
	width: 100%;
	height: auto
}




/* Video-only dialog (for variable-aspect videos) */
.nf-dialog--video-only {
  display: block; /* override grid layout from .nf-dialog */
  box-sizing: border-box;
  margin-inline: auto;
  padding: clamp(12px, 2vw, 20px);
  border-radius: 18px;
  background: black;
  color: var(--nf-dialog-fg);
  box-shadow: var(--nf-shadow);

  /* Wide but contained */
  width: min(1100px, 96vw);
  max-width: 100vw;
}

/* Container for the video */
.nf-dialog--video-only .nf-media {
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  background: black;
}

/* Make the video as big as possible, with any aspect ratio */
.nf-dialog--video-only .nf-media video {
  display: block;
  width: 100%;
  height: auto;
  max-height: calc(100vh - 120px); /* stop it spilling off smaller viewports */
  object-fit: contain; /* show the whole frame, no cropping */
}


@media (min-width: 901px) {
  #trailers .wf-media {
    align-self: center; /* vertically centres the video block within the grid row */
  }
  #lab-feed .wf-media {
    align-self: center; /* vertically centres the video block within the grid row */
  }
}

footer .footer-copy {
  margin-top: 1rem;
  font-size: 0.85rem;
  opacity: 0.75;
}




/* Keep the modal close button above media and give it a bit more space in video-only dialogs */
.nf-modal .nf-close {
  z-index: 3;              /* ensure it's above the video controls */
}

/* On larger screens, add extra padding so the X sits a little further from the video */
@media (min-width: 720px) {
  .nf-dialog--video-only {
    padding-top: 2.75rem;  /* more breathing room above the video */
  }
}


/* Interactive affordance for all wf-feature tiles */
#worlds-feed .wf-feature,
#assets-modelling .wf-feature,
#lab-feed .wf-feature {
  position: relative;
}

/* Hover/focus overlay + “expand” icon */
#worlds-feed .wf-feature::before,
#assets-modelling .wf-feature::before,
#lab-feed .wf-feature::before {
  content: "⤢"; /* expand-style icon */
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--body-font);
  font-size: 1.2rem;
  color: var(--off-white);
  background: radial-gradient(circle at center,
    transparent 55%,
    rgba(0, 0, 0, 0.55) 100%);
  opacity: 0;
  transform: translateY(6px);
  transition:
    opacity 0.18s ease-out,
    transform 0.18s ease-out;
  pointer-events: none; /* don't block clicks */
}

/* Show overlay on hover + keyboard focus */
#worlds-feed .wf-feature:hover::before,
#worlds-feed .wf-feature:focus-within::before,
#assets-modelling .wf-feature:hover::before,
#assets-modelling .wf-feature:focus-within::before,
#lab-feed .wf-feature:hover::before,
#lab-feed .wf-feature:focus-within::before {
  opacity: 1;
  transform: translateY(0);
}

/* Subtle zoom/brighten on the thumbnail itself */
#worlds-feed .wf-feature img,
#assets-modelling .wf-feature img,
#lab-feed .wf-feature img {
  transition: transform 0.22s ease-out, filter 0.22s ease-out;
}

#worlds-feed .wf-feature:hover img,
#worlds-feed .wf-feature:focus-within img,
#assets-modelling .wf-feature:hover img,
#assets-modelling .wf-feature:focus-within img,
#lab-feed .wf-feature:hover img,
#lab-feed .wf-feature:focus-within img {
  transform: scale(1.04);
  filter: brightness(1.3);
}


/* HERO: use poster as background fallback */
#hero {
  background-color: #000; /* safety net */
  background-image: url("assets/img2025/poster/sam-fouracre-ue5-portunus-prime-psyk-labs.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Final worlds-info background override, applies at all sizes */
#worlds-info {
  background-color: #050509;
  background-image: url("assets/img2025/poster/sam-fouracre-prospector-key-art-01.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
	
}

/* Typography override: keep headings on Satoshi, move body copy to Author */
:root{
  --body-font: "Author", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* Contact section: light-only override */
#contact {
  position: relative;
  background: #fff;
  color: #000;
}

#contact::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -1px;
  transform: translateX(-50%);
  width: 100vw;
  height: clamp(56px, 10vw, 140px);
  background: var(--top-divider-fill, var(--ink-950));
  -webkit-mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
  mask: url(assets/dividers/crayon_top.svg) center/cover no-repeat;
  pointer-events: none;
}

#contact .contact-card {
  --card-fg: #000;
  --card-bd: rgba(0, 0, 0, 0.12);
  background: #fff;
  color: #000;
  border-color: var(--card-bd);
}

#contact h2 {
  color: #000;
  font-family: var(--display-font);
  font-weight: 700;
  letter-spacing: 0.8px;
  line-height: var(--h2-lh);
  font-size: var(--h2-size);
}

#contact .measure,
#contact .contact-form label {
  color: #000;
}

#contact .measure {
  font-family: var(--body-font);
  font-size: var(--lead-size);
  line-height: 1.5;
  opacity: 0.95;
}

#contact .measure p {
  font: inherit;
  line-height: inherit;
}

#contact .contact-copy .eyebrow.pill {
  background: rgba(0, 0, 0, 0.05);
  border-color: rgba(0, 0, 0, 0.12);
  color: #000;
}

#contact .contact-form input,
#contact .contact-form textarea {
  background: #fff;
  border-color: rgba(0, 0, 0, 0.18);
  color: #000;
}

#contact .contact-form input::placeholder,
#contact .contact-form textarea::placeholder {
  color: rgba(0, 0, 0, 0.55);
  opacity: 1;
}

#contact .contact-form input:focus,
#contact .contact-form textarea:focus {
  background: #fff;
}

#contact .contact-visual {
  background: #fff;
  border-color: rgba(0, 0, 0, 0.12);
}

/* Director page */
body.director-page {
  background: var(--ink-950);
  color: var(--off-white);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body.director-page .director-main {
  flex: 1 0 auto;
  padding-top: clamp(2rem, 4vw, 3.5rem);
}

body.director-page #director-about {
  padding-bottom: 0;
}

body.director-page #director-about .content-container {
  padding-top: 1.5rem;
  padding-bottom: 2rem;
}

body.director-page #director-about .wf-card {
  --card-bg: var(--ink-950);
  --card-fg: var(--off-white);
  --card-bd: rgba(255, 255, 255, .12);
  display: grid;
  grid-template-columns: minmax(340px, 1.08fr) minmax(320px, .92fr);
  gap: 1rem;
  padding: 1rem;
  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-bd);
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, .28);
}

body.director-page #director-about .wf-media {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  background: #111;
  aspect-ratio: 16/10;
}

body.director-page #director-about .wf-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

body.director-page #director-about .wf-copy {
  padding: clamp(1rem, 2.5vw, 1.5rem);
  display: grid;
  align-content: center;
  gap: .75rem;
}

body.director-page #director-about .eyebrow.pill {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
  font-size: .78rem;
  padding: .4rem .6rem;
  border-radius: 999px;
  margin-bottom: .75rem;
  background: var(--off-white);
  color: #111015;
  border-color: rgba(0, 0, 0, .12);
}

body.director-page #director-about h1 {
  margin: 0;
  font-family: var(--display-font);
  font-weight: 700;
  letter-spacing: .8px;
  line-height: var(--h2-lh);
  font-size: var(--h2-size);
}

body.director-page #director-about .copy-stack {
  max-width: 34rem;
}

body.director-page #director-about .copy-stack p:first-child {
  margin-top: 1.1rem;
}

body.director-page #director-about .copy-stack p + p {
  margin-top: 1.1rem;
}

body.director-page #director-about p {
  margin: 0;
  font-family: var(--body-font);
  font-size: var(--body-size);
  line-height: 1.5;
  opacity: .92;
}

body.director-page #director-about .director-actions {
  margin-top: .5rem;
  flex-wrap: wrap;
}

body.director-page #director-about .director-actions .btn {
  text-decoration: none;
  box-shadow: none;
}

body.director-page #director-about .director-actions .btn:hover {
  transform: translateY(-1px);
}

body.director-page #director-about .btn.btn-outline {
  background: transparent;
  color: var(--off-white);
  border: 1px solid rgba(255, 255, 255, .16);
}

body.director-page #director-about .btn.btn-outline:hover {
  background: rgba(255, 255, 255, .05);
  color: var(--off-white);
}

@media (max-width:900px) {
  body.director-page #director-about .wf-card {
    grid-template-columns: 1fr;
  }

  body.director-page #director-about .wf-media {
    aspect-ratio: 16/9;
  }

  body.director-page #director-about .copy-stack {
    max-width: none;
  }
}

@media screen and (max-width:768px) {
  body.director-page .director-main {
    padding-top: clamp(1rem, 5vw, 1.75rem);
  }

  body.director-page #director-about .content-container {
    padding-top: 1rem;
    padding-bottom: 5.5rem;
  }

  body.director-page #director-about .director-actions {
    flex-direction: column;
    align-items: stretch;
  }

  body.director-page #director-about .director-actions .btn {
    justify-content: center;
  }
}


