.homepage-banner-block {
	display: grid;
	grid-template: "banner";
	place-items: center;
	overflow: hidden;
	position: relative;
	background-color: var(--gray-100);
}

.homepage-banner-block > * {
	grid-area: banner;
	position: relative;
}

.homepage-banner-block img {
	object-fit: cover;
	object-position: var(--focus, center);
	position: absolute;
	height: 100%;
}
.homepage-banner-block:after {
	content: "";
	height: 100%;
	width: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
.homepage-banner-block .banner-caption {
	padding: 0 1rem;
	position: relative;
	z-index: 9;
	padding: 12rem 0 6rem;
}
.homepage-banner-block .banner-caption h2,
.homepage-banner-block .banner-caption p {
	color: #fff;
}
.homepage-banner-block .banner-caption h2 {
	letter-spacing: 0.085em;
}
.homepage-banner-block .banner-caption p {
	letter-spacing: 2px;
}
.homepage-banner-block .banner-caption .banner-link {
	display: flex;
	justify-content: center;
	gap: 1rem;
}
@media screen and (max-width: 48rem) {
	.homepage-banner-block .banner-caption .banner-link {
		flex-direction: column;
		align-items: center;
		margin-top: 6rem;
	}
}
.homepage-banner-block .banner-caption .banner-link a {
	display: block;
}
