#grid, .visual-grid {
	display: grid;
	grid-auto-rows: minmax(100px, auto);
}
.gap-none{
	gap: 0em;
}
.gap-small{
	gap: 0.5em;
}
.gap-medium{
	gap: 1em;
}
.gap-large{
	gap: 2em;
}
.margin-none{
	margin: 0em;
}
.margin-small{
	margin: 0.5em;
}
.margin-medium{
	margin: 1em;
}
.margin-large{
	margin: 2em;
}
.grid-item {
	max-height: 300px;
	position: relative;
}
.grid-item figure{
	height: 100%;
	width: 100%;
	margin: 0;
	position: relative;
}
.grid-item img{
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.grid-item figcaption{
	background: #0008;
	border-radius: 1em;
	color: #FFF;
	left: 50%;
	margin: auto;
	max-height: calc(95% - 2em);
	max-width: calc(100% - 2em);
	overflow: hidden;
	padding: 1em;
	position: absolute;
	transform: translateX(-50%);
	text-align: center;
	width: max-content;
}
.grid-item figcaption.label-center{
	top: 50%;
	transform: translateX(-50%) translateY(-50%);
}
.grid-item figcaption.label-top{
	top: 5%;
}
.grid-item figcaption.label-bottom{
	bottom: 5%;
}
/* BEGIN ADMIN ONLY STYLES */
#adminBox .grid-item {
	background: rgba(100, 100, 100, 0.5);
	cursor: move;
	transition: box-shadow 0.5s;
}
#adminBox .grid-item.focus{
	box-shadow: 0px 0px 10px 5px black;
}
#adminBox .grid-item .deleteGridItem{
	background: #0008;
	cursor: pointer;
	font-size: 1.5em;
	font-weight: 900;
	padding: 1em;
	position: absolute;
	right: 0;
	z-index: 1;
}
/* END ADMIN ONLY STYLES */