.timeline {
	margin-top: 10rem;
}
.timeline-year {
	display: grid;
	grid-template-areas: "gallery name title"
	                     "gallery name content";
 	grid-template-columns: 40% 10% 50%;
	grid-template-rows: auto 1fr;
	margin: -1px 0;
	padding-bottom: 5rem;
	position: relative;
}
.timeline-year .timeline-year-name {
	grid-area: name;
	overflow: hidden;
}
.timeline-year:first-child .timeline-year-name {
	overflow: visible;
}
.timeline-year .timeline-year-name label,
.timeline-year .timeline-year-gallery-name label {
	display: block;
	text-align: center;
	width: 15rem;
	height: 5.833333rem;
	line-height: 5.833333rem;
	box-sizing: border-box;
	transform-origin: top left;
	transform: rotate(-90deg) translateX(-100%);
}
.timeline-year .timeline-year-title {
	grid-area: title;
	padding: 3.5rem 8rem 3.5rem 0;
}
.timeline-year .timeline-year-content {
	padding-right: 8rem;
}
.timeline-year .timeline-year-gallery {
	grid-area: gallery;
}
.timeline-year .timeline-year-gallery-images {
	display: grid;
	grid-template-areas: "large large"
	                     "small1 small2";
	gap: 0.666667rem;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: auto 1fr;
	background: white;
}
.timeline-year .timeline-year-gallery .timeline-year-gallery-image {
	aspect-ratio: 1;
}
.timeline-year .timeline-year-gallery-name {
	display: none;
}
.timeline-year .timeline-year-gallery .timeline-year-gallery-image img,
.timeline-year .timeline-year-gallery .timeline-year-gallery-image img[style] {
	display: block;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
}
.timeline-year .timeline-year-gallery .timeline-year-gallery-image.large {
	grid-area: large;
}
.timeline-year .timeline-year-gallery .timeline-year-gallery-image.small1 {
	grid-area: small1;
}
.timeline-year .timeline-year-gallery .timeline-year-gallery-image.small2 {
	grid-area: small2;
}
.timeline-year .timeline-year-content {
	grid-area: content;
}

.timeline-year:nth-child(odd) {
	grid-template-areas: "title   gallery name"
	                     "content gallery name";
 	grid-template-columns: 55% 45% 0;
}
.timeline-year:nth-child(odd) .timeline-year-title,
.timeline-year:nth-child(odd) .timeline-year-content {
	padding-left: 4.5rem;
	padding-right: 6rem;
}
.timeline-year:nth-child(odd) .timeline-year-name label {
	display: none;
}
.timeline-year:nth-child(odd) .timeline-year-gallery-images {
	grid-template-areas: "small1 small2 name"
	                     "large large large";
	grid-template-columns: 1fr 1fr 5.166666rem;
}
.timeline-year:nth-child(odd) .timeline-year-gallery-name {
	display: flex;
	align-items: center;
	align-content: center;
	margin-left: -0.666667rem;
}
.timeline-year:nth-child(odd) .timeline-year-gallery-name label {
	transform: rotate(-90deg) translateY(-1.2rem);
	transform-origin: center center;
	background: transparent;
}

.timeline-year::before,
.timeline-year::after {
	content: '';
	position: absolute;
	inset: 0;
	border: 1px none #a9abae;
	z-index: -1;
	pointer-events: none;
}
.timeline-year:nth-child(even)::before,
.timeline-year:nth-child(even)::after {
	left: 40%;
	margin-left: 5.833333rem;
	margin-left: calc(5.833333rem - 1px);
	border-left-style: solid;
}
.timeline-year:nth-child(even)::before {
	border-top-style: solid;
	right: 25%;
}
.timeline-year:nth-child(even)::after {
	border-bottom-style: solid;
}

.timeline-year:nth-child(odd)::after {
	border-right-style: solid;
	right: 25%;
}


.timeline-year:first-child {
	grid-template-areas: "name title   gallery"
	                     "name content gallery";
 	grid-template-columns: 0 61.5% 38.5%;
}
.timeline-year:first-child .timeline-year-name label {
	display: block;
}
.timeline-year:first-child .timeline-year-title,
.timeline-year:first-child .timeline-year-content {
	padding-left: 9rem;
	padding-right: 8rem;
}
.timeline-year:first-child .timeline-year-gallery-images {
	grid-template-areas: "small1 small2"
	                     "large large";
	grid-template-columns: repeat(2, 1fr);
}
.timeline-year:first-child .timeline-year-gallery-name {
	display: none;
}
.timeline-year:first-child::after {
	border-style: none;
}
.timeline-year:first-child .timeline-year-content {
	position: relative;
	margin-top: 2rem;
}
.timeline-year:first-child .timeline-year-content::before {
	content: '';
	position: absolute;
	z-index: -1;
	pointer-events: none;
	inset: 0;
	top: -4rem;
	bottom: -5rem;
	right: 4rem;
	border: 1px solid #a9abae;
	border-left: none;
}
.timeline-year:first-child + .timeline-year::before {
	border-top-style: none;
}
.timeline-year:last-child {
	padding-bottom: 0;
	margin-bottom: 0;
}

@media screen and (max-width: 800px) {
	.timeline {
		margin-top: 4rem;
	}
	.timeline-year {
		grid-template-areas: "name title"
		                     "gallery gallery"
		                     "content content" !important;
		grid-template-columns: 5.8rem auto !important;
		padding-bottom: 2rem !important;
	}
	.timeline-year::before,
	.timeline-year::after,
	.timeline-year-content::before {
		display: none !important;
	}
	.timeline-year .timeline-year-name label {
		display: block !important;
		width: 12rem;
	}
	.timeline-year .timeline-year-title {
		padding: 0 0 0 2rem !important;
		min-height: 12rem;
		box-sizing: border-box;
		margin-bottom: 2rem;
	}
	.timeline-year .timeline-year-gallery-name {
		display: none !important;
	}
	.timeline-year:nth-child(2n+1) .timeline-year-gallery-images {
		grid-template-areas: "small1 small2"
		                     "large large" !important;
		grid-template-columns: 1fr 1fr;
	}
	.timeline-year .timeline-year-content {
		padding: 2rem !important;
	}
}

#banner_image {
	left: 30rem !important;
	top: 6rem !important;
}
#banner > #banner_image::after {
	background: none !important;
}
#banner > #banner_image img {
	background-size: contain !important;
}

@media screen and (max-width: 800px) {
	#banner {
		flex-direction: column;
	}
	#banner > #banner_image {
		position: relative !important;
		left: 0 !important;
		top: 0 !important;
		flex: 1;
	}
	#banner > #banner_image img.background {
		background-size: cover !important;
	}
	#banner > #banner_caption {
		flex: 0;
	}
}