.container {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	position: relative;
	overflow: hidden;
	container: block-container / inline-size;
}

.block-container {
	max-width: 160rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: var(--block-spacing);
	place-content: stretch;
	place-items: start;
	padding: var(--block-spacing) calc(var(--block-spacing) * 2);
	position: relative;
	margin: 0 auto;
	z-index: 4;
}

.block-container.grid-1\/1 {
	grid-template-columns: 1fr 1fr;
}

.block-container.grid-1\/2 {
	grid-template-columns: 1fr 2fr;
}

.block-container.grid-1\/3 {
	grid-template-columns: 1fr 3fr;
}

.block-container.grid-2\/1 {
	grid-template-columns: 2fr 1fr;
}

.block-container.grid-3\/1 {
	grid-template-columns: 3fr 1fr;
}

.block-container.full {
	grid-template-columns: 1fr;
}

.block-title {
	margin-bottom: 2rem;
	z-index: 2;
}

.block-content-container {
	width: 100%;
}

.full {
	width: 100svw;
	width: 100vw;
}

.align-title {
	position: absolute;
	top: calc(8rem + 4.4rem / 2);
	left: 0;
	margin: 0;
}

.block-image {
	width: 100%;
	height: auto;
	object-fit: cover;
	object-position: center center;
	padding: 0;
}

.block-image img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	object-position: center center;
}

.block-image .image-link {
	display: grid;
	grid-template-areas:
		'image image'
		'text arrow';
	grid-template-columns: 1fr 1.4rem;
	grid-template-rows: auto auto;
	place-content: start;
	place-items: start;
	width: 100%;
	height: auto;
	color: var(--color-accent);
	cursor: pointer;
}

.block-image .image-link div {
	display: block;
	width: 100%;
	height: fit-content;
	grid-area: image;
	margin-bottom: 1.5rem;
	overflow: hidden;
}

.block-image .image-link div img {
	transition: 0.2s;
}

.block-image .image-link:hover div img {
	scale: 1.1;
}

.block-image .image-link span {
	grid-area: text;
	display: flex;
	text-align: left !important;
	align-content: center;
	align-items: center;
	min-height: 1.8rem;

	font-family: 'Barlow Semi Condensed', sans-serif;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.2rem;
}

.block-image .image-link i {
	grid-area: arrow;
	position: relative;
	height: 1.8rem;
	width: 1.4rem;
	color: var(--color-accent);
	opacity: 0.5;
	transition: 0.2s;
}

.block-image .image-link:hover i {
	opacity: 1;
}

.block-image .image-link i::before {
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	transition: 0.3s ease-in-out;
}

.block-image .image-link:hover i::before {
	rotate: 315deg;
}

.col-span-2 {
	grid-column: span 2;
}

/* layouts */

.block-align-top > *,
.block-align-middle > *,
.block-align-bottom > *,
.block-align-top-stepped > *,
.block-align-bottom-stepped > * {
	padding-top: calc(var(--block-spacing) / 2);
	padding-bottom: calc(var(--block-spacing) / 2);
}

.block-align-middle {
	align-items: center;
}

.block-align-bottom,
.block-align-bottom-stepped {
	align-items: end;
}

.block-align-top-staggered > :first-child,
.block-align-bottom-staggered > :last-child {
	padding-top: calc(var(--block-spacing) / 2);
	padding-bottom: calc(var(--block-spacing) * 1.5);
}

.block-align-top-staggered > :last-child,
.block-align-bottom-staggered > :first-child {
	padding-top: calc(var(--block-spacing) * 1.5);
	padding-bottom: calc(var(--block-spacing) / 2);
	align-self: end;
}

.block-align-top-stepped > :last-child {
	padding-top: calc(var(--block-spacing) * 1.5);
}

.block-align-bottom-stepped > :last-child {
	padding-bottom: calc(var(--block-spacing) * 1.5);
}

.block-bg-image + .block-content-container {
	position: relative;
	z-index: 2;
}

.block-bg-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	z-index: 1;
}

.block-bg-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.block-container.full:has(+ .block-bg-image) {
	min-height: 36rem;
	align-items: center;
}

.block-contact-details {
	width: 100%;
}

.block-contact-details ul {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 1.2rem;
	list-style: none;
	padding: 0;
	margin: 0;
	width: 100%;
}

.block-contact-details ul li {
	display: grid;
	grid-template-columns: 2.4rem auto;
	gap: .7rem;
	place-content: start;
	place-items: start;
	width: 100%;
}

.block-contact-details ul li:nth-child(n+2) {
	padding-top: 1.2rem;
	border-top: 1px solid rgba(var(--color-secondary-rgb), 0.2);
}

.block-contact-details span {
	font-family: 'Roboto', sans-serif;
    font-weight: 300;
    font-size: 1.6rem;
    line-height: 2.2rem;
}

@container block-container (max-width: 1280px) {
	.block-align-bottom,
	.block-align-bottom-stepped {
		align-items: start;
	}

	.block-align-top-staggered > :first-child,
	.block-align-bottom-staggered > :last-child,
	.block-align-bottom-stepped > :last-child {
		padding-bottom: calc(var(--block-spacing) / 2);
		align-self: start;
	}

	.block-align-top-staggered > :last-child,
	.block-align-bottom-staggered > :first-child,
	.block-align-top-stepped > :last-child {
		padding-top: calc(var(--block-spacing) / 2);
	}

	.block-container.grid-1\/3 {
		grid-template-columns: 1fr 2fr;
	}

	.block-container.grid-3\/1 {
		grid-template-columns: 2fr 1fr;
	}
}


/* tablet view */

@media only screen and (max-width: 1023px) {
	.block-container {
		grid-template-columns: 1fr;
		row-gap: calc(var(--block-spacing) / 2);
	}

	.block-image-left,
	.block-image-right {
		grid-template-areas: 'text' 'image';
	}

	.block-image-left .block-image,
	.block-image-right .block-image {
		grid-area: image;
	}

	.block-image-left .block-content-container,
	.block-image-right .block-content-container {
		grid-area: text;
	}

	.block-container.grid-1\/1 {
		grid-template-columns: 1fr;
		grid-template-areas: 'text' 'image';
	}

	.block-container.grid-1\/2 {
		grid-template-columns: 1fr 1fr;
		grid-template-areas: 'image text';
	}

	.block-container.grid-2\/1 {
		grid-template-columns: 1fr 1fr;
		grid-template-areas: 'text image';
	}

	.block-container.grid-1\/3 {
		grid-template-columns: 1fr 2fr;
		grid-template-areas: 'image text';
	}

	.block-container.grid-3\/1 {
		grid-template-columns: 2fr 1fr;
		grid-template-areas: 'text image';
	}
}

/* mobile view */

@media only screen and (max-width: 767px) {
	.block-container {
		max-width: 100%;
		padding-top: calc(var(--block-spacing) * 2);
		padding-bottom: calc(var(--block-spacing) * 2);
	}

	.block-container.grid-1\/1,
	.block-container.grid-1\/2,
	.block-container.grid-1\/3,
	.block-container.grid-2\/1,
	.block-container.grid-3\/1 {
		grid-template-columns: 1fr;
		grid-template-areas: 'text' 'image';
	}
}
