@font-face {
    font-family: 'Barlow';
	src: url(/media/fonts/Barlow-SemiBold.eot);
	src: url(/media/fonts/Barlow-SemiBold.eot?#iefix) format('embedded-opentype'),
		url('/media/fonts/Barlow-SemiBold.woff2') format('woff2'),
		url('/media/fonts/Barlow-SemiBold.woff') format('woff'),
		url('/media/fonts/Barlow-SemiBold.ttf') format('truetype'),
		url('/media/fonts/Barlow-SemiBold.svg#Barlow-SemiBold') format('svg');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Barlow';
	src: url(/media/fonts/Barlow-Bold.eot);
	src: url(/media/fonts/Barlow-Bold.eot?#iefix) format('embedded-opentype'),
		url('/media/fonts/Barlow-Bold.woff2') format('woff2'),
		url('/media/fonts/Barlow-Bold.woff') format('woff')
		url('/media/fonts/Barlow-Bold.ttf') format('truetype'),
		url('/media/fonts/Barlow-Bold.svg#Barlow-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Barlow';
	src: url(/media/fonts/Barlow-Regular.eot);
	src: url(/media/fonts/Barlow-Regular.eot?#iefix) format('embedded-opentype'),
		url('/media/fonts/Barlow-Regular.woff2') format('woff2'),
		url('/media/fonts/Barlow-Regular.woff') format('woff')
		url('/media/fonts/Barlow-Regular.ttf') format('truetype'),
		url('/media/fonts/Barlow-Regular.svg#Barlow-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
	--black: 0, 0, 0;
	--white: 255, 255, 255;
	--off-black: 33, 37, 41;
	--dark-gray: 112, 111, 111;
	--gray: 155, 154, 154;
	--light-gray: 242, 242, 242;
	--red: 214, 13, 24;
	--dimmed-red: 190, 20, 35;

	--content-width: 1600px;
	--column-width: 1000px;
}

.box a {
	font-size: 30px;
	color: inherit;
	text-decoration: none;
}
.box a:hover{
	text-decoration: underline;
}
.box a span:hover{
	text-decoration: none;
}
.box img:hover{
	text-decoration: none;
}

input:not([type="radio"], [type="checkbox"], [type="reset"], [type="submit"]),
select {
	width: 100%;
	padding: 1em .5em;
	border: 1px solid rgb(var(--dark-gray));
	border-radius: 0;
	color: rgb(var(--dark-gray));
	font-size: 1rem;
}

input::placeholder,
select::placeholder {
	color: rgb(var(--gray));
}

.button {
	text-align: left;
}

#message .button {
	text-align: center;
	margin-top: 10px;
}

.button a,
.button input[type="submit"] {
	display: inline-block;
	border: 3px solid #6c3f86;
	background-color: #ffffff;
	color: #6c3f86;
	transition: background-color .4s ease;
	font-size: 1rem;
	padding: .875em 2.5em;
	margin: 0;
	border: none;
	border-radius: 20px;
	cursor: pointer;
	text-align: center;
}

.button a:hover,
.button input[type="submit"]:hover {
	background-color: #ffffff;
}

.button a:hover {
	text-decoration: none;
}

html,
body {
	font-family: Barlow, Arial, Helvetica, sans-serif;
	font: normal 16px/1.25, Arial, Helvetica, sans-serif;
	vertical-align: middle;
	color: rgb(var(--off-black));
}

body {
	display: flex;
	flex-direction: column;
	text-align: center;
}

header {
	overflow-x: hidden;
    overflow-y: visible;
	position: sticky;
	top: 0;
	z-index: 1000;
	object-fit: cover;
	overflow: hidden;
}

#main-navigation {
	display: grid;
	grid-template-columns: 202px 1fr;
	grid-template-rows: 21% 39.5% 39.5%;
}

#top-navigation {
	background-color: #ffffff;
}

#middle-navigation {
	background-color: #ffffff;
}

#bottom-navigation {
	background-color: #ffffff;
	display: flex;
	justify-content: end;
	align-items: center;
}

#logo {
	position: sticky;
	top: 0;
	z-index: 1000;
	grid-row: 1 / span 3;
	background-color: #ffffff;
}

#top-navigation,
#middle-navigation,
#bottom-navigation,
#logo {
	position: sticky;
	top: 0;
	z-index: 1000;
}

#menu-toggle {
	padding: 20px 44px;
	cursor: pointer;
}

#menu-toggle svg {
	width: 24px;
}

#banner {
	width: 100%;
	object-fit: cover;
	position: static;
}

#banner[src$="/banner.jpg"] {
	object-position: 62%;
}

#navigation-menu {
	position: fixed;
	background-color: #4b5564;
	color: rgb(var(--white));
	top: 1;
	right: 1;
	max-height: calc(100vh - 175px);
	max-height: calc(100svh - 202px);
	padding: 1.875rem 1.875rem 2.875rem 1.875rem;
	transition: transform .4s ease;
	z-index: 2000;
}

#navigation-menu[data-visible="false"] {
	transform: translateX(100%);
}

#navigation-menu > .container {
	max-width: 400px;
	margin: 0 auto;
}

#menu-close {
	display: flex;
    justify-content: end;
	align-items: center;
    gap: 0.5em;
	margin-left: auto;
	color: rgb(var(--white));
	text-transform: uppercase;
	font-size: .625rem;
}

#menu-close svg {
	fill: rgb(var(--white));
	height: .8em;
	aspect-ratio: 1;
}

#menu-label {
	display: block;
	font-size: 2.375rem;
	font-weight: bold;
	padding: .5em 0;
	color: rgb(var(--white));
	text-transform: uppercase;
	text-align: left;
}

#navigation-grid {
	display: grid;
	grid-template-columns: repeat(3, var(--column-width));
	justify-content: space-between;
	grid-auto-flow: dense;
	gap: 0 2rem;
	margin: 0 auto;
}

#navigation-menu .nav {
	display: grid;
	gap: 0 2rem;
	grid-auto-flow: dense;
}

#nav {
	grid-column: 1;
	grid-template-columns: var(--column-width);
}

#global_nav {
	grid-column: 2 / span 2;
	grid-template-columns: repeat(2, var(--column-width));
}

#navigation-menu .nav a {
	display: flex;
	align-items: center;
	padding: 1em 0;
	font-size: 1.275rem;
	color: rgb(var(--white));
	text-align: left;
	border-bottom: 1px solid #cb5b35;
}

#navigation-menu .nav a:hover {
	font-weight: bold;
	text-decoration: none;
}

#navigation-menu .nav a .arrow {
	margin-left: auto;
	fill: rgb(var(--white));
}

@media screen and (max-width: 1275px) {
	#navigation-grid {
		display: flex;
		flex-direction: column;
	}
}

@media screen and (min-width: 860px) and (max-width: 1275px) {
	#nav {
		grid-column: 1;
		grid-template-columns: repeat(2, var(--column-width));
	}
}

@media screen and (min-width: 860px) {
	#navigation-menu .nav a[href="/content/view/7"] {
		grid-column: 2;
	}

	#navigation-grid {
		align-items: start;
	}
}

@media screen and (max-width: 859px) {
	#navigation-menu .nav {
		display: flex;
		flex-direction: column;
	}
}

main {
	flex-grow: 1;
	padding: 2.5rem;
	background-color: #f8f8f8;
}

main > #column2 {
	max-width: var(--content-width);
	margin-left: auto;
	margin-right: auto;
}

#return-to-top {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: rgb(var(--dark-gray));
	text-transform: uppercase;
	font-size: .875rem;
	background-color: #f8f8f8;
}

#return-to-top svg {
	fill: rgb(var(--dark-gray));
	margin-bottom: .5rem;
}

footer {
	font-size: 18px;
	padding: 1.25em;
	background-color: #f8f8f8;
	color: rgb(var(--black));
	font-weight: bold;
	text-transform: uppercase;
}

footer a {
	color: inherit;
}

h1 {
	margin-top: .5em;
	margin-bottom: 1em;
	text-transform: uppercase;
	font-weight: bold;
	color: #613b72;
	font-size: 3rem;
}

h2 {
	color: rgb(var(--black));
	font-size: 2rem;
	font-weight: normal;
	font-weight: bold;
	color: #613b72;
	margin: 1em 0 .5em;
}

h3 {
	padding-left: 25px;
	padding-right: 25px;
	color: rgb(var(--black));
	font-size: 0px;
	font-weight: 600;
	color: #613b72;
	margin: 1em 0 .5em;
}

table {
	background-color: #000000;
	width: 100%;
	border: none;
	border-collapse: collapse;
}

table th,
table td {
	text-align: left;
	padding: 1em 2em;
}

table td {
	vertical-align: middle;
}

table thead td,
table th {
	color: rgb(var(--white));
	background-color: #613b72;
	text-transform: uppercase;
	font-weight: bold;
	border-left: 0;
	border-right: 0;
	vertical-align: text-top;
}

table tbody tr,
table.dataTable tbody tr:nth-child(2n-1) {
	background-color: #ffffff;
	color: #613b72;
	font-weight: 600;
}

.overview-font{
	font-weight: normal;
	font-size: 14px;
}

table tbody tr:not(:last-child) {
	border-bottom: 2px solid rgb(var(--white));
}

form > .recordset > ul {
	list-style-type: none;
	padding-left: 0;
}

@media screen and (max-width: 1199px) {
	table th,
	table td {
		padding: 1em 1.25em;
	}
}

form > .recordset > ul > li {
	display: grid;
	grid-template-columns: 1fr auto;
	text-align: left;
}

form > .recordset > ul > li:not(:first-child) {
	margin-top: 1em;
}

form > .recordset > ul > li > :not(.vtip) {
	grid-column: 1;
}

form .vtip {
	margin-left: .5em;
	vertical-align: middle;
	align-self: center;
}

form .required_error.vtip {
	background-color: rgb(var(--red));
	color: rgb(var(--white));
	padding: .5em;
	font-weight: bold;
}

form > .recordset > ul > li > .vtip {
height: 100%;
display: flex;
align-items: center;
}

form > .recordset > ul > li > label {
	font-size: .875rem;
	color: rgb(var(--dark-gray));
	margin-bottom: .5em;
}

#login-title {
	color: rgb(var(--black));
	font-size: 3.5rem;
}

body[data-section="main"][data-page="login"] h1::after,
body[data-section="main"][data-page="logout"] h1::after {
	content: 'Login';
	display: block;
	margin-top: 1em;
}

#login {
	margin-top: 4rem;
}

#login_text {
	font-size: 1.25rem;
}

#login_ul {
	list-style-type: none;
	margin: 1.5rem auto;
	padding: 0;
	max-width: var(--column-width);
}

#login_ul>li:not(:last-child) {
	margin-bottom: 1rem;
}

#login_ul>li>label,
#login_ul>li>input {
	display: block;
	width: 100%;
	text-align: left;
}

#login_ul>li>label {
	color: rgb(var(--dark-gray));
	font-size: .875rem;
	margin-bottom: .5em;
}

#login .ok_button {
	display: none;
}

#login #submit_button {
	max-width: var(--column-width);
	margin: 0 auto;
}

#login_links {
	margin-top: 2rem;
}

#forgot > .recordset > ul,
#forgot > .recordset ~ .button,
#my_details > .recordset > ul,
#my_details > .recordset ~ .button,
#password_change > .recordset > ul,
#password_change > .recordset ~ .button {
	display: block;
	max-width: var(--column-width);
	margin-left: auto;
	margin-right: auto;
}

#forgot > .recordset ~ .button {
	pointer-events: none;
}

#forgot > .recordset ~ .button > a,
#forgot > .recordset ~ .button > input {
	pointer-events: all;
}

#forgot > .recordset + .button.back {
	position: absolute;
	width: 100%;
	float: right !important;
	margin-left: auto !important;
	left: 0;
	right: 0;
	text-align: right;
}

#register_button,
:not(h1) + #boxes_container {
	margin-top: 2rem;
}

#boxes {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	justify-content: center;
}

.box {
	border-radius: 15px;
	display: block;
	width: 100%;
	max-width: 280px;
}

.box.icon,
.box.image {
	max-height: 280px;
	aspect-ratio: 1;
}

.box.icon,
.box.image img {
	max-height: 280px;
	border: 3px solid #613b72;
	background-color: #ffffff;
}

.box img {
	display: block;
}

.box.icon img {
	width: 100%;
	max-width: 100px;
	aspect-ratio: 1;
	object-fit: contain;
	margin: 20px auto 10px auto;
}

.box.image img {
	padding: 7px;
}

.box.icon .name {
	padding: 10px;
	color: #613b72;
	font-size: 20px;
	font-weight: normal;
}

.box.icon a.normal span.border {
	display: none;
}

.box.icon h3 {
	padding: 0 !important;
}

.box.icon a.normal {
	height: 65%;
	width: 100%;
	display: inline-block;
}

.box.icon h3 a {
	width: 100%;
	height: 100px;
	display: inline-block;
	padding: 0 50px;
}

.box.image .name {
	color: #613b72;
	font-size: 16px;
	text-align: center;
	margin: .5em 0;
}

.box.image .border {
	display: none;
}

#boxes .clear {
	display: none;
}

#pagecookies #column2 p,
#pagecookies #column2 ul {
	text-align: left;
	max-width: calc(var(--column-width) * 2);
	margin-left: auto;
	margin-right: auto;
}

table.dataTable thead th,
table.dataTable thead td,
table.dataTable.no-footer {
	border-bottom: none;
}

.dataTables_paginate.paging_simple_numbers > span {
	display: none;
}
#page91 #s2_basket_form .button input[type="submit"]{
	display: none;
}

#s2_product_list td.s2_main_col {
	vertical-align: top;
	padding: 5px 30px 20px 5px;
}

td.s2_quantity_col {
	width: 50px;
	vertical-align: top;
}

td.s2_quantity_col input {
	width: 50px;
}

td.s2_price_col {
	width: 50px;
	vertical-align: top;
	display: none;
}

td.s2_price_col span {
    display: none;
}

th.last {
	display:none;
}

.s2-basket #column2 > h2{
	display: none;
}

.s2-basket #content form:nth-of-type(2) h2:last-of-type{
	display: none;
}


.event-dates {width: 261px;}

.schedule tr {
	border-bottom: 1px solid grey;
}
.schedule tr:nth-child(odd) {
	background: #FAFAFA;
}