:root {
	--bg: #11262d;
	--bg-2: #16323b;
	--panel: rgba(18, 48, 57, 0.72);
	--line: rgba(255, 255, 255, 0.1);
	--text: #f6f3ea;
	--muted: #b8c7cb;
	--blue: #30afe5;
	--pink: #ee3e96;
	--violet: #ee3e96;
	--cyan: #30afe5;
	--yellow: #f8c018;
	--orange: #f26722;
	--shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}
* {
	box-sizing: border-box;
}
html {
	scroll-behavior: smooth;
}
body {
	margin: 0;
	min-height: 100vh;
	overflow-x: hidden;
	font-family: "Outfit", sans-serif;
	color: var(--text);
	background:
		radial-gradient(
			circle at 15% 15%,
			rgba(238, 62, 150, 0.16),
			transparent 22%
		),
		radial-gradient(
			circle at 85% 20%,
			rgba(48, 175, 229, 0.16),
			transparent 20%
		),
		radial-gradient(
			circle at 50% 90%,
			rgba(248, 192, 24, 0.1),
			transparent 30%
		),
		linear-gradient(180deg, #11262d 0%, #132c34 45%, #102228 100%);
	position: relative;
}
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 80px 80px;
	opacity: 0.18;
}
a {
	color: inherit;
	text-decoration: none;
}
.site-header,
.section,
.ticker-wrap {
	width: min(1320px, calc(100% - 56px));
	margin-inline: auto;
	position: relative;
	z-index: 2;
}
.site-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px 0 12px;
}
.brand-lockup {
	display: flex;
	align-items: center;
	gap: 12px;
}
.brand-mark {
	width: 18px;
	height: 18px;
	border-radius: 5px;
	background: linear-gradient(
		135deg,
		var(--yellow),
		var(--orange) 34%,
		var(--pink) 68%,
		var(--blue)
	);
	box-shadow: 0 0 25px rgba(242, 103, 34, 0.28);
}
.brand-name,
.top-nav {
	font-family: "Space Grotesk", sans-serif;
}
.brand-name {
	font-size: 0.96rem;
	font-weight: 700;
	letter-spacing: 0.04em;
}
.top-nav {
	display: flex;
	gap: 26px;
	color: rgba(246, 243, 234, 0.72);
	font-size: 0.88rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.section {
	padding: 76px 0;
}
.hero {
	min-height: 88vh;
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(520px, 0.95fr);
	gap: 72px;
	align-items: center;
}
.eyebrow,
.panel-kicker,
.card-label {
	margin: 0 0 14px;
	font-size: 0.82rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--yellow);
	font-family: "Space Grotesk", sans-serif;
}
h1,
h2,
h3,
p {
	margin-top: 0;
}
h1 {
	max-width: 10ch;
	margin-bottom: 24px;
	font-size: clamp(3.8rem, 8.7vw, 7.8rem);
	line-height: 0.88;
	letter-spacing: -0.05em;
	color: #ffffff;
}
h1 span {
	display: block;
	background: linear-gradient(
		90deg,
		var(--yellow),
		var(--orange) 28%,
		var(--pink) 62%,
		var(--blue)
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
h2 {
	font-size: clamp(2rem, 3vw, 3.4rem);
	line-height: 0.98;
	letter-spacing: -0.04em;
	margin-bottom: 18px;
	color: #ffffff;
}
h3 {
	font-size: 1.4rem;
	line-height: 1.12;
	margin-bottom: 12px;
	color: #ffffff;
}
p,
li {
	color: var(--muted);
	font-size: 1.02rem;
	line-height: 1.7;
}
.lead {
	max-width: 56ch;
	font-size: 1.08rem;
}
.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 34px;
}
.hero-meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-top: 30px;
}
.hero-meta div {
	padding-top: 14px;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.meta-label {
	display: block;
	margin-bottom: 8px;
	color: var(--yellow);
	font-family: "Space Grotesk", sans-serif;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.hero-meta strong {
	color: rgba(246, 243, 234, 0.92);
	font-weight: 500;
	line-height: 1.4;
}
.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 22px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	font-weight: 600;
	transition:
		transform 0.25s ease,
		border-color 0.25s ease,
		background 0.25s ease;
}
.button.primary {
	background: linear-gradient(
		90deg,
		rgba(248, 192, 24, 0.2),
		rgba(242, 103, 34, 0.2) 34%,
		rgba(238, 62, 150, 0.2) 68%,
		rgba(48, 175, 229, 0.2)
	);
	border-color: rgba(248, 192, 24, 0.32);
	box-shadow: 0 16px 34px rgba(242, 103, 34, 0.18);
}
.button.ghost {
	background: rgba(255, 255, 255, 0.06);
}
.scene {
	position: relative;
	min-height: 700px;
	perspective: 1600px;
	transform-style: preserve-3d;
	isolation: isolate;
	border-radius: 36px;
	background:
		radial-gradient(
			circle at 22% 24%,
			rgba(238, 62, 150, 0.14),
			transparent 24%
		),
		radial-gradient(
			circle at 78% 74%,
			rgba(48, 175, 229, 0.14),
			transparent 28%
		),
		linear-gradient(180deg, rgba(21, 48, 57, 0.94), rgba(17, 38, 45, 0.92));
	border: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.08),
		0 30px 80px rgba(0, 0, 0, 0.22);
}
.scene-tag {
	position: absolute;
	left: 24px;
	top: 22px;
	z-index: 5;
	padding: 10px 14px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: rgba(246, 243, 234, 0.76);
	font-family: "Space Grotesk", sans-serif;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.visual-orb,
.data-core,
.orbit,
.beam,
.floating-card,
.cube,
.ring,
.scene-haze,
.signal-net {
	position: absolute;
}
.visual-orb {
	right: 12%;
	top: 14%;
	width: 180px;
	height: 180px;
	border-radius: 50%;
	background:
		radial-gradient(
			circle at 30% 30%,
			rgba(255, 255, 255, 0.16),
			transparent 30%
		),
		linear-gradient(135deg, rgba(255, 79, 216, 0.3), rgba(99, 245, 255, 0.18));
	filter: blur(2px);
	opacity: 0.8;
	box-shadow: 0 0 60px rgba(217, 70, 239, 0.1);
	z-index: 1;
}
.data-core {
	left: 50%;
	top: 50%;
	width: 280px;
	height: 280px;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background:
		radial-gradient(circle, rgba(99, 245, 255, 0.22), transparent 34%),
		radial-gradient(circle, rgba(255, 79, 216, 0.16), transparent 58%);
	filter: blur(18px);
	animation: corePulse 9s ease-in-out infinite;
	z-index: 0;
}
.scene-haze {
	inset: 8% 4% 6% 4%;
	background:
		radial-gradient(
			circle at 28% 26%,
			rgba(255, 79, 216, 0.2),
			transparent 18%
		),
		radial-gradient(
			circle at 72% 72%,
			rgba(99, 245, 255, 0.18),
			transparent 24%
		),
		radial-gradient(
			circle at 56% 44%,
			rgba(138, 92, 255, 0.12),
			transparent 26%
		);
	filter: blur(28px);
	z-index: 0;
}
.ring {
	border-radius: 50%;
	border: 1px solid rgba(17, 24, 39, 0.06);
	box-shadow: 0 0 30px rgba(47, 128, 255, 0.04);
}
.ring-a {
	left: 10%;
	right: 12%;
	bottom: 20%;
	height: 140px;
	transform: rotateX(78deg);
}
.ring-b {
	left: 18%;
	right: 24%;
	bottom: 40%;
	height: 90px;
	opacity: 0.5;
	transform: rotateX(78deg);
}
.signal-net {
	border-radius: 50%;
	opacity: 0.7;
	z-index: 1;
}
.signal-net::before,
.signal-net::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
}
.signal-net-a {
	left: 6%;
	top: 18%;
	width: 240px;
	height: 240px;
	border: 1px solid rgba(99, 245, 255, 0.08);
	animation: driftA 18s ease-in-out infinite;
}
.signal-net-a::before {
	background:
		radial-gradient(
			circle at 20% 30%,
			rgba(99, 245, 255, 0.95) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 48% 18%,
			rgba(255, 79, 216, 0.9) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 72% 34%,
			rgba(255, 225, 98, 0.92) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 36% 70%,
			rgba(110, 182, 255, 0.95) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 78% 78%,
			rgba(99, 245, 255, 0.9) 0 1px,
			transparent 2px
		);
}
.signal-net-a::after {
	background:
		linear-gradient(
			125deg,
			transparent 28%,
			rgba(99, 245, 255, 0.34) 29%,
			transparent 30%
		),
		linear-gradient(
			152deg,
			transparent 44%,
			rgba(255, 79, 216, 0.28) 45%,
			transparent 46%
		);
}
.signal-net-b {
	right: 4%;
	bottom: 14%;
	width: 300px;
	height: 300px;
	border: 1px solid rgba(255, 255, 255, 0.06);
	animation: driftB 22s ease-in-out infinite;
}
.signal-net-b::before {
	background:
		radial-gradient(
			circle at 18% 58%,
			rgba(255, 225, 98, 0.95) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 34% 22%,
			rgba(255, 79, 216, 0.9) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 62% 36%,
			rgba(99, 245, 255, 0.95) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 72% 72%,
			rgba(110, 182, 255, 0.95) 0 1px,
			transparent 2px
		),
		radial-gradient(
			circle at 48% 84%,
			rgba(188, 142, 255, 0.92) 0 1px,
			transparent 2px
		);
}
.orbit {
	border-radius: 50%;
	border: 1px solid rgba(17, 24, 39, 0.08);
	transform-style: preserve-3d;
	opacity: 0.5;
}
.orbit-a {
	inset: 5% 8% auto auto;
	width: 420px;
	height: 420px;
	transform: rotateX(74deg) rotateZ(18deg);
}
.orbit-b {
	inset: auto auto 8% 6%;
	width: 360px;
	height: 360px;
	transform: rotateX(72deg) rotateZ(-22deg);
}
.floating-card,
.glass-panel,
.stack-card,
.news-card,
.impact-card {
	background: linear-gradient(
		180deg,
		rgba(20, 52, 61, 0.82),
		rgba(16, 38, 45, 0.78)
	);
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow:
		0 20px 60px rgba(0, 0, 0, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.06);
	backdrop-filter: blur(22px);
}
.floating-card {
	border-radius: 26px;
	padding: 26px;
	transform-style: preserve-3d;
	overflow: hidden;
}
.floating-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 48%),
		radial-gradient(
			circle at 20% 18%,
			rgba(255, 79, 216, 0.14),
			transparent 34%
		);
	pointer-events: none;
}
.card-main {
	inset: 20% 18% auto auto;
	width: 360px;
	transform: translate3d(var(--px, 0), var(--py, 0), 0) rotateY(-24deg)
		rotateX(12deg);
	z-index: 3;
}
.card-side {
	left: 8%;
	bottom: 15%;
	width: 250px;
	transform: translate3d(var(--px, 0), var(--py, 0), 0) rotateY(24deg)
		rotateX(-8deg);
	z-index: 3;
}
.mini-stat {
	display: block;
	margin-bottom: 12px;
	font-size: 3.4rem;
	font-weight: 800;
	line-height: 1;
	background: linear-gradient(180deg, var(--cyan), var(--blue));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.beam {
	border-radius: 999px;
	filter: blur(1px);
}
.beam-a {
	inset: 20% 16% auto auto;
	width: 420px;
	height: 7px;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 79, 216, 0.05),
		rgba(255, 79, 216, 0.9),
		transparent
	);
	transform: rotate(-36deg) translateZ(80px);
	box-shadow: 0 0 24px rgba(255, 79, 216, 0.55);
	z-index: 2;
}
.beam-b {
	inset: auto auto 16% 10%;
	width: 360px;
	height: 7px;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(99, 245, 255, 0.08),
		rgba(99, 245, 255, 0.95),
		transparent
	);
	transform: rotate(29deg) translateZ(70px);
	box-shadow: 0 0 24px rgba(99, 245, 255, 0.55);
	z-index: 2;
}
.beam-c {
	inset: 34% auto auto 30%;
	width: 210px;
	height: 3px;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(182, 137, 255, 0.9),
		transparent
	);
	transform: rotate(-18deg) translateZ(70px);
	box-shadow: 0 0 20px rgba(182, 137, 255, 0.45);
	opacity: 0.6;
}
.cube {
	width: 170px;
	height: 170px;
	transform-style: preserve-3d;
	transform: translate3d(var(--px, 0), var(--py, 0), 0);
	animation: spinCube 34s linear infinite;
	filter: drop-shadow(0 0 26px rgba(255, 151, 239, 0.22));
}
.cluster-one {
	top: 10%;
	left: 8%;
}
.cluster-two {
	right: 10%;
	bottom: 6%;
	width: 230px;
	height: 230px;
	animation-direction: reverse;
	animation-duration: 42s;
}
.face {
	position: absolute;
	inset: 0;
	border: 1px solid rgba(185, 228, 255, 0.28);
	background:
		linear-gradient(180deg, rgba(30, 152, 201, 0.18), rgba(30, 152, 201, 0.08)),
		radial-gradient(
			circle at 35% 30%,
			rgba(255, 255, 255, 0.22),
			transparent 46%
		),
		rgba(255, 255, 255, 0.05);
	box-shadow:
		inset 0 0 34px rgba(255, 255, 255, 0.08),
		inset 0 0 70px rgba(30, 152, 201, 0.06),
		0 0 34px rgba(30, 152, 201, 0.12);
	backdrop-filter: blur(20px);
}
.cube .front {
	transform: translateZ(85px);
}
.cube .back {
	transform: rotateY(180deg) translateZ(85px);
}
.cube .left {
	transform: rotateY(-90deg) translateZ(85px);
}
.cube .right {
	transform: rotateY(90deg) translateZ(85px);
}
.cube .top {
	transform: rotateX(90deg) translateZ(85px);
}
.cube .bottom {
	transform: rotateX(-90deg) translateZ(85px);
}
.cluster-two .front {
	transform: translateZ(115px);
}
.cluster-two .back {
	transform: rotateY(180deg) translateZ(115px);
}
.cluster-two .left {
	transform: rotateY(-90deg) translateZ(115px);
}
.cluster-two .right {
	transform: rotateY(90deg) translateZ(115px);
}
.cluster-two .top {
	transform: rotateX(90deg) translateZ(115px);
}
.cluster-two .bottom {
	transform: rotateX(-90deg) translateZ(115px);
}
.ticker-wrap {
	margin-top: 8px;
	margin-bottom: 20px;
}
.signal-rail {
	padding: 24px 28px 28px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 28px;
	background:
		linear-gradient(180deg, rgba(20, 52, 61, 0.8), rgba(17, 38, 45, 0.74)),
		radial-gradient(
			circle at top left,
			rgba(242, 103, 34, 0.12),
			transparent 28%
		);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.16);
}
.rail-lead {
	margin-bottom: 18px;
	color: rgba(246, 243, 234, 0.9);
	font-size: 1.2rem;
	font-weight: 600;
}
.rail-marquee {
	overflow: hidden;
	width: 100%;
}
.rail-track {
	display: flex;
	align-items: center;
	gap: 12px;
	width: max-content;
	white-space: nowrap;
	animation: railScroll 42s linear infinite;
}
.rail-track span {
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.06);
	color: rgba(246, 243, 234, 0.72);
	font-family: "Space Grotesk", sans-serif;
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	flex: 0 0 auto;
}
.hero-copy,
.section-heading,
.immersive-copy,
.showcase-left,
.footer-copy {
	position: relative;
}
.hero-copy::after,
.section-heading::after,
.immersive-copy::after {
	content: "";
	position: absolute;
	left: 0;
	top: -24px;
	width: 90px;
	height: 1px;
	background: linear-gradient(90deg, rgba(248, 192, 24, 0.9), transparent);
}
.section-heading {
	max-width: 780px;
	margin-bottom: 34px;
}
.manifesto-section {
	padding-top: 28px;
}
.manifesto-head {
	max-width: 900px;
	margin-bottom: 28px;
}
.manifesto-grid,
.awards-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}
.manifesto-panel,
.awards-card {
	position: relative;
	padding: 28px;
	border-radius: 28px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background:
		linear-gradient(180deg, rgba(20, 52, 61, 0.82), rgba(16, 38, 45, 0.78)),
		radial-gradient(
			circle at top right,
			rgba(238, 62, 150, 0.12),
			transparent 30%
		);
	box-shadow: 0 16px 48px rgba(0, 0, 0, 0.14);
}
.manifesto-index {
	display: inline-block;
	margin-bottom: 18px;
	color: var(--yellow);
	font-family: "Space Grotesk", sans-serif;
	font-size: 0.9rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}
.section-grid {
	padding-top: 70px;
}
.ecosystem-layout {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: 20px;
}
.narrative-grid {
	grid-template-columns: 1.2fr 1fr 1fr;
}
.glass-panel,
.stack-card,
.news-card,
.impact-card {
	border-radius: 28px;
	padding: 30px;
	position: relative;
	overflow: hidden;
	transform-style: preserve-3d;
}
.glass-panel.large {
	min-height: 100%;
	grid-row: span 2;
}
.stat-number {
	display: block;
	margin-bottom: 18px;
	font-size: 3.1rem;
	line-height: 1;
	font-weight: 800;
	color: #1e98c9;
}
.immersive-section {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 24px;
	align-items: start;
}
.dual-story {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
}
.editorial-break {
	padding-top: 26px;
	padding-bottom: 26px;
}
.editorial-copy {
	max-width: 980px;
	margin: 0 auto;
	text-align: center;
}
.editorial-copy h2 {
	font-size: clamp(2.6rem, 5vw, 5.2rem);
	line-height: 0.94;
	margin-bottom: 18px;
}
.editorial-copy p {
	max-width: 680px;
	margin-inline: auto;
}
.detail-section {
	padding-top: 12px;
}
.detail-grid,
.service-grid {
	display: grid;
	gap: 20px;
}
.detail-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}
.verticals-section {
	padding-top: 18px;
}
.immersive-marquee {
	padding-top: 10px;
}
.marquee-panel {
	display: grid;
	grid-template-columns: 1.25fr 1fr;
	gap: 22px;
	align-items: end;
	padding: 34px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 34px;
	background:
		radial-gradient(
			circle at top left,
			rgba(242, 103, 34, 0.12),
			transparent 24%
		),
		radial-gradient(
			circle at bottom right,
			rgba(48, 175, 229, 0.12),
			transparent 22%
		),
		linear-gradient(180deg, rgba(20, 52, 61, 0.84), rgba(16, 38, 45, 0.8));
	box-shadow: 0 22px 60px rgba(0, 0, 0, 0.16);
}
.marquee-copy h2 {
	font-size: clamp(2.4rem, 4vw, 4.6rem);
	line-height: 0.92;
	margin-bottom: 0;
}
.marquee-stats {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}
.marquee-stats div {
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.marquee-stats strong {
	color: rgba(246, 243, 234, 0.94);
	font-weight: 600;
}
.service-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.service-card {
	position: relative;
	overflow: hidden;
	min-height: 100%;
	padding: 30px;
	border-radius: 28px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background:
		linear-gradient(180deg, rgba(20, 52, 61, 0.84), rgba(16, 38, 45, 0.8)),
		radial-gradient(
			circle at top right,
			rgba(238, 62, 150, 0.12),
			transparent 30%
		);
	box-shadow: var(--shadow);
	backdrop-filter: blur(20px);
}
.service-media {
	height: 220px;
	margin: -30px -30px 22px;
	border-bottom: 1px solid rgba(17, 24, 39, 0.08);
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	position: relative;
	overflow: hidden;
}

.service-kicker {
	margin-bottom: 14px;
	color: var(--cyan);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-size: 0.8rem;
	font-family: "Space Grotesk", sans-serif;
}
.bullet-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 20px;
}
.bullet-list span {
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 0 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.1);
	color: rgba(246, 243, 234, 0.9);
	font-size: 0.9rem;
}
.stack-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}
.stack-card {
	min-height: 220px;
}
.stack-card span {
	display: inline-block;
	margin-bottom: 18px;
	color: var(--cyan);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-size: 0.76rem;
	font-family: "Space Grotesk", sans-serif;
}
.stack-card strong {
	display: block;
	font-size: 1.38rem;
	line-height: 1.25;
	font-weight: 600;
	color: #ffffff;
}
.showcase {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 34px;
	align-items: center;
}
.showcase-right {
	position: relative;
	min-height: 440px;
	perspective: 1200px;
}
.prism {
	position: absolute;
	inset: 12% 18% 12% 18%;
	border-radius: 28px;
	background:
		linear-gradient(135deg, rgba(30, 152, 201, 0.8), rgba(30, 152, 201, 0.08)),
		linear-gradient(180deg, rgba(255, 255, 255, 0.5), transparent);
	box-shadow: 0 30px 90px rgba(5, 7, 18, 0.12);
}
.impact-card {
	position: absolute;
	right: 6%;
	bottom: 6%;
	width: min(360px, 90%);
	transform: rotateY(-18deg) rotateX(6deg);
}
.impact-line {
	display: block;
	width: 64px;
	height: 3px;
	margin-bottom: 18px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--cyan), var(--pink));
}
.news-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}
.awards-moment {
	padding-top: 18px;
	padding-bottom: 26px;
}
.awards-copy {
	max-width: 780px;
	margin-bottom: 26px;
}
.news-visual {
	height: 210px;
	border-radius: 20px;
	margin-bottom: 22px;
	border: 1px solid rgba(17, 24, 39, 0.1);
}
.gradient-a {
	background:
		radial-gradient(
			circle at 30% 30%,
			rgba(99, 245, 255, 0.6),
			transparent 24%
		),
		linear-gradient(135deg, #e9effd, #f9fbff 50%, #ebf2ff);
}
.gradient-b {
	background:
		linear-gradient(135deg, rgba(255, 79, 216, 0.24), transparent 40%),
		radial-gradient(
			circle at 70% 40%,
			rgba(99, 245, 255, 0.2),
			transparent 26%
		),
		#f4f7fd;
}
.gradient-c {
	background:
		linear-gradient(180deg, rgba(110, 182, 255, 0.24), transparent 30%),
		radial-gradient(
			circle at 50% 60%,
			rgba(138, 92, 255, 0.24),
			transparent 34%
		),
		#f3f5fb;
}
.site-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	margin-bottom: 40px;
	padding: 34px 0 60px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition:
		opacity 1.1s ease,
		transform 1.1s ease;
}
.reveal.in-view {
	opacity: 1;
	transform: translateY(0);
}
.tilt-card:hover {
	border-color: rgba(99, 245, 255, 0.28);
	box-shadow: 0 34px 90px rgba(0, 0, 0, 0.12);
}
@keyframes spinCube {
	from {
		transform: rotateX(-24deg) rotateY(0deg);
	}
	to {
		transform: rotateX(-24deg) rotateY(360deg);
	}
}
@keyframes corePulse {
	0%,
	100% {
		opacity: 0.55;
		transform: translate(-50%, -50%) scale(0.92);
	}
	50% {
		opacity: 1;
		transform: translate(-50%, -50%) scale(1.08);
	}
}
@keyframes driftA {
	0%,
	100% {
		transform: translate3d(0, 0, 0) rotate(0deg);
	}
	50% {
		transform: translate3d(14px, -12px, 0) rotate(8deg);
	}
}
@keyframes driftB {
	0%,
	100% {
		transform: translate3d(0, 0, 0) rotate(0deg);
	}
	50% {
		transform: translate3d(-16px, 10px, 0) rotate(-7deg);
	}
}
@keyframes railScroll {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-50%);
	}
}
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation: none !important;
		transition: none !important;
		scroll-behavior: auto !important;
	}
	.reveal {
		opacity: 1;
		transform: none;
	}
}
@media (max-width: 1100px) {
	.hero,
	.immersive-section,
	.showcase,
	.ecosystem-layout,
	.news-grid,
	.detail-grid,
	.manifesto-grid,
	.awards-grid,
	.marquee-panel {
		grid-template-columns: 1fr;
	}
	.ecosystem-layout {
		grid-template-columns: 1fr 1fr;
	}
	.glass-panel.large {
		grid-row: auto;
		grid-column: 1 / -1;
	}
	.scene {
		min-height: 580px;
	}
	.site-footer {
		flex-direction: column;
		align-items: flex-start;
	}
}
@media (max-width: 820px) {
	.site-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
	}
	.top-nav {
		flex-wrap: wrap;
		gap: 14px;
		font-size: 0.88rem;
	}
	.hero {
		min-height: auto;
		padding-top: 30px;
	}
	.scene {
		min-height: 460px;
	}
	.card-main {
		width: 270px;
		right: 10%;
	}
	.card-side {
		left: 4%;
		width: 200px;
	}
	.stack-grid,
	.news-grid,
	.ecosystem-layout,
	.dual-story,
	.service-grid,
	.detail-grid,
	.manifesto-grid,
	.awards-grid,
	.marquee-stats,
	.hero-meta {
		grid-template-columns: 1fr;
	}
	.featured-services .service-card:nth-child(1),
	.featured-services .service-card:nth-child(4) {
		transform: none;
	}
}
@media (max-width: 600px) {
	.site-header,
	.section,
	.ticker-wrap {
		width: min(100% - 24px, 1320px);
	}
	.section {
		padding: 44px 0;
	}
	h1 {
		max-width: none;
		font-size: clamp(2.7rem, 15vw, 4.4rem);
	}
	h2 {
		font-size: clamp(1.8rem, 8vw, 2.8rem);
	}
	.lead,
	p,
	li {
		font-size: 0.98rem;
	}
	.scene {
		min-height: 390px;
	}
	.orbit-a,
	.orbit-b,
	.beam,
	.cluster-two,
	.ring-b,
	.signal-net-b {
		display: none;
	}
	.card-main {
		inset: 8% 6% auto auto;
		width: 230px;
	}
	.card-side {
		left: 4%;
		bottom: 8%;
	}
	.glass-panel,
	.stack-card,
	.news-card,
	.impact-card,
	.floating-card,
	.service-card,
	.signal-rail {
		padding: 22px;
		border-radius: 22px;
	}
	.service-media {
		margin: -22px -22px 18px;
		height: 180px;
	}
	.scene-tag {
		left: 16px;
		top: 16px;
	}
}

.detail-page {
	background:
		radial-gradient(
			circle at top left,
			rgba(217, 70, 239, 0.08),
			transparent 22%
		),
		radial-gradient(
			circle at top right,
			rgba(6, 182, 212, 0.08),
			transparent 18%
		),
		linear-gradient(180deg, #fbfcff 0%, #f4f7fb 50%, #eef3fa 100%);
}

.global-header,
.detail-main,
.detail-footer {
	width: min(1320px, calc(100% - 56px));
	margin-inline: auto;
}

.global-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px 0 10px;
}

.brand {
	font-family: "Space Grotesk", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.main-nav {
	display: flex;
	gap: 24px;
	font-family: "Space Grotesk", sans-serif;
	font-size: 0.82rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(17, 24, 39, 0.62);
}

.detail-main {
	padding: 18px 0 72px;
	z-index: 999999;
	position: relative;
}

.detail-hero {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1fr);
	gap: 36px;
	align-items: start;
}

.detail-copy h1 {
	max-width: 11ch;
	margin-bottom: 16px;
	font-size: clamp(2.8rem, 6vw, 5rem);
	line-height: 1.14;
	letter-spacing: -0.05em;
}

.detail-visual {
	min-height: 520px;
	border-radius: 32px;
	border: 1px solid rgba(17, 24, 39, 0.08);
	box-shadow: var(--shadow);
}

.detail-lead {
	max-width: 58ch;
	margin-bottom: 22px;
}

.detail-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
	margin-top: 26px;
}
.detail-marquee,
.capability-card,
.process-card,
.cta-panel {
	border-radius: 28px;
	border: 1px solid rgba(17, 24, 39, 0.08);
	box-shadow: var(--shadow);
}

.detail-stats article,
.detail-content-grid article,
.capability-card,
.process-card,
.cta-panel {
	padding: 28px;
}

.detail-stats strong {
	display: block;
	margin-bottom: 10px;
	font-size: 2rem;
	line-height: 1;
	color: var(--cyan);
}

.detail-marquee {
	margin: 34px 0;
	padding: 26px 30px;
}

.detail-marquee p {
	max-width: 72ch;
	margin-bottom: 0;
}

.detail-content-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	margin: 26px 0 34px;
}

.detail-content-grid h2,
.capability-card h3,
.process-card h3,
.cta-panel h2 {
	font-size: 1.45rem;
	line-height: 1.08;
	letter-spacing: -0.03em;
}

.capability-grid,
.process-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-bottom: 34px;
	gap: 20px;
	justify-items: center;
}

.capability-card span,
.process-card span {
	display: inline-block;
	margin-bottom: 12px;
	font-size: 0.82rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--yellow);
}

.process-card ol {
	margin: 0;
	padding-left: 18px;
	color: var(--muted);
}

.cta-panel {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
}

.cta-panel .button {
	white-space: nowrap;
}

@media (max-width: 1100px) {
	.detail-hero,
	.detail-content-grid,
	.capability-grid,
	.process-grid,
	.cta-panel {
		grid-template-columns: 1fr;
	}

	.detail-stats {
		grid-template-columns: 1fr;
	}

	.cta-panel {
		align-items: flex-start;
	}
}

@media (max-width: 720px) {
	.global-header,
	.detail-main,
	.detail-footer {
		width: min(100% - 24px, 1320px);
	}

	.global-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 14px;
	}

	.main-nav {
		flex-wrap: wrap;
		gap: 14px;
	}

	.detail-visual {
		min-height: 320px;
		border-radius: 24px;
	}

	.detail-stats article,
	.detail-content-grid article,
	.detail-marquee,
	.capability-card,
	.process-card,
	.cta-panel {
		padding: 22px;
		border-radius: 22px;
	}
}
.service-media img {
	opacity: 0.6;
}
.detail-visual img {
	border-radius: 12px;
}
