:root {
	--main-text: #7f7f7f;
	--table-main-colour: #4a4a4a;
	--table-hr-colour: #cfcfcf;
	--banner-bkg-colour: #212121;
	--date-bkg-colour: #e8ecec;
	--lower-footer-main: #1f1f1f;
}

* {
	padding: 0;
	margin: 0;
	overflow-x: hidden;
}

main {
	min-height: 80vh;
}

p {
	font-family: serif;
	font-size: 14pt;
	line-height: 1.75;
	color: var(--main-text);
	text-align: justify;
}


.concerturl a:link {
	font-family: serif;
	font-size: 14pt;
	line-height: 1.75;
	color: var(--main-text);
	text-decoration: underline;
}

.concerturl a:visited {
	font-family: serif;
	font-size: 14pt;
	line-height: 1.75;
	color: var(--main-text);
	text-decoration: underline;
}

.concerturl a:hover {
	text-decoration: none;
}

.download a:link {
	font-family: serif;
	font-size: 10pt;
	line-height: 1.25;
	color: #d3d3d3;
	text-decoration: underline;
}

.download a:visited {
	font-family: serif;
	font-size: 10pt;
	line-height: 1.25;
	color: #d3d3d3;
	text-decoration: underline;
}

.download a:hover {
	text-decoration: none;
}

table {
	width: 65vw;
	border-collapse: collapse;
}

td {
	padding: 4vmin;
}

tr {
	border-top: 1px solid var(--table-hr-colour);
}

tr:first-of-type {
	border: none;
}

table h1 {
	font-family: "Raleway", sans-serif;
	font-size: 16pt;
	text-transform: uppercase;
	font-weight: 400;
	color: var(--table-main-colour);
}

.noConcertImage,
.concertImage {
	width: 30vmin;
}

.concertImage {
	height: 30vmin;
}

.noConcertImage {
/*	background-color: var(--date-bkg-colour); */
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-size: 48pt;
	color: var(--main-text);
	position: relative;
	overflow: hidden;
}

/*
.concertPassed::after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 28.284vmin;
	height: 28.284vmin;
	border-top: 1px solid red;
	transform: rotate(45deg);
	transform-origin: 0% 0%;
}
*/

td > a, .img-link {
	text-decoration: none;
}

.banner > h1, .banner > span{
	overflow-y: hidden !important;
	text-align: center;
}

.credits{
	font-style: italic;
	font-size: 10pt;
	color: #d3d3d3;
}

@media (max-width: 1400px) {

	body{
		background-color: var(--lower-footer-main);
	}

	main{
		background-color: #FFFFFF;
	}

	p{
		font-size: 16pt;
	}

	tr{
		display: flex;
		flex-direction: column;
	}

	table{
		width: 95%;
	}

	tr > td:first-of-type{
		padding-bottom: 0;
		padding-top: 5vh;
	}

	.banner > h1{
		font-size: 24pt !important;
	}
	.banner > span{
		font-size: 16pt !important;
	}

}
