*,
*::after,
*::before {
	box-sizing: border-box;
}

:root {
	font-size: 16px;
}

html, body {
	overflow: hidden;
	height: 100vh;
}

body {
	margin: 0;
	--color-text: #ff5353;
	--color-bg: #ffe3e3;
	--color-link: #000;
	--color-link-hover: #010300;
	color: var(--color-text);
	background-color: var(--color-bg);
	font-family: halyard-display, sans-serif;
	font-weight: 300;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	will-change: background-color;
}


.oh {
	position: relative;
	overflow: hidden;
}

.oh__inner {
	display: inline-block;
	will-change: transform;
}

.unbutton {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font: inherit;
}

.unbutton:focus {
	outline: none;
}


.content {
	display: grid;
	place-items: center;
	width: 100%;
}

.content__item {
	height: 100vh;
	width: 100%;
	padding-top: 1rem;
	display: grid;
	align-items: center;
}

.content__item-title {
	grid-area: 1 / 1 / -1 / -1;
	margin: 0;
	cursor: default;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	line-height: 0.85;
	font-size: 15.5vw;
	text-transform: uppercase;
	font-family: ivymode, sans-serif;
	font-weight: 200;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.content__item-title span {
	position: relative;
	z-index: 100;
	display: block;
	will-change: transform, opacity;
}



.content__item-img {
	background-size: cover;
	background-position: 50% 50%;
	align-self: center;
	justify-self: center;
	grid-area: 1 / 1 / -1 / -1;
	height: 50vh;
	width: 80vw;
	will-change: transform;
}

.content__enter {
	grid-area: 1 / 1 / -1 / -1;
	align-self: center;
	justify-self: center;
	color: #fff;
	font-size: 2rem;
	cursor: pointer;
	font-family: ivymode, sans-serif;
	font-weight: 200;
	z-index: 1;
}

.button-circle {
	width: 200px;
	height: 200px;
	display: grid;
	place-items: center;
}

.button-circle__text {
	line-height: 1;
	overflow: hidden;
	grid-area: 1 / 1 / -1 / -1;
}

.button-circle__text span {
	display: block;
	padding: 0 0.5rem;
}

.button-circle__text span::before {
	position: absolute;
	content: attr(data-text);
	bottom: 100%;
	font-style: italic;
	width: 100%;
	text-align: center;
	left: 0;
}

.button-circle:hover .button-circle__text span {
	transform: translate3d(0,100%,0);
}

.button-circle__deco {
	width: 100%;
	height: 100%;
	grid-area: 1 / 1 / -1 / -1;
	fill: none;
	stroke: currentColor;
	stroke-width: 1px;
}

.button-circle:hover .button-circle__deco {
	transform: scale3d(1.4,1.4,1);
}

.button-circle__text span,
.button-circle__deco {
	transition: transform 0.3s ease-out;
}

.button-circle:hover .button-circle__text span,
.button-circle:focus .button-circle__text span,
.button-circle:hover .button-circle__deco,
.button-circle:focus .button-circle__deco {
	transition: transform 0.4s cubic-bezier(0.7,0,0.3,1);
}

.grid {
	position: fixed;
	counter-reset: grid-counter;
	top: calc(50vh - 40vw);
	left: 0;
	width: 100%;
	height: 80vw;
	display: grid;
	grid-template-columns: repeat(100,1fr);
	grid-template-rows: repeat(100,1fr);
	opacity: 0;
	pointer-events: none;
}

.grid--open {
	opacity: 1;
	pointer-events: auto;
}

.grid__item {
	position: relative;
	display: grid;
	grid-template-areas: 'grid-img' 'grid-title';
	grid-template-rows: 100% auto;
	grid-column: var(--c) / span var(--cs);
	grid-row: var(--r) / span  var(--rs);
	will-change: opacity, transform;
}

.grid__item--title {
	grid-column: 5 / span 25;
	grid-row: 5 / span 14;
	margin: 0;
	position: relative;
	z-index: 100;
	justify-content: center;
	display: flex;
	flex-direction: column;
	font-family: ivymode, sans-serif;
	font-weight: 200;
	text-transform: uppercase;
	font-size: clamp(1.5rem,3vw,3.5rem);
    line-height: 1;
}

.grid__item--title span {
	will-change: transform, opacity;
}

.grid__item--title span:last-child {
	margin-left: 2rem;
}

.grid__item--back {
	z-index: 100;
	grid-column: 5 / span 6;
	grid-row: 20 / span 10;
}

.button-back {
	cursor: pointer;
	display: flex;
	padding: 0.5rem 0;
	align-self: start;
}

.button-back svg {
	pointer-events: none;
	stroke: #000;
	stroke-width: 1px;
	transition: stroke 0.3s;
}

.button-back:hover svg {
	stroke: #989898;
}

.grid__item .content__item-img,
.grid__item-img {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: 50% 50%;
}

.grid__item-title {
	font-size: 0.9rem;
	position: absolute;
	top: 100%;
	left: 0;
	margin: 0.5rem 0 0 0;
	white-space: nowrap;
	font-weight: 300;
	line-height: 1;
	visibility: hidden;
}

.grid__item-title--above {
	top: auto;
	bottom: 100%;
	margin: 0 0 0.5rem 0;
}

.grid__item-title span::before {
	counter-increment: grid-counter;                   
	content: counter(grid-counter, decimal-leading-zero) "\00a0 \2014 \00a0" ;
}

@media screen and (min-width: 53em) {
	.grid {
		height: 100%;
		top: 0;
	}
	.grid__item-title {
		visibility: visible;
	}
	.content__item {
		padding: 0;
	}
	.content__item-img {
		height: 80vh;
		width: 60vw;
		max-width: 600px;
	}
	.content__item-title {
		justify-content: space-between;
	}
	
}

/*# sourceMappingURL=/app.ae05fb60.css.map */