

/* WORLD PAGE */

.logo-type-header--world {
	position: absolute;
		top: 2.8vw;
		left: 2.8vw;

	width: 2vw;
	z-index: 20;
}

.logo-type-header--world img {
	position: absolute;
	width: 100%;
	height: auto;
}

.world__hero--menu {
	position: absolute;
		top: 2.8vw;
		right: 2.8vw;
}

.page__world {
	position: relative;
	width: 100%;

	padding: 0;
	margin: 0;
}

.world__hero {
	position: relative;
	width: 100%;
	/*height: 100vh;*/
}

.world__hero--margin {
	position: relative;
	width: calc(100% - 19.2vw);
	/*height: calc(100vh - 6.4vw);*/
	padding: 3.2vw 9.6vw;
	margin: 0 auto;

/*	min-height: 50vw;*/
}

.world__hero--header {
	position: relative;
	width: 100%;
	text-align: center;

	font-family: 'Editorial New';
	font-size: 1.6vw;
	letter-spacing: -0.04em;
}

.world__hero--headline {
	position: relative;
		/*top: calc(50% + 1.6vw);
		left: 50%;*/

	/*transform: translate(-50%, -50%);*/
	margin: 0 auto;
	padding-top: 4.8vw;

	width: 60vw;
}

.world__hero--tagline {
	position: relative;
	width: calc(100% - 19.2vw);

	text-align: center;

	margin: 0 auto;
}

.world__hero--tagline:before {
	content: "";
	position: absolute;
		top: 50%;
		left: 0;

	width: 100%;
	height: 1px;

	background-color: var(--black);
	opacity: 0.4;
}

.world__hero--tagline span {
	position: relative;
	margin: 0 auto;

	padding: 0 2.4vw;

	font-family: 'Editorial New Thin';
	font-size: 1.4vw;
	line-height: 2.4vw;
	letter-spacing: 0.02em;

	background-color: var(--offwhite);
}

.world__hero--headline h1 {
	position: relative;
	width: 100%;

	padding: 1.6vw 0;

	font-family: 'Editorial New Bold';
	font-size: 4vw;
	line-height: 4.8vw;
	text-align: center;
	letter-spacing: -0.04em;
}

.world__hero--cta {
	position: relative;

	width: calc(100% - 19.2vw);
	text-align: center;

	padding-bottom: 3.2vw;
	padding-top: 0.8vw;
	margin: 0 auto;
}

.world__hero--cta:before {
	content: "";
	position: absolute;
		bottom: 0%;
		left: 0;

	width: 100%;
	height: 1px;

	background-color: var(--black);
	opacity: 0.4;
}

.world__hero--intro {
	position: relative;

	width: calc(100% - 19.2vw);
	text-align: center;

	padding-top: 1.6vw;
	margin: 0 auto;
}

/* GAME */

.section__game {
	position: relative;
	width: 100%;
}

.section__game--margin {
	position: relative;
	width: calc(100% - 19.2vw);
	padding: 3.2vw 9.6vw;
}

.game__field {
	position: relative;
	width: 100%;

	padding-bottom: 56.25%;
}

.game__field--framework {
	position: absolute;
		top: 0;
		left: 0;

	width: 100%;
	height: 100%;

	overflow: hidden;
}

.game__field--grid {
	position: absolute;
		top: 0;
		left: 0;

	width: 100%;
	height: 100%;

	overflow: hidden;

	background: url('_images/pattern-grid-dashed.svg');
	background-size: 3.2vw;

	pointer-events: none;
}

.game__intro {
	position: absolute;
		top: 50%;
		left: 50%;

	width: 70%;

	padding: 3.2vw 2.4vw 2.4vw 2.4vw;

	z-index: 1;

	transform: translate(-50%, -50%);
	transition-duration: 0.6s;

	box-shadow: 0.6vw 0.6vw 0 rgba(0, 0, 0, 0.2);
}

.game__intro:after {
	content: "";
	position: absolute;
		top: 0;
		left: 0;

	width: 100%;
	height: 0.8vw;

	background-color: var(--black);
}

.game__intro--window {
	position: relative;
	width: 100%;
}

.game__intro--challenge {
	position: relative;
	width: 100%;
}

.game__intro--challenge h2 {
	font-family: 'Editorial New';
	font-size: 2.2vw;
	line-height: 3vw;
	font-weight: normal;
	letter-spacing: -0.04em;

	text-align: center;
}

.game__intro--onboarding {
	position: relative;
	width: 100%;

	margin: 1.6vw 0;
	padding: 1.6vw 0;

	display: flex;

	border-top: 1px solid var(--black);
}

.game__intro--about {
	position: relative;
	width: calc(60% - 2.4vw);
	padding-right: 2.4vw;
}

.game__intro--instructions {
	position: relative;
	width: 40%;
}

.game__intro--about span, .game__intro--instructions span {
	font-size: 1vw;
	line-height: 1.2vw;
	text-transform: uppercase;
	letter-spacing: 0.1em;

	padding-bottom: 0.8vw;

	opacity: 0.8;

	display: block;
}

.game__intro--start {
	position: relative;
	width: 100%;

	text-align: center;
}

.game__intro--start:before {
	content: "";
	position: absolute;
		top: 50%;
		left: 0;

	width: 100%;
	height: 1px;

	background-color: var(--black);
	opacity: 0.4;
}

.game__status--run .game__intro {

	transform: translate(-50%, 150%) scale(0);

}

/* RESULTS */

.section__results {
	position: relative;
	width: 100%;

	margin-bottom: 3.2vw;
}

.section__results--margin {
	position: relative;
	width: calc(100% - 19.2vw);
	padding: 3.2vw 9.6vw;
}

.game__results {
	position: relative;
	width: 100%;

	padding-bottom: 56.25%;

	border-top-left-radius: 0.4vw;
	border-top-right-radius: 0.4vw;
}

.game__results--framework {
	position: absolute;
		top: 0;
		left: 0;

	width: 100%;
	height: 100%;

	overflow: hidden;
}

.game__status--show .game__intro {

	transform: translate(-50%, 150%) scale(0);

}

.panel__pitch {
	position: relative;
	width: calc(100%);

	padding-top: 3.2vw;
	padding-bottom: 6.4vw;

	text-align: center;

	border-bottom-left-radius: 0.4vw;
	border-bottom-right-radius: 0.4vw;
}

.panel__pitch h3 {
	font-family: 'Editorial New';
	font-size: 2.2vw;
	line-height: 3vw;
	font-weight: normal;
	letter-spacing: -0.04em;

	padding-bottom: 0.8vw;
	width: calc(100% - 12.8vw);
	margin: 0 6.4vw;
}

.panel__pitch--content {
	position: relative;
	width: 50%;
	margin: 0 auto;
}

.panel__contact {
	position: relative;
	width: calc(50% - 4.8vw);

	display: flex;

	padding: 1.6vw 2.4vw;

	border-top-left-radius: 0.4vw;
	border-top-right-radius: 0.4vw;

	margin: 0 auto;

	transform: translateY(-4vw);
}

.panel__contact--name {
	position: relative;
	width: 50%;

	font-family: 'Editorial New';
	font-size: 1.2vw;
	line-height: 2.4vw;
	font-weight: normal;
	letter-spacing: -0.04em;
}

.panel__contact--name span {
	font-family: 'freight-sans-pro';
	font-size: 1vw;
	line-height: 1.2vw;
	text-transform: uppercase;
	letter-spacing: 0.1em;

	display: block;
}

.panel__contact--type {
	position: relative;
	width: 50%;

	text-align: right;
}

/* NEWS WORLD */

.section__news {
	position: relative;
	width: 100%;
}

.section__news--margin {
	position: relative;
	width: calc(100% - 19.2vw);

	margin: 0 auto;

}

.world__news--header {
	position: relative;
	width: 100%;

	display: flex;

	padding-top: 1.6vw;
	padding-bottom: 1.2vw;
	margin-bottom: 1.6vw;

	border-bottom: 1px solid rgba(0, 0, 0, 0.4);
}

.world__news--name {
	font-family: 'Editorial New';
	font-size: 2.4vw;
	letter-spacing: -0.04em;

	width: 50%;
}

.world__news--name span {
	position: relative;
	font-size: 1.6vw;
	display: inline-block;

	transform: translateY(-0.6vw);
}

.world__news--name span:before {
	content: "";
	position: absolute;
		bottom: -0.2vw;
		left: 0;

	width: 100%;
	height: 1px;

	background-color: var(--black);
	opacity: 0.2;
}

.world__news--about {
	position: relative;
	text-align: right;

	width: 50%;

	font-size: 1vw;
	line-height: 1.2vw;

	text-transform: uppercase;
	letter-spacing: 0.1em;
}

.world__news--hero {
	position: relative;
	width: 100%;

	display: flex;

	padding-bottom: 2.4vw;
	margin-bottom: 2.4vw;

	border-bottom: 1px dashed rgba(0, 0, 0, 0.1);
}

.news__hero--title {
	width: calc(50% - 1.6vw);
}

.news__hero--title {
	position: relative;

	font-size: 1.8vw;
	line-height: 2.6vw;

	padding-top: 2.4vw;

	padding-right: 1.6vw;
}

.news__hero--snippet {
	position: relative;
	width: calc(80%);

	padding-top: 1.6vw;
	padding-bottom: 1.6vw;

	font-size: 1.4vw;
	line-height: 1.8vw;

	opacity: 0.8;
}

.interview--label {
	font-family: 'Editorial New Thin';
	font-size: 1.4vw;
	line-height: 2.4vw;
	letter-spacing: 0.05em;
}

.world__news--hero .button-large {
	margin-left: -0.2vw;
}

.news__hero--media {
	width: 50%;
}

.news__item--thumbnail {
	position: relative;
	width: 100%;
	padding-bottom: 80%;
}

.news__item--thumbnail img {
	position: absolute;
	width: 100%;
	height: 100%;

	object-fit: cover;
}


.world__news--articles {
	position: relative;
	width: 100%;

	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 2.4vw 2.4vw;
}

.news__item {
	position: relative;
	width: 100%;

	column-span: 1;
}

.news__item:nth-child(2):before, .news__item:nth-child(2):after {
	content: "";
	position: absolute;
		top: 0.8vw;

	width: 1px;
	height: calc(100% - 1.6vw);

	border-left: 1px dashed rgba(0, 0, 0, 0.1);
}

.news__item:nth-child(2):before {
	left: -1.2vw;
}

.news__item:nth-child(2):after {
	right: -1.2vw;
}

.news__item--title {
	position: relative;
	width: 100%;

	font-size: 1.4vw;
	padding-top: 0.8vw;
	padding-bottom: 0.8vw;
}

.section__news--footer {
	position: relative;
	width: 100%;

	display: block;

	margin-top: 3.2vw;
	padding: 1.6vw 0 1.2vw 0;
	margin-bottom: 1.6vw;

	border-top: 1px solid rgba(0, 0, 0, 0.4);
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);

	text-align: center;
}

.section__footer {
	position: relative;
	width: 100%;

	padding-top: 1.6vw;
	padding-bottom: 8vw;

	text-align: center;
}

.ESC-name-footer {
	font-family: 'Editorial New Heavy';
	font-size: 1.2vw;
	line-height: 2vw;

	letter-spacing: -0.04em;
}

/* WORLD FOOTER */

.section__explore_more {
	position: relative;
	width: 100%;

	padding-top: 6.4vw;
}

.section__explore_more--margin {
	position: relative;
	/*width: calc(100% - 19.2vw);*/
	/*width: calc(100% - 38.4vw);*/
	width: calc(100% - 32vw);

	margin: 0 auto;

}

.explore__more--headline {
	position: relative;
	width: 100%;

	font-family: 'Editorial New Bold';
	font-size: 4vw;
	line-height: 4.8vw;
	text-align: center;
	letter-spacing: -0.04em;

	padding-bottom: 7.2vw;
}

.explore__more {
	position: relative;
	width: 100%;

	display: flex;
}

.object--binocular {
	position: absolute;
		left: 3.2vw;
		bottom: 0;

	width: calc(100% - 6.4vw);

	display: flex;

	opacity: 0.4;
}

.object--binocular img {
	position: relative;
	width: 100%;
	height: auto;
}

/*.object--binocular div {
	position: relative;
	width: 50%;
	padding-bottom: 50%;

	border-radius: 50%;

	background-color: white;
}*/

.explore__more--worlds {
	position: relative;
	width: calc(50% - 3.2vw);

	padding: 6.4vw 0;
	padding-bottom: 12.8vw;
}

.explore__more--worlds span {
	padding-left: 3.2vw;

	font-family: 'Editorial New Thin';
	font-size: 1.4vw;
	line-height: 2.4vw;
	letter-spacing: 0.05em;
}

.explore__more--airballoon {
	position: relative;
	width: 50%;
}

.world__thumbnail {
	position: relative;
	width: 50%;

	margin: -7.2vw 0;
}

.world__thumbnail a {
	position: absolute;
		top: 50%;
		left: 50%;

	width: max-content;

	transform: translate(-50%, -50%);
	z-index: 2;
}

.world__thumbnail img {
	position: relative;
	width: 100%;
	transition-duration: 0.1s;
}

.world__thumbnail:hover img {
	transform: scale(1.1);
}

.world__thumbnail:nth-child(2) {
	margin-left: 50%;
}

.world__thumbnail:nth-child(4) {
	margin-left: 50%;
}

.explore__more--airballoon {
	position: relative;
	width: calc(50% - 3.2vw);

	padding-left: 3.2vw;
	padding-top: 15.8vw;
}

.world__hero--airballoon {
	position: absolute;
		top: 0;
		right: 0;
		width: 50vw;
		height: 100vh;

	overflow: hidden;
}

.object--hero-world-airballoon {
	position: absolute;
		right: -9.6vw;
		bottom: 20vw;

	width: 32vw;
	height: auto;

	animation-name: airballoon_floating;
	animation-duration: 14s;
	animation-iteration-count: infinite;
	animation-timing-function: ease-out;
}

.object--footer-world-airballoon {
	position: absolute;
		right: -5.6vw;
		top: -6.4vw;

	width: 22vw;
	height: auto;

	animation-name: airballoon_floating;
	animation-duration: 14s;
	animation-iteration-count: infinite;
	animation-timing-function: ease-out;
}

@keyframes airballoon_floating {
	0% { transform: translateY(-1.6vw) rotate(0deg); }
	50% { transform: translateY(0vw) rotate(0deg); }
	100% { transform: translateY(-1.6vw) rotate(0deg);  }
}

.logo-type-footer {

}

.logo-type-footer img {
	width: auto;
	height: 0.8vw;
}

#game__area, #results__area {
	position: absolute;
		bottom: 100%;
		left: 0;

	width: 100%;
	height: 100%;

	transition-duration: 0.2s;
}

.game__status--run #game__area, .game__status--show #results__area {
	bottom: 0%;
}



@media screen and (max-width: 768px){

	.world__hero--tagline span {
		font-size: 3.2vw;
		line-height: 6.4vw;
	}

	.world__hero--headline {
		width: calc(100% - 12.8vw);
	}

	.world__hero--headline h1 {
		padding: 6.4vw 0;
		font-size: 8vw;
		line-height: 9.6vw;
		padding-top: 3.2vw;
	}

	.world__hero--cta {
		padding-bottom: 6.4vw;
	}

	.world__hero--intro {
		padding-top: 3.2vw;
	}

	.game__field, .game__results {
		padding-bottom: 177.77%;
	}

	.game__intro {
		width: calc(100% - 6.4vw);
	}

	.game__field--grid {
		background-size: 12.8vw;
	}	

	.explore__more--headline {
		font-size: 8vw;
		line-height: 8.8vw;
		letter-spacing: -0.04em;
		padding-bottom: 8vw;
	}

	.object--binocular {
		position: relative;
		left: 0;
		bottom: 0;
		width: calc(100%);
		opacity: 0.4;
	}

	.explore__more--airballoon {
		position: absolute;
		width: 100%;
		padding-left: 6.4vw;
		padding-top: 14vw;
		text-align: left;
	}

	.object--footer-world-airballoon {
		position: absolute;
		right: -5.6vw;
		top: -12.8vw;
		width: 30vw;
	}

	.ESC-name-footer {
		font-size: 4vw;
		line-height: 4vw;
		letter-spacing: -0.04em;
		padding-top: 4.8vw;
	}

	.logo-type-footer img {
		width: auto;
		height: 2.4vw;
		padding-top: 3.2vw;
	}

	.explore__more--worlds {
		display: none;
	}

}
