*,
*::after,
*::before {
	box-sizing: border-box;
}
:root {
	font-size: 16px;
	--color-text: #fff;
	--color-bg: #000319;
	--color-link: #fff;
	--color-link-hover: #252379;
	--color-title: #252379;
	--perspective: 1500px;
	--grid-item-ratio: 1.5;
	--grid-width: 100%;
	--grid-height: auto;
	--grid-gap: 2vw;
	--grid-columns: 4;
	--grid-inner-scale: 1;

}
body {
	margin: 0;
	color: var(--color-text);
	background-color: var(--color-bg);
	font-family: Montserrat, arial, sans-serif;
	font-variation-settings: "ital" 0, "wght" 300;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;

}
@font-face {
    font-family: "roc-grotesk";
    src: url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff2"), url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff"), url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("opentype");
    font-display: auto;
    font-style: normal;
    font-weight: 500;
    font-stretch: normal;
	font-display: swap;
}

@font-face {
    font-family: "roc-grotesk";
    src: url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
    font-display: auto;
    font-style: normal;
    font-weight: 400;
    font-stretch: normal;
	font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 400;
    src: url(https://fonts.gstatic.com/s/montserrat/v26/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCtr6Hw0aXpsog.woff2) format('woff2');
    unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
	font-display: swap;
}
/* latin-ext */
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 400;
	font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v26/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCtr6Hw3aXpsog.woff2) format('woff2');
    unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
	font-display: swap;
    font-weight: 400;
    src: url(https://fonts.gstatic.com/s/montserrat/v26/JTUHjIg1_i6t8kCHKm4532VJOt5-QNFgpCtr6Hw5aXo.woff2) format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: "moret-variable";
    src: url("https://use.typekit.net/af/abe581/0000000000000000774f3b44/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3&display=swap") format("woff2"), url("https://use.typekit.net/af/abe581/0000000000000000774f3b44/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/abe581/0000000000000000774f3b44/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
    font-display: auto;
    font-style: normal;
    font-weight: 400;
    font-stretch: normal;
	font-display: swap;
}
.tk-moret-variable {
    font-family: "moret-variable", Book Antiqua, serif;
}
.tk-roc-grotesk {
    font-family: "roc-grotesk", Century Gothic, sans-serif;
}

/* Page Loader */
.js .loading::before,
.js .loading::after {
	content: '';
	position: fixed;
	z-index: 1000;
}
.js .loading::before {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-bg);
}
.js .loading::after {
	top: 50%;
	left: 50%;
	width: 60px;
	height: 60px;
	margin: -30px 0 0 -30px;
	border-radius: 50%;
	opacity: 0.4;
	background: var(--color-link);
	animation: loaderAnim 0.7s linear infinite alternate forwards;
}
@keyframes loaderAnim {
	to {
		opacity: 1;
		transform: scale3d(0.5, 0.5, 1);
	}
}
a {
	text-decoration: none;
	color: var(--color-link);
	outline: none;
	cursor: pointer;
}
a:hover {
	color: var(--color-link-hover);
	outline: none;
}
.unbutton {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font: inherit;
	cursor: pointer;
}
.unbutton:focus {
	outline: none;
}
main {
	position: relative;
	overflow: hidden;
	width: 100%;
	z-index: 100;
	background-color: #000319;
}
.frame {
	position: relative;
	width: 100%;
	padding: 1rem;
	display: grid;
	grid-template-columns: 100%;
	grid-template-areas: 'back' 'prev' 'sponsor';
	grid-gap: 0.5rem;
	justify-items: start;
	align-self: start;
	justify-self: start;
	pointer-events: none;
	align-items: center;
	text-transform: uppercase;
	font-size: 0.85rem;
	background: var(--color-bg-alt);
}
body #cdawrap {
	justify-self: start;
}
.frame a {
	pointer-events: auto;
}
.frame a:not(.frame__title-back) {
	white-space: nowrap;
	overflow: hidden;
	position: relative;
}
.frame a:not(.frame__title-back)::before {
	content: '';
	height: 1px;
	width: 100%;
	background: currentColor;
	position: absolute;
	top: 90%;
	transition: transform 0.3s;
	transform-origin: 0% 50%;
}
.frame a:not(.frame__title-back):hover::before {
	transform: scaleX(0);
	transform-origin: 100% 50%;
}
.frame__title {
	grid-area: title;
	display: flex;
}
.frame__title-main {
	font-size: inherit;
	margin: 0;
	font-weight: inherit;
}
.frame__title-back {
	position: relative;
	display: flex;
	align-items: flex-end;
	margin-bottom: 0.15rem;
}

.frame__title-back span {
	display: none;
}
.frame__title-back svg {
	fill: currentColor;
}
.frame__prev {
	grid-area: auto;
}
.h1__title {
	line-height: clamp(4rem, 8vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	font-size: clamp(2rem, 8vw, 5rem);
	font-weight: 400;
	text-align: center;
}
.h2__title {
	line-height: clamp(1.5rem, 5vw, 5rem);
	font-size: clamp(1rem, 1vw, 1rem);
	text-align: center;
	font-weight: 600;
}
.h3__title {
	line-height: clamp(4rem, 8vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	font-size: clamp(2rem, 3vw, 3rem);
	font-weight: 400;
	text-align: center;
	margin-top: 5em;
	margin-bottom: 0;
}
.h4__title {
	line-height: clamp(1.5rem, 2vw, 2rem);
	font-size: clamp(1rem, 1vw, 1rem);
	text-align: center;
	margin-top: 0;
	margin-left: 2em;
	margin-right: 2em;
}
.intro {
	height: calc(100vh - 3rem);
	text-align: center;
	place-items: center;
	display: grid;
	margin-bottom: 30vh;
	background: linear-gradient(0deg, transparent, var(--color-bg-alt));
}
.intro__title {
	place-items: center;
	margin: 15px;
	line-height: clamp(1rem, 8vw, 5rem);
	font-weight: 400;
}
.intro__title-pre {
	font-weight: 300;
	font-size: clamp(2rem, 8vw, 5rem);
	color: var(--color-title);
	text-transform: uppercase;
}
.intro__title-sub {
	font-size: clamp(1.5rem, 5vw, 8rem);
	max-width: 15ch;
	margin: 0 auto;
	font-family: "moret-variable", Book Antiqua, serif;
}
.intro__title-sub02 {
	font-size: clamp(1.5rem, 2vw, 8rem);
	max-width: 15ch;
	margin: 0 auto;
}
.intro__info {
	max-width: 15ch;
	opacity: .6;
	margin-bottom: 4rem;
	padding-bottom: 1rem;
	line-height: 1.2;
	position: relative;
	align-self: end;
}
.intro__info::after {
	content: "";
	width: 1px;
	height: 2rem;
	background: #fff;
	position: absolute;
	top: 100%;
	left: 50%;
}
.card-wrap {
	margin-top: 5vh;
	display: grid;
	grid-gap: 2rem;
	grid-auto-flow: row;
	grid-template-columns: 250px;
}
.card__image {
	display: block;
	border-radius: 7px;
	background-size: cover;
	background-position: 50% 50%;
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 3;
}
.credits {
	font-size: 1.5rem;
	text-align: center;
	margin: 50vh auto 0;
	padding-bottom: 50vh;
}
.content {
	position: relative;
	margin-bottom: 20vh;
}
.content--spacing {
	margin-bottom: 100vh;
}
.content__title {
	position: absolute;
	height: 100vh;
	width: 100vw;
	top: 100%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 6.5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
.chapitre {
	font-size: clamp(1rem, 3vw, 2rem) !important;
	line-height: clamp(1rem, 6vw, 2rem) !important;
}
.content__title01 {
	position: absolute;
	height: 30vh;
	width: 100vw;
	top: 40%;
	left: 45%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 5rem);
	line-height: clamp(3rem, 15vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
.content__title02 {
	position: absolute;
	height: 30vh;
	width: 100vw;
	top: 40%;
	left: 45%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 5rem);
	line-height: clamp(3rem, 15vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
.content__title03 {
	position: absolute;
	height: 20vh;
	width: 100vw;
	top: 40%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 5rem);
	line-height: clamp(3rem, 15vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
.content__title04 {
	position: absolute;
	height: 20vh;
	width: 100vw;
	top: 50%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 5rem);
	line-height: clamp(3rem, 15vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
.content__title05 {
	position: absolute;
	height: 15vh;
	width: 100vw;
	top: 40%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(1.5rem, 15vw, 5rem);
	line-height: clamp(3rem, 15vw, 5rem);
	font-family: "moret-variable", Book Antiqua, serif;
	z-index: 55;
}
@media screen and (min-width: 54em) {
	.content__title--top {
		align-items: start;
	}
	.content__title--bottom {
		align-items: end;
	}
	.content__title--left {
		justify-items: start;
		text-align: left;
	}
	.content__title--right {
		justify-items: end;
		text-align: right;
	}
}
@media screen and (max-width: 53em) {
	.intro {
		/* calc(25vh - 3rem) permet de changer la hauteur des apparations des images */
		height: calc(1vh - 3rem) !important;
		margin-bottom: 140vh !important;
	}
	.content__title--top {
		justify-items: end;
		text-align: right;
	}
	.content__title--bottom {
		justify-items: end;
		text-align: right;
	}
	.content__title--left {
		justify-items: end;
		text-align: right;
	}
	.content__title--right {
		justify-items: end;
		text-align: right;
	}
	.content__title--05 {
		justify-items: end;
		text-align: right;
	}
}
.content__txt {
	position: absolute;
	height: 10vh;
	width: 100vw;
	top: 100%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	z-index: 1;
}
.content__txt02 {
	position: absolute;
	height: 25vh;
	width: 100vw;
	top: 75%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 15vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	z-index: 1;
}
.content__txt03 {
	position: absolute;
	height: 10vh;
	width: 100vw;
	top: 130%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
}
.content__txt04 {
	position: absolute;
	height: 10vh;
	width: 100vw;
	top: 110%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	z-index: 1;
}
.content__txt05 {
	position: absolute;
	height: 10vh;
	width: 100vw;
	top: 190%;
	left: 50%;
	margin: -50vh 0 0 -50vw;
	padding: 0 10vw;
	display: grid;
	place-items: center;
	text-align: center;
	font-weight: 300;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	z-index: 1;
}
@media screen and (max-width: 53em) {
	.content__title01 {
		position: relative !important;
		height: auto !important;
		left: 50% !important;
		margin: -50vh 0 0 -46vw !important;
		margin-bottom: 2vw !important;
		display: inherit !important;
	}
	.content__title02 {
		position: relative !important;
		height: auto !important;
		display: table !important;
		margin-bottom: 2vw !important;
		text-align: right !important;
		margin: -100vw 0 0 -50vw !important;
	}
	.content__title03 {
		position: relative !important;
		height: auto !important;
		left: 50% !important;
		margin: -100vw 0 0 -50vw !important;
		margin-bottom: 2vw !important;
		display: inherit !important;
		text-align: right !important;
	}
	.content__title04 {
		position: relative !important;
		height: auto !important;
		left: 50% !important;
		margin: -100vw 0 0 -50vw !important;
		margin-bottom: 2vw !important;
		display: inherit !important;
		text-align: right !important;
	}
	.content__title05 {
		position: relative !important;
		height: auto !important;
		left: 50% !important;
		margin: -100vw 0 0 -50vw !important;
		margin-bottom: 2vw !important;
		display: inherit !important;
		text-align: right !important;
	}
	.chapitre {
		text-align: right !important;
		justify-items: start !important;
	}
	.intro__title {
		padding-top: 3em;
	}
	.content {
		margin-bottom: 110vh;
	}
	.content__txt {
		position: relative !important;
		margin: 0 !important;
		top: 0 !important;
		left: 0 !important;
		padding: 0 5vw !important;
	}
	.content__txt02 {
		position: relative !important;
		margin: 0 !important;
		top: 0 !important;
		left: 0 !important;
		padding: 0 5vw !important;
	}
	.content__txt03 {
		position: relative !important;
		margin: 0 !important;
		top: 0 !important;
		left: 0 !important;
		padding: 0 7vw !important;
	}
	.content__txt04 {
		position: relative !important;
		margin: 0 !important;
		top: 0 !important;
		left: 0 !important;
		padding: 0 7vw !important;
	}
	.content__txt05 {
		position: relative !important;
		margin: 0 !important;
		top: 0 !important;
		left: 0 !important;
		padding: 0 7vw !important;
	}
	.content--spacing {
		margin-bottom: 100vh !important;
	}
	.img-footer {
		margin-left: 0 !important;
		width: 7vw !important;
	}
	.footer-right {
		margin-right: 0 !important;
	}
	.icon-footer {
		width: 3em !important;
		padding: clamp(0.5rem, 1vw, 2rem) !important;
	}
	.container-title-footer {
		padding-top: 0 !important;
	}
	.box1 {
		width: 50% !important;
		padding-bottom: 0em !important;
	}
	.box2 {
		width: 50% !important;
		text-align: right !important;
		padding-bottom: 0em !important;
	}
	.box3 {
		width: 100% !important;
		text-align: center !important;
		padding-top: 0em !important;
	}
	.box {
		padding-top: 0 !important;
		margin-top: 12em!important;
	}
	.grid_mobile {
		display: none !important;
	}
	.content_mobile_marge_bot01 {
		padding-bottom: 40vh;
	}
	.content_mobile_marge_bot02 {
		padding-bottom: 40vh;
	}
	.content_mobile_marge_bot02 {
		padding-bottom: 40vh;
	}
	.content_mobile_marge_bot03 {
		padding-bottom: 40vh;
	}
	.content_mobile_marge_bot04 {
		padding-bottom: 40vh;
	}
	.content_mobile_marge_bot05 {
		padding-bottom: 40vh;
	}
	:root {
		--perspective: 1500px !important;
		--grid-item-ratio: 1 !important;
		--grid-width: 100% !important;
		--grid-height: 0 !important;
		--grid-gap: 8vw !important;
		--grid-columns: 2 !important;
		--grid-inner-scale: 1 !important;
	}
}
.container-title-footer {
	padding-top: 20em;
}
.footer-title01 {
	text-align: center;
	font-weight: 900;
	font-size: clamp(0.8rem, 2vw, 1rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	color: #BBBBBB;
	text-transform: uppercase;
}
.footer-title02 {
	text-align: center;
	font-family: "moret-variable", Book Antiqua, serif;
	font-weight: 400;
	font-size: clamp(1.5rem, 5vw, 8rem);
	line-height: clamp(1rem, 8vw, 6rem);
	padding-right: 2em;
	padding-left: 2em;
	margin-top: 1em;
	margin-bottom: 1em;
}
.footer-title03 {
	text-align: center;
	font-weight: 400;
	font-size: clamp(0.8rem, 2vw, 1.4rem);
	line-height: clamp(1.4rem, 4vw, 3rem);
	margin-bottom: 3em;
	padding-right: 2em;
	padding-left: 2em;
}
.border {
	border-bottom: 1px solid #333547;
	margin-top: 10em;
}
.img-footer {
	width: 4.5vw;
	height: 10vh;
	max-width: 50px;
	max-height: 50px;
	vertical-align: middle;
	margin-left: 2em;
}
.icon-footer {
	width: 3.5vw;
	height: auto;
	max-width: 100px;
	max-height: 100px;
	vertical-align: middle;
	transition: transform .5s;
	border-radius: 500px;
	padding: clamp(0.1rem, 0.7vw, 1rem);
}
.footer-right {
	margin-right: 2em;
}
.icon-footer:hover {
	transform: translate(0, -10%);
	border: 0.1rem solid;
	color: #bbbbbb;
}
.link:hover {
	color: #4caaf2;
}
/*FOOTER*/
.box div {
	width: 33%;
	display: inline-block;
	padding: 15px;
	margin: 0;
	vertical-align: middle;
	padding-top: 6em;
	padding-bottom: 2em;
}
.box1 {
	font-size: clamp(0.8rem, 2vw, 1.3rem);
}
.box2 {
	text-align: center;
	font-size: clamp(0.8rem, 2vw, 0.9rem);
}
.box3 {
	padding-top: 1em;
	margin-right: 2em;
	text-align: right;
}
.benoit-footer {
	padding: 0.2em !important;
	text-transform: uppercase;
}
.grid {
	display: grid;
	place-items: center;
	padding: 2rem;
	width: 100%;
	perspective: var(--perspective);
}
.grid-wrap {
	height: var(--grid-height);
	width: var(--grid-width);
	display: grid;
	grid-template-columns: repeat(var(--grid-columns), 1fr);
	gap: var(--grid-gap);
	transform-style: preserve-3d;
}
.grid__item {
	aspect-ratio: var(--grid-item-ratio);
	width: 100%;
	height: auto;
	overflow: hidden;
	position: relative;
	border-radius: 8px;
	display: grid;
	place-items: center;
}
.grid__item-inner {
	position: relative;
	width: calc(1 / var(--grid-inner-scale) * 100%);
	height: calc(1 / var(--grid-inner-scale) * 100%);
	background-size: cover;
	background-position: 50% 50%;
	border-radius: 8px;
}
@media screen and (min-width: 53em) {
	.frame {
		grid-template-columns: auto auto auto 1fr;
		grid-template-areas: 'title prev ... sponsor';
		align-content: space-between;
		justify-items: start;
		grid-gap: 2rem;
	}
	.frame__demos {
		justify-self: end;
	}
	.content--outro {
		height: 100vh;
		justify-content: center;
	}
	.card-wrap {
		grid-template-columns: repeat(3, 250px);
	}
	body #cdawrap {
		justify-self: end;
	}
}
label {
	color: #BBBBBB;
	font-size: 1em;
	font-weight: normal;
	position: absolute;
	pointer-events: none;
	top: 15px;
	opacity: 0.8;
	transition: 0.2s ease all;
	-moz-transition: 0.2s ease all;
	-webkit-transition: 0.2s ease all;
}
input {
	font-size: 13px;
	height: 50px;
	padding: 10px 10px 10px 5px;
	display: block;
	width: 300px;
	border: none;
	outline: none;
	border-bottom: 1px solid #bbbbbb;
	color: #ffffff;
	background: rgba(0, 0, 0, 0);
	transition: 0.2s ease;
}
input:focus {
	outline: none;
	opacity: 1;
}
input:focus~label,
input:valid~label {
	top: -10px;
	font-size: 0.8em;
	color: #e8e8e8;
	opacity: 1;
}
input:focus~.highlight {
	-webkit-animation: inputHighlighter 0.3s ease;
	-moz-animation: inputHighlighter 0.3s ease;
	animation: inputHighlighter 0.3s ease;
}
/* ANIMATIONS ================ */
@-webkit-keyframes inputHighlighter {
	from {
		background: #e8e8e8;
	}

	to {
		width: 0;
		background: transparent;
	}
}
@-moz-keyframes inputHighlighter {
	from {
		background: #e8e8e8;
	}
	to {
		width: 0;
		background: transparent;
	}
}
@keyframes inputHighlighter {
	from {
		background: #e8e8e8;
	}
	to {
		width: 0;
		background: transparent;
	}
}
	textarea {
		background: transparent;
		border-bottom: 1px solid #e8e8e8;
		color: #ffffff;
		border-top: 0;
		border-left: 0;
		border-right: 0;
		margin-top: 1em;
	}
	textarea:focus {
		outline: none;
		opacity: 1;
	}
	textarea:focus~label,
	textarea:valid~label {
		top: -10px;
		font-size: 0.8em;
		color: #e8e8e8;
		opacity: 1;
	}
	.ohno {
		opacity: 0;
		position: absolute;
		top: 0;
		left: 0;
		height: 0;
		width: 0;
		z-index: -1;
	}
	.text-menu {
		margin-right: 9.5px;
		margin-left: 9.5px;
		font-size: clamp(0.5rem, 5vw, 0.9rem);
		color: #fff;
		text-decoration: none;
		display: inline-block;
		position: relative;
	}
	.text-menu:after  {
		background: none repeat scroll 0 0 transparent;
		bottom: 0;
		content: "";
		display: block;
		height: 1px;
		left: 50%;
		position: absolute;
		background: var(--color-link-hover);
		transition: width 0.3s ease 0s, left 0.3s ease 0s;
		width: 0;
	}
	.text-menu:hover:after {
		width: 100%; 
		left: 0; 
		margin-bottom: -0.5em;
	}
	#navbar {
		z-index: 99999999999;
		padding-top: 1em;
		padding-bottom: 1em;
		position: fixed;
		text-align: center;
		width: 100%;
	}
	.menu-header {
		background: rgba(33, 0, 2, 0.27);
		box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
		backdrop-filter: blur(8.2px);
		-webkit-backdrop-filter: blur(8.2px);
		--color-link-hover: #4caaf2 !important;
	}
	.box {
		background-image: url(../images/parallax/parallax3.svg) !important;
		background-position-y: top !important;
		margin-top: 18em;
	}	