.lazy,
body {
	height: auto
}

.button,
.caption-button,
.category-button,
.project-entry .project-button,
.year-button {
	color: #fff;
	border-radius: .15rem;
	background: var(--button-bg-dark);
	padding: .55rem .65rem .35rem
}

.active,
.old-active {
	will-change: transform
}

.about,
.caption,
.project-description,
figure figcaption {
	font-size: 1.2rem;
	line-height: 1.5rem
}

#scroll-horizontal,
#scroll-vertical {
	background: rgba(255, 255, 255, .4);
	color: #000
}

.privacy-button,
.privacy-button:hover,
a,
a:hover {
	text-decoration: none
}

:root {
	--slide-speed: 0.5s ease-in-out;
	--button-bg-dark: rgba(0, 0, 0, 0.45);
	--button-bg-medium: rgba(71, 71, 71, 0.4)
}

body,
html {
	overscroll-behavior-x: none
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box
}

figure {
	display: flex;
	flex-direction: column
}

figure figcaption {
	padding-top: .5rem;
	margin-bottom: -.2rem
}

figure video {
	width: 100%;
	height: auto
}

.lazy {
	opacity: 0;
	transition: opacity .3s ease-in-out;
	display: block;
	width: 100%
}

.lazy.loaded,
img.lazy,
video.lazy {
	opacity: 1
}

.active,
.old-active,
.project-gallery,
.project-gallery.collapsed,
.project-gallery.expanding,
.project-page,
.project-page.closing-top {
	transition: transform .5s ease-in-out
}

#project-button-container:empty,
#project-category-container:empty,
#project-year-container:empty,
.about-table tr:last-child td::after,
.category-button:empty,
.hidden-loading-image,
.mobile-project-gallery,
.project-menu .bottom-close-button.button,
.year-button:empty {
	display: none
}

img.lazy {
	filter: blur(5px);
	transform: scale(1.02);
	transition: filter .5s, transform .5s
}

img.lazy.loaded {
	filter: blur(0);
	transform: scale(1)
}

.project-highlight-image figure,
.project-images figure {
	overflow: hidden
}

.lazy::before {
	content: "";
	display: block;
	width: 100%;
	padding-bottom: 56.25%
}

@font-face {
	font-family: FriedlBETA1;
	src: url("../fonts/FriedlBETA1-Book.woff2") format("woff2");
	font-style: normal
}

body {
	overflow-x: hidden;
	overflow-y: auto;
	font-family: FriedlBETA1, Arial, sans-serif;
	font-size: .9rem
}

.page-menu {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: fixed;
	text-transform: uppercase;
	letter-spacing: .06rem;
	margin: .3rem;
	gap: .1rem;
	top: 0;
	left: 0;
	z-index: 20;
	opacity: 1
}

#scroll-horizontal.hidden,
.dropdown-menu,
.page-menu.hidden {
	opacity: 0;
	pointer-events: none
}

#projects-button {
	cursor: pointer;
	position: relative
}

.dropdown-menu {
	position: absolute;
	width: 100%;
	z-index: 20;
	text-transform: none;
	letter-spacing: 0;
	min-width: unset;
	display: flex !important;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start
}

.dropdown-menu.show {
	display: block;
	opacity: 1;
	pointer-events: all
}

.dropdown-menu .button {
	display: inline-block;
	opacity: 0;
	margin-top: .09rem;
	white-space: nowrap;
	text-align: left
}

.dropdown-menu.show .button {
	opacity: 1;
	transition: opacity 0s ease-in-out var(--delay, 0ms), background 0s ease-in-out
}

.dropdown-menu:not(.show) .button {
	transition-delay: 0s !important;
	opacity: 0 !important
}

.dropdown-menu .project-entry {
	display: flex;
	align-items: center;
	gap: .1rem;
	white-space: nowrap
}

.project-entry .category-button,
.project-entry .year-button {
	background: var(--button-bg-medium);
	padding: .55rem .65rem .35rem;
	color: #fff;
	border-radius: .15rem
}

.about-menu,
.close,
.project-menu {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: fixed;
	bottom: 0;
	left: 0;
	margin: .3rem;
	gap: .1rem;
	z-index: 20;
	opacity: 0;
	visibility: hidden;
	cursor: pointer
}

.about-menu {
	right: 0;
	left: unset;
}

.about-close-button,
.project-close-button {
	position: absolute;
	top: .3rem;
	right: .3rem;
	z-index: 21 !important;
	cursor: pointer;
	opacity: 0;
	visibility: hidden
}

.about-close-button.visible,
.project-close-button.visible {
	opacity: 1;
	visibility: visible
}

.close.visible,
.project-menu.visible {
	opacity: 1;
	visibility: visible !important
}

.button,
.caption-button,
.category-button,
.year-button {
	-webkit-backdrop-filter: blur(0.6rem);
	box-shadow: .03rem .06rem .25rem 0 rgba(0, 0, 0, .25);
	backdrop-filter: blur(0.6rem);
	z-index: 19;
	cursor: pointer
}

#project-button-container,
#project-category-container,
#project-year-container,
.category-button,
.year-button {
	background: var(--button-bg-medium)
}

#project-button-container,
#scroll-vertical,
.button.no-hover,
.caption-button.no-hover,
.category-button.no-hover,
.meta,
.meta *,
.year-button.no-hover {
	cursor: default
}

.button.active-route,
.caption-button.active-route,
.category-button.active-route,
.year-button.active-route {
	background-color: rgba(0, 0, 0, .8) !important;
	cursor: default !important;
	pointer-events: none !important
}

.button.active-route#projects-button,
.caption-button.active-route#projects-button,
.category-button.active-route#projects-button,
.year-button.active-route#projects-button {
	cursor: pointer !important;
	pointer-events: all !important
}

.category-button,
.year-button {
	white-space: nowrap;
	height: fit-content;
	text-overflow: ellipsis
}

.meta {
	gap: .1rem;
	display: flex;
	align-content: baseline;
	position: absolute;
	align-items: end;
	bottom: .3rem;
	left: .3rem;
	z-index: 10;
	opacity: 0;
	pointer-events: none
}

.slider,
.slider-container {
	position: relative;
	width: 100%
}

.meta .caption-button {
	cursor: pointer !important
}

.back-to-top,
.mobile-project-gallery .slide,
.project-gallery .slide {
	cursor: pointer
}

.meta.hidden {
	opacity: 0 !important
}

.slider-container:hover .meta {
	opacity: 1;
	pointer-events: auto
}

.button:hover:not(.no-hover),
.caption-button:hover {
	background: rgba(0, 0, 0, .8)
}

.about,
.project-gallery,
.project-page,
.slide,
.slider {
	will-change: transform;
	backface-visibility: hidden;
	perspective: 1000px
}

.project-gallery {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	width: 100vw;
	height: 100vh;
	transform: scaleY(1);
	transform-origin: top;
	background-color: grey
}

.project-gallery.collapsed,
.project-page.closing-top {
	transform: scaleY(0);
	transform-origin: top
}

.project-gallery.expanding {
	transform: scaleY(1);
	transform-origin: top
}

.project-gallery.about-collapsed,
.project-page.closing {
	transform: scaleY(0);
	transform-origin: bottom;
	transition: transform .5s ease-in-out
}

.slider-container {
	height: 100%;
	overflow: hidden
}

.slider {
	height: 100%
}

.slide {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transform-origin: right;
	transform: scaleX(0)
}

.project-highlight-image,
.project-page {
	height: 100vh;
	width: 100%
}

.slide:first-child {
	transform: scaleX(1)
}

.active {
	transform-origin: right;
	transform: scaleX(1)
}

.old-active {
	transform-origin: left;
	transform: scaleX(0)
}

.project-highlight-image img,
.project-highlight-image video,
.slide img,
.slide video {
	width: 100%;
	height: 100%;
	object-fit: cover
}

#slider1 .slide,
#slider2 .slide,
#slider3 .slide,
#slider4 .slide {
	transition: transform var(--slide-speed) ease-in-out
}

.project-page {
	position: fixed;
	bottom: 0;
	left: 0;
	background: #fff;
	transform: scaleY(0);
	display: none;
	transform-origin: bottom;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	overflow-y: auto;
	box-shadow: 0 -5px 15px rgba(0, 0, 0, .2);
	z-index: 19
}

.about.active,
.privacy-page.active,
.project-page.active {
	transform: scaleY(1)
}

.project-page.collapse-top {
	transform: scaleY(0);
	transform-origin: top
}

.project-highlight-image figure {
	width: 100%;
	height: 100%
}

.project-description {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
	max-width: 90vw;
	margin: .5rem auto;
	text-align: left;
	padding-bottom: 3.5rem
}

.text-container {
	flex: 1
}

.about .text-container p:first-of-type {
	padding-right: 2.5rem
}

.about-table,
.project-table {
	width: 100%;
	border-collapse: collapse
}

.about-table td,
.project-table td {
	position: relative;
	padding-bottom: .7rem
}

.about-table td::after,
.project-table td::after {
	content: "";
	position: absolute;
	bottom: .39rem;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #000
}

.about-table td:first-child,
.project-table td:first-child {
	width: 17%;
	font-size: .85rem;
	vertical-align: baseline;
	line-height: 1rem
}

.project-images {
	width: calc(90vw);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 4.8rem
}

.project-images img {
	width: calc(100vw - 9rem);
	height: auto
}

.caption {
	text-align: left;
	padding-top: .8rem
}

.about,
.privacy-page {
	transition: transform .5s ease-in-out;
	gap: 2.2rem;
	position: absolute;
	padding-top: .5rem;
	padding-right: 1rem;
	height: 100vh
}

.one-image img.landscape,
.one-image video.landscape {
	min-width: min(calc(94vh * var(--imgratio)), 84vw);
	max-height: 94vh;
	max-width: 84vw
}

.one-image img.landscape.loaded,
.one-image img.portrait.loaded,
.one-image video.landscape.loaded,
.one-image video.portrait.loaded {
	width: auto
}

.one-image img.portrait,
.one-image video.portrait {
	height: 94vh;
	min-width: min(calc(94vh * var(--imgratio)), 84vw)
}

.one-image figure {
	align-items: center
}

.one-image figure.landscape figcaption {
	width: min(calc(94vh * var(--imgratio)), 84vw);
}

.one-image-vertical {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100vh
}

.one-image-vertical img,
.one-image-vertical video {
	height: 100vh;
	width: auto;
	object-fit: contain
}

.image-container.two-images {
	display: flex;
	flex-direction: column;
	align-items: baseline;
	width: 100%
}

.image-container.two-images .image-wrapper {
	justify-content: space-between;
	width: 100%;
	gap: 3rem;
	display: flex;
	justify-content: center
}

.image-container.four-images figure.portrait,
.image-container.two-images figure,
.three-images figure.portrait {
	align-items: center
}

.image-container.two-images figure.landscape figcaption,
.image-container.two-images figure.portrait figcaption {
	max-width: calc(94vh * var(--imgratio))
}

.image-container.two-images img.portrait,
.image-container.two-images video.portrait {
	max-height: 94vh;
	width: calc(94vh * var(--imgratio))
}

.image-container.two-images img.landscape,
.image-container.two-images video.landscape {
	max-height: 94vh;
	width: 100%
}

.image-container.two-images .caption {
	width: 100%
}

.image-container.three-images .image-wrapper {
	display: flex;
	gap: 3vw;
	justify-content: center
}

.three-images figure.portrait figcaption {
	max-width: min(calc(83vw / 3), calc(94vh * var(--imgratio)))
}

.three-images figure.landscape figcaption {
	width: calc(83vw / 3)
}

.three-images .image-wrapper img.landscape,
.three-images .image-wrapper video.landscape {
	width: calc(84vw / 3);
	height: auto
}

.three-images .image-wrapper img.portrait,
.three-images .image-wrapper video.portrait {
	height: unset;
	width: unset;
	max-height: 94vh;
	max-width: calc(84vw / 3)
}

.image-container.four-images {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%
}

.image-container.four-images .image-wrapper {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 3rem;
	width: 100%
}

.image-container.four-images figure.portrait figcaption {
	max-width: min(calc(83vw / 2), calc(94vh * var(--imgratio)))
}

.image-container.four-images figure.landscape figcaption {
	width: calc(83vw / 2)
}

.image-container.four-images figure img.landscape,
.image-container.four-images figure video.landscape {
	width: calc(83vw / 2);
	height: auto
}

.image-container.four-images figure img.portrait,
.image-container.four-images figure video.portrait {
	height: unset;
	width: unset;
	max-height: 94vh;
	max-width: min(calc(83vw / 2), calc(94vh * var(--imgratio)))
}

.image-container.four-images .caption {
	width: 100%;
	text-align: left
}

.about {
	transform: scaleY(0);
	transform-origin: top;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 50vw;
	left: 50%;
	text-align: left;
	overflow: scroll
}

.project-gallery.about-expanding {
	transform: scaleY(1);
	transform-origin: bottom;
	transition: transform .5s ease-in-out
}

.about-table {
	align-self: flex-end;
	margin-top: auto;
	width: 100%
}

.about-table tr:last-child td {
	padding-bottom: .4rem
}

.back-to-top {
	display: block;
	width: fit-content;
	margin: 4rem auto .3rem;
	text-align: center
}

@keyframes horizontalMotion {

	0%,
	100% {
		transform: translateX(-50%)
	}

	25%,
	75% {
		transform: scaleX(2)
	}

	50% {
		transform: translateX(50%)
	}
}

@keyframes verticalMotion {

	0%,
	100% {
		transform: scaleY(1)
	}

	50% {
		transform: scaleY(1.66)
	}
}

#wrapper-horizontal {
	display: flex;
	position: fixed;
	top: 0;
	left: 50%;
	margin-top: .3rem;
	justify-content: center;
	z-index: 19
}

#scroll-horizontal {
	position: fixed;
	display: block;
	opacity: 1;
	animation: 2.5s ease-in-out infinite horizontalMotion;
	cursor: default
}

#wrapper-vertical,
.privacy-page {
	display: flex;
	left: 50%;
	z-index: 21
}

#wrapper-vertical {
	position: fixed;
	bottom: 2.2rem;
	justify-content: center
}

#scroll-vertical {
	display: block;
	position: fixed;
	opacity: 0;
	transform-origin: bottom;
	animation: 1.5s ease-in-out infinite verticalMotion;
	pointer-events: auto
}

#scroll-vertical.visible {
	opacity: 1;
	pointer-events: none
}

.privacy-button {
	all: unset;
	cursor: pointer;
	color: inherit;
	font: inherit
}

.button,
.caption-button,
.privacy-button {
	user-select: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none
}

.privacy-page {
	flex-direction: column;
	justify-content: space-between;
	transform: scaleY(0);
	transform-origin: top;
	flex-direction: column;
	justify-content: space-between;
	width: 50vw;
	text-align: left;
	font-size: 1.2rem;
	line-height: 1.5rem
}

.about.collapsed-bottom {
	transform: scaleY(0);
	transform-origin: bottom
}

a {
	color: #000
}

#scroll-horizontal::after {
	content: "Scroll"
}

@media (min-width:768px) {
	.about-menu {
		display: none !important
	}
}

@media (max-width:768px) {
	
	a {
		text-decoration: none !important;
	}

	.page-menu,
	.project-menu {
		gap: .1rem;
		margin: .3rem;
		right: 0
	}

	#project-button-container,
	.dropdown-menu .button {
		white-space: nowrap;
		text-overflow: ellipsis;
		overflow: hidden
	}

	.project-menu,
	.three-images .image-wrapper img {
		max-width: 100%
	}

	.caption-button.hidden,
	.category-button.hidden,
	.mobile-menu.hidden,
	.year-button.hidden {
		opacity: 0;
		pointer-events: none
	}

	.body,
	html {
		overflow: hidden
	}

	.page-menu {
		position: fixed;
		letter-spacing: 0;
		display: flex;
		top: 0;
		letter-spacing: .05rem
	}

	.page-menu>* {
		flex-grow: 1
	}

	.menu .page-menu .button {
		text-align: center
	}

	.dropdown-menu {
		left: 0;
		flex-direction: row;
		flex-wrap: wrap
	}

	.dropdown-menu .button {
		max-width: 100%;
		right: 0;
		margin-right: .1rem
	}

	.about-close-button,
	.back-to-top,
	.caption-button,
	.category-button,
	.project-close-button,
	.project-gallery,
	.year-button {
		display: none
	}

	.mobile-project-gallery,
	.project-menu .bottom-close-button.button {
		display: block
	}

	.button,
	.caption-button,
	.category-button,
	.year-button {
		font-size: .9rem;
		padding: .5rem .6rem .3rem;
		cursor: pointer
	}

	.project-menu {
		justify-content: flex-start
	}

	.button:hover:not(.no-hover),
	.caption-button:hover {
		background: rgba(0, 0, 0, .4)
	}

	#wrapper-horizontal {
		position: fixed;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		margin-top: 0
	}

	#scroll-horizontal {
		position: relative;
		display: block
	}

	#scroll-horizontal.hidden {
		opacity: 0
	}

	#wrapper-vertical {
		display: none !important
	}

	.mobile-project-gallery {
		will-change: transform;
		backface-visibility: hidden;
		perspective: 1000px;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-rows: 1fr 1fr 1fr;
		height: 100dvh;
		min-height: 100dvh;
		width: 100vw;
		transform: scaleY(1);
		transform-origin: top;
		transition: transform .5s ease-in-out;
		overflow: hidden
	}

	.about,
	.privacy-page,
	.project-description {
		display: flex;
		flex-direction: column;
		text-align: left;
		font-size: 1rem;
		line-height: 1.2rem
	}

	.mobile-project-gallery.collapsed {
		transform: scaleY(0);
		transform-origin: top;
		transition: transform .5s ease-in-out
	}

	.mobile-project-gallery.expanding {
		transform: scaleY(1);
		transform-origin: top;
		transition: transform .5s ease-in-out
	}

	.mobile-project-gallery.about-collapsed {
		transform: scaleY(0);
		transform-origin: bottom;
		transition: transform .5s ease-in-out
	}

	.mobile-project-gallery.about-expanding {
		transform: scaleY(1);
		transform-origin: bottom;
		transition: transform .5s ease-in-out
	}

	.project-page {
		top: 0;
		left: 0;
		height: 100dvh
	}

	.one-image img,
	.one-image-vertical video,
	.project-highlight-image,
	.project-highlight-image figure {
		width: 100%;
		height: auto
	}

	.project-highlight-image img,
	.project-highlight-image video {
		width: 100%;
		height: auto;
		object-fit: cover
	}

	.project-images img,
	.project-images video,
	figure figcaption {
		width: calc(100vw - 2.6rem) !important;
		max-width: unset !important
	}

	.about,
	.privacy-page {
		position: fixed;
		top: env(safe-area-inset-top, 0);
		left: 0;
		width: 100vw;
		height: calc(100dvh - env(safe-area-inset-bottom, 0rem));
		justify-content: space-between;
		gap: 1.1rem;
		padding: 2.8rem .35rem 0;
		overflow-y: auto;
		overscroll-behavior: contain;
		z-index: 19
	}

	.about .text-container p:first-of-type {
		padding-right: 0
	}

	.about.collapsed-bottom {
		transform-origin: bottom
	}

	.project-description {
		justify-content: space-between;
		gap: .15rem;
		max-width: 90vw;
		margin: .4rem auto .5rem;
		padding-bottom: .3rem
	}

	.image-container.three-images,
	.image-container.two-images,
	.project-images {
		flex-direction: column;
		display: flex
	}

	.about-table td:first-child,
	.project-table td:first-child {
		width: 24%;
		font-size: .7rem;
		vertical-align: baseline;
		line-height: .8rem
	}

	.project-images {
		width: calc(100vw - 2.6rem);
		margin: 0 auto;
		gap: 1.3rem;
		padding-bottom: 2.8rem
	}

	.project-images img,
	.project-images video {
		height: auto !important
	}

	figure figcaption {
		font-size: 1rem;
		line-height: 1.2rem;
		padding-top: .4rem;
		margin-bottom: .1rem
	}

	.one-image-vertical,
	.one-image-vertical img {
		height: auto;
		width: 100%
	}

	.image-container.three-images .image-wrapper,
	.image-container.two-images .image-wrapper {
		display: flex;
		flex-direction: column;
		gap: 1.3rem
	}

	.image-container.four-images {
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 100%
	}

	.image-container.four-images .image-wrapper {
		display: flex;
		flex-direction: column;
		width: 100%;
		gap: 1.3rem
	}

	.mobile-menu.hidden {
		transition: var(--fade-transition)
	}

	.caption-button {
		opacity: 1;
		transition: var(--fade-transition)
	}

	#scroll-horizontal::after {
		content: "Swipe"
	}
}