:root {
	--theme-color1: #a2366e;
	--theme-color2: #b4c3cb;
	--theme-color3: black;
	--theme-color4: white;
	--theme-color5: #e9e9e9;
	--calendar-accent-color: var(--theme-color3);
}

body {
	background-color: #909090;
	max-width: 1020px;
	margin: 0 auto;
	padding: 0 15px 15px;
	color: var(--theme-color3);
	font-family: Helvetica, Arial, Sans-Serif;
}


#title {
	color: var(--theme-color3);
	text-transform: uppercase;
	font-weight: bold;
	font-size: 1.5em;
}

#title:hover { color: var(--theme-color1); }

a {
	color: var(--theme-color1);
	text-decoration: none;
}

a.current, .sidebar li a.current { color: var(--theme-color1); }

a:hover { color: var(--theme-color3); }

.page a, .sidebar a { color: var(--theme-color1); }

h1 {
	font-family: Helvetica, Arial, Sans-Serif;
	font-size: 1.4em;
	text-transform: uppercase;
}

h2 {
	font-size: 1.1em;
	color: var(--theme-color1);
}

h3 { font-size: 1em; }

#topbar {
	padding: 7.5px;
	border-bottom: 5px solid var(--theme-color1);
	background-color: var(--theme-color3);
}

.marquee { text-align: right; }

#topbar .marquee {
	color: var(--theme-color4);
	text-align: center;
}

#accountbar {
	padding: 7.5px 0;
	min-height: 38px;
	line-height: 23px;
	text-align: center;
}

#account_menu {	float: right; }

.select_bar a.current, .ui-tabs-active a {
	color: #909090;
	padding: 3px 5px;
	border-radius: 5px;
	background-color: var(--theme-color3);
}

#account_menu li + li::before { content: ' / '; }

.container {
	padding-left: 60px;
	padding-right: 60px;
}

#main {
	background-color: var(--theme-color5);
	padding-bottom: 40px;
}

#main::after {
	content: '';
	width: 100%;
	display: table;
}

.has-sidebar header, .has-sidebar .page {
	width: calc(58% - 15px);
	float: left;
}

.slogan {
	color: var(--theme-color1);
	font-weight: bold;
}

header nav, #mobile-menu {
	margin-top: 15px;
	text-align: center;
	padding: 15px 10px;
	border-radius: 10px;
	background-color: var(--theme-color3);
	font-size: 0.85em;
}

#mobile-menu {
	display: none;
	font-size: 25px;
	color: var(--theme-color1) !important;
}

#mobile-menu.active i::before { content: "\F0156"; /* close */ }

nav ul { display: inline; }

nav li {
	text-transform: uppercase;
	list-style: none;
	display: inline-block;
	position: relative;
}

nav > ul > li + li::before {
	margin: 5px;
	content: '/';
	color: var(--theme-color1);
}

nav a, #mobile-menu { color: var(--theme-color5); }

nav a:hover { color: var(--theme-color1); }

nav ul ul { display: none; }

header nav li:hover > ul {
	display: block;
	position: absolute;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	background-color: var(--theme-color3);
	border: thin solid var(--theme-color3);
	left: 0;
	z-index: 5;
}

header nav ul ul {
	width: 200px;
	padding: 10px;
}

header nav ul ul li {
	display: block;
	text-align: left;
}

header nav ul ul li a {
	display: block;
	padding: 5px;
	padding-top: 8px;
	border-bottom: thin solid var(--theme-color1);
}

header nav ul ul li:last-of-type > a { border-bottom: none; }

header nav ul ul ul {
	border-top-right-radius: 10px;
	top: -10px;
	left: 170px !important;
	margin-top: 0 !important;
}

.page {
	margin-top: 15px;
	padding: 50px 50px;
	background-color: var(--theme-color2);
	border-radius: 10px;
	min-height: 491px;
	font-size: .95em;
	text-align: justify;
}

.page .copy { line-height: 1.5em; }

.copy img { border-radius: 10px; }

blockquote {
	background-color: var(--theme-color1);
	padding: 2em;
	border-radius: 10px;
	color: var(--theme-color4);
}

blockquote h2, blockquote a { color: var(--theme-color2) !important; }

#PhotoBox {
	float: right;
	width: 42%;
	aspect-ratio: 1;
	border-radius: 10px;
	overflow: hidden;
}

#photospot {
	border-bottom: 20px solid var(--theme-color3);
	background-color: var(--theme-color1);
}

#photocaption {
	font-size: 1.2em;
	font-weight: bold;
	text-shadow: 0 0 3px var(--theme-color3);
	margin: 0 10px;
	text-transform: uppercase;
	bottom: 25px;
	background-color: transparent;
	opacity: 1;
}

figure.image {
	background-color: var(--theme-color1);
	border-radius: 10px;
	overflow: hidden;
	border: none;
	padding-top: 0;
	padding-left: 0;
	padding-right: 0;
}

figure.image figcaption { color: var(--theme-color4); }

.custom_button, .cms-button {
	--btn-bg: var(--theme-color1);
	--btn-text: var(--theme-color4);
	--btn-hover-bg: var(--theme-color3);
	font: inherit;
	border-radius: 999px;
	padding: 7px 15px;
	border: none !important;
	box-shadow: none !important;
}

blockquote .custom_button, blockquote .cms-button {
    --btn-bg: var(--theme-color2);
}

.sidebar {
	font-size: .95em;
	float: right;
	clear: right;
	width: 42%;
	margin-top: 20px;
}

:not(#PhotoBox + .page) + .sidebar:first-of-type { margin-top: -140px; }

.sidebar > h1 { padding-left: 10px; }

.sidebar ul {
	padding-left: 0;
	text-transform: uppercase;
	color: var(--theme-color2);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.sidebar li {
	position: relative;
	list-style: none;
	display: inline-block;
	overflow: hidden;
	width: calc(50% - 7.5px);
	border-radius: 10px;
	background-color: var(--theme-color3);
	background-image: repeating-linear-gradient(
		-65deg,
		black,
		black 5px,
		#171515 5px,
		#171515 6px
	);
	vertical-align: top;
	margin: 0 0 15px;
}

.sidebar li a {
	color: var(--theme-color5);
	display: block;
	min-height: 125px;
	padding: 15px;
	padding-top: 25px;
	position: relative;
	z-index: 1;
}

.sidebar li a:hover { color: var(--theme-color1); }

.sidebar li img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100% !important;
	margin: 0 !important;
	object-fit: cover;
	z-index: -1;
}

/* :has() is not supported by Firefox as of 2022 */
.sidebar li:has(img) {
	font-weight: bold;
	text-shadow: 0 0 3px black;
}

.sidebar:has(li img) li a { aspect-ratio: 4 / 5; }

.sidebar li:has(img) a:not(:hover) { color: white; }

footer {
	clear: both;
	color: var(--theme-color2);
	font-size: 0.8em;
	min-height: 105px;
	padding: 15px 0;
	border-top: 5px solid var(--theme-color1);
	background-color: var(--theme-color3);
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	display: flex;
	flex-wrap: wrap;
	row-gap: 15px;
	justify-content: space-between;
}

@media screen and (max-width: 1050px) {
	.container {
		padding-left: 6vw;
		padding-right: 6vw;
	}

	header nav { font-size: 1.2vw; }

	#photocaption { font-size: 1.8vw; }
}

@media screen and (max-width: 768px) {
	#mobile-menu {
		display: block;
		cursor: pointer;
	}

	header nav {
		display: none;
		font-size: 0.85em;
		text-align: left;
		padding: 6vw;
		background-image: repeating-linear-gradient(
			-65deg,
			var(--theme-color3),
			var(--theme-color3) 5px,
			#171515 5px,
			#171515 6px
		);
	}

	header nav ul ul { padding: 0; }

	header nav ul li a {
		display: block;
		padding: 10px 0 !important;
		border-bottom: none !important;
	}

	header nav li:hover > ul { border: none !important; }

	header nav li { margin-left: 20px !important; }

	header nav ul, nav li, nav a { background-color: transparent !important; }

	header nav ul ul {
		position: static;
		display: block;
		width: auto;
	}

	header nav li:hover ul {
		position: static;
		margin-top: 0;
		width: auto;
	}

	header nav > ul > li + li::before { display: none; }

	header nav li { display: block; }

	.has-sidebar header, .has-sidebar .page { width: 100%; }

	.page { min-height: auto; }

	#PhotoBox, .sidebar { width: 100%; }

	.sidebar { margin-top: 20px !important; }
	
	#PhotoBox { margin-top: 15px; }

	#photocaption { font-size: 4vw; }

	footer .two-column { columns: auto; }
}

@media screen and (max-width: 480px) {
	.slogan {
		float: none;
		text-align: center;
	}

	.container {
		padding-left: 15px;
		padding-right: 15px;
	}
		
	.page {
		padding-left: 6vw;
		padding-right: 6vw;
	}
}
