/* Responsive About Us text font size */
.about-text p {
	font-size: clamp(1.05em, 1.1em + 0.5vw, 1.18em);
	line-height: 1.7;
}
@media (max-width: 700px) {
	.about-text p {
		font-size: clamp(0.98em, 1em + 1vw, 1.08em);
	}
}
@media (max-width: 500px) {
	.about-text p {
		font-size: 0.97em;
	}
}
@media (max-width: 500px) {
	.past-events-grid {
		grid-template-columns: 1fr !important;
		gap: 18px 0 !important;
	}
}
@media (max-width: 715px) {
	.project-slider {
		max-width: 98vw;
		min-width: 0;
		margin: 0 auto;
		padding: 0 1vw;
	}
	.slider-track {
		gap: 0.5vw;
	}
	.project-feature.glass {
		min-width: 96vw;
		max-width: 96vw;
		padding: 0 !important;
		border-radius: 14px;
		min-height: 320px;
	}
	.project-feature .image-pane img {
		width: 100%;
		max-width: 100%;
		height: auto;
		border-radius: 14px 14px 0 0;
	}
	.project-feature .content-pane {
		padding: 12px 8px 14px 8px !important;
		font-size: 0.97em;
		min-height: 120px;
	}
	.project-title {
		font-size: 1.05em !important;
		margin-bottom: 6px;
	}
	.project-summary {
		font-size: 0.93em !important;
		margin-bottom: 8px;
	}
	.primary-actions {
		margin-top: 6px;
	}
}
/* Responsive Project Slider Section */
/* Remove underline from all links site-wide */
a, a:link, a:visited, a:hover, a:active {
	text-decoration: none !important;
}
@media (max-width: 700px) {
	html, body {
		width: 100vw !important;
		max-width: 100vw !important;
		overflow-x: hidden !important;
	}
	.container {
		width: 100vw !important;
		max-width: 100vw !important;
		min-width: 0 !important;
		padding-left: 1rem !important;
		padding-right: 1rem !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		box-sizing: border-box !important;
	}
	section {
		width: 100vw !important;
		max-width: 100vw !important;
		min-width: 0 !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		box-sizing: border-box !important;
	}
}
@media (max-width: 700px) {
	nav.glass {
		width: 92vw;
		max-width: 92vw;
		min-width: 0;
		box-sizing: border-box;
		display: flex !important;
		flex-direction: row !important;
		align-items: center !important;
		justify-content: space-between !important;
		padding: 6px 20px !important; /* Add small horizontal gap */
		min-height: unset !important;
		overflow-x: hidden;
	}
	nav.glass .logo {
		margin: 0 0 0 0 !important;
		justify-content: flex-start !important;
		flex: 0 0 auto !important;
		min-width: 0 !important;
		padding: 0 !important;
		max-width: 60vw;
		overflow: hidden;
	}
	nav.glass .logo img {
		max-width: 48vw;
		height: 44px !important;
		width: auto !important;
	}
	nav.glass .desktop-nav {
		display: none !important;
	}
	nav.glass .menu-toggle {
		display: flex !important;
		margin-left: auto !important;
		margin-right: 0 !important;
		position: relative !important;
		top: 0 !important;
		transform: none !important;
		flex: 0 0 auto !important;
		z-index: 2;
	}
}

@media (max-width: 400px) {
	nav.glass {
		padding-left: 1em !important;
		padding-right: 1em !important;
	}
	nav.glass .logo span {
		font-size: 1em !important;
	}
	nav.glass .logo img {
		height: 36px !important;
		max-width: 38vw;
	}
}
/* Hero Slider Title and Subtitle Responsive Styling */
.hero-details .detail {
	font-size: clamp(2.2rem, 5vw, 3.5rem);
	font-weight: 800;
	line-height: 1.13;
	word-break: break-word;
	white-space: pre-line;
	letter-spacing: 0.01em;
	margin-bottom: 0.2em;
}
.hero-details .subtitle {
	font-size: clamp(1rem, 2.2vw, 1.35rem);
	font-weight: 500;
	opacity: 0.85;
	margin-top: 0.1em;
	line-height: 1.3;
}
@media (max-width: 600px) {
	.hero-details .detail {
		font-size: clamp(2.1rem, 10vw, 2.8rem);
		line-height: 1.12;
	}
	.hero-details .subtitle {
		font-size: clamp(0.8rem, 2vw, 0.98rem);
		line-height: 1.25;
	}
	.hero-callout {
		padding: 14px 18px;
		max-width: 320px;
	}
	.hero-callout-text {
		font-size: 0.88rem;
	}
	.hero-callout-cta {
		width: 100%;
		justify-content: center;
	}
}
/* Responsive hero slider text */
.hero-content {
	max-width: 700px;
	margin: 0 auto;
	padding: 0 16px;
	text-align: center;
}
.hero-details {
	font-size: clamp(1.2rem, 2vw + 1.2rem, 2.6rem);
	font-weight: 700;
	letter-spacing: 0.01em;
	margin-bottom: 18px;
	line-height: 1.15;
	position: relative;
	height: auto;
	display: inline-block;
}
.hero-details .detail {
	font-size: clamp(2.1rem, 3vw + 1.5rem, 4rem) !important;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: transparent; -webkit-text-fill-color: transparent;
	background-clip: text; -webkit-background-clip: text;
	background-image: linear-gradient(90deg,
		#0a2a6b 0%,
		#1f3a8a 18%,
		#4338ca 36%,
		#6d28d9 52%,
		#9d174d 68%,
		#b45309 84%,
		#c2410c 100%
	);
	-webkit-text-stroke: 1px rgba(255,255,255,0.35);
	text-shadow:
		0 1px 0 rgba(255,255,255,0.28),
		0 2px 12px rgba(0,0,0,0.6),
		0 0 36px rgba(224,90,14,0.30),
		0 0 28px rgba(11,59,138,0.35);
	transition: opacity 400ms ease, transform 400ms ease;
}
@media (max-width: 900px) {
	.hero-details {
		font-size: 1.3rem;
	}
	.hero-details .detail {
		font-size: 2rem !important;
	}
}
@media (max-width: 700px) {
	.hero-content {
		padding: 0 6vw;
	}
	.hero-details {
		font-size: 1.05rem;
		margin-bottom: 12px;
	}
	.hero-details .detail {
		font-size: 2.2rem !important;
		line-height: 1.15 !important;
		word-break: break-word !important;
		white-space: pre-line !important;
	}
	.hero-content p {
		font-size: 0.92em !important;
		line-height: 1.4 !important;
		max-width: 95vw;
	}
}
html {
	scroll-behavior: smooth;
}
/* Reset and Base */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { color-scheme: dark; }
:root {
	--bh-x: 50%;
	--bh-y: 50%;
	--bh-parallax-x: 0%;
	--bh-parallax-y: 0%;
}
/* Visually hidden utility (for accessible, non-visual headings) */
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
body {
	--bg: #02030a;
	--card: rgba(255,255,255,0.06);
	--stroke: rgba(255,255,255,0.12);
	--text: #e8eaed;
	--muted: #9aa0a6;
	--accent: #0ea5e9; /* sky-500 */
	--accent-2: #22d3ee; /* cyan-400 */
	--glow: 0 0 40px rgba(34,211,238,0.25);
	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--text);
	background: var(--bg);
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
	cursor: url("/images/cursor/orb-cursor.png") 12 12, url("/images/cursor/orb-cursor.cur") 12 12, auto;
}

/* Photo background layer (switches by color scheme) */
body::before {
	content: "";
	position: fixed; inset: 0; z-index: -4;
	background: url("images/dark bg.png") center/cover no-repeat;
	opacity: .28;
	transform: scale(1.02);
	filter: brightness(0.6) saturate(0.8);
}

/* Space + Ambient Background */
.stars, .twinkling, .aurora, .blobs { position: fixed; inset: 0; width: 100%; height: 100%; z-index: -3; }
.stars {
	background: #000 url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiPjxkZWZzPjxwYXR0ZXJuIGlkPSJzdGFycyIgd2lkdGg9IjQwIiBoZWlnaHQ9IjQwIiBwYXR0ZXJuVW5pdHM9InVzZXJTcGFjZU9uVXNlIj48Y2lyY2xlIGN4PSIyMCIgY3k9IjIwIiByPSIxIiBmaWxsPSIjZmZmIiBvcGFjaXR5PSIwLjEiLz48Y2lyY2xlIGN4PSIxMCIgY3k9IjEwIiByPSIxIiBmaWxsPSIjZmZmIiBvcGFjaXR5PSIwLjIiLz48Y2lyY2xlIGN4PSIzMCIgY3k9IjMwIiByPSIxIiBmaWxsPSIjZmZmIiBvcGFjaXR5PSIwLjE1Ii8+PC9wYXR0ZXJuPjwvZGVmcz48cmVjdCB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJ1cmwoI3N0YXJzKSIvPjwvc3ZnPg==') repeat;
	opacity: .8;
}
.cosmic-canvas {
	position: fixed;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: -2;
	pointer-events: none;
	opacity: 0.94;
	mix-blend-mode: screen;
}

.blackhole-field {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: -2;
	opacity: 0.45;
	mix-blend-mode: screen;
	translate: var(--bh-parallax-x) var(--bh-parallax-y);
	background-position: calc(50% + var(--bh-parallax-x)) calc(50% + var(--bh-parallax-y));
	background:
		radial-gradient(circle at var(--bh-x) var(--bh-y),
			rgba(2, 4, 10, 0) 0%,
			rgba(2, 4, 10, 0.05) 14%,
			rgba(3, 7, 18, 0.48) 26%,
			rgba(6, 15, 32, 0.24) 38%,
			rgba(9, 20, 44, 0.12) 52%,
			rgba(2, 6, 18, 0) 68%),
		repeating-conic-gradient(from 45deg at var(--bh-x) var(--bh-y),
			rgba(56, 189, 248, 0.12) 0deg 18deg,
			transparent 18deg 40deg);
	animation: blackhole-pulse 22s ease-in-out infinite alternate;
	will-change: transform, background-position;
}
.blackhole-field::after {
	content: "";
	position: absolute;
	inset: -15%;
	background: conic-gradient(from 90deg at var(--bh-x) var(--bh-y),
		rgba(148, 197, 253, 0.18) 0deg 60deg,
		rgba(56, 189, 248, 0.08) 60deg 160deg,
		transparent 160deg 360deg);
	opacity: 0.45;
	animation: blackhole-spin 48s linear infinite;
	mix-blend-mode: screen;
	will-change: transform;
}
.blackhole-field::before {
	content: "";
	position: absolute;
	width: 36vmin;
	height: 36vmin;
	left: calc(var(--bh-x) - 18vmin);
	top: calc(var(--bh-y) - 18vmin);
	border-radius: 50%;
	background: radial-gradient(circle,
		rgba(0, 0, 0, 0.8) 0%,
		rgba(0, 0, 0, 0.62) 28%,
		transparent 65%);
	filter: blur(8px);
	opacity: 0.72;
	transform: scale(0.96);
	animation: blackhole-core 9s ease-in-out infinite alternate;
}
.blackhole-field.is-reduced,
.blackhole-field.is-reduced::after,
.blackhole-field.is-reduced::before {
	animation: none;
}

@media (prefers-reduced-motion: reduce) {
	.blackhole-field,
	.blackhole-field::after,
	.blackhole-field::before {
		animation: none !important;
	}
}

@keyframes blackhole-pulse {
	0% { transform: scale(1) rotate(0deg); opacity: 0.48; }
	50% { transform: scale(1.02) rotate(1deg); opacity: 0.56; }
	100% { transform: scale(1.04) rotate(-1deg); opacity: 0.5; }
}

@keyframes blackhole-spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

@keyframes blackhole-core {
	0% { transform: scale(0.94); opacity: 0.66; }
	50% { transform: scale(1.02); opacity: 0.75; }
	100% { transform: scale(0.96); opacity: 0.68; }
}
.twinkling { z-index: -2; animation: twinkling 7s ease-in-out infinite; }
@keyframes twinkling { 0%, 100% { opacity: 0.8; } 50% { opacity: 0.5; } }

/* Aurora sweep */
.aurora { z-index: -1; filter: blur(50px) saturate(110%); opacity: .45; background: radial-gradient(1200px 600px at 20% 20%, rgba(34,211,238,.12), transparent 60%), radial-gradient(1000px 500px at 80% 70%, rgba(14,165,233,.1), transparent 55%), radial-gradient(800px 400px at 40% 80%, rgba(148,163,184,.12), transparent 60%); animation: aurora-move 28s ease-in-out infinite alternate; }
@keyframes aurora-move { 0% { transform: translateY(0) translateX(0); } 100% { transform: translateY(-4%) translateX(2%); } }

/* Floating gradient blobs */
.blobs { pointer-events: none; z-index: -1; }
.blobs::before, .blobs::after {
	content: ""; position: absolute; border-radius: 50%; filter: blur(60px);
}
.blobs::before { width: 36vmax; height: 36vmax; left: -10vmax; top: 12vmax; background: radial-gradient(circle at 30% 30%, rgba(34,211,238,.18), transparent 60%); animation: blob1 26s ease-in-out infinite; }
.blobs::after { width: 32vmax; height: 32vmax; right: -8vmax; bottom: -6vmax; background: radial-gradient(circle at 60% 40%, rgba(14,165,233,.18), transparent 60%); animation: blob2 30s ease-in-out infinite;
}
@keyframes blob1 { 0% { transform: translate(0,0) scale(1); } 50% { transform: translate(4%, -2%) scale(1.06); } 100% { transform: translate(-2%, 3%) scale(1); } }
@keyframes blob2 { 0% { transform: translate(0,0) scale(1); } 50% { transform: translate(-3%, 4%) scale(1.05); } 100% { transform: translate(2%, -2%) scale(1); } }

/* Glass Effect */
.glass {
	background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
	backdrop-filter: saturate(160%) blur(16px);
	-webkit-backdrop-filter: saturate(160%) blur(16px);
	border: 1px solid var(--stroke);
	border-radius: 20px; padding: 20px;
	box-shadow: 0 1px 0 rgba(255,255,255,0.05) inset, 0 10px 30px rgba(0,0,0,0.35);
}

/* Navigation */
nav { position: fixed; top: 16px; left: 50%; transform: translateX(-50%); display: flex; justify-content: space-between; align-items: center; width: min(1100px, 92%); z-index: 30; padding: 10px 16px; gap: 12px; }
.logo { font-size: 1.2rem; font-weight: 700; letter-spacing: 0.2px; white-space: nowrap; 
	/* Force solid white logo text */
	color: #ffffff; -webkit-text-fill-color: #ffffff;
	background: none !important; background-image: none !important;
	background-clip: initial; -webkit-background-clip: initial;
	-webkit-text-stroke: 0; text-shadow: 0 1px 2px rgba(0,0,0,0.35);
}
nav .desktop-nav { list-style: none; display: flex; gap: 16px; }
nav a { color: var(--text); text-decoration: none; font-weight: 500; padding: 8px 12px; border-radius: 999px; transition: color .2s ease, background-color .2s ease; }
nav a:hover { color: #000; background: linear-gradient(180deg, var(--accent-2), var(--accent)); box-shadow: var(--glow); }

/* Hamburger */
.menu-toggle { display: none; width: 42px; height: 38px; border-radius: 10px; border: 1px solid var(--stroke); background: var(--card); cursor: pointer; align-items: center; justify-content: center; gap: 5px; padding: 6px; margin-left: auto; flex-shrink: 0; }
.menu-toggle span { display: block; width: 22px; height: 2px; background: var(--text); border-radius: 2px; transition: transform .25s ease, opacity .25s ease; }
.menu-toggle.active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.menu-toggle.active span:nth-child(2) { opacity: 0; }
.menu-toggle.active span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Mobile Drawer */
.scrim { position: fixed; inset: 0; background: rgba(0,0,0,.5); backdrop-filter: blur(2px); opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; z-index: 40; }
.scrim.show { opacity: 1; visibility: visible; }
.mobile-drawer { position: fixed; top: 0; right: 0; left: auto; height: 100vh; width: min(84vw, 320px); transform: translateX(100%); transition: transform .3s ease; z-index: 41; display: flex; flex-direction: column; padding: 14px; }
.mobile-drawer.show { transform: translateX(0); }
.drawer-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.drawer-header .menu-close { background: transparent; color: var(--text); border: none; font-size: 28px; line-height: 1; cursor: pointer; }
.drawer-links { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.drawer-links a { display: block; padding: 10px 12px; border-radius: 12px; color: var(--text); text-decoration: none; }
.drawer-links a:hover { background: linear-gradient(180deg, var(--accent-2), var(--accent)); color: #001018; }

/* Sections */
section { padding: 120px 20px 80px; min-height: 100vh; display: flex; align-items: center; justify-content: center; position: relative; }
.container { max-width: 1200px; margin: 0 auto; text-align: center; }
h2 { font-size: clamp(1.8rem, 1.2rem + 2vw, 2.6rem); margin-bottom: 28px; letter-spacing: .2px; }
p { color: var(--muted); line-height: 1.7; }

/* Hero */
.hero { padding-top: 160px; background: linear-gradient(to bottom, rgba(0,0,0,0.2), transparent 40%); }
.hero-content { text-align: center; max-width: 900px; margin: 0 auto; padding: 28px 16px; }
h1 { font-size: clamp(2.4rem, 2rem + 3vw, 4rem); margin-bottom: 14px; font-weight: 800; letter-spacing: -0.02em; }
.hero p { font-size: clamp(1rem, .9rem + .6vw, 1.25rem); margin-bottom: 22px; }
.hero-details { position: relative; height: auto; margin: 10px 0 18px; display: inline-block; }
.hero-callout {
	margin: 18px auto 24px;
	padding: 16px 22px;
	background: rgba(10,16,32,0.72);
	border-radius: 18px;
	border: 1px solid rgba(255,255,255,0.12);
	box-shadow: 0 20px 45px -18px rgba(14,165,233,0.45);
	backdrop-filter: blur(18px) saturate(140%);
	-webkit-backdrop-filter: blur(18px) saturate(140%);
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	max-width: clamp(280px, 60vw, 420px);
}
.hero-callout-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 700;
	background: linear-gradient(135deg, var(--accent-2), var(--accent));
	color: #03131c;
	padding: 6px 14px;
	border-radius: 999px;
	box-shadow: 0 10px 30px rgba(34,211,238,0.25);
}
.hero-callout-text {
	font-size: 0.95rem;
	color: var(--text);
	opacity: 0.88;
	background: none !important;
	-webkit-text-fill-color: var(--text) !important;
	-webkit-text-stroke: 0 !important;
	text-shadow: none;
}
.hero-callout-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	font-size: 0.88rem;
	font-weight: 600;
	border-radius: 999px;
	background: rgba(34,211,238,0.12);
	color: var(--accent-2);
	border: 1px solid rgba(34,211,238,0.35);
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.hero-callout-cta:hover {
	background: linear-gradient(135deg, var(--accent-2), var(--accent));
	color: #04101c;
	border-color: transparent;
}
.hero-details .detail {
	display: inline-block;
	white-space: nowrap;
	/* make it main-title sized and styled */
	font-size: clamp(2.4rem, 2rem + 3vw, 4rem);
	font-weight: 800;
	letter-spacing: -0.02em;
	color: transparent; -webkit-text-fill-color: transparent;
	background-clip: text; -webkit-background-clip: text;
	background-image: linear-gradient(90deg,
		#0a2a6b 0%,
		#1f3a8a 18%,
		#4338ca 36%,
		#6d28d9 52%,
		#9d174d 68%,
		#b45309 84%,
		#c2410c 100%
	);
	-webkit-text-stroke: 1px rgba(255,255,255,0.35);
	text-shadow:
		0 1px 0 rgba(255,255,255,0.28),
		0 2px 12px rgba(0,0,0,0.6),
		0 0 36px rgba(224,90,14,0.30),
		0 0 28px rgba(11,59,138,0.35);
	transition: opacity 400ms ease, transform 400ms ease;
}

/* Gradient glassy lettering (no cover boxes) */
.hero-content h1,
.hero-content p {
	color: transparent;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	-webkit-background-clip: text;
	/* subtle “glassy” edge + glow */
	-webkit-text-stroke: 0.6px rgba(255,255,255,0.08);
	text-shadow:
		0 1px 0 rgba(255,255,255,0.22),
		0 10px 28px rgba(0,0,0,0.35);
	filter: drop-shadow(0 0 18px rgba(255,255,255,0.12));
}

/* Main title gradient: dark blue to dark orange */
.hero-content h1 {
		background-image: linear-gradient(90deg,
			#0a2a6b 0%,   /* deep navy */
			#1f3a8a 18%, /* dark royal blue */
			#4338ca 36%, /* indigo */
			#6d28d9 52%, /* violet */
			#9d174d 68%, /* crimson */
			#b45309 84%, /* burnt amber */
			#c2410c 100% /* dark orange */
		);
		background-size: 200% 200%;
		animation: gradientShift 16s ease-in-out infinite;
		/* Boost legibility */
		-webkit-text-stroke: 1px rgba(255,255,255,0.35);
		text-shadow:
			0 1px 0 rgba(255,255,255,0.28),       /* subtle bevel */
			0 2px 12px rgba(0,0,0,0.6),           /* dark outline */
			0 0 36px rgba(224,90,14,0.30),        /* orange glow */
			0 0 28px rgba(11,59,138,0.35);        /* blue glow */
		filter: drop-shadow(0 0 22px rgba(255,255,255,0.2));
}

/* Subtitle: neutral glassy white/gray with animated sheen */
.hero-content p {
	/* base gradient + moving specular highlight */
	background-image:
		linear-gradient(90deg, #ffffff, #d1d5db),
		linear-gradient(110deg, rgba(255,255,255,0) 40%, rgba(255,255,255,0.28) 50%, rgba(255,255,255,0) 60%);
	background-size: 100% 100%, 300% 100%;
	background-position: 0% 0%, -50% 0%;
	animation: subtitleSheen 6s ease-in-out infinite;
	-webkit-text-stroke: 0.5px rgba(255,255,255,0.14);
	text-shadow:
		0 1px 0 rgba(255,255,255,0.26),
		0 2px 10px rgba(0,0,0,0.38),
		0 0 26px rgba(255,255,255,0.14);
	letter-spacing: 0.1px;
	font-weight: 400;
	will-change: background-position;
	opacity: 0.92;
}

@keyframes gradientShift {
	0% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
	100% { background-position: 0% 50%; }
}
@keyframes subtitleSheen {
	0% { background-position: 0% 0%, -50% 0%; }
	50% { background-position: 0% 0%, 150% 0%; }
	100% { background-position: 0% 0%, -50% 0%; }
}
.cta {
	position: relative;
	padding: 14px 26px;
	border-radius: 999px;
	background: linear-gradient(180deg, rgba(255,255,255,0.16), rgba(255,255,255,0.06));
	color: var(--text);
	border: 1px solid var(--stroke);
	backdrop-filter: saturate(160%) blur(12px);
	-webkit-backdrop-filter: saturate(160%) blur(12px);
	font-weight: 700; cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease, background-color 0.2s ease;
	box-shadow: 0 1px 0 rgba(255,255,255,0.05) inset, 0 12px 30px rgba(0,0,0,0.35), 0 0 24px rgba(34,211,238,0.18);
}
.cta:hover {
	transform: translateY(-1px) scale(1.02);
	background: linear-gradient(180deg, rgba(255,255,255,0.22), rgba(255,255,255,0.10));
	box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset, 0 14px 34px rgba(0,0,0,0.4), 0 0 30px rgba(34,211,238,0.28);
}
.cta:active { transform: translateY(0) scale(0.99); }
.cta:focus-visible {
	outline: none;
	box-shadow: 0 0 0 4px rgba(34,211,238,0.22), 0 12px 30px rgba(0,0,0,0.35);
}
.rocket { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 50px; height: 100px; background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMCAxMDAiPjxwYXRoIGQ9Ik0xMCAwTDIwIDMwSDB6IiBmaWxsPSIjZmZmIi8+PHJlY3QgeD0iNCIgeT0iMzAiIHdpZHRoPSIxMiIgaGVpZ2h0PSI2MCIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik0xMCA5MEwxNSA5NUwxMCAxMDBMNCA5NUwxMCA5MFoiIGZpbGw9IiNmZjAwMDAiLz48L3N2Zz4=') no-repeat center/contain; animation: launch 7s linear infinite; opacity: .8; }
@keyframes launch { 0% { transform: translate(-50%, 80%); } 100% { transform: translate(-50%, -120%); } }

/* Hero background slider */
.hero { position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg .slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 1200ms cubic-bezier(.4,.0,.2,1), transform 1400ms cubic-bezier(.4,.0,.2,1); transform: scale(1.04); will-change: opacity, transform; }
.hero-bg .slide.active { opacity: 0.9; transform: scale(1); }
.hero::after { /* overlay to ensure text legibility */
	content: ""; position: absolute; inset: 0; z-index: 1;
	background: radial-gradient(120% 80% at 50% 20%, rgba(0,0,0,.20), rgba(0,0,0,.32) 60%, rgba(0,0,0,.44));
}
.hero:hover .hero-bg .slide.active { transform: scale(1.02); }
.hero-dots { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; z-index: 3; }
.hero .hero-content { position: relative; z-index: 2; }
.hero .rocket { z-index: 2; }
.hero-dots button { position: relative; width: 18px; height: 18px; border: none; background: transparent; padding: 0; cursor: pointer; }
.hero-dots button::before {
	content: ""; position: absolute; top: 50%; left: 50%; width: 6px; height: 6px; transform: translate(-50%, -50%);
	border-radius: 50%; background: rgba(255,255,255,0.18); border: 1px solid var(--stroke);
	backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
	box-shadow: 0 1px 1px rgba(255,255,255,0.12) inset, 0 6px 14px rgba(0,0,0,0.25);
	transition: transform .2s ease, background-color .2s ease, box-shadow .2s ease;
}
.hero-dots button:hover::before { transform: translate(-50%, -50%) scale(1.08); }
.hero-dots button.active::before {
	background: linear-gradient(180deg, var(--accent-2), var(--accent));
	box-shadow: var(--glow), 0 1px 1px rgba(255,255,255,0.1) inset;
	transform: translate(-50%, -50%) scale(1.2);
}

/* Grids & Cards */
.about-grid, .events-grid, .blog-grid, .team-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.card, .event-card, .blog-card, .team-card { transition: transform 0.25s ease, box-shadow .25s ease, border-color .25s ease; border: 1px solid var(--stroke); background: var(--card); border-radius: 16px; padding: 18px; }
.card:hover, .event-card:hover, .blog-card:hover, .team-card:hover { transform: translateY(-6px); box-shadow: 0 12px 40px rgba(0,0,0,0.45), 0 0 0 1px rgba(255,255,255,0.05) inset; }
img { width: 100%; border-radius: 12px; margin-bottom: 12px; }

/* Past Events Cards */
a.event-card { position: relative; text-decoration: none; color: inherit; display: flex; flex-direction: column; padding: 0; overflow: hidden; isolation: isolate; }
a.event-card img { margin: 0; border-radius: 0; aspect-ratio: 16 / 9; object-fit: cover; filter: saturate(105%) contrast(105%); transition: transform .9s ease, filter .5s ease; }
a.event-card .event-card-body { padding: 18px 20px 22px; text-align: left; display: flex; flex-direction: column; gap: 6px; }
a.event-card h3 { font-size: 1.15rem; letter-spacing: .3px; margin: 0 0 4px; }
.event-meta { font-size: .78rem; letter-spacing: .8px; text-transform: uppercase; font-weight: 600; color: var(--accent-2); opacity: .9; }
.event-desc { font-size: .85rem; line-height: 1.5; color: var(--muted); margin: 2px 0 4px; }
.event-link-label { font-size: .78rem; font-weight: 600; letter-spacing: .6px; text-transform: uppercase; align-self: flex-start; background: linear-gradient(90deg,var(--accent-2),var(--accent)); background-clip: text; -webkit-background-clip: text; color: transparent; position: relative; padding-right: 14px; }
a.event-card::after { content:""; position: absolute; inset: 0; border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; pointer-events: none; transition: border-color .4s ease, box-shadow .4s ease; }
a.event-card:hover img { transform: scale(1.06); filter: saturate(120%) contrast(110%) brightness(1.05); }
a.event-card:hover::after { border-color: rgba(255,255,255,0.18); box-shadow: 0 0 0 1px rgba(255,255,255,0.1) inset, 0 8px 30px -6px rgba(0,0,0,0.55), 0 0 50px -10px rgba(34,211,238,0.35); }
a.event-card:hover .event-link-label { background: linear-gradient(90deg,var(--accent),var(--accent-2)); }
.past-events-grid { --min: 300px; grid-template-columns: repeat(auto-fit,minmax(var(--min),1fr)); }
.event-card-header { display:flex; justify-content:flex-start; margin-bottom:10px; }
.event-status-pill { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border-radius:999px; font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase; font-weight:700; }
.event-status-ongoing { background: rgba(34,211,238,0.14); border:1px solid rgba(34,211,238,0.35); color: var(--accent-2); }
.event-status-upcoming { background: rgba(139,92,246,0.16); border:1px solid rgba(139,92,246,0.32); color: #c4b5fd; }
.event-status-past { background: rgba(148,163,184,0.14); border:1px solid rgba(148,163,184,0.32); color: rgba(226,232,240,0.85); }
.event-filter-bar { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin:0 auto 36px; }
.event-filter-btn { position:relative; display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:999px; border:1px solid rgba(255,255,255,0.16); background:rgba(15,20,35,0.55); color:var(--text); font-size:0.82rem; font-weight:600; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer; transition:border-color 0.2s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease; }
.event-filter-btn span { font-size:0.78rem; font-weight:700; color:var(--accent-2); letter-spacing:0.04em; }
.event-filter-btn:hover { border-color:rgba(255,255,255,0.26); transform:translateY(-1px); }
.event-filter-btn.active { background:linear-gradient(135deg,var(--accent-2),var(--accent)); color:#03131c; border-color:transparent; box-shadow:0 12px 30px -12px rgba(14,165,233,0.55), 0 0 20px -6px rgba(14,165,233,0.45); }
.event-filter-btn.active span { color:#04101c; }
.events-empty-message { text-align:center; margin-top:40px; padding:26px 28px; border-radius:20px; border:1px dashed rgba(255,255,255,0.18); background:rgba(12,16,28,0.6); color:var(--muted); }

/* Contact */
.contact-form { display: flex; flex-direction: column; gap: 12px; max-width: 520px; margin: 0 auto; }
input, textarea { padding: 14px 16px; border: 1px solid var(--stroke); border-radius: 12px; background: rgba(255,255,255,0.06); color: var(--text); outline: none; transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease; }
input:focus, textarea:focus { border-color: var(--accent-2); box-shadow: 0 0 0 4px rgba(34,211,238,0.15); }
textarea { min-height: 120px; resize: vertical; }
button { background: linear-gradient(180deg, var(--accent-2), var(--accent)); border: none; padding: 14px 18px; border-radius: 12px; color: #001018; cursor: pointer; font-weight: 700; box-shadow: var(--glow); }
.social-links { margin-top: 18px; display: flex; justify-content: center; gap: 18px; flex-wrap: wrap; }
.social-links a { color: var(--text); opacity: .9; transition: opacity .2s ease; }
.social-links a:hover { opacity: 1; }

/* Footer */
footer { text-align: center; padding: 28px; background: rgba(0,0,0,0.55); border-top: 1px solid var(--stroke); }

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce) {
	.twinkling, .aurora, .blobs, .rocket { animation: none !important; }
}

/* Responsive */
@media (max-width: 820px) {
	.people-grid {
		grid-template-columns: 1fr 1fr !important;
		gap: 14px 8px !important;
	}
	nav .desktop-nav { display: none; }
	/* tighter, consistent mobile header height */
	nav { padding: 8px 12px; min-height: 56px; }
	.menu-toggle { width: 40px; height: 36px; }
	.logo { font-size: 1.1rem; }
}
@media (max-width: 640px) {
	nav { flex-direction: row; align-items: center; gap: 8px; padding: 12px; }
	nav ul { flex-wrap: nowrap; }
}

/* Prevent body scroll when drawer open */
body.lock-scroll { overflow: hidden; }

	/* Light scheme adjustments (if OS/browser prefers light) */
	@media (prefers-color-scheme: light) {
		html { color-scheme: light; }
		body {
			--bg: #f7f8fb;
			--card: rgba(255,255,255,0.72);
			--stroke: rgba(0,0,0,0.08);
			--text: #0b1220;
			--muted: #475569;
			--accent: #0077ff;
			--accent-2: #4cc0ff;
		}
		body::before {
			background-image: url("images/light bg.png");
			opacity: .25;
		}
		.stars { opacity: .15; filter: invert(1) hue-rotate(180deg) saturate(0.2); }
		.twinkling { opacity: .12; }
		.aurora { opacity: .35; }
		.glass { background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,255,255,0.78)); border-color: rgba(0,0,0,0.06); }
		footer { background: rgba(255,255,255,0.7); }
		nav a:hover { color: #fff; }
		button, .cta { color: #001018; }
		.logo { -webkit-text-stroke: 0.4px rgba(0,0,0,0.15); text-shadow: 0 1px 0 rgba(255,255,255,0.6), 0 8px 20px rgba(0,0,0,0.15); }
	}

/* Project-specific styles */
.project-tech {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 1rem 0;
}

.tech-tag {
	background: rgba(59, 130, 246, 0.2);
	color: #60a5fa;
	padding: 0.25rem 0.75rem;
	border-radius: 12px;
	font-size: 0.75rem;
	font-weight: 500;
	border: 1px solid rgba(59, 130, 246, 0.3);
}

.project-links {
	display: flex;
	gap: 0.75rem;
	margin-top: 1rem;
	flex-wrap: wrap;
}

.project-link {
	padding: 0.5rem 1rem;
	border-radius: 8px;
	text-decoration: none;
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	transition: all 0.3s ease;
	font-size: 0.875rem;
}

.project-link.primary {
	background: linear-gradient(135deg, #3b82f6, #9333ea);
	color: white;
	border: none;
}

.project-link:not(.primary) {
	background: rgba(255, 255, 255, 0.1);
	color: white;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.project-link:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.event-card-body {
	padding: 1.5rem;
}

.event-meta {
	color: var(--muted);
	font-size: 0.875rem;
	margin-bottom: 0.75rem;
}

.event-desc {
	margin-bottom: 1rem;
	line-height: 1.6;
	opacity: 0.9;
}

/* About Section Refactor */
.about-wrapper { display:flex; gap:50px; align-items:stretch; padding:40px; margin-top:10px; text-align:left; }
.about-image { flex:1 1 45%; position:relative; border-radius:22px; overflow:hidden; }
.about-image img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(110%) contrast(105%); }
.about-text { flex:1 1 55%; font-size:clamp(0.95rem,0.85rem + .4vw,1.08rem); line-height:1.75; }
.about-text p { color:var(--text); }
/* Image Right Variant */
.about-image-right { flex-direction:row; }
.about-image-right .about-text { order:1; }
.about-image-right .about-image { order:2; }
@media (max-width: 900px){
	.about-wrapper { flex-direction:column; padding:32px 26px; }
	.about-image { aspect-ratio:16/10; }
}
@media (max-width: 520px){
	.about-wrapper { padding:26px 20px; }
	.about-text { font-size:1rem; }
}

/* Featured Project Two-Column Layout */
.project-feature { display:flex; flex-wrap:wrap; gap:0; padding:0; overflow:hidden; border-radius:28px; }
.project-feature .image-pane { flex:1 1 50%; min-width:320px; aspect-ratio:1/1; position:relative; overflow:hidden; }
.project-feature .image-pane img { width:100%; height:100%; object-fit:cover; display:block; }
.project-feature .content-pane { flex:1 1 50%; min-width:320px; padding:52px clamp(32px,4vw,72px); display:flex; flex-direction:column; justify-content:center; text-align:left; }
.project-feature .pill { display:inline-block; background:linear-gradient(135deg,var(--accent-2),var(--accent)); padding:6px 14px; font-size:12px; letter-spacing:.5px; font-weight:600; border-radius:999px; margin-bottom:20px; color:#001018; }
.project-feature .project-title { font-size:clamp(2rem,1.4rem + 1.8vw,3rem); line-height:1.1; margin:0 0 24px; }
.project-feature .project-summary { font-size:clamp(1rem,0.9rem + .4vw,1.15rem); max-width:640px; margin:0 0 28px; color:var(--text); opacity:.85; }
.tech-inline { display:flex; flex-wrap:wrap; gap:10px; margin:0 0 36px; }
.tech-inline .chip { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.14); padding:6px 14px; font-size:12px; border-radius:999px; backdrop-filter:blur(12px); }
.learn-more-btn { font-size:1rem; }
.primary-actions { display:flex; gap:20px; align-items:center; }
.all-projects-link { margin-top:46px; }
.text-link { color:var(--accent-2); text-decoration:none; font-weight:500; position:relative; }
.text-link::after { content:""; position:absolute; left:0; bottom:-3px; width:100%; height:2px; background:linear-gradient(90deg,var(--accent-2),var(--accent)); transform-origin:left; transform:scaleX(.4); opacity:.6; transition:.35s; }
.text-link:hover::after { transform:scaleX(1); opacity:1; }

@media (max-width: 980px) {
	.project-feature { flex-direction:column; }
	.project-feature .image-pane { aspect-ratio:16/10; }
	.project-feature .content-pane { padding:40px 34px 52px; }
}

@media (max-width: 560px) {
	.project-feature .content-pane { padding:34px 26px 46px; }
	.project-feature .project-title { font-size:2.1rem; }
}

/* Articles Promo Section (Modern CTA) */
.articles-promo { position:relative; display:flex; gap:60px; align-items:stretch; padding: clamp(34px,4vw,60px); margin-top:10px; text-align:left; overflow:hidden; border-radius:34px; }
.articles-promo::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 18% 20%, rgba(34,211,238,0.18), transparent 60%), radial-gradient(circle at 80% 80%, rgba(14,165,233,0.16), transparent 65%); pointer-events:none; }
.articles-promo-content { flex:1 1 52%; display:flex; flex-direction:column; justify-content:center; gap:24px; }
.articles-promo-title { font-size:clamp(2rem,1.4rem + 1.8vw,3rem); line-height:1.1; margin:0; }
.articles-promo-text { font-size:clamp(1rem,0.9rem + .4vw,1.15rem); color:var(--text); opacity:.85; margin:0; max-width:640px; }
.articles-highlights { list-style:none; padding:0; margin:4px 0 6px; display:grid; gap:10px; }
.articles-highlights li { position:relative; padding-left:26px; font-size:.9rem; line-height:1.5; color:var(--muted); }
.articles-highlights li::before { content:"✦"; position:absolute; left:0; top:0; font-size:.85rem; color:var(--accent-2); text-shadow:0 0 12px rgba(34,211,238,0.6); }
.articles-promo-btn { align-self:flex-start; }
.articles-promo-visual { flex:1 1 48%; position:relative; display:flex; align-items:center; justify-content:center; }
.articles-image-stack { position:relative; width:100%; max-width:560px; aspect-ratio:4/3; }
.ap-img { position:absolute; overflow:hidden; border-radius:24px; border:1px solid rgba(255,255,255,0.12); box-shadow:0 8px 30px -8px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.05) inset; backdrop-filter:blur(6px); }
.ap-img img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(112%) contrast(108%); transition: transform 1.2s ease; }
.ap-img-main { inset:0; }
.ap-img-side { width:48%; aspect-ratio:4/5; }
.ap-img-1 { top:6%; left:-6%; }
.ap-img-2 { bottom:4%; right:-6%; }
.articles-image-stack:hover .ap-img img { transform:scale(1.05); }
.ap-accent-orb { position:absolute; width:260px; height:260px; border-radius:50%; background:radial-gradient(circle at 30% 35%, rgba(34,211,238,0.55), rgba(34,211,238,0) 70%); filter:blur(40px) saturate(140%); top:50%; left:50%; transform:translate(-50%,-50%); mix-blend-mode:screen; opacity:.55; pointer-events:none; animation:orbPulse 14s ease-in-out infinite alternate; }
@keyframes orbPulse { 0% { transform:translate(-50%,-50%) scale(1); opacity:.55; } 50% { transform:translate(-50%,-50%) scale(1.08); opacity:.7; } 100% { transform:translate(-50%,-50%) scale(1); opacity:.55; } }

@media (max-width: 1080px){
	.articles-promo { flex-direction:column; gap:40px; }
	.articles-promo-content { order:2; }
	.articles-promo-visual { order:1; }
	.ap-img-1 { left:0; }
	.ap-img-2 { right:0; }
}
@media (max-width: 640px){
	.articles-promo { padding:32px 26px 46px; }
	.articles-promo-title { font-size:2.1rem; }
	.ap-img-side { display:none; }
	.ap-accent-orb { width:200px; height:200px; }
}

/* Team Showcase */
.team-showcase { position:relative; display:flex; gap:60px; align-items:stretch; padding:clamp(34px,4vw,60px); margin-top:10px; text-align:left; border-radius:34px; overflow:hidden; }
.team-showcase::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 78% 30%, rgba(99,102,241,0.18), transparent 65%); pointer-events:none; }
.team-intro { flex:1 1 48%; display:flex; flex-direction:column; gap:24px; justify-content:center; }
.team-title { font-size:clamp(2rem,1.4rem + 1.8vw,3rem); line-height:1.1; margin:0; }
.team-text { font-size:clamp(1rem,0.9rem + .4vw,1.15rem); color:var(--text); opacity:.85; margin:0; }
.team-pill-list { list-style:none; display:flex; flex-wrap:wrap; gap:10px; margin:4px 0 4px; padding:0; }
.team-pill-list li { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.14); padding:6px 14px; font-size:.7rem; letter-spacing:.6px; text-transform:uppercase; font-weight:600; border-radius:999px; backdrop-filter:blur(8px); }
.team-cta-row { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.team-cta { font-size:.95rem; }
.team-mini-note { font-size:.7rem; letter-spacing:.6px; text-transform:uppercase; opacity:.6; font-weight:600; }
.team-visual { flex:1 1 52%; position:relative; display:flex; align-items:center; justify-content:center; }
.team-avatar-stack { position:relative; width:100%; max-width:560px; aspect-ratio:4/3; }
.tv-img { position:absolute; overflow:hidden; border-radius:24px; border:1px solid rgba(255,255,255,0.12); box-shadow:0 8px 30px -8px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.05) inset; }
.tv-img img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(112%) contrast(108%); transition: transform 1.2s ease; }
.tv-main { inset:0; }
.tv-side { width:42%; aspect-ratio:4/5; }
.tv-1 { top:8%; left:-6%; }
.tv-2 { bottom:4%; right:-6%; }
.team-avatar-stack:hover .tv-img img { transform:scale(1.05); }
.tv-orb { position:absolute; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle at 35% 40%, rgba(168,85,247,0.55), rgba(168,85,247,0) 70%); filter:blur(40px) saturate(140%); top:50%; left:50%; transform:translate(-50%,-50%); mix-blend-mode:screen; opacity:.55; pointer-events:none; animation:orbPulse 16s ease-in-out infinite alternate; }
.team-stats-panel { position:absolute; bottom:-16px; left:50%; transform:translate(-50%, 50%); display:flex; gap:22px; background:linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.08)); backdrop-filter:blur(16px) saturate(160%); border:1px solid rgba(255,255,255,0.2); padding:18px 34px; border-radius:22px; box-shadow:0 8px 30px rgba(0,0,0,0.45); }
.team-stat { display:flex; flex-direction:column; align-items:center; min-width:90px; }
.team-stat-num { font-size:1.4rem; font-weight:700; letter-spacing:.5px; background:linear-gradient(90deg,var(--accent-2),var(--accent)); background-clip:text; -webkit-background-clip:text; color:transparent; }
.team-stat-label { font-size:.6rem; letter-spacing:.6px; text-transform:uppercase; font-weight:600; opacity:.7; margin-top:4px; text-align:center; }

@media (max-width: 1100px){
	.team-showcase { flex-direction:column; gap:42px; }
	.team-intro { order:2; }
	.team-visual { order:1; }
	.tv-1 { left:0; }
	.tv-2 { right:0; }
	.team-stats-panel { position:static; transform:none; margin-top:24px; }
}
@media (max-width: 640px){
	.team-showcase { padding:32px 26px 46px; }
	.team-title { font-size:2.1rem; }
	.tv-side { display:none; }
	.team-stats-panel { flex-wrap:wrap; justify-content:center; }
}

/* Team Lists */
.team-lists-wrapper { margin-top:120px; text-align:left; }
.team-block-title { font-size:1.65rem; margin:0 0 28px; letter-spacing:.3px; }
.people-grid { display:grid; gap:36px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.people-grid.small { gap:30px; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); }
.person-card { position:relative; display:flex; flex-direction:column; gap:14px; padding:20px 20px 22px; border-radius:22px; backdrop-filter:blur(14px) saturate(160%); }
.glass-sub { background:linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04)); border:1px solid rgba(255,255,255,0.14); }
.person-photo { position:relative; width:100%; aspect-ratio:1/1; border-radius:16px; overflow:hidden; background:rgba(255,255,255,0.06); }
.person-photo.small { aspect-ratio:1/1; }
.person-photo img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(108%) contrast(105%); transition:transform .8s ease; }
.person-card:hover .person-photo img { transform:scale(1.06); }
.person-meta { display:flex; flex-direction:column; gap:4px; }
.person-name { font-weight:600; letter-spacing:.4px; font-size:1rem; }
.person-role { font-size:.72rem; letter-spacing:.6px; text-transform:uppercase; font-weight:600; opacity:.65; }
@media (max-width:780px){
	.team-lists-wrapper { margin-top:90px; }
}
@media (max-width:560px){
	.person-card { padding:18px 18px 20px; }
	.team-block-title { font-size:1.45rem; }
}

/* Simplified Team Showcase */
.team-showcase-simple { position:relative; display:flex; gap:56px; align-items:stretch; padding:clamp(34px,4vw,60px); margin-top:10px; text-align:left; border-radius:34px; overflow:hidden; }
.team-showcase-simple::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 24% 30%, rgba(34,211,238,0.18), transparent 62%), radial-gradient(circle at 80% 76%, rgba(168,85,247,0.16), transparent 65%); pointer-events:none; }
.team-simple-text { flex:1 1 48%; display:flex; flex-direction:column; justify-content:center; gap:26px; }
.team-simple-image { flex:1 1 52%; display:flex; align-items:center; justify-content:center; position:relative; }
.team-single-figure { position:relative; width:100%; max-width:640px; aspect-ratio:4/3; border-radius:30px; overflow:hidden; border:1px solid rgba(255,255,255,0.14); background:rgba(255,255,255,0.05); box-shadow:0 14px 40px -10px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.08) inset; }
.team-single-figure img { width:100%; height:100%; object-fit:cover; display:block; filter:saturate(110%) contrast(107%); transition:transform 1.2s ease; }
.team-single-figure:hover img { transform:scale(1.045); }
.team-image-accent { position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.55)); mix-blend-mode:overlay; pointer-events:none; }
@media (max-width:1080px){
	.team-showcase-simple { flex-direction:column; gap:42px; }
	.team-simple-text { order:2; }
	.team-simple-image { order:1; }
}
@media (max-width:640px){
	.team-showcase-simple { padding:32px 26px 40px; }
	.team-simple-text { gap:20px; }
	.team-title { font-size:2.05rem; }
}

/* Team Stats Band */
.team-stats-band { margin:70px auto 40px; display:flex; align-items:stretch; justify-content:center; gap:34px; padding:28px 46px; border-radius:32px; position:relative; flex-wrap:wrap; }
.team-stats-band::before { content:""; position:absolute; inset:0; background:linear-gradient(110deg, rgba(255,255,255,0.14), rgba(255,255,255,0.06)); mix-blend-mode:overlay; pointer-events:none; border-radius:inherit; }
.tsb-item { display:flex; flex-direction:column; align-items:center; min-width:150px; padding:6px 4px; position:relative; }
.tsb-num { font-size:clamp(1.8rem,1.2rem + 1.6vw,2.6rem); font-weight:700; letter-spacing:.5px; background:linear-gradient(90deg,var(--accent-2),var(--accent)); background-clip:text; -webkit-background-clip:text; color:transparent; filter:drop-shadow(0 4px 14px rgba(0,0,0,0.5)); }
.tsb-label { font-size:.65rem; letter-spacing:.7px; text-transform:uppercase; font-weight:600; opacity:.75; margin-top:6px; text-align:center; }
.tsb-divider { width:1px; background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,0.4), rgba(255,255,255,0)); align-self:stretch; opacity:.4; }
@media (max-width:900px){
	.team-stats-band { gap:28px; padding:26px 34px; }
	.tsb-item { min-width:130px; }
}
@media (max-width:640px){
	.team-stats-band { margin:50px auto 30px; padding:24px 26px; gap:18px; }
	.tsb-divider { display:none; }
	.tsb-item { min-width:46%; }
}

/* Contact Modern */
.contact-section { padding-top:140px; }
.contact-shell { position:relative; padding: clamp(38px,4vw,60px); border-radius:38px; overflow:hidden; }
.contact-shell::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 18% 22%, rgba(34,211,238,0.18), transparent 60%), radial-gradient(circle at 82% 78%, rgba(168,85,247,0.16), transparent 65%); pointer-events:none; }
.contact-grid { display:flex; gap:70px; align-items:stretch; }
.contact-info-col { flex:1 1 44%; display:flex; flex-direction:column; gap:26px; }
.contact-heading { font-size:clamp(2rem,1.4rem + 1.8vw,3rem); line-height:1.1; margin:0; }
.contact-lead { font-size:clamp(1rem,0.9rem + .4vw,1.15rem); color:var(--text); opacity:.9; margin:0; }
.contact-highlights { list-style:none; padding:0; margin:4px 0 4px; display:grid; gap:10px; }
.contact-highlights li { font-size:.9rem; line-height:1.5; color:var(--muted); display:flex; align-items:flex-start; gap:8px; }
.contact-highlights .ch-icon { font-size:.75rem; color:var(--accent-2); line-height:1.6; }
.social-icon-bar { display:flex; gap:14px; margin-top:6px; flex-wrap:wrap; }
.soc-icon { --size:52px; width:var(--size); height:var(--size); display:inline-flex; align-items:center; justify-content:center; border-radius:18px; position:relative; text-decoration:none; color:var(--text); font-size:0; background:linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05)); border:1px solid rgba(255,255,255,0.16); backdrop-filter:blur(12px) saturate(160%); box-shadow:0 4px 20px -6px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.06) inset; transition:.35s; }
.soc-icon::after { content:attr(aria-label); position:absolute; bottom:-26px; left:50%; transform:translateX(-50%); font-size:.55rem; letter-spacing:.6px; text-transform:uppercase; font-weight:600; opacity:0; pointer-events:none; transition:.25s; background:rgba(0,0,0,0.5); padding:4px 8px; border-radius:8px; backdrop-filter:blur(4px); }
.soc-icon:hover { transform:translateY(-4px); border-color:rgba(255,255,255,0.28); box-shadow:0 8px 30px -6px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.1) inset, 0 0 40px -6px rgba(34,211,238,0.4); }
.soc-icon:hover::after { opacity:1; }
.soc-icon svg { width:26px; height:26px; stroke:var(--accent-2); stroke-width:1.6; fill:none; }
.soc-icon[data-variant="fill"] svg { fill:var(--accent-2); stroke:none; }

/* Ongoing Events & Competitions Section */
.ongoing-section {
	padding: 90px 20px 60px;
	background: none;
	min-height: auto;
}
.ongoing-header {
	max-width: 720px;
	margin: 0 auto 48px;
	text-align: center;
}
.ongoing-header h2 { margin-bottom: 12px; }
.ongoing-header p {
	max-width: 640px;
	margin: 0 auto;
}
.pill-live {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: 999px;
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 700;
	background: rgba(34,211,238,0.12);
	color: var(--accent-2);
	border: 1px solid rgba(34,211,238,0.28);
	margin-bottom: 18px;
}
.pill-live::before {
	content: "";
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #f75590;
	box-shadow: 0 0 8px rgba(247,85,144,0.9);
}
.ongoing-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px;
	text-align: left;
}
.ongoing-column {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.ongoing-column-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
}
.ongoing-column-header h3 {
	margin: 0;
	font-size: 1.4rem;
}
.ongoing-column-header span {
	font-size: 0.9rem;
	color: var(--muted);
}
.ongoing-list {
	display: grid;
	gap: 16px;
}
.ongoing-card {
	padding: 20px;
	border-radius: 18px;
	border: 1px solid rgba(255,255,255,0.09);
	background: linear-gradient(180deg, rgba(15,20,35,0.85), rgba(12,16,28,0.7));
	box-shadow: 0 14px 40px -20px rgba(0,0,0,0.55);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.ongoing-card-cover {
	position: relative;
	width: 100%;
	aspect-ratio: 16/9;
	border-radius: 14px;
	overflow: hidden;
	margin-bottom: 14px;
	background: rgba(255,255,255,0.05);
}
.ongoing-card-cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: saturate(108%) contrast(104%);
}
.ongoing-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 50px -20px rgba(14,165,233,0.35);
}
.ongoing-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	font-size: 0.82rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.68);
}
.ongoing-card-title {
	font-size: 1.18rem;
	margin: 12px 0 10px;
	color: #fff;
}
.ongoing-card-summary {
	font-size: 0.96rem;
	margin-bottom: 14px;
}
.ongoing-card-link {
	font-weight: 600;
	color: var(--accent-2);
	text-decoration: none;
}
.ongoing-card-link:hover { color: var(--accent); }
.ongoing-empty {
	padding: 24px;
	border-radius: 16px;
	border: 1px dashed rgba(255,255,255,0.12);
	background: rgba(10,14,25,0.6);
	text-align: center;
	color: rgba(255,255,255,0.6);
}

@media (max-width: 900px) {
	.ongoing-grid {
		grid-template-columns: 1fr;
	}
	.ongoing-column-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
	}
}

@media (max-width: 600px) {
	.ongoing-section {
		padding: 72px 16px 48px;
	}
	.ongoing-card {
		padding: 18px;
	}
}
.contact-form-col { flex:1 1 56%; display:flex; }
.contact-form-modern { width:100%; display:flex; flex-direction:column; gap:28px; }
.field-group { display:flex; gap:24px; flex-wrap:wrap; }
.field-group .floating { flex:1 1 240px; }
.floating { position:relative; display:flex; flex-direction:column; gap:6px; }
.floating span { font-size:.65rem; letter-spacing:.6px; text-transform:uppercase; font-weight:600; opacity:.65; }
.floating input, .floating textarea { width:100%; padding:18px 16px 14px; border:1px solid rgba(255,255,255,0.18); border-radius:16px; background:rgba(255,255,255,0.07); color:var(--text); resize:vertical; font:inherit; outline:none; transition:border-color .25s, background-color .25s, box-shadow .25s; }
.floating input:focus, .floating textarea:focus { border-color:var(--accent-2); box-shadow:0 0 0 4px rgba(34,211,238,0.18); background:rgba(255,255,255,0.10); }
.submit-btn { align-self:flex-start; }
.contact-flash { margin-top:6px; padding:14px 16px; background:rgba(34,211,238,0.12); border:1px solid rgba(34,211,238,0.3); border-radius:14px; font-size:.8rem; }
.contact-accent-orb { position:absolute; width:420px; height:420px; top:50%; right:-120px; transform:translateY(-50%); background:radial-gradient(circle at 35% 40%, rgba(34,211,238,0.4), rgba(34,211,238,0) 70%); filter:blur(50px) saturate(140%); pointer-events:none; opacity:.6; animation:orbPulse 16s ease-in-out infinite alternate; }
@media (max-width:1080px){
	.contact-grid { flex-direction:column; gap:54px; }
	.contact-info-col { order:1; }
	.contact-form-col { order:2; }
	.contact-shell { padding:34px 32px 52px; }
}
@media (max-width:640px){
	.contact-grid { gap:44px; }
	.field-group { flex-direction:column; gap:24px; }
	.soc-icon { --size:48px; }
	.contact-shell { border-radius:30px; }
}

/* Inline Social Icons (replace @svg placeholders) */
/* Because @svg helper not defined, we can map tokens to background masks if needed later */