:root {
	/* Updated Color Palette */
	--c-bg: #221b00; /* color3 - main background */
	--c-bg-2: #333100; /* slightly lighter variant of color3 */
	--c-ink: #001110; /* darker than color3 for deep elements */
	--c-t: #e2e2e2; /* color5 - main text */
	--c-d: #717978; /* color4 - dimmed text */
	--c-cyan: #ae00ff; /* color1 - main accent */
	--c-mag: #e44eff; /* color2 - secondary accent */
	--c-vio: #c800ff; /* color1 variant for gradients */
	--c-lime: #c44eff; /* color2 for lime accents */
}

* {
	box-sizing: border-box;
}
body,
html {
	margin: 0;
	padding: 0;
	background: var(--c-bg);
	color: var(--c-t);
	font:
		400 16px/1.6 system-ui,
		-apple-system,
		Segoe UI,
		Roboto,
		Ubuntu,
		'Helvetica Neue',
		'Noto Sans',
		Arial,
		sans-serif;
}
img {
	max-width: 100%;
	display: block;
}
a {
	color: var(--c-cyan);
	text-decoration: none;
}
:focus-visible {
	outline: 2px dashed var(--c-cyan);
	outline-offset: 2px;
}

.u-vh {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	overflow: hidden;
	white-space: nowrap;
}
.u-max {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 1rem;
}
@media (min-width: 960px) {
	.u-max {
		padding: 0 2rem;
	}
}

.s-14010101 {
	position: sticky;
	top: 0;
	z-index: 60;
	background: linear-gradient(
		180deg,
		rgba(0, 34, 32, 0.92),
		rgba(0, 34, 32, 0.45)
	);
	backdrop-filter: saturate(1.2) blur(10px);
	border-bottom: 1px solid rgba(226, 226, 226, 0.06);
	padding: 20px 0;
}
.s-14010102 {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0.6rem 1rem;
	display: flex;
	align-items: center;
	gap: 0.9rem;
	justify-content: space-between;
}
.s-14010103 {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	font-size: 30px;
}
.s-14010104 {
	width: 36px;
	height: 36px;
	filter: drop-shadow(0 0 8px rgba(0, 255, 243, 0.75));
}
.s-14010105 {
	font-weight: 900;
	letter-spacing: 0.4px;
}
.s-14010105 i {
	font-style: normal;
	background: linear-gradient(
		90deg,
		var(--c-cyan),
		var(--c-lime),
		var(--c-mag)
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.s-14010101 nav {
	display: none;
}
.s-14010106 {
	display: inline-grid;
	gap: 0.25rem;
}
.s-14010106 span {
	width: 26px;
	height: 2px;
	background: linear-gradient(90deg, var(--c-lime), var(--c-cyan));
	border-radius: 2px;
	transition:
		transform 0.35s,
		opacity 0.35s;
}
.s-14010101.is-open .s-14010106 span:first-child {
	transform: translateY(6px) rotate(45deg);
}
.s-14010101.is-open .s-14010106 span:nth-child(2) {
	opacity: 0;
}
.s-14010101.is-open .s-14010106 span:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}
.s-14010107 {
	position: fixed;

	background: linear-gradient(180deg, var(--c-bg-2) 0, var(--c-bg) 100%);
	display: none;
	border-top: 1px solid rgba(226, 226, 226, 0.06);
}
.s-14010101.is-open .s-14010107 {
	display: block;
}
.s-14010107 ul {
	list-style: none;
	margin: 0;
	padding: 1rem;
	display: grid;
	gap: 0.5rem;
}
.s-14010107 a {
	display: block;
	padding: 0.9rem 1rem;
	border: 1px solid rgba(226, 226, 226, 0.08);
	border-radius: 12px;
	background: rgba(226, 226, 226, 0.03);
}

@media (min-width: 960px) {
	.s-14010102 {
		padding: 0.7rem 2rem;
	}
	.s-14010101 nav {
		display: flex;
		gap: 0.6rem;
	}
	.s-14010101 nav a {
		padding: 0.5rem 0.9rem;
		border-radius: 12px;
		border: 1px solid rgba(226, 226, 226, 0.08);
		background: rgba(226, 226, 226, 0.03);
	}
	.s-14010106,
	.s-14010107 {
		display: none !important;
	}
}

.s-24020202 {
	position: relative;
	isolation: isolate;

	overflow: hidden;
	background: radial-gradient(
		120% 100% at 10% 10%,
		#003330 0,
		var(--c-bg) 55%,
		var(--c-ink) 100%
	);
}

.s-2402-plankton {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	mix-blend-mode: screen;
	opacity: 0.8;
}
.s-24020203 {
	max-width: 1240px;
	margin: 0 auto;

	padding: clamp(1.4rem, 3vw, 3rem) 2rem 3rem;
	position: relative;
	z-index: 1;
}

.s-24020204 {
	display: grid;
	align-content: center;
	gap: 1.1rem;
	z-index: 2;
}
.s-24020204 h1 {
	margin: 0;
	font-weight: 1000;
	letter-spacing: -0.02em;
	line-height: 0.92;
	font-size: clamp(2.4rem, 6.2vw, 6.8rem);
	background: conic-gradient(
		from 210deg at 40% 40%,
		var(--c-cyan),
		var(--c-lime),
		var(--c-mag),
		var(--c-cyan)
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	text-shadow:
		0 0 18px rgba(0, 255, 243, 0.25),
		0 0 48px rgba(78, 255, 186, 0.16);
	animation: 14s linear infinite s-hue;
}

@keyframes s-hue {
	to {
		filter: hue-rotate(360deg);
	}
}

.s-24020204 p {
	color: var(--c-cyan);
	max-width: 70ch;
	font-size: clamp(1rem, 1.7vw, 1.2rem);
	animation: 0.9s 0.15s both s-fadeup;
}

@keyframes s-fadeup {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: none;
	}
}

.s-24020205 {
	display: flex;
	gap: 0.7rem;
	flex-wrap: wrap;
}
.s-24020205 a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.85rem 1rem;
	border-radius: 14px;
	border: 1px solid rgba(226, 226, 226, 0.08);
	background: rgba(226, 226, 226, 0.03);
	transition:
		transform 0.2s,
		box-shadow 0.2s,
		filter 0.2s;
	box-shadow: 0 0 0 0 rgba(78, 255, 186, 0);
	animation: 6s ease-in-out infinite s-breathe;
}

@keyframes s-breathe {
	0%,
	100% {
		box-shadow: 0 0 0 0 rgba(78, 255, 186, 0);
		filter: none;
	}
	50% {
		box-shadow: 0 12px 40px rgba(78, 255, 186, 0.24);
		filter: saturate(1.05) brightness(1.05);
	}
}

.s-24020205 a:hover {
	transform: translateY(-2px) scale(1.01);
}
.s-24020206 {
	position: relative;
	width: min(82vw, 560px);
	height: min(82vw, 560px);
	margin: 1rem auto 0;
}
.s-24020207 {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 1px dashed rgba(226, 226, 226, 0.14);
	animation: 40s linear infinite s-rot;
}
.s-24020206 svg {
	position: absolute;
	inset: 0;
}

@keyframes s-rot {
	to {
		transform: rotate(360deg);
	}
}

.s-24020208 {
	position: relative;
	display: grid;
	align-content: center;
}
.s-24020209 {
	position: relative;
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr 1fr;
	transform: rotate(45deg);
	filter: drop-shadow(0 40px 120px rgba(0, 17, 16, 0.55));
}
.s-24020209 figure {
	margin: 0;
	position: relative;
	aspect-ratio: 1/1;
	border-radius: 28px;
	overflow: hidden;
	will-change: transform;
	animation: 14s ease-in-out infinite s-rock;
}
.s-24020209 figure:nth-child(2) {
	animation-duration: 16s;
}
.s-24020209 figure:nth-child(3) {
	animation-duration: 18s;
}
.s-24020209 figure:nth-child(4) {
	animation-duration: 15s;
}

@keyframes s-rock {
	0%,
	100% {
		transform: translate3d(0, 0, 0);
	}
	50% {
		transform: translate3d(0, -6px, 0);
	}
}

.s-24020210 {
	grid-column: 1 / span 2;
}
.s-24020211 {
	clip-path: polygon(12% 0, 100% 0, 100% 88%, 88% 100%, 0 100%, 0 12%);
	border: 2px solid transparent;
	background:
		linear-gradient(
				180deg,
				rgba(226, 226, 226, 0.06),
				rgba(226, 226, 226, 0.02)
			)
			padding-box,
		conic-gradient(
				from 0deg,
				var(--c-cyan),
				var(--c-lime),
				var(--c-mag),
				var(--c-cyan)
			)
			border-box;
	animation: 20s linear infinite s-frameHue;
}
.s-24020212 {
	clip-path: polygon(0 0, 88% 0, 100% 12%, 100% 100%, 12% 100%, 0 88%);
	border: 2px solid transparent;
	background:
		linear-gradient(
				180deg,
				rgba(226, 226, 226, 0.06),
				rgba(226, 226, 226, 0.02)
			)
			padding-box,
		conic-gradient(
				from 360deg,
				var(--c-mag),
				var(--c-lime),
				var(--c-cyan),
				var(--c-mag)
			)
			border-box;
	animation: 24s linear infinite reverse s-frameHue;
}

@keyframes s-frameHue {
	to {
		filter: hue-rotate(360deg);
	}
}

.s-24020209 img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.12);

	filter: saturate(1.05) contrast(1.06) brightness(1.04);
	animation: 22s ease-in-out infinite s-ken;
}
.s-24020209 figure:nth-child(2) img {
	animation-duration: 26s;
}
.s-24020209 figure:nth-child(3) img {
	animation-duration: 28s;
}
.s-24020209 figure:nth-child(4) img {
	animation-duration: 24s;
}

@keyframes s-ken {
	0%,
	100% {
		transform: scale(1.12) translate3d(0, 0, 0);
	}
	25% {
		transform: scale(1.18) translate3d(-2%, -2%, 0);
	}
	50% {
		transform: scale(1.15) translate3d(2%, 1%, 0);
	}
	75% {
		transform: scale(1.2) translate3d(0, -1%, 0);
	}
}

.s-24020209 figcaption {
	position: absolute;
	left: 8px;
	bottom: 8px;
	font-size: 0.75rem;
	background: rgba(0, 34, 32, 0.55);
	border: 1px solid rgba(226, 226, 226, 0.12);
	padding: 0.35rem 0.5rem;
	border-radius: 10px;
	color: var(--c-t);
	transform: rotate(-45deg);
	animation: 0.8s 0.2s both s-fadeup;
}

[data-rv] {
	opacity: 0;
	transform: translateY(18px) scale(0.985);
	transition:
		opacity 0.7s,
		transform 0.7s cubic-bezier(0.2, 0.65, 0.2, 1);
}
[data-rv].in {
	opacity: 1;
	transform: none;
}

@media (prefers-reduced-motion: reduce) {
	.s-24020202::after,
	.s-24020202::before,
	.s-24020204 h1,
	.s-24020205 a,
	.s-24020206 svg,
	.s-24020207,
	.s-24020209 figure,
	.s-24020209 img,
	.s-5601-rail .s-rail-i,
	.s-8803-bar svg .dash {
		animation: none !important;
	}
}

.s-sec {
	position: relative;
	padding: 3.2rem 0;
}
@media (min-width: 960px) {
	.s-sec {
		padding: 4.2rem 0;
	}
}
.s-sec h2 {
	margin: 0 0 0.8rem;
	font-size: clamp(1.8rem, 4.2vw, 3rem);
	letter-spacing: -0.02em;
	line-height: 1;
	background: linear-gradient(
		90deg,
		var(--c-cyan),
		var(--c-lime),
		var(--c-mag)
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.s-sec p.lead {
	margin: 0.5rem 0 1.2rem;
	color: var(--c-d);
	max-width: 70ch;
}

.s-5601-rail {
	overflow: auto;
	padding-bottom: 0.6rem;
}
.s-5601-rail .s-rail {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 85%;
	gap: 1rem;
}
@media (min-width: 720px) {
	.s-5601-rail .s-rail {
		grid-auto-columns: 46%;
	}
}
@media (min-width: 1120px) {
	.s-5601-rail .s-rail {
		grid-auto-columns: 32%;
	}
}

.s-rail-i {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	background: rgba(226, 226, 226, 0.02);
	border: 1px solid rgba(226, 226, 226, 0.08);
	min-height: 360px;
	display: grid;
	animation: 16s ease-in-out infinite s-rock;
}
.s-rail-i img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(1.05) contrast(1.06) brightness(1.04);
}
.s-rail-i .s-grad {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent, rgba(0, 34, 32, 0.8));
}
.s-rail-i .s-txt {
	margin-top: auto;
	position: relative;
	padding: 1rem;
}
.s-rail-i h3 {
	margin: 0 0 0.25rem;
	font-size: 1.25rem;
}
.s-rail-i p {
	margin: 0;
	color: var(--c-t);
}
.s-rail-i:nth-child(2) {
	animation-duration: 18s;
}
.s-rail-i:nth-child(3) {
	animation-duration: 14s;
}
.s-rail-i:nth-child(4) {
	animation-duration: 20s;
}

.s-8803-bar {
	background: linear-gradient(180deg, var(--c-bg-2), var(--c-bg));
}
.s-8803-grid {
	display: grid;
	gap: 1.2rem;
}
.s-8803-fig {
	position: relative;
	border: 1px dashed rgba(226, 226, 226, 0.12);
	border-radius: 18px;
	padding: 1rem;
	background: rgba(226, 226, 226, 0.02);
}
.s-8803-bar svg {
	width: 100%;
	height: auto;
}
.s-8803-bar svg .dash {
	stroke-dasharray: 4 6;
	animation: 14s linear infinite dashMove;
}

@keyframes dashMove {
	to {
		stroke-dashoffset: -200;
	}
}

.s-7702 {
	display: grid;
	gap: 1rem;
}
@media (min-width: 960px) {
	.s-7702 {
		grid-template-columns: 1fr 0.9fr;
		gap: 2rem;
	}
}
.s-7702 ul {
	margin: 0.6rem 0 0 1rem;
}
.s-7702 li {
	margin: 0.25rem 0;
}
.s-7702 .s-chip {
	display: inline-block;
	margin: 0.3rem 0.3rem 0 0;
	padding: 0.45rem 0.65rem;
	border-radius: 999px;
	border: 1px solid rgba(226, 226, 226, 0.12);
	background: rgba(226, 226, 226, 0.03);
	font-size: 0.85rem;
}
.s-7702 .s-ring {
	aspect-ratio: 1/1;
	border-radius: 50%;
	position: relative;
	isolation: isolate;
	background: radial-gradient(
		60% 60% at 50% 50%,
		rgba(0, 255, 243, 0.25),
		transparent 60%
	);
}
.s-7702 .s-ring::after,
.s-7702 .s-ring::before {
	content: '';
	position: absolute;
	inset: 8% 8%;
	border-radius: 50%;
	border: 2px solid rgba(226, 226, 226, 0.08);
	animation: 24s linear infinite s-rot;
}
.s-7702 .s-ring::after {
	inset: 18% 18%;
	animation-direction: reverse;
}

.s-4407 {
	display: grid;
	gap: 1.2rem;
}
@media (min-width: 960px) {
	.s-4407 {
		grid-template-columns: 1.2fr 0.8fr;
		gap: 2rem;
	}
}
.s-4407-article {
	background: rgba(226, 226, 226, 0.02);
	border: 1px solid rgba(226, 226, 226, 0.08);
	border-radius: 18px;
	padding: 1rem;
}
.s-4407-article h3 {
	margin: 0.2rem 0 0.4rem;
}
.s-4407-article p {
	margin: 0.5rem 0;
	color: var(--c-t);
}
.s-4407-aside {
	display: grid;
	gap: 1rem;
}
.s-4407-aside .s-note {
	border-left: 3px solid rgba(0, 255, 243, 0.6);
	padding: 0.8rem;
	background: rgba(226, 226, 226, 0.02);
	border-radius: 12px;
}

.s-5506 {
	display: grid;
	gap: 1rem;
}
.s-5506 .s-step {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.8rem;
	border: 1px solid rgba(226, 226, 226, 0.08);
	border-radius: 14px;
	padding: 0.8rem;
	background: rgba(226, 226, 226, 0.02);
}
.s-5506 .s-icon {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: linear-gradient(90deg, var(--c-cyan), var(--c-lime));
	display: grid;
	place-items: center;
	filter: drop-shadow(0 0 10px rgba(0, 255, 243, 0.5));
}

.s-6608 {
	overflow: hidden;
}
.s-6608 .s-marq {
	display: flex;
	gap: 1rem;
	will-change: transform;
	animation: 40s linear infinite marq;
}
@keyframes marq {
	to {
		transform: translateX(-50%);
	}
}
.s-6608 img {
	height: 180px;
	width: auto;
	border-radius: 14px;
	object-fit: cover;
	filter: saturate(1.05) contrast(1.05);
	opacity: 0.95;
}

@media (min-width: 960px) {
	.s-5506 {
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
	}
	.s-6608 img {
		height: 220px;
	}
	.s-3304 {
		grid-template-columns: 1fr 1fr 1fr;
		gap: 1rem;
	}
}

.s-3304 {
	display: grid;
	gap: 1rem;
}
.s-3304 .s-kpi {
	border: 1px solid rgba(226, 226, 226, 0.08);
	border-radius: 14px;
	padding: 1rem;
	background: rgba(226, 226, 226, 0.02);
	text-align: center;
}
.s-3304 .s-kpi b {
	display: block;
	font-size: clamp(1.8rem, 4.5vw, 3rem);
}
.s-3304 .s-kpi span {
	color: var(--c-d);
}
.s-3304 svg {
	width: 100%;
	height: auto;
}
.s-3304 .line {
	stroke: url(#gradLine);
	stroke-width: 3;
	fill: none;
	stroke-dasharray: 600;
	animation: 6s ease-in-out infinite draw;
}

@keyframes draw {
	from {
		stroke-dashoffset: 600;
	}
	50% {
		stroke-dashoffset: 0;
	}
	to {
		stroke-dashoffset: -600;
	}
}

.s-2205 {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.s-2205 details {
	border: 1px solid rgba(226, 226, 226, 0.1);
	border-radius: 12px;
	padding: 0.8rem;
	background: rgba(226, 226, 226, 0.02);
}
.s-2205 summary {
	cursor: pointer;
	font-weight: 700;
}
.s-2205 p {
	color: var(--c-t);
}

.s-cookie {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 70;
	display: none;
}
.s-cookie .s-wrap {
	max-width: 1240px;
	margin: 0 auto;
	background: rgba(0, 51, 48, 0.92);
	backdrop-filter: blur(10px);
	border-top: 1px solid rgba(226, 226, 226, 0.1);
	padding: 1rem;
	display: grid;
	gap: 0.7rem;
}
.s-cookie b {
	background: linear-gradient(90deg, var(--c-cyan), var(--c-lime));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.s-cookie .s-actions {
	display: flex;
	gap: 0.6rem;
	flex-wrap: wrap;
}
.s-cookie button {
	border-radius: 12px;
	border: 1px solid rgba(226, 226, 226, 0.12);
	background: rgba(226, 226, 226, 0.03);
	color: var(--c-t);
	padding: 0.6rem 0.9rem;
}
.s-cookie .s-accept {
	background: linear-gradient(
		90deg,
		var(--c-cyan),
		var(--c-lime),
		var(--c-mag)
	);
	border-color: transparent;
}

footer {
	border-top: 1px solid rgba(226, 226, 226, 0.06);
	background: linear-gradient(180deg, var(--c-bg), var(--c-ink));
	padding: 1.4rem 0;
}
footer .s-foot {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	color: var(--c-d);
}
footer .s-foot a {
	color: var(--c-t);
}

@media (min-width: 760px) {
	footer .s-foot {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

body {
	max-width: 100vw;
	overflow-x: hidden;
}
