:root {
	--bg: #0b0b11;
	--fg: #e7e7ec;
	--muted: #9aa0a6;
	--accent1: #9f7aea;
	--accent2: #22d3ee;
	--accent3: #f472b6;
	--glass: rgba(255, 255, 255, 0.04);
	--glow: 0 0 2rem rgba(159, 122, 234, 0.28), 0 0 4rem rgba(34, 211, 238, 0.18);
}

/* Hide scrollbars across browsers (applies site-wide). If you want
   scrollbars for specific elements, add an explicit override. */
html,
body,
* {
	-ms-overflow-style: none; /* IE and Edge */
	scrollbar-width: none; /* Firefox */
}
/* WebKit-based browsers */
*::-webkit-scrollbar {
	width: 0px;
	height: 0px;
	background: transparent;
}

/* Local Nohemi font faces */
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Thin-BF6438cc57e2011.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Thin-BF6438cc5896c67.ttf") format("truetype");
	font-weight: 100;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-ExtraLight-BF6438cc581502c.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-ExtraLight-BF6438cc58a2634.ttf") format("truetype");
	font-weight: 200;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Light-BF6438cc5702321.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Light-BF6438cc5899919.ttf") format("truetype");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Regular-BF6438cc579d934.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Regular-BF6438cc4d0e493.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Medium-BF6438cc57ddecd.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Medium-BF6438cc5883899.ttf") format("truetype");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-SemiBold-BF6438cc57db2ff.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-SemiBold-BF6438cc588a48a.ttf") format("truetype");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Bold-BF6438cc577b524.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Bold-BF6438cc587b5b5.ttf") format("truetype");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-ExtraBold-BF6438cc5761ae2.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-ExtraBold-BF6438cc5881baf.ttf") format("truetype");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Nohemi";
	src: url("/Nohemi-Font/Nohemi-Black-BF6438cc565e67b.woff") format("woff"),
		url("/Nohemi-Font/Nohemi-Black-BF6438cc58744d4.ttf") format("truetype");
	font-weight: 900;
	font-style: normal;
	font-display: swap;
}

:root {
	--bg: #0b0b11;
	--fg: #e7e7ec;
	--muted: #9aa0a6;
	--accent1: #9f7aea;
	--accent2: #22d3ee;
	--accent3: #f472b6;
	--glass: rgba(255, 255, 255, 0.04);
	--glow: 0 0 2rem rgba(159, 122, 234, 0.28), 0 0 4rem rgba(34, 211, 238, 0.18);
}

* {
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
}
body {
	margin: 0;
	background: var(--bg);
	color: var(--fg);
	font-family: "Nohemi", "Satoshi", system-ui, -apple-system, "Segoe UI", Roboto,
		"Helvetica Neue", Arial, sans-serif;
	line-height: 1.5;
	overflow-x: hidden;
	letter-spacing: 0.05em;
}

a {
	color: var(--fg);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover {
	color: var(--accent2);
}
.mono {
	font-family: "JetBrains Mono", monospace;
}

/* Global Layout */
.container {
	width: min(75rem, 92vw);
	margin-inline: auto;
}
section {
	padding: 8rem 0;
}

@media (max-width: 768px) {
	section {
		padding: 3rem 0;
	}
	
	#who {
		padding: 1.5rem 0;
	}
}
.eyebrow {
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-size: 1rem;
	margin-bottom: 0.75rem;
}
h1,
h2 {
	line-height: 1.1;
	margin: 0 0 1rem;
	/* Slightly reduced weight for improved readability */
	font-weight: 500;
}
h1 {
	font-size: clamp(2.5rem, 6vw, 5rem);
}
h2 {
	font-size: clamp(2rem, 4vw, 3rem);
}
p {
	font-family: "Satoshi", sans-serif;
	color: #c9c9d3;
	font-size: clamp(1rem, 1.2vw, 1.35rem);
	font-weight: 400;
	max-width: 65ch;
	margin: 0;
}

/* Add subtle character spacing for paragraph and body text (excluding monospace/eyebrow styles) */
p,
.sub,
.card p,
.panel-content p,
.who-text p,
section p {
	letter-spacing: 0.02em;
}

/* Skip link for a11y */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 1rem;
	z-index: 9999;
	background: #111;
	color: #fff;
	padding: 0.5rem 1rem;
	text-decoration: none;
	border-radius: 0.25rem;
}

.skip-link:focus {
	left: 1rem;
}

.skip {
	display: none;
}

/* Focus styles for keyboard navigation */
a:focus,
button:focus,
input:focus,
textarea:focus {
	outline: 2px solid var(--accent2);
	outline-offset: 2px;
}

/* Navigation */
.nav {
	position: fixed;
	inset: 1rem 1rem auto 1rem;
	z-index: 50;
	display: flex;
	align-items: center;
	gap: 1rem;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.065),
		rgba(255, 255, 255, 0.02)
	);
	border: 0.0625rem solid rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(0.75rem);
	-webkit-backdrop-filter: blur(0.75rem);
	padding: 0.625rem 1rem;
	border-radius: 0.875rem;
	box-shadow: var(--glow);
}

/* Initial hidden state for nav */
.nav-hidden {
	opacity: 0;
	transform: translateY(-4rem);
	animation: nav-reveal 0.8s ease-out 1.4s forwards;
}

/* Initial hidden states for hero elements */
.eyebrow-hidden {
	opacity: 0;
	transform: translateY(-3rem);
	filter: blur(0.5rem);
	animation: eyebrow-reveal 0.8s ease-out 1.6s forwards;
}

.pillbar-hidden {
	opacity: 0;
	transform: translateY(2rem) scale(0.95);
	filter: blur(0.5rem);
	animation: pillbar-reveal 0.8s ease-out 2s forwards;
}

.scroll-hidden {
	opacity: 0;
	transform: translateY(2rem);
	animation: scroll-reveal 1s ease-out 1.8s forwards;
}
.nav .brand {
	display: flex;
	gap: 1rem;
	align-items: center;
	font-weight: 700;
}
.logo {
	width: 3rem;
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.logo img {
	width: 3rem;
	height: 3rem;
	object-fit: contain;
	margin-left: 1rem;
}

.brand-text {
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
}

.brand-text img {
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	height: 3rem;
	object-fit: contain;
}

@keyframes spin {
	to {
		transform: rotate(1turn);
	}
}
.nav a.link {
	opacity: 0.9;
	font-weight: 500;
	font-size: 0.92rem;
	transition: color 0.2s, opacity 0.2s;
}

.nav a.link:hover {
	color: var(--accent2);
	opacity: 1;
}
.spacer {
	flex: 1;
}
.cta-nav {
	position: relative;
	overflow: hidden;
	padding: 0.625rem 1rem;
	border-radius: 0.75rem;
	font-weight: 500;
	font-size: 0.92rem;
	/* layered gradient with subtle radial highlights for richness */
	background: linear-gradient(
			90deg,
			rgba(34, 211, 238, 0.2) 0%,
			rgba(159, 122, 234, 0.22) 35%,
			rgba(244, 114, 182, 0.18) 65%,
			rgba(34, 211, 238, 0.2) 100%
		),
		radial-gradient(
			60% 60% at 10% 10%,
			rgba(255, 255, 255, 0.04),
			transparent 35%
		);
	background-blend-mode: screen;
	background-size: 300% 100%;
	animation: gradient-move-slow 6s ease-in-out infinite;
	border: 0.0625rem solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 6px 18px rgba(34, 211, 238, 0.06),
		0 2px 8px rgba(159, 122, 234, 0.05);
	transition: transform 0.2s ease, box-shadow 0.25s ease, filter 0.2s ease;
}
.cta-nav::after {
	/* glossy sheen */
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		120deg,
		rgba(255, 255, 255, 0.06),
		rgba(255, 255, 255, 0) 40%
	);
	mix-blend-mode: overlay;
	opacity: 0.6;
	transform: translateX(-60%);
	transition: transform 0.6s ease;
	pointer-events: none;
}
.cta-nav:hover {
	transform: translateY(-0.125rem) scale(1.01);
	filter: brightness(1.08);
	box-shadow: 0 14px 34px rgba(34, 211, 238, 0.12),
		0 6px 20px rgba(159, 122, 234, 0.08);
}
.cta-nav:hover::after {
	transform: translateX(0);
}

/* HERO Section */
.hero {
	position: relative;
	min-height: 100dvh;
	display: grid;
	place-items: center;
	overflow: hidden;
}
canvas#aether {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}
.hero-inner {
	z-index: 1;
	text-align: center;
	padding: 12vh 0 10vh;
}
.glitch {
	display: inline-block;
	position: relative;
	opacity: 0;
	animation: glitch-container 0.2s ease-out 0.5s forwards;
}

.glitch-bg {
	position: absolute;
	top: -2rem;
	left: -2rem;
	right: -2rem;
	bottom: -2rem;
	width: calc(100% + 4rem);
	height: calc(100% + 4rem);
	z-index: -1;
	opacity: 0;
	pointer-events: none;
	mix-blend-mode: screen;
}

#glitch-canvas-1 {
	animation: glitch-bg-1-reveal 0.5s ease-out 0.8s forwards;
}

#glitch-canvas-2 {
	animation: glitch-bg-2-reveal 0.5s ease-out 1s forwards;
}

.glitch .text {
	opacity: 0;
	animation: glitch-main 1s ease-out 0.7s both;
}

.glitch .ghost {
	position: absolute;
	inset: 0;
	color: var(--accent2);
	clip-path: inset(0 0 50% 0);
	mix-blend-mode: screen;
	opacity: 0;
	filter: blur(0.0375rem);
	animation: glitch-ghost-1 0.8s ease-out 0.9s both;
}

.glitch .ghost:nth-child(3) {
	color: var(--accent3);
	clip-path: inset(48% 0 0 0);
	animation: glitch-ghost-2 0.8s ease-out 1.1s both;
}

/* Animation Keyframes */
@keyframes glitch-container {
	to {
		opacity: 1;
	}
}

@keyframes glitch-main {
	0% {
		opacity: 0;
		transform: translateX(-2rem) skewX(-5deg);
		filter: blur(1rem);
	}
	20% {
		opacity: 1;
		transform: translateX(0.5rem) skewX(2deg);
		filter: blur(0.2rem);
	}
	40% {
		transform: translateX(-0.2rem) skewX(-1deg);
		filter: blur(0.1rem);
	}
	60% {
		transform: translateX(0.1rem) skewX(0.5deg);
		filter: blur(0.05rem);
	}
	80% {
		transform: translateX(-0.05rem) skewX(-0.2deg);
	}
	100% {
		opacity: 1;
		transform: translateX(0) skewX(0);
		filter: blur(0);
	}
}

@keyframes glitch-ghost-1 {
	0% {
		opacity: 0;
		transform: translateX(0);
	}
	20% {
		opacity: 0.35;
		transform: translateX(-0.5rem);
	}
	40% {
		transform: translateX(0.3rem);
	}
	60% {
		transform: translateX(-0.2rem);
	}
	80% {
		transform: translateX(0.1rem);
	}
	100% {
		opacity: 0.35;
		transform: translateX(0);
	}
}

@keyframes glitch-ghost-2 {
	0% {
		opacity: 0;
		transform: translateX(0);
	}
	25% {
		opacity: 0.35;
		transform: translateX(0.4rem);
	}
	45% {
		transform: translateX(-0.2rem);
	}
	65% {
		transform: translateX(0.15rem);
	}
	85% {
		transform: translateX(-0.08rem);
	}
	100% {
		opacity: 0.35;
		transform: translateX(0);
	}
}

@keyframes glitch-bg-1-reveal {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 0.3;
	}
}

@keyframes glitch-bg-2-reveal {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 0.2;
	}
}

@keyframes nav-reveal {
	0% {
		opacity: 0;
		transform: translateY(-4rem);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes eyebrow-reveal {
	0% {
		opacity: 0;
		transform: translateY(-3rem);
		filter: blur(0.5rem);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		filter: blur(0);
	}
}

@keyframes sub-reveal {
	0% {
		opacity: 0;
		transform: translateY(2rem);
		filter: blur(0.5rem);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		filter: blur(0);
	}
}

@keyframes pillbar-reveal {
	0% {
		opacity: 0;
		transform: translateY(2rem) scale(0.95);
		filter: blur(0.5rem);
	}
	100% {
		opacity: 1;
		transform: translateY(0) scale(1);
		filter: blur(0);
	}
}

@keyframes scroll-reveal {
	0% {
		opacity: 0;
		transform: translateY(2rem);
		filter: blur(0.5rem);
	}
	100% {
		opacity: 0.75;
		transform: translateY(0);
		filter: blur(0);
	}
}
.sub {
	max-width: 43.75rem;
	margin: 1rem auto;
	opacity: 0;
	font-size: clamp(1.1rem, 2vw, 1.5rem);
	line-height: 1.6;
}

/* Override default opacity for hidden state */
.sub.sub-hidden {
	transform: translateY(2rem);
	filter: blur(0.5rem);
	animation: sub-reveal 0.8s ease-out 1.8s forwards;
}
.pillbar {
	display: inline-flex;
	gap: 0.625rem;
	flex-wrap: wrap;
	justify-content: center;
}
.pill {
	border: 0.0625rem solid rgba(255, 255, 255, 0.12);
	background: var(--glass);
	padding: 0.5rem 0.875rem;
	border-radius: 62.4375rem;
	font-size: 0.9rem;
	color: #d8d8e0;
}
.scroll-indicator {
	position: absolute;
	/* left: 50%; */
	bottom: 1.625rem;
	transform: translateX(-50%);
	opacity: 0;
	font-size: 0.85rem;
	cursor: pointer;
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-direction: column;
}

.scroll-indicator:hover {
	opacity: 1;
	transform: translateX(-50%) translateY(-0.25rem);
}

.scroll-indicator:hover .scroll-text {
	color: var(--accent2);
}

.scroll-text {
	transition: color 0.3s ease;
	letter-spacing: 0.1em;
}

.scroll-arrow {
	position: relative;
	width: 1.5rem;
	height: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

.arrow-line {
	width: 0.125rem;
	height: 1.25rem;
	background: linear-gradient(
		to bottom,
		transparent 0%,
		var(--fg) 20%,
		var(--fg) 80%,
		transparent 100%
	);
	border-radius: 0.0625rem;
	animation: arrow-line-pulse 2s ease-in-out infinite;
	transition: all 0.3s ease;
}

.arrow-head {
	width: 0;
	height: 0;
	border-left: 0.375rem solid transparent;
	border-right: 0.375rem solid transparent;
	border-top: 0.5rem solid var(--fg);
	margin-top: -0.125rem;
	animation: arrow-head-bounce 2s ease-in-out infinite;
	transition: all 0.3s ease;
}

.scroll-indicator:hover .arrow-line {
	background: linear-gradient(
		to bottom,
		transparent 0%,
		var(--accent2) 20%,
		var(--accent2) 80%,
		transparent 100%
	);
	box-shadow: 0 0 0.5rem rgba(34, 211, 238, 0.4);
}

.scroll-indicator:hover .arrow-head {
	border-top-color: var(--accent2);
	filter: drop-shadow(0 0 0.5rem rgba(34, 211, 238, 0.6));
}
@keyframes pulse {
	0%,
	100% {
		opacity: 0.2;
		transform: translateY(0);
	}
	50% {
		opacity: 1;
		transform: translateY(0.375rem);
	}
}

@keyframes enhanced-pulse {
	0% {
		opacity: 0.3;
		transform: translateY(0) scale(1);
	}
	25% {
		opacity: 0.6;
		transform: translateY(0.125rem) scale(1.05);
	}
	50% {
		opacity: 1;
		transform: translateY(0.5rem) scale(1.1);
	}
	75% {
		opacity: 0.6;
		transform: translateY(0.125rem) scale(1.05);
	}
	100% {
		opacity: 0.3;
		transform: translateY(0) scale(1);
	}
}

@keyframes enhanced-pulse-fast {
	0% {
		opacity: 0.4;
		transform: translateY(0) scale(1);
	}
	50% {
		opacity: 1;
		transform: translateY(0.375rem) scale(1.15);
	}
	100% {
		opacity: 0.4;
		transform: translateY(0) scale(1);
	}
}

@keyframes arrow-line-pulse {
	0% {
		opacity: 0.4;
		transform: scaleY(0.8);
	}
	50% {
		opacity: 1;
		transform: scaleY(1.1);
	}
	100% {
		opacity: 0.4;
		transform: scaleY(0.8);
	}
}

@keyframes arrow-head-bounce {
	0% {
		opacity: 0.6;
		transform: translateY(0) scale(1);
	}
	25% {
		opacity: 0.8;
		transform: translateY(-0.125rem) scale(1.05);
	}
	50% {
		opacity: 1;
		transform: translateY(0.25rem) scale(1.1);
	}
	75% {
		opacity: 0.8;
		transform: translateY(-0.0625rem) scale(1.05);
	}
	100% {
		opacity: 0.6;
		transform: translateY(0) scale(1);
	}
}

/* Reveal Animation */
.reveal {
	opacity: 0;
	transform: translateY(1.25rem);
	filter: blur(0.5rem);
	transition: opacity 1s ease, transform 1s ease, filter 1.2s ease;
	transition-delay: calc(var(--reveal-delay, 0) * 1s);
}
.reveal.in {
	opacity: 1;
	transform: none;
	filter: none;
}

/* Panel */
.panel {
	position: relative;
	overflow: hidden;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.02),
		rgba(255, 255, 255, 0)
	);
	border: 0.0625rem solid rgba(255, 255, 255, 0.07);
	border-radius: 1.5rem;
	padding: 2rem;
	box-shadow: var(--glow);
}
.panel-content {
	position: relative;
	z-index: 2;
	color: #ffffff;
	/* mix-blend-mode: difference;
	text-shadow: 0 0 1rem rgba(255, 255, 255, 0.8); */
}

/* WHO Section - Enhanced Visual Design */
#who {
	position: relative;
	overflow: hidden;
}

.who-content {
	display: grid;
	grid-template-columns: 1fr 1.8fr;
	gap: 5rem;
	align-items: center;
	min-height: 70vh;
	padding: 2.5rem 0;
}

@media (max-width: 768px) {
	.who-content {
		grid-template-columns: 1fr;
		gap: 3.75rem;
		text-align: center;
		min-height: auto;
		padding: 4rem 0;
	}
	
	.who-visual {
		height: auto;
		min-height: 20rem;
	}
}

.who-visual {
	position: relative;
	height: 31.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
}

.section-floating-elements {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 1;
}

.floating-elements {
	position: absolute;
	inset: -3.125rem;
}

.float-element {
	position: absolute;
	width: 0.375rem;
	height: 0.375rem;
	border-radius: 50%;
	opacity: 0.7;
	animation: float 8s ease-in-out infinite;
	animation-delay: var(--delay, 0s);
	box-shadow: 0 0 1.25rem currentColor;
}

.float-element:nth-child(1) {
	top: 10%;
	left: 15%;
	background: var(--accent1);
	animation-duration: 9s;
}

.float-element:nth-child(2) {
	top: 25%;
	left: 75%;
	background: var(--accent2);
	animation-duration: 11s;
}

.float-element:nth-child(3) {
	top: 45%;
	left: 10%;
	background: var(--accent3);
	animation-duration: 7s;
}

.float-element:nth-child(4) {
	top: 15%;
	left: 90%;
	background: var(--accent1);
	animation-duration: 10s;
	opacity: 0.5;
}

.float-element:nth-child(5) {
	top: 60%;
	left: 85%;
	background: var(--accent2);
	animation-duration: 8.5s;
	opacity: 0.6;
}

.float-element:nth-child(6) {
	top: 80%;
	left: 20%;
	background: var(--accent3);
	animation-duration: 12s;
	opacity: 0.4;
}

.float-element:nth-child(7) {
	top: 35%;
	left: 50%;
	background: var(--accent1);
	animation-duration: 9.5s;
	opacity: 0.5;
}

.float-element:nth-child(8) {
	top: 70%;
	left: 65%;
	background: var(--accent2);
	animation-duration: 7.5s;
	opacity: 0.6;
}

.float-element:nth-child(9) {
	top: 90%;
	left: 45%;
	background: var(--accent3);
	animation-duration: 11.5s;
	opacity: 0.4;
}

.float-element:nth-child(10) {
	top: 5%;
	left: 40%;
	background: var(--accent1);
	animation-duration: 8s;
	opacity: 0.3;
}

.float-element:nth-child(11) {
	top: 55%;
	left: 5%;
	background: var(--accent2);
	animation-duration: 10.5s;
	opacity: 0.5;
}

.float-element:nth-child(12) {
	top: 75%;
	left: 95%;
	background: var(--accent3);
	animation-duration: 9s;
	opacity: 0.4;
}

.visual-logo {
	position: relative;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	transform: scale(1.2);
}

.logo-glow {
	position: absolute;
	width: 12.5rem;
	height: 12.5rem;
	background: radial-gradient(
		circle,
		rgba(159, 122, 234, 0.15) 0%,
		rgba(34, 211, 238, 0.1) 50%,
		transparent 70%
	);
	border-radius: 50%;
	animation: pulse-glow 4s ease-in-out infinite;
}

.visual-logo img {
	position: relative;
	z-index: 4;
	height: 8.75rem;
	width: auto;
	filter: drop-shadow(0 0 1.875rem rgba(159, 122, 234, 0.4));
	animation: logo-float 6s ease-in-out infinite;
}

.visual-accent {
	position: absolute;
	bottom: -1.25rem;
	right: -1.25rem;
	font-family: "JetBrains Mono", monospace;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--accent1);
	opacity: 0.6;
	animation: accent-pulse 3s ease-in-out infinite alternate;
}

.who-text {
	padding: 0;
	animation: slide-in-right 1s ease-out;
}

@keyframes float {
	0%,
	100% {
		transform: translate(0, 0) scale(1);
		opacity: 0.7;
	}
	33% {
		transform: translate(-0.9375rem, -1.5625rem) scale(1.1);
		opacity: 1;
	}
	66% {
		transform: translate(1.25rem, -0.625rem) scale(0.9);
		opacity: 0.8;
	}
}

@keyframes pulse-glow {
	0%,
	100% {
		transform: scale(1);
		opacity: 0.6;
	}
	50% {
		transform: scale(1.1);
		opacity: 0.8;
	}
}

@keyframes logo-float {
	0%,
	100% {
		transform: translateY(0rem) rotate(0deg);
	}
	50% {
		transform: translateY(-0.625rem) rotate(2deg);
	}
}

@keyframes accent-pulse {
	0% {
		opacity: 0.4;
		transform: scale(0.95);
	}
	100% {
		opacity: 0.8;
		transform: scale(1.05);
	}
}

@keyframes slide-in-right {
	0% {
		opacity: 0;
		transform: translateX(3.125rem);
	}
	100% {
		opacity: 1;
		transform: translateX(0);
	}
}

@media (max-width: 768px) {
	.who-content {
		grid-template-columns: 1fr;
		gap: 2rem;
		text-align: center;
		min-height: auto;
		padding: 3rem 0;
	}

	.who-visual {
		height: auto;
		min-height: 12rem;
		margin: 0 auto;
	}

	.visual-logo {
		transform: scale(1);
	}

	.visual-logo img {
		height: 6.25rem;
	}

	.logo-glow {
		width: 9.375rem;
		height: 9.375rem;
	}

	.who-stats {
		gap: 1.25rem;
	}

	.stat-item {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
		padding: 1.25rem;
	}

	.stat-icon {
		margin: 0 auto;
	}
}

/* NAV responsive tweaks for small screens */
@media (max-width: 640px) {
	.nav {
		inset: 0.75rem 0.75rem auto 0.75rem;
		gap: 0.5rem;
		padding: 0.5rem 0.75rem;
		align-items: center;
		/* keep items on a single row: logo and CTA */
		flex-wrap: nowrap;
		justify-content: space-between;
	}

	/* hide the brand text on very small screens to save space */
	.nav .brand-text {
		display: none;
	}

	/* hide non-contact nav links on mobile (keeps only the CTA visible) */
	.nav a.link {
		display: none;
	}

	/* reduce link size slightly and keep CTA prominent */
	.nav a.link,
	.nav .cta-nav {
		font-size: 0.86rem;
		padding: 0.45rem 0.75rem;
	}

	/* remove spacer so logo and contact sit together */
	.nav .spacer {
		display: none;
	}

	/* ensure CTA remains prominent but fits */
	.cta-nav {
		white-space: nowrap;
	}
}

/* Hide decorative pillbar in hero on small screens to reduce clutter */
@media (max-width: 640px) {
	.pillbar {
		display: none;
	}
}

/* Grid */
.grid {
	display: grid;
	gap: 1.5rem;
}
.grid.cols-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid.cols-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 900px) {
	.grid.cols-3 {
		grid-template-columns: 1fr 1fr;
	}
}
@media (max-width: 640px) {
	.grid.cols-2,
	.grid.cols-3 {
		grid-template-columns: 1fr;
	}
}

/* Card hover and touch improvements */
.card {
	position: relative;
	overflow: hidden;
	border-radius: 1.25rem;
	padding: 1.5rem;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.04),
		rgba(255, 255, 255, 0.02)
	);
	border: 0.0625rem solid rgba(255, 255, 255, 0.08);
	transform-style: preserve-3d;
	transition: transform 0.3s ease, border-color 0.3s;
	will-change: transform;
	touch-action: manipulation;
}
.card:hover {
	border-color: rgba(255, 255, 255, 0.2);
}
.card::after {
	content: "";
	position: absolute;
	inset: -0.125rem;
	background: radial-gradient(
		9.375rem 9.375rem at var(--mx, 50%) var(--my, 50%),
		rgba(159, 122, 234, 0.2),
		transparent 70%
	);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s;
}
.card:hover::after {
	opacity: 1;
}
.card h3 {
	margin: 0.375rem 0 0.625rem;
	font-size: 1.3rem;
	font-weight: 700;
}

/* Service card icons */
.service-icon {
	/* width: 3.5rem;
	height: 3.5rem; */
	flex-shrink: 0;
	display: flex;
	align-items: center;
	/* justify-content: center; */
	/* margin-right: 1rem;
	border-radius: 0.75rem;
	background: rgba(255, 255, 255, 0.02);
	border: 0.0625rem solid rgba(255, 255, 255, 0.04); */
}
.service-icon img {
	width: 5rem;
	height: 5rem;
	object-fit: contain;
	display: block;
}

/* Layout tweak: place icon and content inline on larger cards */
.arena.card .service-icon,
.card .service-icon {
	margin-bottom: 0.25rem;
}

@media (min-width: 641px) {
	.card {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}
}

/* Arenas (Industries) Section */
.arena.card {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	padding: 2rem;
	transition: transform 0.3s ease, background 0.3s ease;
}

.arena.card:hover {
	transform: translateY(-0.125rem);
}

.arena .icon {
	flex-shrink: 0;
	width: 3rem;
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(159, 122, 234, 0.1);
	border-radius: 0.75rem;
	border: 0.0625rem solid rgba(159, 122, 234, 0.2);
}

/* Industry images inside .icon */
.arena .icon img {
	width: 2rem;
	height: 2rem;
	object-fit: contain;
	display: block;
}

.arena .icon svg {
	width: 1.5rem;
	height: 1.5rem;
	stroke: var(--accent1);
	stroke-width: 1.5;
	fill: none;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.arena h3 {
	margin: 0 0 0.5rem 0;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--fg);
}

@media (max-width: 640px) {
	.arena.card {
		flex-direction: column;
		gap: 1rem;
		padding: 1.5rem;
		/* text-align: center; */
	}

	.arena .icon {
		margin: 0 auto;
	}
}

/* Contact */
.cta-block {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.875rem;
}
.cta-big {
	display: inline-flex;
	gap: 0.625rem;
	align-items: center;
	padding: 1rem 1.5rem;
	border-radius: 0.875rem;
	touch-action: manipulation;
}
.cta-big:hover {
	filter: brightness(1.1);
	transform: translateY(-0.1875rem);
	box-shadow: 0 0.625rem 1.25rem rgba(0, 0, 0, 0.2);
}

.cta-big {
	position: relative;
	overflow: hidden;
	border: 0.0625rem solid rgba(255, 255, 255, 0.1);
	background: linear-gradient(
			90deg,
			rgba(159, 122, 234, 0.22) 0%,
			rgba(34, 211, 238, 0.18) 45%,
			rgba(244, 114, 182, 0.17) 75%,
			rgba(159, 122, 234, 0.22) 100%
		),
		radial-gradient(
			80% 60% at 90% 10%,
			rgba(255, 255, 255, 0.03),
			transparent 30%
		);
	background-blend-mode: screen;
	background-size: 200% 100%;
	animation: gradient-move 3s linear infinite;
	font-weight: 800;
	font-size: 1.1rem;
	transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.2s ease;
}
.cta-big::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		100deg,
		rgba(255, 255, 255, 0.05),
		rgba(255, 255, 255, 0) 45%
	);
	mix-blend-mode: overlay;
	opacity: 0.7;
	transform: translateX(-50%);
	transition: transform 0.5s cubic-bezier(0.2, 0.9, 0.2, 1);
	pointer-events: none;
}
.cta-big:hover {
	transform: translateY(-0.25rem) scale(1.01);
	filter: brightness(1.07);
	box-shadow: 0 18px 40px rgba(34, 211, 238, 0.1),
		0 8px 26px rgba(159, 122, 234, 0.06);
}
.cta-big:hover::after {
	transform: translateX(0);
}

/* Animated gradient keyframes */
@keyframes gradient-move {
	0% {
		background-position: 0% 50%;
	}
	100% {
		background-position: 200% 50%;
	}
}

@keyframes gradient-move-slow {
	0% {
		background-position: 0% 50%;
	}
	100% {
		background-position: 200% 50%;
	}
}
form[name="contact"] {
	margin-top: 1.5rem;
	width: 100%;
	max-width: 40rem;
	display: grid;
	gap: 0.75rem;
}
form[name="contact"] .form-row {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: 1fr 1fr;
}
form[name="contact"] input,
form[name="contact"] textarea {
	padding: 0.75rem 0.875rem;
	border-radius: 0.625rem;
	border: 0.0625rem solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	color: var(--fg);
	font-family: "Satoshi", sans-serif;
	font-size: 1rem;
	transition: border-color 0.2s, box-shadow 0.2s;
}

form[name="contact"] input:focus,
form[name="contact"] textarea:focus {
	border-color: var(--accent2);
	box-shadow: 0 0 0 0.125rem rgba(34, 211, 238, 0.3);
	outline: none;
}
form[name="contact"] button {
	margin-top: 0.75rem;
}

/* Make form submit buttons visually match CTA style */
form[name="contact"] button.cta-big,
form[name="contact"] button[type="submit"] {
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	color: var(--fg);
	background: linear-gradient(
		90deg,
		rgba(159, 122, 234, 0.22) 0%,
		rgba(34, 211, 238, 0.18) 45%,
		rgba(244, 114, 182, 0.17) 75%,
		rgba(159, 122, 234, 0.22) 100%
	);
	border: 0.0625rem solid rgba(255, 255, 255, 0.1);
	padding: 0.9rem 1.25rem;
	border-radius: 0.75rem;
	font-weight: 700;
	transition: transform 0.22s ease, box-shadow 0.22s ease, filter 0.18s ease;
	background-blend-mode: screen;
	background-size: 300% 100%;
	animation: gradient-move 2.5s ease-in-out infinite;
}
form[name="contact"] button[type="submit"]:hover {
	transform: translateY(-0.18rem) scale(1.01);
	filter: brightness(1.06);
	box-shadow: 0 14px 28px rgba(34, 211, 238, 0.08),
		0 6px 18px rgba(159, 122, 234, 0.05);
}

form[name="contact"] button[type="submit"] {
	touch-action: manipulation;
}

/* Animation Timing Hierarchy */
.eyebrow.reveal {
	--reveal-delay: 0.1;
}

h2.reveal {
	--reveal-delay: 0.2;
}

.reveal.panel {
	--reveal-delay: 0.3;
}

p.reveal, .who-text p {
	--reveal-delay: 0.3;
}

.who-text .eyebrow {
	--reveal-delay: 0.1;
}

.who-text h2 {
	--reveal-delay: 0.2;
}

/* Contact section hierarchy */
.cta-block .eyebrow {
	--reveal-delay: 0.1;
}

.cta-block h2 {
	--reveal-delay: 0.2;
}

.cta-block p {
	--reveal-delay: 0.3;
}

.contact-actions {
	--reveal-delay: 0.4;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.logo,
	.scroll-indicator .dot {
		animation: none;
	}
	.card,
	.cta-nav,
	.cta-big {
		transition: none;
		animation: none !important;
	}
}
