/* Body Elements */
html, body {
	width: 100%;
	height: 100%;
	min-width: 280px;
	min-height: 280px;
	top: 0;
	left: 0;
	overflow: hidden;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}
body, td, th {
	font-family: Open Sans Condensed, 'Open Sans Condensed', sans-serif;
	font-weight: 300;
	text-rendering: optimizeLegibility;
}
body {
	margin: 0;
	background-color: #000000;
}
header, section, footer, aside, nav, main, article, figure {
	display: block;
}
a:link {
	color: #0085BF;
	text-decoration: none;
}
a:visited {
	text-decoration: none;
	color: #0085BF;
}
a:hover {
/* text-decoration: underline;
	color: #00AEFA; */
}
a:active {
	text-decoration: none;
	color: #0085BF;
}
audio {
	display: none;
}
#svgs {
	display: none;
}
#microdata {
	display: none;
	position: absolute;
	overflow: hidden;
	width: 128px;
	height: 128px;
	color: #000000;
}
#splash {
	display: none;
	position: absolute;
	overflow: hidden;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	pointer-events: none;
	background-image: url(igneous/images/Splash.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	z-index: 50000;
}
#splash > img {
	opacity: 0;
}
/* Loading */
#loading {
	pointer-events: none;
	width: 100px;
	height: 100px;
	overflow: visible;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	padding-left: -20px;
	z-index: 14000;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
#spinner {
	font-size: 100px;
	width: 1em;
	height: 1em;
	position: relative;
	margin: auto;
	border-radius: 50%;
	list-style: none;
}
#spinner li {
	position: absolute;
	width: .2em;
	height: .2em;
	border-radius: 50%;
}
#spinner li:nth-child(1) {
	left: 50%;
	top: 0;
	margin: 0 0 0 -.1em;
	background: #00C176;
	-webkit-transform-origin: 50% 250%;
	transform-origin: 50% 250%;
	-webkit-animation: rota 1.13s linear infinite, opa 3.67s ease-in-out infinite alternate;
	animation: rota 1.13s linear infinite, opa 3.67s ease-in-out infinite alternate;
}
#spinner li:nth-child(2) {
	top: 50%;
	right: 0;
	margin: -.1em 0 0 0;
	background: #FF003C;
	-webkit-transform-origin: -150% 50%;
	transform-origin: -150% 50%;
	-webkit-animation: rota 1.86s linear infinite, opa 4.29s ease-in-out infinite alternate;
	animation: rota 1.86s linear infinite, opa 4.29s ease-in-out infinite alternate;
}
#spinner li:nth-child(3) {
	left: 50%;
	bottom: 0;
	margin: 0 0 0 -.1em;
	background: #FABE28;
	-webkit-transform-origin: 50% -150%;
	transform-origin: 50% -150%;
	-webkit-animation: rota 1.45s linear infinite, opa 5.12s ease-in-out infinite alternate;
	animation: rota 1.45s linear infinite, opa 5.12s ease-in-out infinite alternate;
}
#spinner li:nth-child(4) {
	top: 50%;
	left: 0;
	margin: -.1em 0 0 0;
	background: #88C100;
	-webkit-transform-origin: 250% 50%;
	transform-origin: 250% 50%;
	-webkit-animation: rota 1.72s linear infinite, opa 5.25s ease-in-out infinite alternate;
	animation: rota 1.72s linear infinite, opa 5.25s ease-in-out infinite alternate;
}
 @-webkit-keyframes rota {
 from {
}
 to {
-webkit-transform: rotate(360deg);
}
}
 @keyframes rota {
 from {
}
 to {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}
 @-webkit-keyframes opa {
 0% {
}
 12.0% {
opacity: 0.80;
}
 19.5% {
opacity: 0.88;
}
 37.2% {
opacity: 0.64;
}
 40.5% {
opacity: 0.52;
}
 52.7% {
opacity: 0.69;
}
 60.2% {
opacity: 0.60;
}
 66.6% {
opacity: 0.52;
}
 70.0% {
opacity: 0.63;
}
 79.9% {
opacity: 0.60;
}
 84.2% {
opacity: 0.75;
}
 91.0% {
opacity: 0.87;
}
}
 @keyframes opa {
 0% {
}
 12.0% {
opacity: 0.80;
}
 19.5% {
opacity: 0.88;
}
 37.2% {
opacity: 0.64;
}
 40.5% {
opacity: 0.52;
}
 52.7% {
opacity: 0.69;
}
 60.2% {
opacity: 0.60;
}
 66.6% {
opacity: 0.52;
}
 70.0% {
opacity: 0.63;
}
 79.9% {
opacity: 0.60;
}
 84.2% {
opacity: 0.75;
}
 91.0% {
opacity: 0.87;
}
}
.fullscreen {
	display: block;
	position: absolute;
	overflow: hidden;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	margin: 0;
	padding: 0;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}
#curtain {
	pointer-events: none;
	z-index: 10001;
	background: rgb(0,0,0); /* Old browsers */
	background: -moz-radial-gradient(center, ellipse cover, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 100%); /* FF3.6+ */
	background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%, rgba(0,0,0,1)), color-stop(100%, rgba(0,0,0,1))); /* Chrome,Safari4+ */
	background: -webkit-radial-gradient(center, ellipse cover, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 100%); /* Chrome10+,Safari5.1+ */
	background: -o-radial-gradient(center, ellipse cover, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 100%); /* Opera 12+ */
	background: -ms-radial-gradient(center, ellipse cover, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 100%); /* IE10+ */
	background: radial-gradient(ellipse at center, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 100%); /* W3C */
 filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#000000', GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
}
#vignette {
	pointer-events: none;
	z-index: 10000;
	background: none;
	background: -moz-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%); /* FF3.6+ */
	background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%, rgba(0,0,0,0)), color-stop(100%, rgba(0,0,0,0.9))); /* Chrome,Safari4+ */
	background: -webkit-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%); /* Chrome10+,Safari5.1+ */
	background: -o-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%); /* Opera 12+ */
	background: -ms-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%); /* IE10+ */
	background: radial-gradient(ellipse at center, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#e6000000', GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
}
#name {
	font-weight: 1500;
}
#title {
	font-weight: 800;
}
.academic-card .centerIcon {
	width: 120px;
	height: 120px;
	border-radius: 8px;
	border: 3px solid #e0e0e0;
	box-shadow: 0 4px 12px rgba(0,0,0,.18);
	overflow: hidden;
	margin-top: 10px;
}
.academic-card .textContent {
	text-align: center;
	margin: 15px 18px 8px;
	padding-bottom: 10px;
}
.academic-card .textContent h2 {
	margin-bottom: 8px;
}
.academic-card .details {
	list-style: none;
	padding: 0;
	margin: 12px 0 0;
	font-size: 13px;
	line-height: 1.45;
}
.academic-card .details li {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 2px;
	border-bottom: 1px solid rgba(0,0,0,0.12);
}
.academic-card .details li:last-child {
	border-bottom: 0;
}
.academic-card .details .label {
	color: #777;
	font-weight: 600;
	font-size: 13px;
	text-transform: none;
	flex: 0 0 44%;
	text-align: left;
}
.academic-card .details .value {
	color: #2b2b2b;
	font-weight: 600;
	text-align: right;
	flex: 1;
}
.connect-card .contact-list {
	list-style: none;
	padding: 0;
	margin: 10px 0 0;
	font-size: 13px;
	line-height: 1.5;
}
.connect-card .contact-list li {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0;
	padding: 1px 2px;
}
.connect-card .contact-list .label {
	color: #777;
	font-weight: 600;
	text-align: left;
}
.connect-card .contact-list .value {
	color: #2b2b2b;
	font-weight: 600;
	text-align: left;
	white-space: normal;
	line-height: 1.45;
	display: block;
	width: 100%;
}
.connect-card .connect-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 18px;
	align-items: start;
}
.connect-card .leftCol h3,
.connect-card .rightCol h3 {
	text-align: left;
	margin-bottom: 6px;
}
.connect-card .social-list {
	list-style: none;
	padding: 0;
	margin: 10px 0 0;
	font-size: 13px;
	line-height: 1.5;
}
.connect-card .social-list li {
	margin: 6px 0;
	padding: 0;
}
.connect-card .social-list li:before {
	display: none;
}
.connect-card .social-list li a {
	font-weight: 600;
	color: #2b2b2b;
	text-align: left;
}
#Shiblee .textContent p {
	text-align: justify;
	line-height: 1.5;
	margin: 12px auto 0;
	max-width: 90%;
	font-size: 14px;
}

#sky_blue {
	overflow: hidden;
}

#fireworks-layer {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 2;
}

#fireworks-canvas {
	display: block;
	width: 100%;
	height: 100%;
}

#newyear-banner {
	position: relative;
	display: block;
	margin: 6px 0 0;
	width: 100%;
	z-index: 4;
	pointer-events: none;
	color: #ffffff;
	font-size: clamp(14px, 2.2vw, 24px);
	letter-spacing: 4px;
	text-transform: uppercase;
	text-shadow: 0 0 12px rgba(255, 255, 255, 0.6), 0 0 26px rgba(255, 190, 90, 0.8);
	animation: newyearCycle 8s ease-in-out infinite;
}

@keyframes newyearCycle {
	0%, 15% {
		opacity: 0;
		transform: translateY(-10px) scale(0.98);
	}
	28%, 55% {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
	70%, 100% {
		opacity: 0;
		transform: translateY(10px) scale(1.02);
	}
}

@media (max-width: 480px) {
	#newyear-banner {
		letter-spacing: 3px;
	}
}

@media (prefers-reduced-motion: reduce) {
	#fireworks-layer {
		display: none;
	}

	#newyear-banner {
		animation: none;
		opacity: 1;
	}
}
