h2 {
	margin: 16px auto;
	text-align: center;
}

.gallery {
	padding: 64px;
	margin: auto;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	align-content: center;
	gap: 32px;
	overflow-x: visible;
}

.gallery a img {
	box-shadow: 0 0 8px gray;
	border-radius: 8px;
}

.fullscreen {
	position: fixed;
	background-color: #111;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	vertical-align: middle;
	justify-content: center;
	display: flex;
	align-items: center;
}

.photo {
	max-width: 100%;
	max-height: 100%;
	margin: auto;
}

.controls {
	position: fixed;
	width: 25%;
	min-width: 300px;
	bottom: 5%;
	margin: 16px auto;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	background-color: #ffd5d5;
	border-radius: 8px;
	padding: 4px;
}

.controls * {
	margin: 0 8px;
	padding: 8px;
}

.galcards {
	width: 100%;
	display: flex;
	flex-direction: row;
	justify-content: center;
}

.galcard {
	flex: 1 10%;
	margin: 16px;
	max-width: 30%;
	min-width: 200px;
	background-color: white;
	border-radius: 8px;
	box-shadow: 0 0 8px gray;

	display: flex;
	flex-direction: column;
	align-items: center;
}

.galcard * {
	text-align: center;
	padding: 0;
	margin: 0;
}

.galcard a {
	width: 100%;
	height: 100%;
}

.galcard img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 8px 8px 0 0;
}
