/* Global */

html {
	height: 100%;
	min-width: 360px;
	box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

p, h1, h2, h3, h4, a, time, li {
	font-family: 'Avenir Next', 'HelveticaNeue-Light', 'Helvetica Neue', Helvetica, Arial, sans-serif;
	color: #FFFFFF;

}

h2 {
	text-align: center;
}

a {
	transition: 100ms linear;
}

a:hover {
	color: grey;
}

/* Navigation */

nav {
	margin-bottom: 8px;
}

#nav-list {
	padding: 0;
	margin: 0;
	display: inline;
}

.nav-list-item {
	display: inline;
	padding: 0 10px;
}

.nav-list-item a {
	font-size: 18pt;
	text-decoration: none;
}

#active-link {
	text-decoration-line: underline;
	text-decoration-thickness: 3px;
	text-underline-offset: 5px;
}

/* Header */

.site-logo {
	width: 139px;
	margin-bottom: -15px;
	overflow: hidden;
}

header {
	width: 100%;
	background-color: #3c3c3c;
	border-bottom: solid grey;
	padding-bottom: 40px;
	position: sticky;
	top: -120px;
}

#social-menu {
	position: absolute;
	left: 0;
	right: 0;
	margin: 8px auto;
	list-style: none;
	padding:0;
	width: 295px;
}

.social-menu-item {
	display: inline;
	margin: 0 10px;
}

.social-icon {
	height: 22px;
}

@media screen and (min-width: 750px) {
	#social-menu {
		bottom: 0;
		left: auto;
		margin: 16px;
		margin-bottom: 8px;
		width: 190px;
	}
	
	.social-menu-item {
		margin: 0 5px;
	}
	
	.social-icon {
		height: 16px;
	}
}

.social-icon g path {
	transition: 100ms linear;
}

.social-icon:not(:hover) g path {
	fill: white !important;
}

/* Footer */

footer {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 0 15px;
}

#footer-content {
	display: flex;
	align-items: center;
	flex-direction: column;
}

@media screen and (min-width: 750px) {
	#footer-content {
		display: inline;
	}
}

#watermark {
	text-align: center;
	margin-top:0;
}

#email {
	margin-bottom:0;
	text-align: center;
}

footer h2 {
	margin-bottom: 10px;
}

.footer-links {
	display:flex;
	flex-wrap: wrap;
}

.link-list {
	list-style: none;
	padding-left: 15px;
	margin: 0;
}

/* Content */

body {
	background-color: #000000;
	margin: 0;
	position: relative;
	min-height: 100%;
	padding-bottom: 18rem;
}

main {
	padding: 0px 5px 0;
}

@media screen and (min-width: 750px) {
	header {
		position: fixed;
		top: 0;
		padding-bottom: 0;
	}
	
	main {
		padding: 170px 40px 0;
	}
}

.centered-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.centered-container > div {
	width: 100%
}

.gallery {
	display: block flex;
	align-content: start;
	justify-content: center;
	flex-wrap: wrap;
}

/* Home */

.site-title {
	text-align: center;
	font-size: 69px;
	margin: 24px 0;
	padding: 0;
}

.nowrap {
	white-space: nowrap;
}

.youtube-video {
	width: 75%;
	aspect-ratio: 16 / 9;
}

.big-button {
	background-color: white;
	padding: 28px 48px;
	margin: 20px;
	border-radius: 28px;
	color: black;
	text-align: center;
	text-decoration: none;
	font-weight: bold;
	font-size: 24pt;
	transition: 100ms linear;

}

.big-button:hover {
	background-color: grey;
	color:white;
}

/* About */

.side-by-side {
	display: flex;
	flex-direction: column;
	align-content: start;
	align-items: start;
}

.contained-image {
	width: 90%;
	margin-top: 20pt;
}

@media screen and (min-width: 650px) {
	.side-by-side {
		flex-direction: row;
		column-gap: 5%;
	}

	.side-by-side div {
		flex-basis: 50%;
	}

	.contained-image {
		width: 100%;
	}
}

.members {
	max-width: 1000px;
	width: 100%;
	margin: auto;
}

.member-card {
	padding: 40px;
	flex: 1 1 0;
	min-width: 270px;
	max-width: 400px;
}

.member-card img {
	padding:0;
	width: 100%;
}

.member-card h2 {
	font-size: 40pt;
	margin: 0 0 10px;
}

.member-card h3 {
	margin: 0;
}

.member-card p {
	margin: 0;
}

.members ul {
	list-style: none;
}

/* Shows */

.show-row {
	width: 100%;
	max-width: 1000px;
	min-width: 350px;
	border-bottom: solid gray;
	display: flex;
	align-content: center;
	align-items: center;
}

.show-details {
	display: block flex;
	align-content: start;
	justify-content: start;
	flex-wrap: wrap;
}

.tickets-link, .show-details {
	margin: 20px;
}

.show-details > p,
.show-details > time,
.show-details > a {
	margin: 0 20px;
	text-decoration: none;
}

.tickets-link {
	font-weight: bold;
	margin-left: auto;
	vertical-align: middle;
}

.show-tag {
	margin-bottom: 0;
}

/* Music */

.album-card {
	margin: 60px 0;
	display: flex;
	align-content: center;
	column-gap: 5%;
	flex-wrap: wrap
}

.album-details {
	margin: 0 auto 10px;
}

.album-details h1 {
	font-size: 40pt;
	margin: 10pt 0 0;
	width: max-content;
	text-align: center;
	margin: auto;
}

.album-details h2 {
	font-size: 20pt;
	margin-top: 0;
	width: max-content;
	text-align: center;
	margin: auto;
}

.album-card a {
	margin: 0 5%;
}

.album-card a img {
	width: 100%;
}

@media screen and (min-width: 600px) {
	.album-card {
		max-width: 800px;
	}
	
	.album-details {
		margin: 0;
		margin-right: auto;
	}
	
	.album-details h1 {
		margin: 0;
	}
	
	.album-details h2 {
		margin: 0;
	}
	
	.album-card a img {
		width: auto;
		height: 200px;
	}
}
