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

:root {
	font-size: 18px;
}

body {
	margin: 0;
	--color-text: #867a8b;
	--color-text-alt: #ff2d71;
	--color-link-hover: #ff2d71;
	--color-link-active: #ff2d71;
	--color-menu: #5b6265;
	--color-menu-hover: #ff2d71;
	--color-menu-border: #4c2d4e;
	color: #5b6265;
	background: #fff;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-weight: 300;
	--size-menu: 4vh;
}



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

.unbutton:focus {
	outline: none;
}

main {
	width: 100%;
	/* min-height: 100vh; */
	display: grid;
	grid-template-columns: 10vw 10vh 10vw 5vw 32vw 1fr;
	grid-template-rows: auto 1fr;
	grid-template-areas: 'side side side frame frame frame'
						'content content content content content content';
}

.no-js main {
	grid-template-areas: 'content content content content content content';
}

.frame {
	position: relative;
	color: var(--color-text-alt);
	grid-area: frame;
	padding: 0.75rem 1.5rem;
	background: #2b192c;
}

.frame a {
	pointer-events: auto;
}

.frame__title {
	font-size: 1rem;
	font-weight: 300;
	margin: 0;
	justify-self: start;
	grid-area: title;
}

.frame__links {
	grid-area: links;
	padding: 0;
	margin: 1rem 0;
	justify-self: end;
}

.frame__links a:not(:last-child) {
	margin-right: 1rem;
}

.content {
	grid-area: content;
	display: grid;
	place-content: center;
	padding: 1rem 5vw;
}

.button-next {
	cursor: not-allowed;
	grid-area: content;
	align-self: center;
	justify-self: end;
	width: 70px;
	height: 140px;
	display: none;
	place-items: center;
	border-radius: 70px 0 0 70px;
	background: linear-gradient(to bottom, #9b498a, #9b7749);
}

.color-alt {
	color: var(--color-text-alt);
}

.menu {
	grid-area: 1 / 1 / 2 / 7;
	display: grid;
	grid-template-columns: 5vw 5vw 11vh 5vw 1fr;
	grid-template-rows: auto 1fr;
	position: fixed;
	height: 100vh;
	pointer-events: none;
	z-index: 800;
}

.no-js .menu {
	display: none;
}

.menu__bg {
	position: absolute;
	left: 0;
	width: 5rem;
	height: 100vh;
	background: #fff;
	/* box-shadow: rgb(0 0 0 / 10%) 0px 0px 10px 0px;  */
	/* border-right: 1px solid rgb(0 0 0 / 15%); */
	pointer-events: none;
	-webkit-transition: 1s;
	-moz-transition: 1s;
	-o-transition: 1s;
	transition: 1s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
}
.menu.menu--open .menu__bg {
	width: 100%;
	box-shadow: rgb(0 0 0 / 10%) 0px 0px 10px 0px !important; 
}

.menu__button {
	margin: 1rem 1rem;
	position: relative;
	align-self: start;
	cursor: pointer;
	pointer-events: auto;
	grid-area: 1 / 1 / 2 / 3;
	justify-self: start;
}

.logo {
	max-width: 100px;
    text-align: center;
    /* display: block; */
    margin-left: auto;
    margin-right: auto;
}

.menu__button path {
	stroke: #5b6265;
	fill: none;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
}

.menu__button:hover path,
.menu__button:focus-visible path {
	stroke: var(--color-menu-hover);
}

.menu__button-cross {
	opacity: 0;
}

.menu__items {
	grid-area: 2 / 1 / 2 / 6;
	justify-content: center;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	position: relative;
	pointer-events: none;
	margin: 1rem 1.5rem;
	padding-bottom: 1rem;
}

.menu--open .menu__items {
	pointer-events: auto;
}

.menu__item {

	font-weight: 400;
	text-transform: uppercase;
	font-size: var(--size-menu);
	line-height: 1;
	color: var(--color-menu);
	position: relative;
	cursor: pointer;
	font-family: space-mono, monospace;
	
}

.menu.menu--open .menu__item {
	/* font-family: bpgbold; */
}

.menu__item_vertfont {
	font-family: space-mono, monospace;
}

.menu__item span {
	pointer-events: none;
}

.menu__item .letter-wrap__inner span:first-child,
.menu__item .letter-wrap__inner span,
.menu__item .letter-wrap span.char {
	transition: color 0.2s ease;
	
}

.menu .menu__item .word .letter-wrap:first-child {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
	-webkit-transition-delay: 0.5s;
	-moz-transition-delay: 0.5s;
	-o-transition-delay: 0.5s;
	transition-delay: 0.5s;
	color: #5b6265;
	
}

.menu.menu--open .menu__item.menuactive .word .letter-wrap {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
	-webkit-transition-delay: 0.8s;
	-moz-transition-delay: 0.8s;
	-o-transition-delay: 0.8s;
	transition-delay: 0.8s;
	
}

.menu.menu--open .menu__item.active .word .letter-wrap:first-child {
	color: #ff2d71;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
	-webkit-transition-delay: 0.5s;
	-moz-transition-delay: 0.5s;
	-o-transition-delay: 0.5s;
	transition-delay: 0.5s;
	
}

.menu.menu--open .menu__item .word .letter-wrap:first-child {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease-out;
	-moz-transition-timing-function: ease-out;
	-o-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
	-webkit-transition-delay: 0.5s;
	-moz-transition-delay: 0.5s;
	-o-transition-delay: 0.5s;
	transition-delay: 0.5s;
}

.menu.menu--open .menu__item:hover .word .letter-wrap:first-child {
	color: #ff2d71;
}


.menu--open .menu__item:hover .letter-wrap__inner span:first-child,
.menu--open .menu__item:hover .letter-wrap__inner span,
.menu--open .menu__item:hover .letter-wrap span.char,
.menu--open .menu__item:focus .letter-wrap__inner span:first-child,
.menu--open .menu__item:focus .letter-wrap__inner span,
.menu--open .menu__item:focus .letter-wrap span.char {
	color: var(--color-menu-hover);
}

.menu--open .menu__item:focus-visible {
	outline: 2px solid var(--color-link);
	background: transparent;
}

.menu__item.splitting .word {
	display: flex;
}

.menu__item.splitting .char {
	flex: none;
	display: flex;
	justify-content: center;
	transform-origin: 50% 100%;
	will-change: transform, color;
	
}

.menu__item .char {
	color: var(--color-link);
}

.letter-wrap,
.letter-wrap__inner span,
.menu__item.splitting .char {
	width: calc(var(--size-menu) * 0.9);
	display: flex;
	justify-content: center;
	will-change: transform, color;
}

.letter-wrap__inner span:first-child {
	color: var(--color-link);
}

.letter-wrap {
	flex: none;
	height: calc(var(--size-menu) * 1.1);
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	/* font-family: bpgbold; */
}


.letter-wrap > span:not(.letter-wrap__inner) {
	opacity: 0;
}

.letter-wrap__inner {
	display: flex;
	flex-direction: column;
	height: fit-content;
}

.menu__tagline {
	display: none;
	font-family: kudryashev-d-excontrast-sans, sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size: 1.75rem;
	grid-area: 1 / 4 / 2 / 5;
	text-transform: none;
	margin: 12.5vh 0 0 1.5vw;
	text-align: right;
	-webkit-writing-mode: vertical-rl;
	writing-mode: vertical-rl;
	transform: rotate(180deg);
}

@media screen and (max-width: 765px) {
	.menu__bg {
    width: 100vw;
    height: 50px;
	box-shadow: none;
}
	.menu__items {
	/* margin: 1.8rem; */
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-transition-timing-function: ease;
	-moz-transition-timing-function: ease;
	-o-transition-timing-function: ease;
	transition-timing-function: ease;

	}
	.menu.menu--open .menu__bg {
	width: 100vw;
	height: 100vh;
	}
	.menu .menu__items {
    left: -240px;
	}
	.menu.menu--open .menu__items {
    left: 0px;
	}
	.menu__button {
	margin: 0;
	}

}

@media screen and (min-width: 54em) {
	body {
		--size-menu: 9vh;
	}
	main {
		/* height: 100vh; */
		overflow: hidden;
		grid-template-rows: 100%;
		grid-template-areas: 'side side side content content content'
	}
	
	.menu__items {
	grid-area: 2 / 1 / 2 / 6;
	justify-content: center;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	position: relative;
	pointer-events: none;
	margin: 1rem 0.5rem;
	padding-bottom: 1rem;
}

/* 	.menu {
		grid-area: 1 / 1 / 2 / 6;
		grid-template-rows: 100%;
		border: 0;
	}

	.menu__items {
		grid-area: 1 / 3 / 2 / 6;
		justify-content: center;
		margin: 1vh 0 0 0;
		padding-bottom: 0;
	} */

	.frame {
		background: none;
		grid-area: content;
		display: grid;
		align-content: space-between;
		pointer-events: none;
		grid-template-columns: 50% 50%;
		grid-template-rows: auto auto auto;
		grid-template-areas: '... sponsor'
						'... arrow'
						'title links';
	}

	.frame::after {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		pointer-events: none;
		width: 100%;
		height: 100%;
		z-index: 10;
		background: linear-gradient(to bottom, #2b192c, #1a191c);
		opacity: 0;
		transition: opacity 1s ease-in-out 0.3s;
	}

	.menu--open ~ .frame::after {
		opacity: 0.8;
		transition-delay: 0s;
		pointer-events: auto;
	}

	.button-next {
		display: grid;
	}
	.menu__tagline {
		display: block;
	}

	.menu__button {
		/* align-self: center;
		justify-self: center; */
		/* margin: 0; */
		
	}

	.content {
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 0;
	}

	.content__column {
		max-width: 34ch;
		padding: 0 1.5rem;
	}

	.content__column:first-child {
		margin-top: -10vh;
	}

	.content__column:last-child {
		margin-top: 10vh;
	}

	.frame__links {
		margin: 0;
	}

}

