/*

	Variables

*/

:root {
	--ucbaja-purple: #a855f7;
	--ucbaja-purple-rgb: 132, 0, 255;
	--ucbaja-red: #d71925;
	--ucbaja-red-rgb: #d71925;
	--ucbaja-red-dark: #b30d18;
	--ucbaja-red-light: #f0484f;
	--ucbaja-red-bright: #ff7a80;
	--ucbaja-font-body: "Nutmeg-Book", "Nutmeg", Arial, Helvetica, sans-serif;
	--ucbaja-font-display: "Nutmeg-Black", "Nutmeg", Arial, Helvetica, sans-serif;
}

html {
	min-height: 100%;
	background:
		url("/images/tile_bg.png") repeat,
		#07070b;
}

body {
	min-height: 100%;
	background: transparent;
	font-family: var(--ucbaja-font-body);
	font-weight: 400;
}

button,
input,
select,
textarea {
	font-family: var(--ucbaja-font-body);
}

input,
select,
textarea {
	font-family: Arial, Helvetica, sans-serif;
}



/*

	Font-faces

*/

@font-face {
	font-family: "Nutmeg-Black";
	src:
		url("/fonts/Nutmeg/Nutmeg-Black.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Black.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Black.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Black.eot");
	font-weight: 900;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Nutmeg-Book";
	src:
		url("/fonts/Nutmeg/Nutmeg-Book.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Book.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Book.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Book.eot");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Nutmeg-Book";
	src:
		url("/fonts/Nutmeg/Nutmeg-Book.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Book.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Book.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Book.eot");
	font-weight: 900;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Nutmeg";
	src:
		url("/fonts/Nutmeg/Nutmeg-Regular.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Regular.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Regular.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Regular.eot");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Nutmeg";
	src:
		url("/fonts/Nutmeg/Nutmeg-Bold.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Bold.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Bold.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Bold.eot");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Nutmeg";
	src:
		url("/fonts/Nutmeg/Nutmeg-Black.woff2") format("woff2"),
		url("/fonts/Nutmeg/Nutmeg-Black.woff") format("woff"),
		url("/fonts/Nutmeg/Nutmeg-Black.ttf") format("truetype"),
		url("/fonts/Nutmeg/Nutmeg-Black.eot");
	font-weight: 900;
	font-style: normal;
	font-display: swap;
}


/*

	Inline Media Links

*/

.heading-media-line {
	display: inline-flex;
	align-items: center;
	gap: 0.18em;
	white-space: nowrap;
	vertical-align: middle;
}

.media-links {
	--media-links-size: clamp(1.4rem, 2.14vw, 1.9rem);
	--media-links-gap: 0.5rem;

	display: inline-flex;
	align-items: center;
	gap: var(--media-links-gap);
	margin-left: 0.08em;
	vertical-align: middle;
}

.media-links--small {
	--media-links-size: clamp(1.5rem, 2.2vw, 1.9rem);
	--media-links-gap: 0.5rem;
}

.media-links__link {
	display: inline-grid;
	place-items: center;
	width: var(--media-links-size);
	height: var(--media-links-size);
	color: #ffffff;
	line-height: 0;
	text-decoration: none;
	filter: drop-shadow(0 12px 22px rgba(0, 0, 0, 0.32));
	transition:
		color 180ms ease,
		filter 220ms ease,
		transform 220ms ease;
}

.media-links__link:hover,
.media-links__link:focus-visible {
	color: var(--ucbaja-purple);
	filter: drop-shadow(0 16px 28px rgba(var(--ucbaja-red), 0.28));
	outline: none;
	transform: translateY(-2px);
}

.media-links__link:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.74);
	outline-offset: 4px;
	border-radius: 9px;
}

.media-links__icon {
	display: block;
	width: 100%;
	height: 100%;
	overflow: visible;
	shape-rendering: geometricPrecision;
}

.media-links__fill {
	fill: currentColor;
}

.media-links__stroke {
	fill: none;
	stroke: currentColor;
	stroke-miterlimit: 10;
	stroke-width: 1.91px;
	vector-effect: non-scaling-stroke;
}

@media (max-width: 560px) {
	.media-links {
		--media-links-size: 1.45rem;
		--media-links-gap: 0.5rem;
	}

	.media-links--small {
		--media-links-size: 1.55rem;
	}
}


/*

	Hero Image

*/

.hero-image {
	position: relative;
	width: 100%;
	min-height: 100vh;
	min-height: 100svh;
	overflow: hidden;
	background:
		url("/images/tile_bg.png") repeat,
		#080808;
	color: #ffffff;
}

.hero-image__background {
	position: absolute;
	inset: 0;
	background-image: url("/images/main-preview.jpg");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transform: scale(1);
	animation: heroImageDrift 64s ease-in-out infinite;
	will-change: transform;
}

.hero-image__shade {
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		linear-gradient(
			90deg,
			rgba(0, 0, 0, 0.47) 0%,
			rgba(0, 0, 0, 0.34) 38%,
			rgba(0, 0, 0, 0.18) 68%,
			rgba(0, 0, 0, 0.36) 100%
		),
		linear-gradient(
			180deg,
			rgba(0, 0, 0, 0.26) 0%,
			rgba(0, 0, 0, 0.06) 42%,
			rgba(0, 0, 0, 0.44) 100%
		);
	opacity: 1;
}

.home-hero {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
	gap: 2rem;
	align-content: end;
	align-items: start;
	width: min(1180px, calc(100% - 3rem));
	min-height: 100vh;
	min-height: 100svh;
	margin: 0 auto;
	padding: 12rem 0 4.5rem;
}

.home-hero__content {
	max-width: 660px;
	opacity: 0;
	transform: translateY(28px);
	animation: heroContentLoad 780ms cubic-bezier(0.19, 1, 0.22, 1) 260ms forwards;
}

.home-hero h1 {
	max-width: 10ch;
	font-size: 4.7rem;
	text-shadow: 0 12px 34px rgba(0, 0, 0, 0.68);
}

.home-hero h1 .heading-media-line {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	width: 100%;
	gap: 0.34em;
}

.home-hero h1 .media-links {
	flex: 0 0 auto;
	margin-left: auto;
	padding-bottom: 0.08em;
}

.home-hero__intro {
	max-width: 560px;
	margin-top: 1.35rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1.16rem;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.9);
	text-shadow: 0 6px 18px rgba(0, 0, 0, 0.72);
}

.home-hero__intro + .home-hero__intro {
	margin-top: 0.9rem;
}

.home-hero__intro a {
	color: #ffcf48;
	text-decoration-color: rgba(255, 207, 72, 0.52);
	text-underline-offset: 0.18em;
	transition:
		color 160ms ease,
		text-decoration-color 160ms ease;
}

.home-hero__intro a:hover,
.home-hero__intro a:focus-visible {
	color: #ffffff;
	text-decoration-color: #ffffff;
}

.home-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	margin-top: 2rem;
}

.event-panel {
	position: relative;
	align-self: start;
	padding: 1.35rem;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 8px;
	background:
		linear-gradient(
			145deg,
			rgba(34, 30, 38, 0.66) 0%,
			rgba(18, 17, 22, 0.46) 100%
		);
	box-shadow:
		0 24px 60px rgba(0, 0, 0, 0.34),
		inset 0 1px 0 rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	opacity: 0;
	transform: translateX(28px);
	animation: eventPanelLoad 820ms cubic-bezier(0.19, 1, 0.22, 1) 420ms forwards;
}

.event-panel__header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.event-panel h2 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 1.45rem;
	line-height: 1.05;
	letter-spacing: 0;
	text-transform: uppercase;
}

.event-list {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}

.event-list__item {
	position: relative;
	border-bottom: 1px solid rgba(255, 255, 255, 0.11);
	opacity: 0;
	transform: translateY(16px);
	animation: eventItemLoad 560ms ease-out forwards;
}

.event-list__link {
	position: relative;
	display: grid;
	grid-template-columns: 92px minmax(0, 1fr);
	gap: 0.2rem 1rem;
	width: 100%;
	padding: 1rem 0.8rem 1rem 1rem;
	border-radius: 6px;
	color: inherit;
	text-decoration: none;
	overflow: hidden;
	transition: background-color 180ms ease;
}

.event-list__link::before {
	content: "";
	position: absolute;
	top: 0.7rem;
	bottom: 0.7rem;
	left: 0;
	width: 4px;
	border-radius: 999px;
	background: rgba(var(--ucbaja-purple-rgb), 0.82);
	opacity: 0;
	transform: scaleY(0.35);
	transform-origin: center;
	transition:
		opacity 180ms ease,
		transform 180ms ease;
}

.event-list__link:hover,
.event-list__link:focus-visible {
	background-color: rgba(0, 0, 0, 0.3);
	outline: none;
}

.event-list__link:hover::before,
.event-list__link:focus-visible::before {
	opacity: 1;
	transform: scaleY(1);
}

.event-list__item:nth-child(1) {
	animation-delay: 650ms;
}

.event-list__item:nth-child(2) {
	animation-delay: 760ms;
}

.event-list__item:nth-child(3) {
	animation-delay: 870ms;
}

.event-list__item:nth-child(4) {
	animation-delay: 980ms;
}

.event-list__item:nth-child(5) {
	animation-delay: 1090ms;
}

.event-list__item:last-child {
	border-bottom: 0;
}

.event-list__item--empty {
	display: grid;
	grid-template-columns: 1fr;
	padding: 1rem 0;
}

.event-list__date {
	grid-row: span 2;
	display: grid;
	gap: 0.25rem;
	align-self: start;
	padding-top: 0.1rem;
}

.event-list__days {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 0.8rem;
	line-height: 1;
	color: #ffcf48;
}

.event-list__actual-date {
	font-family: var(--ucbaja-font-body);
	font-size: 0.68rem;
	line-height: 1.25;
	color: rgba(255, 255, 255, 0.58);
}

.event-list__name {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1rem;
	font-weight: 900;
	line-height: 1.25;
	color: #ffffff;
	text-decoration: none;
	transition:
		color 160ms ease,
		text-shadow 160ms ease;
}

.event-list__link:hover .event-list__name,
.event-list__link:focus-visible .event-list__name {
	color: #ffcf48;
	text-shadow: 0 0 12px rgba(255, 207, 72, 0.24);
}

.event-list__meta {
	font-family: var(--ucbaja-font-body);
	font-size: 0.88rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.68);
}

@keyframes heroImageDrift {
	0% {
		transform: scale(1) translateX(0);
	}

	30% {
		transform: scale(1.32) translateX(2%);
	}

	60% {
		transform: scale(1.16) translateX(-3%);
	}

	85% {
		transform: scale(1.04) translateX(4%);
	}

	100% {
		transform: scale(1) translateX(0);
	}
}

@keyframes heroContentLoad {
	0% {
		opacity: 0;
		transform: translateY(28px);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes eventPanelLoad {
	0% {
		opacity: 0;
		transform: translateX(28px);
	}

	100% {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes eventItemLoad {
	0% {
		opacity: 0;
		transform: translateY(16px);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (max-width: 900px) {
	.home-hero {
		grid-template-columns: 1fr;
		align-items: end;
		gap: 2.5rem;
		width: min(680px, calc(100% - 2rem));
		padding-top: 11rem;
	}

	.home-hero h1 {
		max-width: 11ch;
		font-size: 3.45rem;
	}

	.event-panel {
		width: 100%;
		transform: translateY(24px);
	}
}

@media (max-width: 560px) {
	.home-hero {
		width: min(420px, calc(100% - 1.25rem));
		padding-top: 10rem;
		padding-bottom: 2rem;
	}

	.home-hero h1 {
		font-size: 2.62rem;
	}

	.home-hero__intro {
		font-size: 1rem;
	}

	.home-hero__actions {
		display: grid;
		grid-template-columns: 1fr;
	}

	.home-hero__actions .btn {
		width: 100%;
	}

	.event-list__link {
		grid-template-columns: 76px minmax(0, 1fr);
		gap: 0.2rem 0.75rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.hero-image__background,
	.hero-image__shade,
	.home-hero__content,
	.event-panel,
	.event-list__item {
		animation: none;
		opacity: 1;
		transform: none;
	}
}


/*

	Shared Image Pages

*/

.image-page {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	overflow: hidden;
	background:
		url("/images/tile_bg.png") repeat,
		#080808;
	color: #ffffff;
}

.image-page__background,
.image-page__shade {
	position: absolute;
	inset: 0;
}

.image-page__background {
	background-image: url("/images/main-preview.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

/*

	Event Details

*/

.event-detail-page {
	isolation: isolate;
}

.event-detail-page__background {
	background-image: url("/images/events_hero.jpg");
}

.event-detail {
	position: relative;
	z-index: 2;
	width: min(1060px, calc(100% - 3rem));
	margin: 0 auto;
	padding: 12rem 0 5rem;
}

.event-detail__back {
	display: inline-flex;
	margin-bottom: 2rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.86rem;
	font-weight: 900;
	color: #ffcf48;
	text-decoration: none;
	text-transform: uppercase;
}

.event-detail__back:hover,
.event-detail__back:focus-visible {
	color: #ffffff;
}

.event-detail__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
	gap: 2rem;
	align-items: start;
}

.event-detail__main {
	position: relative;
	isolation: isolate;
	max-width: 680px;
	padding: 2rem;
	--glass-panel-border: rgba(255, 255, 255, 0.2);
	--glass-panel-background:
		linear-gradient(
			145deg,
			rgba(22, 20, 26, 0.82) 0%,
			rgba(12, 12, 15, 0.7) 100%
		);
	--glass-panel-shadow:
		0 26px 70px rgba(0, 0, 0, 0.42),
		inset 0 1px 0 rgba(255, 255, 255, 0.14);
	overflow: hidden;
}

.event-detail__main::before {
	content: "";
	position: absolute;
	top: 1rem;
	bottom: 1rem;
	left: 0;
	width: 5px;
	border-radius: 999px;
	background: linear-gradient(
		180deg,
		var(--ucbaja-purple) 0%,
		var(--ucbaja-red) 100%
	);
	box-shadow: 0 0 22px rgba(var(--ucbaja-purple-rgb), 0.34);
}

.event-detail__main::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 9rem;
	height: 9rem;
	background:
		linear-gradient(
			135deg,
			rgba(var(--ucbaja-purple-rgb), 0.18) 0%,
			rgba(215, 25, 37, 0.08) 52%,
			rgba(255, 255, 255, 0) 53%
		);
	pointer-events: none;
}

.event-detail__main > * {
	position: relative;
	z-index: 1;
}

.event-detail h1 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 3.8rem;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
	text-shadow: 0 8px 22px rgba(0, 0, 0, 0.5);
}

.event-detail__summary,
.event-detail__description {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	color: rgba(255, 255, 255, 0.88);
}

.event-detail__summary {
	margin-top: 1.25rem;
	font-size: 1.12rem;
	line-height: 1.65;
	color: #ffcf48;
}

.event-detail__description {
	margin-top: 1.75rem;
	font-size: 1rem;
	line-height: 1.75;
}

.event-detail__description p,
.event-detail__description ul,
.event-detail__description ol {
	margin: 0 0 1rem;
}

.event-detail__description p:last-child,
.event-detail__description ul:last-child,
.event-detail__description ol:last-child {
	margin-bottom: 0;
}

.event-detail__description a {
	color: #c9a7ff;
	font-weight: 900;
	text-decoration-color: rgba(var(--ucbaja-purple-rgb), 0.7);
	text-underline-offset: 0.18em;
	transition: color 180ms ease, text-decoration-color 180ms ease;
}

.event-detail__description a:hover,
.event-detail__description a:focus-visible {
	color: #ff6b76;
	text-decoration-color: rgba(255, 107, 118, 0.85);
}

.event-detail__panel {
	display: grid;
	gap: 1rem;
	padding: 1.35rem;
	--glass-panel-border: rgba(255, 255, 255, 0.16);
	--glass-panel-background: rgba(10, 10, 10, 0.66);
	--glass-panel-shadow:
		0 24px 60px rgba(0, 0, 0, 0.45),
		inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.event-detail__fact {
	display: grid;
	gap: 0.22rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.11);
}

.event-detail__fact:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.event-detail__fact span {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.74rem;
	font-weight: 900;
	color: #ffcf48;
	text-transform: uppercase;
}

.event-detail__fact strong {
	font-family: var(--ucbaja-font-body);
	font-size: 0.96rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.9);
}

.event-detail__location-link {
	display: inline-flex;
	align-items: center;
	gap: 0.42rem;
	color: #ffffff;
	text-decoration-color: rgba(255, 255, 255, 0.34);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
	transition:
		color 180ms ease,
		text-decoration-color 180ms ease,
		text-shadow 180ms ease;
}

.event-detail__location-link:hover,
.event-detail__location-link:focus-visible {
	color: var(--ucbaja-purple);
	text-decoration-color: rgba(var(--ucbaja-purple-rgb), 0.72);
	text-shadow: 0 0 18px rgba(var(--ucbaja-purple-rgb), 0.3);
}

.event-detail__google-pin {
	flex: 0 0 auto;
	width: 1.08rem;
	height: 1.08rem;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.28));
}

.event-detail__map-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.55rem;
}

.event-detail__map-link {
	display: grid;
	place-items: center;
	width: 2.35rem;
	height: 2.35rem;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.075);
	color: rgba(255, 255, 255, 0.88);
	text-decoration: none;
	transition:
		background 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease,
		color 180ms ease,
		transform 180ms ease;
}

.event-detail__map-link svg {
	width: 1.22rem;
	height: 1.22rem;
	fill: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.8;
}

.event-detail__map-link:hover,
.event-detail__map-link:focus-visible {
	border-color: rgba(var(--ucbaja-purple-rgb), 0.64);
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.18), rgba(255, 255, 255, 0.07));
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.24);
	color: var(--ucbaja-purple);
	outline: none;
	transform: translateY(-2px);
}

@media (max-width: 900px) {
	.event-detail {
		width: min(680px, calc(100% - 2rem));
	}

	.event-detail__layout {
		grid-template-columns: 1fr;
	}

	.event-detail h1 {
		font-size: 3rem;
	}

	.event-detail__main {
		max-width: none;
	}
}

@media (max-width: 560px) {
	.event-detail {
		width: min(420px, calc(100% - 1.25rem));
		padding-top: 10rem;
		padding-bottom: 3rem;
	}

	.event-detail h1 {
		font-size: 2.35rem;
	}

	.event-detail__main {
		padding: 1.35rem;
	}
}


/*

	History Page

*/

.history-page {
	position: relative;
	overflow-x: clip;
	color: #ffffff;
	background:
		linear-gradient(180deg, rgba(7, 7, 11, 0.74) 0%, rgba(12, 11, 17, 0.88) 44%, rgba(7, 7, 11, 0.82) 100%),
		url("/images/tile_bg.png") repeat,
		radial-gradient(circle at 16% 16%, rgba(var(--ucbaja-purple-rgb), 0.2), transparent 28rem),
		radial-gradient(circle at 86% 34%, rgba(215, 25, 37, 0.16), transparent 27rem),
		#08080d;
}

.history-page::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		linear-gradient(115deg, transparent 0 58%, rgba(var(--ucbaja-purple-rgb), 0.11) 58.2% 58.8%, transparent 59%),
		linear-gradient(292deg, transparent 0 66%, rgba(215, 25, 37, 0.09) 66.2% 66.8%, transparent 67%);
	opacity: 0.72;
}

@supports not (overflow: clip) {
	.history-page {
		overflow-x: hidden;
	}
}

.history-after {
	position: relative;
	z-index: 1;
	width: min(1180px, calc(100% - 3rem));
	margin: 0 auto;
}

.hero-image--history {
	--hero-min-height: 42vh;
	--hero-min-height-svh: 42svh;
	--hero-content-width: 1180px;
	--hero-content-padding: 8.8rem 0 2.35rem;
}

.history-hero {
	min-height: var(--hero-min-height);
	min-height: var(--hero-min-height-svh);
}

.history-hero__image {
	object-position: center 58%;
}

.history-hero__shade {
	background:
		linear-gradient(
			90deg,
			rgba(0, 0, 0, 0.5) 0%,
			rgba(0, 0, 0, 0.32) 44%,
			rgba(0, 0, 0, 0.14) 72%,
			rgba(0, 0, 0, 0.36) 100%
		),
		linear-gradient(
			180deg,
			rgba(0, 0, 0, 0.26) 0%,
			rgba(0, 0, 0, 0.03) 44%,
			rgba(0, 0, 0, 0.52) 100%
		);
}

.history-hero h1,
.history-after h2 {
	max-width: 11ch;
	margin: 0;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(3.1rem, 7vw, 6.5rem);
	font-weight: 900;
	line-height: 0.9;
	letter-spacing: 0;
	text-transform: uppercase;
	text-shadow: 0 16px 42px rgba(0, 0, 0, 0.54);
}

.history-hero p:not(.page-eyebrow),
.history-after p:not(.page-eyebrow) {
	max-width: 42rem;
	margin: 1.35rem 0 0;
	color: rgba(255, 255, 255, 0.78);
	font-size: clamp(1rem, 1.35vw, 1.16rem);
	line-height: 1.68;
}

.history-timeline-section {
	position: relative;
	z-index: 1;
	min-height: auto;
	--history-x: 0px;
	--history-progress: 0%;
}

.history-timeline__sticky {
	position: relative;
	display: block;
	height: auto;
	min-height: 0;
	overflow: hidden;
	padding: clamp(1.1rem, 2.6vw, 2rem) 0 clamp(1.75rem, 4vw, 3rem);
}

.history-timeline__viewport {
	width: 100%;
	overflow: visible;
}

.history-timeline__track {
	display: flex;
	align-items: stretch;
	gap: clamp(1.1rem, 2.2vw, 2rem);
	width: max-content;
	padding: 0 max(1.5rem, calc((100vw - 1180px) / 2));
	transform: translate3d(calc(var(--history-x) * -1), 0, 0);
	will-change: transform;
}

.history-card {
	position: relative;
	display: grid;
	grid-template-columns: minmax(18rem, 0.95fr) minmax(18rem, 0.88fr);
	width: clamp(48rem, 68vw, 66rem);
	height: clamp(34rem, calc(100svh - 11rem), 40rem);
	min-height: 0;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 8px;
	background:
		linear-gradient(145deg, rgba(18, 18, 27, 0.9), rgba(9, 9, 14, 0.8)),
		rgba(12, 12, 18, 0.86);
	box-shadow:
		0 30px 86px rgba(0, 0, 0, 0.42),
		inset 0 1px 0 rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}

.history-card::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: clamp(8rem, 20vw, 15rem);
	aspect-ratio: 1;
	background: linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.72), rgba(215, 25, 37, 0.62));
	clip-path: polygon(100% 0, 0 0, 100% 100%);
	opacity: 0.55;
}

.history-card::after {
	content: "";
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	width: 5.2rem;
	height: 5.2rem;
	border-left: 2px solid rgba(var(--ucbaja-purple-rgb), 0.52);
	border-bottom: 2px solid rgba(215, 25, 37, 0.5);
	opacity: 0.56;
}

.history-card__media,
.history-card__body {
	position: relative;
	z-index: 1;
	min-height: 0;
}

.history-card__media {
	display: grid;
	grid-template-rows: minmax(0, 1fr) auto;
	gap: 0.75rem;
	padding: 0.85rem;
}

.history-card__primary {
	position: relative;
	height: 100%;
	min-height: 0;
	overflow: hidden;
	border-radius: 7px;
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.18), rgba(215, 25, 37, 0.11)),
		#121219;
}

.history-card__image-button {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
	border: 0;
	border-radius: inherit;
	background: transparent;
	cursor: zoom-in;
}

.history-card__image-button::before,
.history-card__image-button::after {
	content: "";
	position: absolute;
	z-index: 3;
	pointer-events: none;
	opacity: 0;
	transition:
		opacity 220ms ease,
		transform 260ms ease;
}

.history-card__image-button::before {
	inset: 0.65rem;
	border-top: 2px solid rgba(var(--ucbaja-purple-rgb), 0.86);
	border-right: 2px solid rgba(215, 25, 37, 0.84);
	transform: translate(-0.45rem, 0.45rem);
}

.history-card__image-button::after {
	left: 0.65rem;
	bottom: 0.65rem;
	width: 4.6rem;
	height: 4.6rem;
	border-left: 2px solid rgba(215, 25, 37, 0.84);
	border-bottom: 2px solid rgba(var(--ucbaja-purple-rgb), 0.86);
	transform: translate(0.45rem, -0.45rem);
}

.history-card__image-button:hover::before,
.history-card__image-button:hover::after,
.history-card__image-button:focus-visible::before,
.history-card__image-button:focus-visible::after {
	opacity: 1;
	transform: translate(0, 0);
}

.history-card__image-button:focus-visible {
	outline: 2px solid var(--ucbaja-purple);
	outline-offset: 3px;
}

.history-card__image-picture {
	display: block;
	width: 100%;
	height: 100%;
}

.history-card__primary::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.1),
		inset 0 -7rem 8rem rgba(0, 0, 0, 0.34);
}

.history-card__primary-image {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 0;
	object-fit: cover;
	transform: scale(1.02);
	filter: saturate(0.96) contrast(1.05);
	transition: transform 320ms ease, filter 320ms ease;
}

.history-card__image-button:hover .history-card__primary-image,
.history-card__image-button:focus-visible .history-card__primary-image {
	transform: scale(1.065);
	filter: saturate(1.05) contrast(1.08);
}

.history-card__image-placeholder {
	display: grid;
	place-items: center;
	align-content: center;
	gap: 0.4rem;
	height: 100%;
	min-height: 0;
	color: rgba(255, 255, 255, 0.84);
}

.history-card__image-placeholder span {
	font-size: 1rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.history-card__image-placeholder strong {
	font-family: var(--ucbaja-font-display);
	font-size: clamp(5rem, 12vw, 8rem);
	line-height: 0.85;
}

.history-card__thumbs {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.75rem;
	min-height: 5.6rem;
}

.history-card__thumb,
.history-card__empty-thumb {
	width: 100%;
	height: 5.6rem;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.065);
}

.history-card__thumb {
	border-radius: 6px;
}

.history-card__thumb-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(0.88) contrast(1.06);
	transition: transform 280ms ease, filter 280ms ease;
}

.history-card__image-button:hover .history-card__thumb-image,
.history-card__image-button:focus-visible .history-card__thumb-image {
	transform: scale(1.1);
	filter: saturate(1.02) contrast(1.08);
}

.history-card__empty-thumb {
	display: grid;
	grid-column: 1 / -1;
	place-items: center;
	color: rgba(255, 255, 255, 0.48);
	font-size: 0.74rem;
	font-weight: 900;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.history-card__body {
	display: grid;
	grid-template-rows: auto auto auto minmax(0, 1fr);
	align-content: start;
	gap: 0.75rem;
	overflow: hidden;
	padding: clamp(1.35rem, 3vw, 2.2rem);
}

.history-card__topline {
	display: block;
	color: rgba(255, 255, 255, 0.62);
	font-size: 0.74rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.history-card__topline span {
	color: #ffcf48;
}

.history-card__identity {
	display: grid;
	gap: 0.5rem;
	align-items: start;
}

.history-card__number {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.12em;
	color: #ffffff;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(2.9rem, 5.4vw, 4.75rem);
	line-height: 0.8;
	text-shadow: 0 14px 34px rgba(0, 0, 0, 0.42);
}

.history-card__number-amp {
	color: #ffcf48;
	font-size: 0.34em;
	line-height: 1;
	transform: translateY(-0.14em);
}

.history-card h2 {
	margin: 0;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(1.1rem, 2vw, 1.85rem);
	font-weight: 900;
	line-height: 0.95;
	letter-spacing: 0;
	text-transform: uppercase;
}

.history-card__identity p {
	margin: 0.55rem 0 0;
	color: rgba(255, 255, 255, 0.62);
	font-weight: 800;
	line-height: 1.45;
}

.history-card__overall-strip {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(7.2rem, 1fr));
	gap: 0.55rem;
}

.history-card__overall-card {
	display: grid;
	gap: 0.12rem;
	min-width: 0;
	padding: 0.72rem 0.78rem;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.28);
	border-radius: 6px;
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.18), rgba(215, 25, 37, 0.08)),
		rgba(255, 255, 255, 0.045);
}

.history-card__overall-card em,
.history-card__overall-card small {
	overflow: hidden;
	color: rgba(255, 255, 255, 0.56);
	font-size: 0.64rem;
	font-style: normal;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-overflow: ellipsis;
	text-transform: uppercase;
	white-space: nowrap;
}

.history-card__overall-card strong {
	display: flex;
	align-items: baseline;
	gap: 0.14em;
	color: #ffffff;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(1.55rem, 2.6vw, 2.4rem);
	font-weight: 900;
	line-height: 0.92;
	text-transform: uppercase;
}

.history-card__place-number {
	font-size: 1em;
	line-height: 0.92;
}

.history-card__place-suffix {
	font-size: 0.5em;
	line-height: 1;
	transform: translateY(-0.08em);
}

.history-card__overall-card .history-card__place-suffix {
	font-size: 0.375em;
}

.history-card__overall-card small {
	color: var(--ucbaja-purple);
	font-size: 0.83rem;
}

.history-card__results {
	display: grid;
	gap: 0.62rem;
	min-height: 0;
	margin: 0;
	overflow: auto;
	padding: 0;
	list-style: none;
	scrollbar-width: thin;
	scrollbar-color: rgba(var(--ucbaja-purple-rgb), 0.58) rgba(255, 255, 255, 0.08);
}

.history-card__results::-webkit-scrollbar {
	width: 0.48rem;
}

.history-card__results::-webkit-scrollbar-track {
	background: rgba(255, 255, 255, 0.08);
	border-radius: 999px;
}

.history-card__results::-webkit-scrollbar-thumb {
	background: rgba(var(--ucbaja-purple-rgb), 0.58);
	border-radius: 999px;
}

.history-card__competition {
	display: grid;
	gap: 0.68rem;
	padding: 0.82rem;
	border: 1px solid rgba(255, 255, 255, 0.11);
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.055);
}

.history-card__competition-head {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 1rem;
	align-items: start;
}

.history-card__competition-head div {
	display: grid;
	gap: 0.18rem;
	min-width: 0;
}

.history-card__competition-head strong {
	display: flex;
	align-items: baseline;
	gap: 0.14em;
	color: #ffffff;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(1.05rem, 1.8vw, 1.38rem);
	font-weight: 900;
	line-height: 0.95;
	text-transform: uppercase;
}

.history-card__competition-head em {
	color: var(--ucbaja-purple);
	font-size: 0.72rem;
	font-style: normal;
	font-weight: 900;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.history-card__competition-head small,
.history-card__competition-head span,
.history-card__result-grid em {
	color: rgba(255, 255, 255, 0.56);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.history-card__competition-head small {
	text-align: right;
	white-space: nowrap;
}

.history-card__result-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.45rem;
}

.history-card__result-grid span {
	display: grid;
	gap: 0.12rem;
	min-width: 0;
	padding: 0.56rem 0.62rem;
	border: 1px solid rgba(255, 255, 255, 0.09);
	border-radius: 5px;
	background: rgba(0, 0, 0, 0.16);
}

.history-card__result-grid em {
	overflow: hidden;
	font-size: 0.64rem;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.history-card__result-grid strong {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.88rem;
	font-weight: 900;
}

.history-card__comment {
	color: #ffcf48;
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.history-card--empty {
	width: min(38rem, calc(100vw - 3rem));
	grid-template-columns: 1fr;
	min-height: 24rem;
}

.history-rail {
	position: relative;
	display: grid;
	grid-template-columns: auto minmax(12rem, 1fr);
	gap: 1rem;
	align-items: center;
	width: min(1180px, calc(100% - 3rem));
	margin: clamp(0.85rem, 1.8vw, 1.25rem) auto 0;
	padding: 1.55rem 1rem 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 8px;
	background: rgba(8, 8, 12, 0.72);
	box-shadow: 0 20px 52px rgba(0, 0, 0, 0.32);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.history-rail__label {
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.history-rail__label {
	color: rgba(255, 255, 255, 0.52);
}

.history-rail__bar {
	position: relative;
	height: 2.4rem;
}

.history-rail__bar::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	height: 2px;
	background: rgba(255, 255, 255, 0.18);
	transform: translateY(-50%);
}

.history-rail__progress {
	position: absolute;
	top: 50%;
	left: 0;
	width: var(--history-progress);
	height: 3px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red));
	box-shadow: 0 0 18px rgba(var(--ucbaja-purple-rgb), 0.34);
	transform: translateY(-50%);
}

.history-rail__progress::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	width: 0.72rem;
	height: 0.72rem;
	border-radius: 999px;
	background: #ffffff;
	box-shadow:
		0 0 0 4px rgba(var(--ucbaja-purple-rgb), 0.22),
		0 0 22px rgba(var(--ucbaja-purple-rgb), 0.5);
	transform: translate(50%, -50%);
}

.history-rail__marker {
	position: absolute;
	top: 50%;
	left: var(--marker-position);
	display: grid;
	place-items: center;
	width: 0.72rem;
	height: 0.72rem;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.45);
	border-radius: 999px;
	background: #111117;
	color: rgba(255, 255, 255, 0.54);
	cursor: pointer;
	touch-action: manipulation;
	transform: translate(-50%, -50%);
	transition:
		background 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		transform 180ms ease;
}

.history-rail__marker::after {
	content: "";
	position: absolute;
	inset: -1.9rem -0.85rem -0.85rem;
	border-radius: 999px;
}

.history-rail__marker span {
	position: absolute;
	top: -1.6rem;
	opacity: 1;
	font-size: 0.64rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	pointer-events: none;
	text-transform: uppercase;
	transform: translateY(0);
	transition:
		color 180ms ease,
		transform 180ms ease;
}

.history-rail__marker:hover,
.history-rail__marker:focus-visible,
.history-rail__marker.is-active {
	border-color: var(--ucbaja-purple);
	background: var(--ucbaja-purple);
	color: #ffffff;
	outline: none;
	transform: translate(-50%, -50%) scale(1.22);
}

.history-rail__marker:hover span,
.history-rail__marker:focus-visible span,
.history-rail__marker.is-active span {
	color: #ffcf48;
	transform: translateY(0);
}

.history-after {
	display: grid;
	place-items: start;
	min-height: 0;
	padding: 2.75rem 0 4rem;
}

.history-after h2 {
	max-width: 9ch;
	font-size: clamp(2.6rem, 6vw, 5.4rem);
}

.history-lightbox-open {
	overflow: hidden;
}

.history-lightbox[hidden] {
	display: none;
}

.history-lightbox {
	position: fixed;
	z-index: 10000;
	inset: 0;
	display: grid;
	place-items: center;
	padding: clamp(1rem, 3vw, 2rem);
}

.history-lightbox__backdrop {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	background:
		radial-gradient(circle at 22% 18%, rgba(var(--ucbaja-purple-rgb), 0.24), transparent 24rem),
		rgba(3, 3, 6, 0.78);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	cursor: zoom-out;
}

.history-lightbox__panel {
	position: relative;
	display: grid;
	gap: 0.8rem;
	width: min(1120px, 94vw);
	max-height: 88vh;
	padding: clamp(0.75rem, 1.6vw, 1.05rem);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background: rgba(11, 11, 17, 0.92);
	box-shadow: 0 34px 96px rgba(0, 0, 0, 0.62);
	transform: translateY(0.4rem) scale(0.985);
	opacity: 0;
	transition:
		opacity 180ms ease,
		transform 220ms ease;
}

.history-lightbox.is-open .history-lightbox__panel {
	opacity: 1;
	transform: translateY(0) scale(1);
}

.history-lightbox__panel img {
	display: block;
	width: 100%;
	max-height: 76vh;
	border-radius: 6px;
	object-fit: contain;
	background: #050507;
}

.history-lightbox.is-stepping-prev .history-lightbox__panel img {
	animation: historyLightboxStepPrev 220ms ease;
}

.history-lightbox.is-stepping-next .history-lightbox__panel img {
	animation: historyLightboxStepNext 220ms ease;
}

.history-lightbox__panel p {
	margin: 0;
	color: rgba(255, 255, 255, 0.66);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.history-lightbox__close {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	z-index: 2;
	display: grid;
	place-items: center;
	width: 2.35rem;
	height: 2.35rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	background: rgba(5, 5, 8, 0.72);
	color: #ffffff;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	transition:
		background 180ms ease,
		border-color 180ms ease,
		color 180ms ease;
}

.history-lightbox__close:hover,
.history-lightbox__close:focus-visible {
	border-color: var(--ucbaja-purple);
	background: rgba(var(--ucbaja-purple-rgb), 0.28);
	color: #ffffff;
	outline: none;
}

.history-lightbox__arrow {
	position: absolute;
	top: 50%;
	z-index: 2;
	display: none;
	place-items: center;
	width: clamp(2.65rem, 5vw, 3.35rem);
	height: clamp(2.65rem, 5vw, 3.35rem);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	background: rgba(5, 5, 8, 0.68);
	color: #ffffff;
	cursor: pointer;
	transform: translateY(-50%);
	transition:
		background 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		transform 180ms ease;
}

.history-lightbox.has-multiple-images .history-lightbox__arrow {
	display: grid;
}

.history-lightbox__arrow span {
	display: block;
	font-family: Arial, Helvetica, sans-serif;
	font-size: clamp(2.2rem, 4.2vw, 3rem);
	line-height: 0.72;
	transform: translateY(-0.05em);
}

.history-lightbox__arrow--prev {
	left: clamp(0.95rem, 2.4vw, 1.45rem);
}

.history-lightbox__arrow--next {
	right: clamp(0.95rem, 2.4vw, 1.45rem);
}

.history-lightbox__arrow:hover,
.history-lightbox__arrow:focus-visible {
	border-color: var(--ucbaja-purple);
	background: rgba(var(--ucbaja-purple-rgb), 0.34);
	color: #ffffff;
	outline: none;
	transform: translateY(-50%) scale(1.05);
}

@keyframes historyLightboxStepPrev {
	0% {
		opacity: 0.38;
		transform: translateX(-1.1rem) scale(0.985);
	}

	100% {
		opacity: 1;
		transform: translateX(0) scale(1);
	}
}

@keyframes historyLightboxStepNext {
	0% {
		opacity: 0.38;
		transform: translateX(1.1rem) scale(0.985);
	}

	100% {
		opacity: 1;
		transform: translateX(0) scale(1);
	}
}

@media (max-width: 920px) {
	.history-hero,
	.history-after {
		width: min(680px, calc(100% - 2rem));
	}

	.history-hero {
		width: 100%;
	}

	.history-card {
		grid-template-columns: 1fr;
		width: min(34rem, calc(100vw - 2rem));
		height: min(45rem, calc(100svh - 7rem));
		min-height: 36rem;
	}

	.history-card__primary {
		height: 17rem;
		min-height: 0;
	}

	.history-card__body {
		align-content: start;
	}

	.history-card__competition-head {
		grid-template-columns: 1fr;
	}

	.history-card__competition-head small {
		text-align: left;
		white-space: normal;
	}

	.history-rail {
		grid-template-columns: 1fr;
	}

	.history-rail__label {
		display: none;
	}

	.history-rail__bar {
		grid-column: auto;
	}
}

@media (max-width: 560px) {
	.history-hero {
		width: 100%;
		--hero-min-height: 38vh;
		--hero-min-height-svh: 38svh;
		--hero-content-padding: 8.2rem 0 1.85rem;
	}

	.history-hero h1 {
		font-size: clamp(2.65rem, 14vw, 3.75rem);
	}

	.history-timeline__sticky {
		padding-top: 0.8rem;
		padding-bottom: 1.6rem;
	}

	.history-timeline__track {
		padding-inline: 0.75rem;
	}

	.history-card {
		width: calc(100vw - 1.5rem);
	}

	.history-card__media {
		padding: 0.65rem;
	}

	.history-card__thumbs {
		gap: 0.45rem;
	}

	.history-card__thumb,
	.history-card__empty-thumb {
		height: 4.3rem;
	}

	.history-card__identity {
		grid-template-columns: 1fr;
		gap: 0.85rem;
	}

	.history-card__number {
		font-size: clamp(2.75rem, 14.25vw, 3.85rem);
	}

	.history-rail {
		width: calc(100% - 1.25rem);
		padding: 1.45rem 0.75rem 0.72rem;
	}

	.history-rail__marker span {
		top: -1.45rem;
		font-size: 0.56rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.history-timeline-section {
		min-height: auto;
	}

	.history-timeline__sticky {
		position: relative;
	}

	.history-timeline__viewport {
		overflow-x: auto;
	}

	.history-timeline__track {
		transform: none;
	}
}


/*

	About Page

*/

.about-page {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	padding: 0 0 5rem;
	background:
		linear-gradient(
			180deg,
			rgba(9, 9, 11, 0.94) 0%,
			rgba(17, 16, 22, 0.96) 44%,
			rgba(7, 7, 8, 0.94) 100%
		),
		url("/images/tile_bg.png") repeat;
	color: #ffffff;
	overflow: hidden;
}

.about-page::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			90deg,
			rgba(var(--ucbaja-purple-rgb), 0.16) 0%,
			rgba(255, 255, 255, 0) 38%,
			rgba(215, 25, 37, 0.12) 100%
		);
	pointer-events: none;
}

.about-page-hero {
	position: relative;
	z-index: 1;
	display: grid;
	align-items: end;
	min-height: 82vh;
	min-height: 82svh;
	overflow: hidden;
}

.about-page-hero h1 {
	max-width: 760px;
	font-size: 4.8rem;
	text-shadow: 0 12px 34px rgba(0, 0, 0, 0.64);
}

.about-page-hero__content > p:last-child {
	max-width: 580px;
	margin-top: 1.2rem;
	font-size: 1.14rem;
}

.about-hero,
.about-section,
.competition-grid {
	position: relative;
	z-index: 1;
	width: min(1120px, calc(100% - 3rem));
	margin: 0 auto;
}

.about-hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(360px, 0.82fr);
	gap: 2rem;
	align-items: center;
	min-height: auto;
	margin-top: 4rem;
}

.about-hero__panel {
	position: relative;
	padding: 2rem;
	overflow: hidden;
}

.competition-card::before {
	content: "";
	position: absolute;
	top: 1rem;
	bottom: 1rem;
	left: 0;
	width: 5px;
	border-radius: 999px;
	background: linear-gradient(
		180deg,
		var(--ucbaja-purple) 0%,
		var(--ucbaja-red) 100%
	);
	box-shadow: 0 0 22px rgba(var(--ucbaja-purple-rgb), 0.32);
}

.about-hero__panel::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 9rem;
	height: 9rem;
	background:
		linear-gradient(
			135deg,
			rgba(var(--ucbaja-purple-rgb), 0.18) 0%,
			rgba(215, 25, 37, 0.08) 52%,
			rgba(255, 255, 255, 0) 53%
		);
	pointer-events: none;
}

.about-hero__panel > *,
.about-section__content > *,
.competition-card > * {
	position: relative;
	z-index: 1;
}

.about-hero h1,
.about-section h2 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
}

.about-hero h1 {
	font-size: 4rem;
}

.about-section h2 {
	font-size: 3.1rem;
}

.about-copy {
	display: grid;
	gap: 0.95rem;
	margin-top: 1.25rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1rem;
	line-height: 1.68;
	color: rgba(255, 255, 255, 0.88);
}

.about-copy a {
	color: #ffcf48;
	text-decoration-color: rgba(255, 207, 72, 0.54);
	text-underline-offset: 0.18em;
	transition:
		color 160ms ease,
		text-decoration-color 160ms ease;
}

.about-copy a:hover,
.about-copy a:focus-visible {
	color: #ffffff;
	text-decoration-color: #ffffff;
}

.about-hero__media {
	position: relative;
	min-height: 520px;
	--about-image-shift: 0px;
	--about-image-scale: 1.02;
}

.about-hero__image,
.about-section__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	box-shadow: 0 28px 76px rgba(0, 0, 0, 0.45);
}

.about-hero__image {
	position: absolute;
}

.about-hero__image--primary {
	inset: 0 0 4rem 3.5rem;
	width: calc(100% - 3.5rem);
	height: calc(100% - 4rem);
	transform:
		translateY(calc(var(--about-image-shift) * -0.45))
		scale(var(--about-image-scale));
	will-change: transform;
}

.about-hero__image--secondary {
	left: 0;
	bottom: 0;
	width: 48%;
	height: 44%;
	border-color: rgba(var(--ucbaja-purple-rgb), 0.5);
	transform:
		translateY(calc(var(--about-image-shift) * 0.34))
		scale(calc(var(--about-image-scale) + 0.01));
	will-change: transform;
}

.about-section {
	display: grid;
	grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1fr);
	gap: 2rem;
	align-items: stretch;
	margin-top: 4rem;
}

.about-section__image {
	position: relative;
	min-height: 420px;
	padding: 0.65rem;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 8px;
	background:
		linear-gradient(
			145deg,
			rgba(255, 255, 255, 0.12) 0%,
			rgba(255, 255, 255, 0.03) 100%
		);
	box-shadow:
		0 28px 76px rgba(0, 0, 0, 0.45),
		inset 0 1px 0 rgba(255, 255, 255, 0.14);
	overflow: hidden;
	--about-image-shift: 0px;
	--about-image-scale: 1.03;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 3.2rem), calc(100% - 3.2rem) 100%, 0 100%);
}

.about-section__image::before {
	content: "";
	position: absolute;
	inset: 0.65rem;
	z-index: 2;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.38);
	border-radius: 6px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2.7rem), calc(100% - 2.7rem) 100%, 0 100%);
	pointer-events: none;
}

.about-section__image::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 3;
	width: 3.2rem;
	height: 3.2rem;
	background:
		linear-gradient(
			135deg,
			rgba(255, 255, 255, 0) 0%,
			rgba(255, 255, 255, 0) 48%,
			var(--ucbaja-red) 49%,
			var(--ucbaja-purple) 100%
		);
	pointer-events: none;
}

.about-section__image img {
	height: 112%;
	border-radius: 6px;
	box-shadow: none;
	transform:
		translateY(var(--about-image-shift))
		scale(var(--about-image-scale));
	will-change: transform;
}

.about-section__content {
	position: relative;
	padding: 2rem;
	overflow: hidden;
}

.about-section__content::before {
	content: "";
	position: absolute;
	top: 0;
	left: 1.25rem;
	right: 1.25rem;
	height: 4px;
	border-radius: 0 0 999px 999px;
	background: linear-gradient(
		90deg,
		rgba(var(--ucbaja-purple-rgb), 0.92) 0%,
		var(--ucbaja-red) 100%
	);
	box-shadow: 0 0 22px rgba(var(--ucbaja-purple-rgb), 0.24);
}

.about-section__content::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 7.5rem;
	height: 7.5rem;
	background:
		linear-gradient(
			315deg,
			rgba(var(--ucbaja-purple-rgb), 0.16) 0%,
			rgba(215, 25, 37, 0.1) 48%,
			rgba(255, 255, 255, 0) 49%
		);
	pointer-events: none;
}

.competition-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
	margin-top: 1.25rem;
}

.competition-card {
	position: relative;
	padding: 1.5rem 1.5rem 1.5rem 1.8rem;
	overflow: hidden;
}

.competition-card__index {
	display: inline-flex;
	margin-bottom: 1rem;
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 0.78rem;
	color: #ffcf48;
}

.competition-card h3 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 1.65rem;
	line-height: 1;
	text-transform: uppercase;
}

.competition-card p {
	margin-top: 0.9rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.98rem;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.82);
}

@media (max-width: 980px) {
	.about-page-hero h1 {
		font-size: 3.6rem;
	}

	.about-hero,
	.about-section,
	.competition-grid {
		width: min(720px, calc(100% - 2rem));
	}

	.about-hero,
	.about-section,
	.competition-grid {
		grid-template-columns: 1fr;
	}

	.about-hero {
		min-height: 0;
	}

	.about-hero__media {
		order: -1;
		min-height: 420px;
	}
}

@media (max-width: 560px) {
	.about-page {
		padding-bottom: 3rem;
	}

	.about-page-hero h1 {
		font-size: 2.65rem;
	}

	.about-hero,
	.about-section,
	.competition-grid {
		width: min(420px, calc(100% - 1.25rem));
	}

	.about-hero__panel,
	.about-section__content,
	.competition-card {
		padding: 1.35rem;
	}

	.about-hero h1,
	.about-section h2 {
		font-size: 2.45rem;
	}

	.about-hero__media {
		min-height: 320px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.about-hero__image--primary,
	.about-hero__image--secondary,
	.about-section__image img {
		transform: none;
	}
}


/*

	Team Page

*/

.team-page {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	padding: 0 0 5rem;
	background:
		linear-gradient(
			180deg,
			rgba(9, 9, 11, 0.94) 0%,
			rgba(17, 16, 22, 0.96) 44%,
			rgba(7, 7, 8, 0.94) 100%
		),
		url("/images/tile_bg.png") repeat;
	color: #ffffff;
	overflow: hidden;
}

.team-page::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			90deg,
			rgba(var(--ucbaja-purple-rgb), 0.13) 0%,
			rgba(255, 255, 255, 0) 40%,
			rgba(215, 25, 37, 0.1) 100%
		);
	pointer-events: none;
}

.team-page-hero {
	position: relative;
	z-index: 1;
	display: grid;
	align-items: end;
	min-height: 82vh;
	min-height: 82svh;
	overflow: hidden;
}

.team-overview,
.team-subteams {
	position: relative;
	z-index: 1;
	width: min(1120px, calc(100% - 3rem));
	margin: 0 auto;
}

.team-page-hero h1 {
	max-width: 780px;
	font-size: 4.8rem;
	text-shadow: 0 12px 34px rgba(0, 0, 0, 0.64);
}

.team-page-hero__content > p:last-child {
	max-width: 610px;
	margin-top: 1.2rem;
	font-size: 1.14rem;
}

.team-overview {
	position: relative;
	margin-top: 4rem;
	padding: 2rem;
	overflow: hidden;
}

.team-overview::before {
	content: "";
	position: absolute;
	top: 0;
	left: 1.25rem;
	right: 1.25rem;
	height: 4px;
	border-radius: 0 0 999px 999px;
	background: linear-gradient(
		90deg,
		rgba(var(--ucbaja-purple-rgb), 0.92) 0%,
		var(--ucbaja-red) 100%
	);
	box-shadow: 0 0 22px rgba(var(--ucbaja-purple-rgb), 0.24);
}

.team-overview > * {
	position: relative;
	z-index: 1;
}

.team-overview h2 {
	max-width: 780px;
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 2.7rem;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
}

.team-overview p:last-child {
	max-width: 780px;
	margin-top: 1rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1rem;
	line-height: 1.68;
	color: rgba(255, 255, 255, 0.86);
}

.team-subteams {
	display: grid;
	gap: 1.5rem;
	margin-top: 1.5rem;
}

.team-subteam {
	display: grid;
	grid-template-columns: minmax(320px, 0.82fr) minmax(0, 1fr);
	gap: 1.5rem;
	align-items: stretch;
}

.team-subteam--image-right {
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
}

.team-subteam--image-right .team-subteam__image {
	order: 2;
}

.team-subteam__image {
	position: relative;
	min-height: 330px;
	padding: 0.55rem;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 8px;
	background:
		linear-gradient(
			145deg,
			rgba(255, 255, 255, 0.12) 0%,
			rgba(255, 255, 255, 0.03) 100%
		);
	box-shadow:
		0 24px 64px rgba(0, 0, 0, 0.4),
		inset 0 1px 0 rgba(255, 255, 255, 0.14);
	overflow: hidden;
	--team-image-shift: 0px;
	--team-image-scale: 1.03;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2.6rem), calc(100% - 2.6rem) 100%, 0 100%);
}

.team-subteam__image::before {
	content: "";
	position: absolute;
	inset: 0.55rem;
	z-index: 2;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.34);
	border-radius: 6px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2.2rem), calc(100% - 2.2rem) 100%, 0 100%);
	pointer-events: none;
}

.team-subteam__image::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 3;
	width: 2.6rem;
	height: 2.6rem;
	background:
		linear-gradient(
			135deg,
			rgba(255, 255, 255, 0) 0%,
			rgba(255, 255, 255, 0) 48%,
			var(--ucbaja-red) 49%,
			var(--ucbaja-purple) 100%
		);
	pointer-events: none;
}

.team-subteam__image img {
	width: 100%;
	height: 112%;
	object-fit: cover;
	border-radius: 6px;
	transform:
		translateY(var(--team-image-shift))
		scale(var(--team-image-scale));
	will-change: transform;
}

.team-subteam__content {
	position: relative;
	min-height: 330px;
	padding: 2rem;
	--glass-panel-shadow:
		0 26px 70px rgba(0, 0, 0, 0.34),
		inset 0 1px 0 rgba(255, 255, 255, 0.12);
	overflow: hidden;
}

.team-subteam__content::before {
	content: "";
	position: absolute;
	top: 1rem;
	bottom: 1rem;
	left: 0;
	width: 5px;
	border-radius: 999px;
	background: linear-gradient(
		180deg,
		var(--ucbaja-purple) 0%,
		var(--ucbaja-red) 100%
	);
	box-shadow: 0 0 22px rgba(var(--ucbaja-purple-rgb), 0.32);
}

.team-subteam__content::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 7.5rem;
	height: 7.5rem;
	background:
		linear-gradient(
			135deg,
			rgba(var(--ucbaja-purple-rgb), 0.16) 0%,
			rgba(215, 25, 37, 0.08) 52%,
			rgba(255, 255, 255, 0) 53%
		);
	pointer-events: none;
}

.team-subteam--variant-2 .team-subteam__content::before {
	top: 0;
	left: 1.25rem;
	right: 1.25rem;
	bottom: auto;
	width: auto;
	height: 4px;
	border-radius: 0 0 999px 999px;
	background: linear-gradient(
		90deg,
		rgba(var(--ucbaja-purple-rgb), 0.92) 0%,
		var(--ucbaja-red) 100%
	);
}

.team-subteam--variant-2 .team-subteam__content::after {
	top: auto;
	right: 0;
	bottom: 0;
	width: 7.5rem;
	height: 7.5rem;
	background:
		linear-gradient(
			315deg,
			rgba(var(--ucbaja-purple-rgb), 0.16) 0%,
			rgba(215, 25, 37, 0.1) 48%,
			rgba(255, 255, 255, 0) 49%
		);
}

.team-subteam--variant-2 .team-subteam__image {
	clip-path: polygon(2.6rem 0, 100% 0, 100% 100%, 0 100%, 0 2.6rem);
}

.team-subteam--variant-2 .team-subteam__image::before {
	clip-path: polygon(2.2rem 0, 100% 0, 100% 100%, 0 100%, 0 2.2rem);
}

.team-subteam--variant-2 .team-subteam__image::after {
	top: 0;
	right: auto;
	bottom: auto;
	left: 0;
	background:
		linear-gradient(
			315deg,
			rgba(255, 255, 255, 0) 0%,
			rgba(255, 255, 255, 0) 48%,
			var(--ucbaja-red) 49%,
			var(--ucbaja-purple) 100%
		);
}

.team-subteam--variant-3 .team-subteam__content {
	background:
		linear-gradient(
			145deg,
			rgba(18, 16, 23, 0.86) 0%,
			rgba(23, 13, 18, 0.72) 100%
		);
}

.team-subteam--variant-3 .team-subteam__content::before {
	top: auto;
	right: 1rem;
	bottom: 0;
	left: 1rem;
	width: auto;
	height: 5px;
	border-radius: 999px 999px 0 0;
	background: linear-gradient(
		90deg,
		var(--ucbaja-red) 0%,
		var(--ucbaja-purple) 100%
	);
}

.team-subteam--variant-3 .team-subteam__content::after {
	top: 0;
	right: auto;
	left: 0;
	background:
		linear-gradient(
			225deg,
			rgba(255, 255, 255, 0) 0%,
			rgba(255, 255, 255, 0) 44%,
			rgba(var(--ucbaja-purple-rgb), 0.16) 45%,
			rgba(215, 25, 37, 0.1) 100%
		);
}

.team-subteam--variant-3 .team-subteam__image {
	border-color: rgba(255, 255, 255, 0.28);
	clip-path: polygon(0 0, calc(100% - 2.6rem) 0, 100% 2.6rem, 100% 100%, 0 100%);
}

.team-subteam--variant-3 .team-subteam__image::before {
	border-color: rgba(215, 25, 37, 0.42);
	clip-path: polygon(0 0, calc(100% - 2.2rem) 0, 100% 2.2rem, 100% 100%, 0 100%);
}

.team-subteam--variant-3 .team-subteam__image::after {
	top: 0;
	right: 0;
	bottom: auto;
	background:
		linear-gradient(
			45deg,
			rgba(255, 255, 255, 0) 0%,
			rgba(255, 255, 255, 0) 48%,
			var(--ucbaja-purple) 49%,
			var(--ucbaja-red) 100%
		);
}

.team-subteam--variant-4 .team-subteam__content::before {
	top: 1.25rem;
	right: 1.25rem;
	bottom: 1.25rem;
	left: auto;
	width: 5px;
	border-radius: 999px;
	background: linear-gradient(
		180deg,
		var(--ucbaja-red) 0%,
		var(--ucbaja-purple) 100%
	);
}

.team-subteam--variant-4 .team-subteam__content::after {
	top: 0;
	right: 0;
	left: 0;
	width: auto;
	height: 100%;
	background:
		linear-gradient(
			90deg,
			rgba(var(--ucbaja-purple-rgb), 0.08) 0%,
			rgba(255, 255, 255, 0) 38%,
			rgba(215, 25, 37, 0.08) 100%
		);
}

.team-subteam--variant-4 .team-subteam__image {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 2.6rem 100%, 0 calc(100% - 2.6rem));
}

.team-subteam--variant-4 .team-subteam__image::before {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 2.2rem 100%, 0 calc(100% - 2.2rem));
}

.team-subteam--variant-4 .team-subteam__image::after {
	right: auto;
	left: 0;
	background:
		linear-gradient(
			45deg,
			var(--ucbaja-red) 0%,
			var(--ucbaja-purple) 51%,
			rgba(255, 255, 255, 0) 52%,
			rgba(255, 255, 255, 0) 100%
		);
}

.team-subteam__content > * {
	position: relative;
	z-index: 1;
}

.team-subteam h2 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 2.55rem;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
}

.team-subteam p {
	max-width: 660px;
	margin-top: 1rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1rem;
	line-height: 1.68;
	color: rgba(255, 255, 255, 0.86);
}

@media (max-width: 980px) {
	.team-overview,
	.team-subteams {
		width: min(720px, calc(100% - 2rem));
	}

	.team-page-hero h1 {
		font-size: 3.6rem;
	}

	.team-subteam,
	.team-subteam--image-right {
		grid-template-columns: 1fr;
	}

	.team-subteam--image-right .team-subteam__image {
		order: 0;
	}
}

@media (max-width: 560px) {
	.team-page {
		padding-bottom: 3rem;
	}

	.team-overview,
	.team-subteams {
		width: min(420px, calc(100% - 1.25rem));
	}

	.team-page-hero h1 {
		font-size: 2.65rem;
	}

	.team-overview,
	.team-subteam__content {
		padding: 1.35rem;
	}

	.team-overview h2,
	.team-subteam h2 {
		font-size: 2.2rem;
	}

	.team-subteam__image,
	.team-subteam__content {
		min-height: 280px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.team-subteam__image img {
		transform: none;
	}
}


/*

	Site Header

*/
.site-header {
	position: absolute;
	top: 0;
	left: 50%;
	z-index: 20;
	width: min(960px, 100%);
	height: 160px;
	margin: 0;
	transform: translateX(-50%);
	pointer-events: none;
}

.left-box,
.right-box,
.menu-bar {
	pointer-events: auto;
}

/*
.left-box,
.right-box {
	position: absolute;
	top: 0;
	z-index: 5;
	background:
		linear-gradient(
			to bottom,
			#141414 0%,
			#060606 55%,
			#000000 100%
		);
	box-shadow:
		0 18px 35px rgba(0, 0, 0, 0.6),
		inset 0 2px 4px rgba(255, 255, 255, 0.08);
}
*/

/* Begin Right/Left Box Testing Styles */

.left-box,
.right-box {
	position: absolute;
	top: 0;
	z-index: 5;
	height: 100px;
	background:
		radial-gradient(
			ellipse at 50% 0%,
			rgba(255, 255, 255, 0.14) 0%,
			rgba(255, 255, 255, 0.04) 28%,
			rgba(0, 0, 0, 0) 58%
		),
		linear-gradient(
			to right,
			rgba(255, 255, 255, 0.06) 0%,
			rgba(255, 255, 255, 0.015) 16%,
			rgba(0, 0, 0, 0) 45%,
			rgba(0, 0, 0, 0.28) 100%
		),
		linear-gradient(
			to bottom,
			#181818 0%,
			#0b0b0b 42%,
			#030303 72%,
			#000000 100%
		);
	box-shadow:
		0 18px 35px rgba(0, 0, 0, 0.6),
		inset 0 2px 4px rgba(255, 255, 255, 0.1),
		inset 0 -12px 18px rgba(0, 0, 0, 0.85),
		inset 0 -1px 0 rgba(255, 255, 255, 0.08);
	overflow: hidden;
}


.right-box {
	right: 0;
	width: 70px;
	border-radius: 0 0 16px 16px;
	background:
		radial-gradient(
			ellipse at 50% 0%,
			rgba(255, 255, 255, 0.14) 0%,
			rgba(255, 255, 255, 0.04) 28%,
			rgba(0, 0, 0, 0) 58%
		),
		linear-gradient(
			to left,
			rgba(255, 255, 255, 0.06) 0%,
			rgba(255, 255, 255, 0.015) 16%,
			rgba(0, 0, 0, 0) 45%,
			rgba(0, 0, 0, 0.28) 100%
		),
		linear-gradient(
			to bottom,
			#181818 0%,
			#0b0b0b 42%,
			#030303 72%,
			#000000 100%
		);
}

/* End Right/Left Box Testing Styles */




.left-box {
	left: 0;
	width: 150px;
	height: 160px;
	border-radius: 0 0 16px 16px;
}

/*
.right-box {
	right: 0;
	width: 70px;
	height: 80px;
	border-radius: 0 0 16px 16px;
}
*/

.menu-bar {
	position: absolute;
	left: 140px;
	right: 60px;
	top: 20px;
	z-index: 2;
	height: 50px;
	max-height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 2rem;
	border-radius: 0;

	background: rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(20px);

	border-top: 1px solid rgba(255, 255, 255, 0.18);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow:
		inset 0 1px 2px rgba(255, 255, 255, 0.18),
		inset 0 -1px 2px rgba(0, 0, 0, 0.22),
		0 10px 24px rgba(0, 0, 0, 0.33);
}

.menu-bar ul {
	display: flex;
	align-items: stretch;
	justify-content: center;
	gap: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	list-style: none;
}

.menu-bar li {
	display: flex;
	align-items: stretch;

}


.menu-bar a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	padding: 0 1.15rem;

	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-weight: 900;
	color: #ffffff;
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: clamp(0.9rem, 1.2vw, 1.15rem);
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8);
	transition:
		transform 160ms ease,
		opacity 160ms ease,
		background-color 300ms ease;
}

.menu-bar a.current {
	opacity: 1;
	transform: none;
	pointer-events: none;
	cursor: default;
	/* background-color:  rgba(var(--ucbaja-purple-rgb), 0.3); */
	border-bottom: 4px ridge rgba(var(--ucbaja-purple-rgb), 0.3);
	border-top: 4px ridge rgba(var(--ucbaja-purple-rgb), 0.3);
}

.menu-bar a:not(.current):hover,
.menu-bar a:not(.current):focus-visible {
	opacity: 1;
	transform: translateY(-1px);
	background-color: rgba(247, 29, 29, 0.3);
	text-shadow: 0 0 3px rgba(255, 255, 255, 0.6);
}
/*
.menu-bar a.current:hover,
.menu-bar a.current:focus-visible {
	opacity: 1;
	transform: none;
	background-color:rgba(var(--ucbaja-purple-rgb), 0.3);
}
*/

.logo-area,
.login-area {
	position: relative;
	z-index: 2;
}

.logo-area {
	height: 100%;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	color: #ffffff;
	padding-top: 5px;
}

.logo-area img {
	width: 120px;
	height: auto;
	display: block;
}

.login-area {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	padding-top: 0;
}

.login-area svg {
	width: 40px;
	height: 40px;
	stroke-width: 2.2;
	padding-top: 0;
	transition:
		transform 180ms ease,
		filter 180ms ease;
}
.login-area:hover,
.login-area:focus-visible {
	color: var(--ucbaja-purple);
}

.login-area:hover svg,
.login-area:focus-visible svg {
	transform: scale(1.02);
	filter: drop-shadow(0 0 6px rgba(255, 255, 255,0.2));
}


/*

	Sponsors Page

*/

.sponsors-page {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	background:
		radial-gradient(circle at 14% 16%, rgba(var(--ucbaja-purple-rgb), 0.2), transparent 28rem),
		radial-gradient(circle at 86% 28%, rgba(215, 25, 37, 0.18), transparent 26rem),
		linear-gradient(180deg, rgba(9, 9, 13, 0.95) 0%, rgba(17, 16, 24, 0.96) 52%, rgba(9, 9, 13, 0.95) 100%),
		url("/images/tile_bg.png") repeat;
	color: #ffffff;
}

.sponsors-hero {
	position: relative;
	display: grid;
	align-items: end;
	min-height: 78vh;
	min-height: 78svh;
	overflow: hidden;
	background: #08080c;
}

.sponsors-intro h2,
.sponsors-tier h2 {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
}

.sponsors-hero h1 {
	max-width: 820px;
	font-size: 4.55rem;
	text-shadow: 0 16px 36px rgba(0, 0, 0, 0.62);
}

.sponsors-hero__content > p {
	max-width: 650px;
	margin-top: 1.25rem;
	font-size: 1.12rem;
	line-height: 1.65;
	text-shadow: 0 10px 24px rgba(0, 0, 0, 0.58);
}

.sponsors-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	margin-top: 1.7rem;
}

.sponsors-marquee {
	position: absolute;
	left: 50%;
	right: auto;
	bottom: 1.35rem;
	z-index: 3;
	width: min(1180px, calc(100% - 3rem));
	height: 70px;
	overflow: hidden;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(7, 7, 11, 0.58);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	transform: translateX(-50%);
	mask-image: linear-gradient(90deg, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
	-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
}

.sponsors-marquee__track {
	display: flex;
	align-items: center;
	gap: 0.8rem;
	width: max-content;
	height: 100%;
	padding: 0 0.8rem;
	animation: sponsorsMarquee 34s linear infinite;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.sponsors-marquee:hover .sponsors-marquee__track,
.sponsors-marquee:focus-within .sponsors-marquee__track {
	animation-play-state: paused;
}

@media (hover: none), (pointer: coarse) {
	.sponsors-marquee:hover .sponsors-marquee__track,
	.sponsors-marquee:focus-within .sponsors-marquee__track {
		animation-play-state: running;
	}
}

.sponsors-marquee__item {
	display: grid;
	place-items: center;
	flex: 0 0 auto;
	width: 150px;
	height: 48px;
	padding: 0.55rem 0.85rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	background: var(--sponsor-logo-bg, rgba(255, 255, 255, 0.92));
	color: #111118;
	text-decoration: none;
	transition:
		transform 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease;
}

.sponsors-marquee__item:hover,
.sponsors-marquee__item:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(var(--ucbaja-purple-rgb), 0.45);
	box-shadow: 0 12px 26px rgba(0, 0, 0, 0.24);
}

.sponsors-marquee__item img {
	width: 100%;
	max-height: 34px;
	object-fit: contain;
}

.sponsors-marquee__item span {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 0.86rem;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}

@keyframes sponsorsMarquee {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-50%);
	}
}

.sponsors-intro,
.sponsors-tiers {
	position: relative;
	z-index: 1;
	width: min(1180px, calc(100% - 3rem));
	margin-right: auto;
	margin-left: auto;
}

.sponsors-intro {
	display: grid;
	grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.1fr) minmax(150px, 0.32fr);
	gap: 1.5rem;
	align-items: center;
	margin-top: 4rem;
	padding: 1.4rem;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
		linear-gradient(90deg, rgba(var(--ucbaja-purple-rgb), 0.12), rgba(215, 25, 37, 0.08));
	box-shadow: 0 28px 70px rgba(0, 0, 0, 0.25);
	backdrop-filter: blur(20px);
}

.sponsors-intro::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 6.4rem;
	height: 6.4rem;
	background: linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.72), rgba(215, 25, 37, 0.72));
	clip-path: polygon(100% 0, 100% 100%, 0 0);
	opacity: 0.86;
	pointer-events: none;
}

.sponsors-intro > * {
	position: relative;
	z-index: 1;
}

.sponsors-intro h2 {
	font-size: 2.6rem;
}

.sponsors-intro > p {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1.02rem;
	line-height: 1.62;
	color: rgba(255, 255, 255, 0.82);
}

.sponsors-intro__stat {
	display: grid;
	place-items: center;
	min-height: 126px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.24);
	text-align: center;
}

.sponsors-intro__stat strong {
	display: block;
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 3rem;
	line-height: 1;
	color: #ffffff;
}

.sponsors-intro__stat span {
	margin-top: 0.35rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.76rem;
	font-weight: 900;
	color: var(--ucbaja-purple);
	text-transform: uppercase;
}

.sponsors-tiers {
	display: grid;
	gap: 4rem;
	padding: 5rem 0;
}

.sponsors-tier {
	display: grid;
	grid-template-columns: minmax(220px, 0.35fr) minmax(0, 1fr);
	gap: 1.35rem;
	align-items: start;
}

.sponsors-tier__header {
	position: sticky;
	top: 7rem;
	padding: 0.4rem 0 0;
}

.sponsors-tier h2 {
	font-size: 2.25rem;
}

.sponsors-tier__header > p:last-child {
	margin-top: 0.8rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.98rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.72);
}

.sponsors-tier__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.sponsors-tier--diamond .sponsors-tier__grid {
	grid-template-columns: minmax(0, 1fr);
}

.sponsors-tier--platinum .sponsors-tier__grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sponsor-card {
	position: relative;
	display: grid;
	gap: 1rem;
	min-height: 248px;
	padding: 1rem;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.045)),
		rgba(7, 7, 11, 0.82);
	color: #ffffff;
	text-decoration: none;
	box-shadow: 0 22px 54px rgba(0, 0, 0, 0.22);
	transition:
		transform 220ms ease,
		border-color 220ms ease,
		background 220ms ease,
		box-shadow 220ms ease;
}

.sponsor-card::before,
.sponsor-card::after {
	content: "";
	position: absolute;
	pointer-events: none;
	transition:
		opacity 220ms ease,
		transform 220ms ease;
}

.sponsor-card::before {
	inset: 0 auto 0 0;
	width: 5px;
	background: linear-gradient(180deg, var(--ucbaja-purple), var(--ucbaja-red));
	opacity: 0.64;
}

.sponsor-card::after {
	right: 0;
	bottom: 0;
	width: 5.4rem;
	height: 5.4rem;
	background: rgba(var(--ucbaja-purple-rgb), 0.2);
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
	opacity: 0.72;
}

.sponsor-card:hover,
.sponsor-card:focus-visible {
	transform: translateY(-4px);
	border-color: rgba(var(--ucbaja-purple-rgb), 0.44);
	background:
		linear-gradient(145deg, rgba(var(--ucbaja-purple-rgb), 0.18), rgba(215, 25, 37, 0.09)),
		rgba(10, 10, 15, 0.94);
	box-shadow: 0 30px 70px rgba(0, 0, 0, 0.34);
}

.sponsor-card:hover::after,
.sponsor-card:focus-visible::after {
	opacity: 1;
	transform: translate(-0.35rem, -0.35rem);
}

.sponsor-card__logo-wrap {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	height: 118px;
	padding: 1rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	background: var(--sponsor-logo-bg, rgba(255, 255, 255, 0.94));
}

.sponsor-card__logo-wrap--dark {
	background: linear-gradient(135deg, #101018, #1a1825);
}

.sponsor-card__logo-wrap img {
	display: block;
	width: min(100%, 250px);
	max-height: 82px;
	object-fit: contain;
}

.sponsor-card__logo-text {
	display: block;
	max-width: 100%;
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 1.6rem;
	line-height: 1;
	color: #111118;
	text-align: center;
	text-transform: uppercase;
}

.sponsors-tier--diamond .sponsor-card {
	grid-template-columns: minmax(260px, 0.45fr) minmax(0, 1fr);
	align-items: center;
	min-height: 292px;
	padding: 1.25rem;
}

.sponsors-tier--diamond .sponsor-card__logo-wrap {
	height: 220px;
}

.sponsors-tier--diamond .sponsor-card__logo-wrap img {
	width: min(100%, 360px);
	max-height: 150px;
}

.sponsors-tier--diamond .sponsor-card strong {
	font-size: 2rem;
}

.sponsors-tier--diamond .sponsor-card p {
	font-size: 1.05rem;
}

.sponsors-tier--platinum .sponsor-card {
	min-height: 272px;
}

.sponsors-tier--platinum .sponsor-card__logo-wrap {
	height: 148px;
}

.sponsors-tier--platinum .sponsor-card__logo-wrap img {
	width: min(100%, 290px);
	max-height: 104px;
}

.sponsor-card__body {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 0.45rem;
	align-content: start;
}

.sponsor-card__tier,
.sponsor-card__domain {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
}

.sponsor-card__tier {
	color: var(--ucbaja-purple);
}

.sponsor-card strong {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 1.34rem;
	line-height: 1.02;
}

.sponsor-card p {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.94rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.74);
}

.sponsor-card__domain {
	margin-top: 0.2rem;
	color: rgba(255, 255, 255, 0.46);
	text-transform: none;
}

.sponsor-card--variant-2::before {
	inset: 0 0 auto 0;
	width: auto;
	height: 5px;
	background: linear-gradient(90deg, var(--ucbaja-red), var(--ucbaja-purple));
}

.sponsor-card--variant-2::after {
	top: 0;
	right: 0;
	bottom: auto;
	clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.sponsor-card--variant-3::before {
	inset: auto 0 0 0;
	width: auto;
	height: 5px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red));
}

.sponsor-card--variant-3::after {
	right: auto;
	left: 0;
	clip-path: polygon(0 0, 100% 100%, 0 100%);
	background: rgba(215, 25, 37, 0.18);
}

.sponsor-card--variant-4::before {
	inset: 0;
	width: auto;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.26);
	background: none;
	opacity: 1;
	clip-path: polygon(0 0, 100% 0, 100% 5px, 5px 5px, 5px 100%, 0 100%);
}

.sponsor-card--variant-4::after {
	top: 0;
	left: 0;
	right: auto;
	bottom: auto;
	background: rgba(var(--ucbaja-purple-rgb), 0.2);
	clip-path: polygon(0 0, 100% 0, 0 100%);
}

.sponsor-card--variant-5::before {
	inset: auto 1rem 0 1rem;
	width: auto;
	height: 5px;
	border-radius: 999px 999px 0 0;
	background: linear-gradient(90deg, var(--ucbaja-red), var(--ucbaja-purple), var(--ucbaja-red));
}

.sponsor-card--variant-5::after {
	top: 50%;
	right: -2.6rem;
	bottom: auto;
	width: 7rem;
	height: 7rem;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.24);
	background: rgba(255, 255, 255, 0.045);
	clip-path: none;
	transform: translateY(-50%) rotate(45deg);
}

.sponsor-card--variant-5:hover::after,
.sponsor-card--variant-5:focus-visible::after {
	transform: translate(-0.35rem, -50%) rotate(45deg);
}

.sponsor-card--variant-6::before {
	inset: 0 0 0 auto;
	width: 5px;
	background: linear-gradient(180deg, var(--ucbaja-red), var(--ucbaja-purple));
}

.sponsor-card--variant-6::after {
	top: auto;
	right: auto;
	bottom: 1rem;
	left: 1rem;
	width: 4.8rem;
	height: 4.8rem;
	border: 1px solid rgba(215, 25, 37, 0.26);
	background: rgba(215, 25, 37, 0.14);
	clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
}

.sponsor-benefits {
	position: relative;
	z-index: 1;
	width: min(1180px, calc(100% - 3rem));
	margin: 0 auto 5rem;
	padding: 1.2rem;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.16), rgba(215, 25, 37, 0.08)),
		linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.035)),
		rgba(8, 8, 13, 0.84);
	box-shadow: 0 28px 70px rgba(0, 0, 0, 0.28);
	backdrop-filter: blur(20px);
	isolation: isolate;
}

.sponsor-benefits::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--ucbaja-red), var(--ucbaja-purple));
}

.sponsor-benefits::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 8rem;
	height: 8rem;
	background: rgba(var(--ucbaja-purple-rgb), 0.18);
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
	pointer-events: none;
}

.sponsor-benefits__header {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	align-items: end;
	margin-bottom: 1.2rem;
}

.sponsor-benefits h2 {
	max-width: 560px;
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	font-size: 2.45rem;
	line-height: 0.98;
	letter-spacing: 0;
	text-transform: uppercase;
}

.sponsor-benefits__scroller {
	position: relative;
	z-index: 1;
	overflow-x: auto;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.025)),
		rgba(4, 4, 8, 0.62);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.sponsor-benefits__table {
	width: 100%;
	min-width: 820px;
	border-collapse: separate;
	border-spacing: 0 0.55rem;
	padding: 0.55rem;
	background: transparent;
	color: #ffffff;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	table-layout: fixed;
}

.sponsor-benefits__table th,
.sponsor-benefits__table td {
	padding: 1rem 0.82rem;
	border: 0;
	vertical-align: middle;
}

.sponsor-benefits__table thead th {
	position: sticky;
	top: 0;
	z-index: 2;
	border-top: 1px solid rgba(255, 255, 255, 0.13);
	border-bottom: 1px solid rgba(255, 255, 255, 0.13);
	background:
		linear-gradient(180deg, rgba(var(--ucbaja-purple-rgb), 0.22), rgba(255, 255, 255, 0.06)),
		rgba(13, 12, 18, 0.96);
	font-size: 0.96rem;
	font-weight: 900;
	line-height: 1.25;
	text-align: center;
	box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
}

.sponsor-benefits__table thead th:first-child {
	border-left: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 8px 0 0 8px;
	text-align: left;
}

.sponsor-benefits__table thead th:last-child {
	border-right: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 0 8px 8px 0;
}

.sponsor-benefits__table thead th:not(:first-child) {
	background:
		linear-gradient(180deg, rgba(var(--ucbaja-purple-rgb), 0.28), rgba(215, 25, 37, 0.11)),
		rgba(13, 12, 18, 0.96);
}

.sponsor-benefits__table thead span {
	font-weight: 700;
	color: rgba(255, 255, 255, 0.68);
}

.sponsor-benefits__table thead th:first-child,
.sponsor-benefits__table tbody th {
	width: calc(22% - 30px);
}

.sponsor-benefits__table tbody th {
	border-left: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 8px 0 0 8px;
	background:
		linear-gradient(90deg, rgba(var(--ucbaja-purple-rgb), 0.2), rgba(255, 255, 255, 0.075));
	font-size: 1rem;
	font-weight: 900;
	line-height: 1.35;
	text-align: left;
}

.sponsor-benefits__table thead th:not(:first-child),
.sponsor-benefits__table tbody td {
	width: calc(15.6% + 6px);
}

.sponsor-benefits__table tbody td {
	background: rgba(255, 255, 255, 0.075);
	font-size: 1rem;
	font-weight: 900;
	line-height: 1.35;
	text-align: center;
}

.sponsor-benefits__table tbody td,
.sponsor-benefits__table tbody th {
	border-top: 1px solid rgba(255, 255, 255, 0.095);
	border-bottom: 1px solid rgba(255, 255, 255, 0.095);
}

.sponsor-benefits__table tbody td + td,
.sponsor-benefits__table thead th + th {
	border-left: 1px solid rgba(255, 255, 255, 0.075);
}

.sponsor-benefits__table tbody td:last-child {
	border-right: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 0 8px 8px 0;
}

.sponsor-benefits__table tbody tr:hover th,
.sponsor-benefits__table tbody tr:hover td {
	background-color: rgba(var(--ucbaja-purple-rgb), 0.12);
}

.sponsor-benefits__state {
	display: inline-grid;
	place-items: center;
	width: 2rem;
	height: 2rem;
	font-family: var(--ucbaja-font-display);
	font-weight: 900;
	line-height: 1;
}

.sponsor-benefits__state--yes {
	color: var(--ucbaja-purple);
	font-size: 2.3rem;
}

.sponsor-benefits__state--no {
	color: #8f1020;
	font-size: 1.5rem;
}

.sponsor-benefits__note {
	position: relative;
	z-index: 1;
	margin-top: 1.1rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 1rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.78);
}

@media (max-width: 980px) {
	.sponsors-intro,
	.sponsors-tiers,
	.sponsor-benefits {
		width: min(720px, calc(100% - 2rem));
	}

	.sponsors-hero h1 {
		font-size: 3.55rem;
	}

	.sponsors-intro,
	.sponsors-tier {
		grid-template-columns: 1fr;
	}

	.sponsors-tier__header {
		position: relative;
		top: auto;
	}

	.sponsors-tier__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.sponsors-tier--diamond .sponsors-tier__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.sponsors-tier--platinum .sponsors-tier__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.sponsors-tier--diamond .sponsor-card {
		grid-template-columns: 1fr;
	}

	.sponsor-benefits__table {
		min-width: 650px;
	}

	.sponsor-benefits__table th,
	.sponsor-benefits__table td {
		padding-right: 0.52rem;
		padding-left: 0.52rem;
	}

	.sponsor-benefits__table thead th:first-child,
	.sponsor-benefits__table tbody th {
		width: calc(42% - 30px);
	}

	.sponsor-benefits__table thead th:not(:first-child),
	.sponsor-benefits__table tbody td {
		width: calc(11.6% + 6px);
	}
}

@media (max-width: 640px) {
	.sponsors-page {
		padding-bottom: 3rem;
	}

	.sponsors-intro,
	.sponsors-tiers,
	.sponsor-benefits {
		width: min(420px, calc(100% - 1.25rem));
	}

	.sponsors-hero h1 {
		font-size: 2.62rem;
	}

	.sponsors-hero__content > p {
		font-size: 1rem;
	}

	.sponsors-hero__actions .btn {
		width: 100%;
	}

	.sponsors-marquee {
		width: min(420px, calc(100% - 1.25rem));
		height: 64px;
		bottom: 0.9rem;
		mask-image: linear-gradient(90deg, transparent 0%, #000000 15%, #000000 85%, transparent 100%);
		-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000000 15%, #000000 85%, transparent 100%);
	}

	.sponsors-marquee__item {
		width: 128px;
		height: 44px;
	}

	.sponsors-intro {
		margin-top: 3rem;
		padding: 1.2rem;
	}

	.sponsors-intro h2,
	.sponsor-benefits h2,
	.sponsors-tier h2 {
		font-size: 2.1rem;
	}

	.sponsor-benefits {
		padding: 1rem;
	}

	.sponsor-benefits__header {
		display: block;
	}

	.sponsor-benefits__table {
		min-width: 530px;
	}

	.sponsor-benefits__table th,
	.sponsor-benefits__table td {
		padding: 0.72rem 0.36rem;
	}

	.sponsor-benefits__table thead th {
		font-size: 0.78rem;
		line-height: 1.12;
	}

	.sponsor-benefits__table thead span {
		font-size: 0.72rem;
	}

	.sponsor-benefits__table thead th:first-child,
	.sponsor-benefits__table tbody th {
		width: calc(46% - 30px);
	}

	.sponsor-benefits__table tbody th {
		font-size: 0.9rem;
	}

	.sponsor-benefits__table tbody td,
	.sponsor-benefits__table thead th:not(:first-child) {
		width: calc(10.8% + 6px);
		font-size: 0.88rem;
	}

	.sponsor-benefits__state {
		width: 1.45rem;
		height: 1.45rem;
	}

	.sponsor-benefits__state--yes {
		font-size: 1.95rem;
	}

	.sponsor-benefits__state--no {
		font-size: 1.25rem;
	}

	.sponsors-tier__grid {
		grid-template-columns: 1fr;
	}

	.sponsors-tier--diamond .sponsors-tier__grid,
	.sponsors-tier--platinum .sponsors-tier__grid {
		grid-template-columns: 1fr;
	}

	.sponsors-tier--diamond .sponsor-card {
		min-height: 0;
	}

	.sponsors-tier--diamond .sponsor-card__logo-wrap,
	.sponsors-tier--platinum .sponsor-card__logo-wrap {
		height: 118px;
	}

	.sponsors-tier--diamond .sponsor-card strong {
		font-size: 1.34rem;
	}

	.sponsor-card {
		min-height: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sponsors-marquee__track {
		animation: none;
	}
}


/*

	Site Header Refresh

*/

.site-header {
	position: fixed;
	top: 18px;
	left: 50%;
	z-index: 100;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: 0.75rem;
	align-items: center;
	width: min(1180px, calc(100% - 2rem));
	height: 74px;
	margin: 0;
	transform: translateX(-50%);
	pointer-events: none;
	transition:
		top 260ms ease,
		width 260ms ease,
		height 260ms ease,
		filter 260ms ease;
}

.site-header.is-scrolled {
	top: 8px;
	width: min(1040px, calc(100% - 1rem));
	height: 56px;
	filter: drop-shadow(0 18px 34px rgba(0, 0, 0, 0.28));
}

.left-box,
.right-box,
.menu-bar {
	position: relative;
	top: auto;
	left: auto;
	right: auto;
	z-index: 1;
	height: 64px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.055)),
		rgba(9, 9, 14, 0.54);
	box-shadow:
		0 18px 42px rgba(0, 0, 0, 0.22),
		inset 0 1px 0 rgba(255, 255, 255, 0.16);
	backdrop-filter: blur(18px) saturate(135%);
	-webkit-backdrop-filter: blur(18px) saturate(135%);
	pointer-events: auto;
	transition:
		height 260ms ease,
		width 260ms ease,
		background 260ms ease,
		border-color 260ms ease,
		box-shadow 260ms ease,
		transform 260ms ease;
}

.site-header.is-scrolled .left-box,
.site-header.is-scrolled .right-box,
.site-header.is-scrolled .menu-bar {
	height: 52px;
	border-color: rgba(255, 255, 255, 0.2);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.065)),
		rgba(10, 10, 15, 0.78);
	box-shadow:
		0 16px 36px rgba(0, 0, 0, 0.32),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.left-box {
	width: 176px;
}

.right-box {
	width: 96px;
}

.menu-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	max-height: none;
	padding: 0 1rem;
}

.site-header.is-scrolled .left-box {
	width: 64px;
}

.site-header.is-scrolled .right-box {
	width: 52px;
}

.site-header.is-scrolled .menu-bar {
	padding: 0 0.7rem;
}

.logo-area,
.login-area {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	gap: 0.7rem;
	padding: 0;
	color: #ffffff;
	text-decoration: none;
}

.logo-area::before,
.login-area::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 0%, rgba(var(--ucbaja-purple-rgb), 0.24), transparent 44%),
		linear-gradient(135deg, rgba(215, 25, 37, 0.1), transparent 58%);
	opacity: 0;
	transition: opacity 180ms ease;
}

.logo-area:hover::before,
.logo-area:focus-visible::before,
.login-area:hover::before,
.login-area:focus-visible::before {
	opacity: 1;
}

.logo-area img {
	position: relative;
	z-index: 1;
	width: 48px;
	height: auto;
	display: block;
	filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.28));
	transition:
		width 260ms ease,
		transform 180ms ease;
}

.logo-area__text,
.login-area__label {
	position: relative;
	z-index: 1;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
	white-space: nowrap;
	transition:
		opacity 180ms ease,
		transform 180ms ease,
		max-width 220ms ease;
}

.logo-area__text {
	max-width: 96px;
	font-size: 0.76rem;
	line-height: 1.1;
	color: rgba(255, 255, 255, 0.9);
}

.login-area__label {
	max-width: 38px;
	font-size: 0.7rem;
	color: rgba(255, 255, 255, 0.78);
}

.site-header.is-scrolled .logo-area img {
	width: 38px;
}

.site-header.is-scrolled .logo-area__text,
.site-header.is-scrolled .login-area__label {
	max-width: 0;
	opacity: 0;
	transform: translateX(-0.35rem);
}

.login-area svg {
	position: relative;
	z-index: 1;
	width: 27px;
	height: 27px;
	padding: 0;
	stroke-width: 2.15;
	transition:
		transform 180ms ease,
		color 180ms ease,
		filter 180ms ease;
}

.login-area:hover,
.login-area:focus-visible {
	color: var(--ucbaja-purple);
}

.logo-area:hover img,
.logo-area:focus-visible img,
.login-area:hover svg,
.login-area:focus-visible svg {
	transform: translateY(-1px) scale(1.03);
	filter: drop-shadow(0 0 7px rgba(var(--ucbaja-purple-rgb), 0.36));
}

.menu-bar ul {
	display: flex;
	align-items: stretch;
	justify-content: center;
	gap: 0.16rem;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	list-style: none;
}

.menu-bar li {
	display: flex;
	align-items: stretch;
}

.menu-bar a {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	padding: 0 0.95rem;
	overflow: hidden;
	border-radius: 6px;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.88rem;
	font-weight: 900;
	letter-spacing: 1px;
	color: rgba(255, 255, 255, 0.82);
	text-decoration: none;
	text-shadow: none;
	text-transform: uppercase;
	transition:
		color 180ms ease,
		background 180ms ease,
		transform 180ms ease;
}

.site-header.is-scrolled .menu-bar a {
	padding: 0 0.8rem;
	font-size: 0.82rem;
}

.menu-bar a::after {
	content: "";
	position: absolute;
	left: 0.7rem;
	right: 0.7rem;
	bottom: 0.42rem;
	height: 3px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red));
	opacity: 0;
	transform: scaleX(0.42);
	transition:
		opacity 180ms ease,
		transform 180ms ease;
}

.menu-bar a.current {
	color: #ffffff;
	border: 0;
	background: rgba(var(--ucbaja-purple-rgb), 0.16);
	pointer-events: none;
	cursor: default;
}

.menu-bar a.current::after {
	opacity: 1;
	transform: scaleX(1);
}

.menu-bar a:not(.current):hover,
.menu-bar a:not(.current):focus-visible {
	color: #ffffff;
	transform: translateY(-1px);
	background: rgba(215, 25, 37, 0.18);
	text-shadow: none;
}

.menu-bar a:not(.current):hover::after,
.menu-bar a:not(.current):focus-visible::after {
	opacity: 0.75;
	transform: scaleX(1);
}

@media (max-width: 940px) {
	.site-header {
		width: min(100%, calc(100% - 1rem));
		grid-template-columns: 58px minmax(0, 1fr) 52px;
		gap: 0.45rem;
	}

	.left-box,
	.right-box {
		width: auto;
	}

	.logo-area__text,
	.login-area__label {
		display: none;
	}

	.logo-area img {
		width: 38px;
	}

	.menu-bar {
		justify-content: flex-start;
		overflow-x: auto;
		scrollbar-width: none;
	}

	.menu-bar::-webkit-scrollbar {
		display: none;
	}

	.menu-bar ul {
		justify-content: flex-start;
		width: max-content;
		min-width: 100%;
	}

	.menu-bar a,
	.site-header.is-scrolled .menu-bar a {
		padding: 0 0.76rem;
		font-size: 0.8rem;
	}
}

@media (max-width: 620px) {
	.site-header {
		top: 10px;
		height: 54px;
		grid-template-columns: 48px minmax(0, 1fr) 46px;
	}

	.site-header.is-scrolled {
		top: 6px;
		height: 48px;
	}

	.left-box,
	.right-box,
	.menu-bar,
	.site-header.is-scrolled .left-box,
	.site-header.is-scrolled .right-box,
	.site-header.is-scrolled .menu-bar {
		height: 48px;
	}

	.logo-area img,
	.site-header.is-scrolled .logo-area img {
		width: 32px;
	}

	.login-area svg {
		width: 23px;
		height: 23px;
	}

	.menu-bar {
		padding: 0 0.36rem;
	}

	.menu-bar a,
	.site-header.is-scrolled .menu-bar a {
		padding: 0 0.6rem;
		font-size: 0.74rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.site-header,
	.left-box,
	.right-box,
	.menu-bar,
	.logo-area img,
	.logo-area__text,
	.login-area__label,
	.login-area svg,
	.menu-bar a,
	.menu-bar a::after {
		transition: none;
	}
}


/*

	Site Header Reference Pass

*/

.site-header {
	top: 22px;
	display: grid;
	grid-template-columns: 150px minmax(0, 1fr) 150px;
	gap: 0;
	width: min(1120px, calc(100% - 2rem));
	height: 74px;
	filter: drop-shadow(0 20px 32px rgba(0, 0, 0, 0.38));
}

.site-header.is-scrolled {
	top: 8px;
	width: min(980px, calc(100% - 1rem));
	height: 56px;
	filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.42));
}

.left-box,
.right-box,
.menu-bar,
.site-header.is-scrolled .left-box,
.site-header.is-scrolled .right-box,
.site-header.is-scrolled .menu-bar {
	height: 100%;
	border: 0;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: none;
}

.left-box {
	width: auto;
	border-radius: 26px 0 0 26px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0) 42%),
		linear-gradient(90deg, #000000 0%, #050505 58%, #151515 100%);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.12),
		inset -14px 0 22px rgba(0, 0, 0, 0.46);
}

.right-box {
	width: auto;
	border-radius: 0 26px 26px 0;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0) 42%),
		linear-gradient(270deg, #000000 0%, #050505 58%, #151515 100%);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.12),
		inset 14px 0 22px rgba(0, 0, 0, 0.46);
}

.menu-bar {
	min-width: 0;
	padding: 0 1.2rem;
	border-radius: 0;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.04) 28%, rgba(0, 0, 0, 0.12) 100%),
		linear-gradient(90deg, #3f5064 0%, #5f738b 48%, #42546a 100%);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.28),
		inset 0 -1px 0 rgba(255, 255, 255, 0.12),
		inset 0 -12px 20px rgba(0, 0, 0, 0.16);
}

.menu-bar::before,
.menu-bar::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 34px;
	pointer-events: none;
}

.menu-bar::before {
	left: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.36), transparent);
}

.menu-bar::after {
	right: 0;
	background: linear-gradient(270deg, rgba(0, 0, 0, 0.36), transparent);
}

.site-header.is-scrolled {
	grid-template-columns: 70px minmax(0, 1fr) 94px;
}

.site-header.is-scrolled .menu-bar {
	padding: 0 0.9rem;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.03) 32%, rgba(0, 0, 0, 0.16) 100%),
		linear-gradient(90deg, #354456 0%, #50637a 50%, #37475a 100%);
}

.site-header.is-scrolled .left-box {
	width: auto;
}

.site-header.is-scrolled .right-box {
	width: auto;
}

.logo-area,
.login-area {
	gap: 0.75rem;
}

.logo-area::before,
.login-area::before {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 60%);
}

.logo-area:hover::before,
.logo-area:focus-visible::before,
.login-area:hover::before,
.login-area:focus-visible::before {
	opacity: 0.7;
}

.logo-area img {
	width: 58px;
	filter: drop-shadow(0 8px 13px rgba(0, 0, 0, 0.38));
}

.site-header.is-scrolled .logo-area img {
	width: 40px;
}

.login-area svg {
	width: 31px;
	height: 31px;
}

.login-area__label {
	max-width: 48px;
	font-size: 0.9rem;
	color: #ffffff;
}

.site-header.is-scrolled .login-area__label {
	max-width: 38px;
	opacity: 1;
	transform: none;
	font-size: 0.78rem;
}

.menu-bar ul {
	position: relative;
	z-index: 1;
	gap: 0.08rem;
}

.menu-bar a {
	padding: 0 1rem;
	background: transparent;
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.95rem;
	letter-spacing: 1px;
}

.site-header.is-scrolled .menu-bar a {
	padding: 0 0.78rem;
	font-size: 0.82rem;
}

.menu-bar a.current {
	background: transparent;
}

.menu-bar a:not(.current):hover,
.menu-bar a:not(.current):focus-visible {
	background: rgba(255, 255, 255, 0.08);
}

.menu-bar a::after {
	left: 0.8rem;
	right: 0.8rem;
	bottom: 0.6rem;
	height: 3px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red));
}

@media (max-width: 940px) {
	.site-header,
	.site-header.is-scrolled {
		grid-template-columns: 58px minmax(0, 1fr) 72px;
		width: min(100%, calc(100% - 1rem));
	}

	.left-box {
		border-radius: 18px 0 0 18px;
	}

	.right-box {
		border-radius: 0 18px 18px 0;
	}

	.login-area__label {
		display: none;
	}
}

@media (max-width: 620px) {
	.site-header,
	.site-header.is-scrolled {
		top: 8px;
		grid-template-columns: 48px minmax(0, 1fr) 48px;
		height: 50px;
	}

	.logo-area img,
	.site-header.is-scrolled .logo-area img {
		width: 32px;
	}

	.login-area svg {
		width: 23px;
		height: 23px;
	}

	.menu-bar,
	.site-header.is-scrolled .menu-bar {
		padding: 0 0.35rem;
	}

	.menu-bar a,
	.site-header.is-scrolled .menu-bar a {
		padding: 0 0.58rem;
		font-size: 0.74rem;
	}
}


/*

	Menu Fine Tune

*/

.site-header {
	grid-template-columns: 150px minmax(0, 1fr) 82px;
}

.site-header.is-scrolled {
	grid-template-columns: 70px minmax(0, 1fr) 60px;
}

.menu-bar,
.site-header.is-scrolled .menu-bar {
	border-top: 1px solid rgba(255, 255, 255, 0.18);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(0, 0, 0, 0.08)),
		rgba(8, 10, 16, 0.42);
	backdrop-filter: blur(23px) saturate(135%);
	-webkit-backdrop-filter: blur(33px) saturate(135%);
	box-shadow:
		inset 0 1px 2px rgba(255, 255, 255, 0.26),
		inset 0 -1px 2px rgba(0, 0, 0, 0.22),
		0 10px 24px rgba(0, 0, 0, 0.33);
}

.site-header.is-scrolled .menu-bar {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.18)),
		rgba(4, 5, 8, 0.63);
}

.login-area {
	gap: 0;
}

.login-area svg {
	width: 30px;
	height: 30px;
}

.menu-bar a.current {
	background: rgba(var(--ucbaja-purple-rgb), 0.23);
}

.menu-bar a::after {
	background: var(--ucbaja-red);
	transition:
		opacity 260ms ease,
		transform 300ms cubic-bezier(0.19, 1, 0.22, 1);
}

.menu-bar a.current::after {
	background: var(--ucbaja-purple);
}

.menu-bar a:not(.current):hover,
.menu-bar a:not(.current):focus-visible {
	background: rgba(247, 29, 29, 0.3);
}

@media (max-width: 940px) {
	.site-header,
	.site-header.is-scrolled {
		grid-template-columns: 58px minmax(0, 1fr) 52px;
	}
}

@media (max-width: 620px) {
	.site-header,
	.site-header.is-scrolled {
		grid-template-columns: 48px minmax(0, 1fr) 48px;
	}
}

@media (max-width: 620px) {
	.site-header,
	.site-header.is-scrolled {
		top: 8px;
		grid-template-columns: 48px minmax(0, 1fr) 48px;
		width: min(100%, calc(100% - 0.7rem));
		height: 70px;
	}

	.left-box,
	.right-box,
	.menu-bar,
	.site-header.is-scrolled .left-box,
	.site-header.is-scrolled .right-box,
	.site-header.is-scrolled .menu-bar {
		height: 100%;
	}

	.left-box {
		border-radius: 18px 0 0 18px;
	}

	.right-box {
		border-radius: 0 18px 18px 0;
	}

	.logo-area img,
	.site-header.is-scrolled .logo-area img {
		width: 32px;
	}

	.login-area svg,
	.site-header.is-scrolled .login-area svg {
		width: 23px;
		height: 23px;
	}

	.menu-bar,
	.site-header.is-scrolled .menu-bar {
		justify-content: center;
		overflow: hidden;
		padding: 0.42rem 0.32rem;
	}

	.menu-bar ul {
		display: flex;
		flex-wrap: wrap;
		align-content: center;
		align-items: center;
		justify-content: center;
		gap: 0.14rem 0.08rem;
		width: 100%;
		min-width: 0;
		height: 100%;
	}

	.menu-bar li {
		flex: 1 1 calc(33.333% - 0.08rem);
		height: calc(50% - 0.08rem);
		min-width: 0;
	}

	.menu-bar a,
	.site-header.is-scrolled .menu-bar a {
		width: 100%;
		height: 100%;
		min-height: 0;
		padding: 0 0.34rem;
		border-radius: 5px;
		font-size: 0.62rem;
		letter-spacing: 0.8px;
		line-height: 1;
	}

	.menu-bar a::after {
		left: 0.34rem;
		right: 0.34rem;
		bottom: 0.18rem;
		height: 2px;
	}
}

@media (max-width: 360px) {
	.site-header,
	.site-header.is-scrolled {
		grid-template-columns: 44px minmax(0, 1fr) 44px;
		width: min(100%, calc(100% - 0.45rem));
		height: 68px;
	}

	.menu-bar,
	.site-header.is-scrolled .menu-bar {
		padding-inline: 0.22rem;
	}

	.menu-bar a,
	.site-header.is-scrolled .menu-bar a {
		padding-inline: 0.28rem;
		font-size: 0.58rem;
		letter-spacing: 0.65px;
	}

	.logo-area img,
	.site-header.is-scrolled .logo-area img {
		width: 29px;
	}

	.login-area svg,
	.site-header.is-scrolled .login-area svg {
		width: 21px;
		height: 21px;
	}
}


/*

	Shared Page Components

*/

.hero-image.hero-image--page {
	min-height: var(--hero-min-height, 82vh);
	min-height: var(--hero-min-height-svh, 82svh);
}

.hero-image--about,
.hero-image--team {
	--hero-min-height: 82vh;
	--hero-min-height-svh: 82svh;
	--hero-content-width: 1120px;
	--hero-content-padding: 12rem 0 5rem;
}

.hero-image--sponsors {
	--hero-min-height: 78vh;
	--hero-min-height-svh: 78svh;
	--hero-content-width: 1180px;
	--hero-content-padding: 10rem 0 7.5rem;
}

.hero-image--events {
	--hero-min-height: 100vh;
	--hero-min-height-svh: 100svh;
}

.hero-image .hero-image__background,
.hero-image .hero-image__shade {
	position: absolute;
	inset: 0;
}

.hero-image .hero-image__background {
	width: 100%;
	height: 110%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	object-fit: cover;
	object-position: center;
	transform: scale(1);
	animation: heroImageDrift 64s ease-in-out infinite;
	will-change: transform;
}

.hero-image img.hero-image__background {
	background-image: none;
}

.hero-image .hero-image__shade {
	z-index: 1;
	opacity: 1;
}

.hero-image__content {
	position: relative;
	z-index: 2;
	width: min(var(--hero-content-width, 1120px), calc(100% - 3rem));
	margin: 0 auto;
	padding: var(--hero-content-padding, 12rem 0 5rem);
}

.hero-image__title {
	font-family: "Nutmeg-Black", Arial, Helvetica, sans-serif;
	line-height: 0.92;
	letter-spacing: 0;
	text-transform: uppercase;
}

.hero-image__copy {
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	line-height: 1.62;
	color: rgba(255, 255, 255, 0.88);
	text-shadow: 0 8px 24px rgba(0, 0, 0, 0.62);
}

.page-eyebrow {
	margin: 1em 0 0.7rem;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0;
	color: #ffcf48;
	text-shadow:
		0 2px 8px rgba(0, 0, 0, 0.92),
		0 0 20px rgba(0, 0, 0, 0.82),
		0 0 34px rgba(0, 0, 0, 0.56);
	text-transform: uppercase;
}

.page-eyebrow--yellow {
	color: #ffcf48;
}

.page-eyebrow--tight {
	margin-bottom: 0.25rem;
}

.page-eyebrow--spaced {
	margin: 0 0 0.9rem;
	font-size: 0.8rem;
	letter-spacing: 0.14em;
}

.glass-panel {
	border: 1px solid var(--glass-panel-border, rgba(255, 255, 255, 0.18));
	border-radius: 8px;
	background: var(
		--glass-panel-background,
		linear-gradient(
			145deg,
			rgba(24, 22, 29, 0.86) 0%,
			rgba(13, 13, 17, 0.72) 100%
		)
	);
	box-shadow: var(
		--glass-panel-shadow,
		0 26px 70px rgba(0, 0, 0, 0.38),
		inset 0 1px 0 rgba(255, 255, 255, 0.12)
	);
	backdrop-filter: blur(var(--glass-panel-blur, 18px));
	-webkit-backdrop-filter: blur(var(--glass-panel-blur, 18px));
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0.78rem 1.1rem;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 8px;
	color: #ffffff;
	cursor: pointer;
	font-family: "Nutmeg-Book", Arial, Helvetica, sans-serif;
	font-size: 0.92rem;
	font-weight: 900;
	line-height: 1.1;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease,
		color 180ms ease,
		filter 180ms ease,
		transform 180ms ease;
}

.btn:hover,
.btn:focus-visible {
	transform: translateY(-2px);
}

.btn-red-solid {
	background: var(--ucbaja-red-dark);
	border-color: var(--ucbaja-red-light);
	box-shadow: 0 14px 28px rgba(179, 13, 24, 0.3);
}

.btn-red-solid:hover,
.btn-red-solid:focus-visible {
	background: var(--ucbaja-red);
	border-color: var(--ucbaja-red-bright);
}

.btn-white-outline {
	background: rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.btn-white-outline:hover,
.btn-white-outline:focus-visible {
	background: rgba(255, 255, 255, 0.16);
	border-color: rgba(255, 255, 255, 0.46);
}

.btn-color-gradient {
	background:
		linear-gradient(135deg, rgba(215, 25, 37, 0.96), rgba(var(--ucbaja-purple-rgb), 0.88));
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32);
}

.btn-color-gradient:hover,
.btn-color-gradient:focus-visible {
	filter: saturate(1.08);
	box-shadow: 0 22px 42px rgba(0, 0, 0, 0.38);
}

.btn--compact {
	padding: 0.8rem 1.05rem;
	font-size: 0.86rem;
}

.btn--block {
	width: 100%;
}

.btn--tall {
	min-height: 3.35rem;
}

.btn--mt-md {
	margin-top: 1.65rem;
}

.btn--mt-lg {
	margin-top: 2rem;
}

.btn:disabled {
	cursor: wait;
	opacity: 0.66;
	transform: none;
	filter: saturate(0.75);
}

.page-reveal {
	opacity: 1;
	transform: none;
}

.motion-ready .page-reveal {
	opacity: 0;
	transform: translateY(32px);
	transition:
		opacity 720ms cubic-bezier(0.19, 1, 0.22, 1),
		transform 720ms cubic-bezier(0.19, 1, 0.22, 1);
	will-change: opacity, transform;
}

.motion-ready .page-reveal--from-right {
	transform: translateX(32px);
}

.motion-ready .page-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.motion-ready .page-reveal--from-right.is-visible {
	transform: translateX(0);
}

@media (max-width: 980px) {
	.hero-image__content {
		width: min(720px, calc(100% - 2rem));
	}
}

@media (max-width: 560px) {
	.hero-image.hero-image--page {
		min-height: 76vh;
		min-height: 76svh;
	}

	.hero-image__content {
		width: min(420px, calc(100% - 1.25rem));
		padding-top: 10rem;
		padding-bottom: 3rem;
	}
}

@media (max-width: 640px) {
	.hero-image--sponsors .hero-image__content {
		width: min(420px, calc(100% - 1.25rem));
		padding-top: 10rem;
		padding-bottom: 7rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.hero-image .hero-image__background,
	.hero-image .hero-image__shade,
	.page-reveal {
		animation: none;
		transition: none;
		opacity: 1;
		transform: none;
	}
}


/*

	Global Tiled Background

*/

html {
	min-height: 100%;
	background:
		url("/images/tile_bg.png") repeat,
		radial-gradient(circle at 14% 16%, rgba(var(--ucbaja-purple-rgb), 0.2), transparent 28rem),
		radial-gradient(circle at 86% 28%, rgba(215, 25, 37, 0.18), transparent 26rem),
		linear-gradient(180deg, #09090d 0%, #111018 52%, #09090d 100%);
}

body {
	min-height: 100vh;
	background: transparent;
}

.hero-image,
.image-page,
.about-page,
.team-page,
.sponsors-page {
	background:
		linear-gradient(180deg, rgba(7, 7, 11, 0.72) 0%, rgba(12, 12, 18, 0.8) 48%, rgba(7, 7, 11, 0.76) 100%),
		url("/images/tile_bg.png") repeat,
		radial-gradient(circle at 14% 16%, rgba(var(--ucbaja-purple-rgb), 0.2), transparent 28rem),
		radial-gradient(circle at 86% 28%, rgba(215, 25, 37, 0.18), transparent 26rem),
		linear-gradient(180deg, #09090d 0%, #111018 52%, #09090d 100%);
}

.about-page::before,
.team-page::before {
	background:
		linear-gradient(
			90deg,
			rgba(0, 0, 0, 0.16) 0%,
			rgba(255, 255, 255, 0) 42%,
			rgba(0, 0, 0, 0.14) 100%
		);
}


/*

	Site Footer

*/

.site-footer {
	position: relative;
	z-index: 2;
	overflow: hidden;
	padding: 1.15rem 1.5rem;
	color: #ffffff;
	background:
		linear-gradient(180deg, rgba(8, 8, 12, 0.92) 0%, rgba(4, 4, 7, 0.98) 100%),
		url("/images/tile_bg.png") repeat,
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.16), rgba(215, 25, 37, 0.1));
	border-top: 1px solid rgba(255, 255, 255, 0.13);
	box-shadow:
		0 -24px 60px rgba(0, 0, 0, 0.34),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.site-footer::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red), var(--ucbaja-purple));
	pointer-events: none;
}

.site-footer__inner {
	display: grid;
	grid-template-columns: minmax(220px, 1fr) auto auto;
	gap: clamp(1rem, 3vw, 2rem);
	align-items: center;
	width: min(1180px, calc(100% - 3rem));
	margin: 0 auto;
}

.site-footer__identity {
	display: grid;
	gap: 0.18rem;
}

.site-footer__identity strong {
	font-family: var(--ucbaja-font-display);
	font-size: 1.08rem;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
}

.site-footer__identity span {
	color: rgba(255, 255, 255, 0.58);
	font-size: 0.86rem;
	line-height: 1.35;
}

.site-footer__links,
.site-footer__connect {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
}

.site-footer__links {
	justify-content: flex-end;
}

.site-footer__links a {
	display: inline-flex;
	align-items: center;
	min-height: 2.25rem;
	padding: 0.45rem 0.6rem;
	color: rgba(255, 255, 255, 0.84);
	font-family: var(--ucbaja-font-body);
	font-size: 0.78rem;
	font-weight: 900;
	text-decoration: none;
	text-transform: uppercase;
	transition:
		color 180ms ease,
		transform 180ms ease;
}

.site-footer__links a:hover,
.site-footer__links a:focus-visible {
	color: var(--ucbaja-purple);
	transform: translateY(-2px);
}

.site-footer__connect {
	justify-content: flex-end;
}

.site-footer__connect a {
	position: relative;
	display: grid;
	place-items: center;
	width: 2.65rem;
	height: 2.65rem;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.055);
	color: #ffffff;
	text-decoration: none;
	isolation: isolate;
	transition:
		border-color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.site-footer__connect a::before {
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	z-index: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--ucbaja-purple), var(--ucbaja-red));
	opacity: 0.9;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 220ms ease;
}

.site-footer__connect a:hover,
.site-footer__connect a:focus-visible {
	border-color: rgba(255, 255, 255, 0.32);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.26);
	transform: translateY(-3px);
}

.site-footer__connect a:hover::before,
.site-footer__connect a:focus-visible::before {
	transform: scaleX(1);
}

.site-footer__icon {
	position: relative;
	z-index: 1;
	display: block;
	width: 1.35rem;
	height: 1.35rem;
	color: #ffffff;
	fill: #ffffff;
	opacity: 1;
	visibility: visible;
	pointer-events: none;
}

.site-footer__icon path {
	fill: #ffffff;
}

@media (max-width: 920px) {
	.site-footer__inner {
		grid-template-columns: 1fr auto;
	}

	.site-footer__connect {
		justify-content: flex-end;
	}

	.site-footer__links {
		grid-column: 1 / -1;
		grid-row: 2;
		justify-content: flex-start;
	}
}

@media (max-width: 560px) {
	.site-footer {
		padding: 1rem 0.75rem;
	}

	.site-footer__inner {
		grid-template-columns: 1fr;
		width: min(420px, calc(100% - 1.25rem));
	}

	.site-footer__links {
		grid-column: auto;
		grid-row: auto;
		justify-content: flex-start;
	}

	.site-footer__connect {
		justify-content: flex-start;
	}

	.site-footer__connect a {
		width: 2.65rem;
	}
}


/*

	Contact Page

*/

.contact-page {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	overflow: hidden;
	padding: clamp(7.5rem, 12vw, 10rem) 1.5rem clamp(4rem, 8vw, 6rem);
	color: #ffffff;
	background:
		linear-gradient(180deg, rgba(7, 7, 11, 0.7) 0%, rgba(12, 12, 18, 0.82) 50%, rgba(7, 7, 11, 0.78) 100%),
		url("/images/tile_bg.png") repeat,
		radial-gradient(circle at 14% 16%, rgba(var(--ucbaja-purple-rgb), 0.2), transparent 28rem),
		radial-gradient(circle at 86% 28%, rgba(215, 25, 37, 0.18), transparent 26rem),
		linear-gradient(180deg, #09090d 0%, #111018 52%, #09090d 100%);
}

.contact-page::before,
.contact-page::after {
	content: "";
	position: absolute;
	z-index: 0;
	pointer-events: none;
}

.contact-page::before {
	inset: 0;
	background:
		linear-gradient(90deg, rgba(0, 0, 0, 0.2), rgba(255, 255, 255, 0) 42%, rgba(0, 0, 0, 0.18));
}

.contact-page::after {
	right: max(-7rem, -8vw);
	top: clamp(5rem, 11vw, 8rem);
	width: clamp(18rem, 38vw, 34rem);
	aspect-ratio: 1;
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.18);
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.15), rgba(215, 25, 37, 0.09));
	clip-path: polygon(100% 0, 24% 0, 100% 76%);
	opacity: 0.74;
}

.contact-shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(22rem, 0.82fr);
	gap: clamp(1.25rem, 3vw, 2rem);
	align-items: start;
	width: min(1180px, 100%);
	margin: 0 auto;
}

.contact-info-panel,
.contact-form-panel {
	position: relative;
	overflow: hidden;
	--glass-panel-border: rgba(255, 255, 255, 0.15);
	--glass-panel-background:
		linear-gradient(145deg, rgba(18, 18, 27, 0.9), rgba(10, 10, 16, 0.82)),
		rgba(10, 10, 16, 0.84);
	--glass-panel-shadow: 0 26px 70px rgba(0, 0, 0, 0.36);
}

.contact-info-panel::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: clamp(8rem, 22vw, 16rem);
	aspect-ratio: 1;
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.86), rgba(215, 25, 37, 0.74));
	clip-path: polygon(100% 0, 0 0, 100% 100%);
	opacity: 0.72;
}

.contact-info-panel::after {
	content: "";
	position: absolute;
	left: 1.2rem;
	bottom: 1.2rem;
	width: 5.8rem;
	height: 5.8rem;
	border-left: 2px solid rgba(var(--ucbaja-purple-rgb), 0.58);
	border-bottom: 2px solid rgba(215, 25, 37, 0.56);
	opacity: 0.64;
}

.contact-info-panel__content {
	position: relative;
	z-index: 1;
	padding: clamp(1.5rem, 3vw, 2.5rem);
}

.contact-info-panel h1,
.contact-form-panel h2 {
	margin: 0;
	font-family: var(--ucbaja-font-display);
	font-weight: 900;
	line-height: 0.92;
	letter-spacing: 0;
	text-transform: uppercase;
}

.contact-info-panel h1 {
	max-width: 11ch;
	font-size: clamp(2.55rem, 5.2vw, 4.35rem);
	text-shadow: 0 14px 34px rgba(0, 0, 0, 0.58);
}

.contact-info-panel h1 .heading-media-line {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	width: 100%;
	gap: 0.34em;
}

.contact-info-panel h1 .media-links {
	flex: 0 0 auto;
	margin-left: auto;
	padding-bottom: 0.08em;
}

.contact-form-panel h2 {
	font-size: clamp(2.1rem, 4.4vw, 3.85rem);
}

.contact-page__intro {
	max-width: 42rem;
	margin: 1.35rem 0 0;
	color: rgba(255, 255, 255, 0.76);
	font-size: clamp(1rem, 1.3vw, 1.15rem);
	line-height: 1.65;
}

.contact-info-list {
	display: grid;
	gap: 0.9rem;
	margin-top: clamp(1.5rem, 3vw, 2.25rem);
}

.contact-info-list__item {
	display: grid;
	grid-template-columns: minmax(6.5rem, 0.28fr) minmax(0, 1fr);
	gap: 1rem;
	align-items: start;
	padding: 1.05rem;
	border: 1px solid rgba(255, 255, 255, 0.11);
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.055);
}

.contact-info-list__item span {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.11em;
	text-transform: uppercase;
}

.contact-info-list__item address,
.contact-info-list__item a {
	margin: 0;
	color: rgba(255, 255, 255, 0.9);
	font-style: normal;
	font-weight: 800;
	line-height: 1.48;
	text-decoration: none;
}

.contact-info-list__item a {
	width: fit-content;
	color: #ffffff;
	transition:
		color 180ms ease,
		text-shadow 180ms ease;
}

.contact-info-list__item a:hover,
.contact-info-list__item a:focus-visible {
	color: var(--ucbaja-purple);
	text-shadow: 0 0 18px rgba(var(--ucbaja-purple-rgb), 0.34);
}

.contact-map {
	position: relative;
	z-index: 1;
	height: clamp(18rem, 35vw, 26rem);
	margin: 0 clamp(1rem, 2vw, 1.45rem) clamp(1rem, 2vw, 1.45rem);
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background: #111111;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.045);
}

.contact-map::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.08),
		inset 0 -4rem 5rem rgba(0, 0, 0, 0.24);
}

.contact-map iframe {
	width: 100%;
	height: 100%;
	border: 0;
	filter: saturate(0.82) contrast(1.08) brightness(0.9);
}

.contact-form-panel {
	padding: clamp(1.35rem, 3vw, 2rem);
	--glass-panel-background:
		linear-gradient(150deg, rgba(var(--ucbaja-purple-rgb), 0.14), transparent 34%),
		linear-gradient(320deg, rgba(215, 25, 37, 0.16), transparent 38%),
		rgba(9, 9, 15, 0.9);
}

.contact-form-panel::before {
	content: "";
	position: absolute;
	inset: 0;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: inherit;
	pointer-events: none;
}

.contact-form-panel::after {
	content: "";
	position: absolute;
	top: 0.9rem;
	right: 0.9rem;
	width: 5rem;
	height: 5rem;
	border-top: 2px solid rgba(var(--ucbaja-purple-rgb), 0.58);
	border-right: 2px solid rgba(215, 25, 37, 0.58);
	opacity: 0.68;
}

.contact-form-panel__header {
	position: relative;
	z-index: 1;
	margin-bottom: 1.35rem;
}

.contact-form {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 1rem;
}

.contact-response:empty {
	display: none;
}

.contact-field {
	display: grid;
	gap: 0.45rem;
}

.contact-field label {
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.contact-field input,
.contact-field textarea {
	width: 100%;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.07);
	color: #ffffff;
	font-family: Arial, Helvetica, sans-serif;
	font-weight: 400;
	font-size: 1rem;
	line-height: 1.4;
	padding: 0.95rem 1rem;
	outline: none;
	transition:
		background 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.contact-field textarea {
	min-height: 11rem;
	resize: vertical;
}

.contact-field input::placeholder,
.contact-field textarea::placeholder {
	color: rgba(255, 255, 255, 0.36);
}

.contact-field input:focus,
.contact-field textarea:focus {
	border-color: rgba(var(--ucbaja-purple-rgb), 0.65);
	background: rgba(255, 255, 255, 0.1);
	box-shadow:
		0 0 0 3px rgba(var(--ucbaja-purple-rgb), 0.14),
		0 14px 28px rgba(0, 0, 0, 0.22);
	transform: translateY(-1px);
}

.contact-field input[aria-invalid="true"],
.contact-field textarea[aria-invalid="true"] {
	border-color: rgba(190, 18, 30, 0.72);
	box-shadow: 0 0 0 3px rgba(190, 18, 30, 0.13);
}

.contact-field__error {
	color: #ffb3b8;
	font-size: 0.9rem;
	font-weight: 800;
	line-height: 1.35;
}

.contact-field__error:empty {
	display: none;
}

.contact-alert {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 0.25rem;
	margin-bottom: 1rem;
	padding: 0.95rem 1rem;
	border-radius: 6px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.07);
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.45;
}

.contact-alert strong {
	color: #ffffff;
	font-weight: 900;
}

.contact-alert--success {
	border-color: rgba(var(--ucbaja-purple-rgb), 0.46);
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.18), rgba(255, 255, 255, 0.055));
}

.contact-alert--error {
	border-color: rgba(190, 18, 30, 0.54);
	background:
		linear-gradient(135deg, rgba(190, 18, 30, 0.2), rgba(255, 255, 255, 0.055));
}

.contact-form-panel--sent {
	display: grid;
	align-content: center;
	min-height: clamp(24rem, 48vw, 34rem);
}

.contact-receipt {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 0.85rem;
	padding: clamp(1.4rem, 4vw, 2.4rem);
	border: 1px solid rgba(var(--ucbaja-purple-rgb), 0.42);
	border-radius: 8px;
	background:
		linear-gradient(145deg, rgba(var(--ucbaja-purple-rgb), 0.2), rgba(215, 25, 37, 0.08)),
		rgba(255, 255, 255, 0.07);
	box-shadow:
		0 24px 52px rgba(0, 0, 0, 0.28),
		inset 0 0 0 1px rgba(255, 255, 255, 0.06);
	outline: none;
}

.contact-receipt::before {
	content: "";
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 4.2rem;
	height: 4.2rem;
	border-top: 2px solid rgba(var(--ucbaja-purple-rgb), 0.68);
	border-right: 2px solid rgba(215, 25, 37, 0.6);
	opacity: 0.76;
}

.contact-receipt strong {
	max-width: 9ch;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(2.45rem, 5vw, 4rem);
	font-weight: 900;
	line-height: 0.95;
	text-transform: uppercase;
}

.contact-receipt span {
	max-width: 28rem;
	color: rgba(255, 255, 255, 0.78);
	font-size: 1.05rem;
	line-height: 1.6;
}

@media (max-width: 940px) {
	.contact-page {
		padding: 7.5rem 1rem 4rem;
	}

	.contact-shell {
		grid-template-columns: 1fr;
	}

	.contact-info-panel h1 {
		max-width: 12ch;
	}

	.contact-form-panel {
		order: 2;
	}
}

@media (max-width: 620px) {
	.contact-page {
		padding-inline: 0.75rem;
	}

	.contact-info-list__item {
		grid-template-columns: 1fr;
		gap: 0.45rem;
	}

	.contact-info-panel h1 {
		font-size: clamp(2.3rem, 13vw, 3.25rem);
	}

	.contact-form-panel h2 {
		font-size: clamp(2rem, 12vw, 3rem);
	}

	.contact-map {
		height: 18rem;
	}
}


/*

	Login Page

*/

.login-page {
	position: relative;
	display: grid;
	place-items: center;
	min-height: 100vh;
	min-height: 100svh;
	overflow: hidden;
	padding: clamp(5.5rem, 9vw, 7rem) 1.25rem clamp(3rem, 6vw, 4.5rem);
	color: #ffffff;
	background:
		linear-gradient(180deg, rgba(7, 7, 11, 0.62) 0%, rgba(12, 11, 17, 0.82) 100%),
		url("/images/tile_bg.png") repeat,
		radial-gradient(circle at 22% 22%, rgba(var(--ucbaja-purple-rgb), 0.22), transparent 25rem),
		radial-gradient(circle at 78% 80%, rgba(215, 25, 37, 0.18), transparent 24rem),
		#08080d;
}

.login-page::before,
.login-page::after {
	content: "";
	position: absolute;
	pointer-events: none;
}

.login-page::before {
	inset: 0;
	background:
		linear-gradient(115deg, transparent 0 58%, rgba(var(--ucbaja-purple-rgb), 0.12) 58.2% 59%, transparent 59.2%),
		linear-gradient(295deg, transparent 0 62%, rgba(215, 25, 37, 0.1) 62.2% 63%, transparent 63.2%);
	opacity: 0.75;
}

.login-page::after {
	top: 50%;
	left: 50%;
	width: min(42rem, 72vw);
	aspect-ratio: 1;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 999px;
	transform: translate(-50%, -50%);
	box-shadow:
		inset 0 0 0 1px rgba(var(--ucbaja-purple-rgb), 0.08),
		0 0 72px rgba(0, 0, 0, 0.28);
	opacity: 0.74;
}

.login-panel {
	position: relative;
	z-index: 1;
	width: min(27.5rem, 100%);
	overflow: hidden;
	padding: clamp(1.45rem, 4vw, 2.35rem);
	--glass-panel-border: rgba(255, 255, 255, 0.16);
	--glass-panel-background:
		linear-gradient(145deg, rgba(var(--ucbaja-purple-rgb), 0.13), transparent 32%),
		linear-gradient(320deg, rgba(215, 25, 37, 0.14), transparent 36%),
		rgba(10, 10, 16, 0.88);
	--glass-panel-shadow:
		0 32px 86px rgba(0, 0, 0, 0.42),
		inset 0 1px 0 rgba(255, 255, 255, 0.12);
	--glass-panel-blur: 22px;
}

.login-panel::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: clamp(6.5rem, 28vw, 11rem);
	aspect-ratio: 1;
	background: linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.8), rgba(215, 25, 37, 0.68));
	clip-path: polygon(100% 0, 0 0, 100% 100%);
	opacity: 0.62;
}

.login-panel::after {
	content: "";
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	width: 4.8rem;
	height: 4.8rem;
	border-left: 2px solid rgba(var(--ucbaja-purple-rgb), 0.5);
	border-bottom: 2px solid rgba(215, 25, 37, 0.52);
	opacity: 0.58;
}

.login-panel__mark,
.login-panel__header,
.login-form {
	position: relative;
	z-index: 1;
}

.login-panel__mark {
	display: grid;
	place-items: center;
	width: 3.35rem;
	height: 3.35rem;
	margin-bottom: 1.2rem;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(var(--ucbaja-purple-rgb), 0.26), rgba(215, 25, 37, 0.18)),
		rgba(255, 255, 255, 0.08);
	color: #ffffff;
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.24);
}

.login-panel__mark svg {
	width: 1.7rem;
	height: 1.7rem;
	stroke-width: 1.8;
}

.login-panel__header h1 {
	margin: 0;
	font-family: var(--ucbaja-font-display);
	font-size: clamp(2rem, 6vw, 3.1rem);
	font-weight: 900;
	line-height: 0.92;
	letter-spacing: 0;
	text-transform: uppercase;
	text-shadow: 0 14px 34px rgba(0, 0, 0, 0.48);
}

.login-panel__header p:not(.page-eyebrow) {
	max-width: 22rem;
	margin: 1rem 0 0;
	color: rgba(255, 255, 255, 0.72);
	font-size: 1rem;
	line-height: 1.55;
}

.login-form {
	display: grid;
	gap: 1rem;
	margin-top: 1.55rem;
}

.login-field {
	display: grid;
	gap: 0.45rem;
}

.login-field label,
.login-field__label-row a {
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.login-field label {
	color: rgba(255, 255, 255, 0.72);
}

.login-field__label-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.login-field__label-row a {
	color: rgba(255, 255, 255, 0.56);
	text-decoration: none;
	transition:
		color 180ms ease,
		text-shadow 180ms ease;
}

.login-field__label-row a:hover,
.login-field__label-row a:focus-visible {
	color: var(--ucbaja-purple);
	text-shadow: 0 0 18px rgba(var(--ucbaja-purple-rgb), 0.32);
}

.login-field input {
	width: 100%;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.075);
	color: #ffffff;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.4;
	outline: none;
	padding: 0.98rem 1rem;
	transition:
		background 180ms ease,
		border-color 180ms ease,
		box-shadow 180ms ease,
		transform 180ms ease;
}

.login-field input::placeholder {
	color: rgba(255, 255, 255, 0.34);
}

.login-field input:focus {
	border-color: rgba(var(--ucbaja-purple-rgb), 0.66);
	background: rgba(255, 255, 255, 0.11);
	box-shadow:
		0 0 0 3px rgba(var(--ucbaja-purple-rgb), 0.14),
		0 14px 28px rgba(0, 0, 0, 0.22);
	transform: translateY(-1px);
}

@media (max-width: 520px) {
	.login-page {
		padding-inline: 0.85rem;
	}

	.login-panel {
		padding: 1.35rem;
	}

	.login-field__label-row {
		align-items: flex-start;
		flex-direction: column;
		gap: 0.35rem;
	}
}
