:root
{
	--cu-colour-back: white;
	--cu-colour-fore: black;
	--cu-colour-a: #0060A0;
	--cu-colour-b: #c0c0c0;
	--cu-header-height: 64px;
}

html
{
	font-size: 100%;
	scroll-behavior: smooth;
}

header
{
	background-color: var(--cu-colour-back);
	display: block;
}

@font-face
{
	font-family: Kaleko;
	src: url('https://cdn.nxl.ink/fonts/Kaleko105/Kaleko105Book.ttf') format('truetype');
	font-weight: normal;
}

@font-face
{
	font-family: Kaleko;
	src: url('https://cdn.nxl.ink/fonts/Kaleko105/Kaleko105Bold.ttf') format('truetype');
	font-weight: bold;
}

body
{
	background-color: var(--cu-colour-b);
	color: var(--cu-colour-fore);
	font-family: Kaleko, 'PT Sans', sans-serif;
	margin: 0 auto;
	background-image: url('https://cdn.nxl.ink/svg/endless-constellation.svg');
}

main
{
	padding: var(--cu-header-height) 0px 0px 0px;
	min-height: calc(100vh - var(--cu-header-height));
	color: var(--cu-colour-back);
}

footer
{
	background-color: var(--cu-colour-a);
	color: var(--cu-colour-back);
	left: 0;
	right: 0;
	text-align: center;
}

.cu-class-footer-left
{
	padding: 8px;
	margin: 0;
}

.cu-class-footer-centre
{
	padding: 8px;
	margin: 0;
}

.cu-class-footer-right
{
	padding: 8px;
	margin: 0;
}

.cu-class-page-header
{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px;
	margin: 0;
	position: fixed;
	left: 0px;
	top: 0px;
	height: 64px;
	width: 100%;
}

.cu-class-page-main-desc
{
	text-align: center;
	color: var(--cu-colour-back);
	padding: 64px 64px 0px 64px;
}

.cu-class-page-main-hero
{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	padding: 0px 64px 0px 64px;
}

.cu-class-page-main-hero-text
{
	color: var(--cu-colour-back);
	max-width: 75vh;
	height: 100vh;
	vertical-align: middle;
}

.cu-class-page-main-item-text
{
	color: var(--cu-colour-back);
}

.cu-class-page-footer
{
	padding: 0;
	width: 100%;
	display: flex;
	justify-content: space-between;
}

.cu-class-social-button
{
	padding: 4px;
	margin: 4px;
	width: 32px;
	height: 32px;
	text-decoration: none;
}

.cu-class-header-nav-centre
{
	list-style-type: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 3em;
	margin: 0;
	padding: 0;
}

.cu-class-link-menu-button
{
	border: none;
	padding: 8px;
	text-align: center;
	text-decoration: none;
	display: inline;
	margin: 2px 1px;
	border-radius: 8px;
	box-shadow: 2px 2px 8px 2px #A0A0A0;
	font-weight: bold;
	transition: 0.1s;
}

.cu-class-link-menu-button:hover
{
	box-shadow: 1px 1px 4px 2px #A0A0A0;
	border: 2px;
	border-color: #086BCC;
}

.cu-class-header-nav-right
{
	list-style-type: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1.5em;
	margin: 1em;
	padding: 1em;
}

.cu-class-nav-button
{
	background-color: var(--cu-colour-a);
	color: var(--cu-colour-back);
	border: none;
	padding: 8px;
	text-align: center;
	text-decoration: none;
	display: inline;
	margin: 2px 1px;
	border-radius: 8px;
	box-shadow: 2px 2px 8px 2px #A0A0A0;
	font-weight: bold;
	transition: 0.1s;
}

.cu-class-nav-button:hover
{
	background-color: var(--cu-colour-back);
	color: var(--cu-colour-a);
	box-shadow: 1px 1px 4px 2px #A0A0A0;
	border: 2px;
	border-color: #086BCC;
}

.cu-class-nav-button-cta
{
	background-color: var(--cu-colour-fore);
	color: var(--cu-colour-back);
	border: none;
	padding: 8px;
	text-align: center;
	text-decoration: none;
	display: inline;
	margin: 2px 1px;
	border-radius: 8px;
	box-shadow: 2px 2px 8px 2px #A0A0A0;
	font-weight: bold;
	transition: 0.1s;
}

.cu-class-nav-button-cta:hover
{
	background-color: var(--cu-colour-back);
	color: var(--cu-colour-fore);
	box-shadow: 1px 1px 4px 2px #A0A0A0;
	border: 2px;
	border-color: #086BCC;
}

.cu-class-nav-button-selected
{
	background-color: var(--cu-colour-back);
	color: var(--cu-colour-fore);
	border: none;
	padding: 8px;
	text-align: center;
	text-decoration: none;
	display: inline;
	margin: 2px 1px;
	border-radius: 8px;
	box-shadow: 2px 2px 8px 2px #A0A0A0;
	font-weight: bold;
	transition: 0.1s;
}

.cx-class-li-top
{
	list-style-type: none;
	display: flex;
	justify-content: flex-start;
	gap: 8px;
	margin: 0px;
	padding: 0px;
}

.cx-class-li-num
{
	color: var(--cu-colour-back);
	font-weight: normal;
}

.cx-class-li-div
{
	color: var(--cu-colour-back);
	font-weight: normal;
}

.cx-class-li-Txt
{
	color: var(--cu-colour-back);
	font-weight: normal;
}

