@font-face {
	font-family: Gantari;
	src: url('../fonts/Gantari-Regular.ttf');
	src: url('../fonts/Gantari-Regular.ttf?') format('ttf'),
		url('../fonts/Gantari-Regular.woff') format('woff'),
		url('../fonts/Gantari-Regular.otf') format('otf'),
		url('../fonts/Gantari-Regular.svg') format('svg');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: Gantari;
	src: url('../fonts/Gantari-Bold.ttf');
	src: url('../fonts/Gantari-Bold.ttf?') format('ttf'),
		url('../fonts/Gantari-Bold.woff') format('woff'),
		url('../fonts/Gantari-Bold.otf') format('otf'),
		url('../fonts/Gantari-Bold.svg') format('svg');
	font-weight: 700;
	font-style: normal;
}


@font-face {
	font-family: Sancreek;
	src: url('../fonts/Sancreek-Regular.ttf');
	src: url('../fonts/Sancreek-Regular.ttf?') format('ttf'),
		url('../fonts/Sancreek-Regular.woff') format('woff'),
		url('../fonts/Sancreek-Regular.otf') format('otf'),
		url('../fonts/Sancreek-Regular.svg') format('svg');
	font-weight: 400;
	font-style: normal;
}

body {
	font-family: Gantari;
	font-weight: 400;
	font-size: 16px;
	font-style: normal;
	color: #ffffff;
}

.wrapper {
	position: relative;
	top: 0;
	left: 0;
	background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 1920px 1080px no-repeat,
		#2C2017;
	padding: 59px calc((100% - 1440px) / 2) 30px;
	overflow: hidden;
}

.wrapper .first-bottom-background {
	transform: rotate(180deg);
	position: absolute;
	background: transparent;
	z-index: 1;
}

.wrapper .second-bottom-background {
	position: absolute;
	background: transparent;
	z-index: 1;
	bottom: 0;
	width: 1920px;
	height: 875px;
	left: calc(50% - 960px);
	transform: rotate(180deg);
	background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 1920px 875px no-repeat;
}


.wrapper .wrapper-background {
	position: absolute;
	inset: 0;
	background: url(../images/romb-background.svg) center top / auto no-repeat;
	z-index: 1;
	mix-blend-mode: overlay;
}

.wrapper > header,
.wrapper > main,
.wrapper > footer,
.wrapper > .info {
	position: relative;
	top: 0;
	left: 0;
	z-index: 2;
}

.wrapper header {
	height: 102px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	top: 0;
	left: 0;
}

.wrapper header .left,
.wrapper header .right {
	display: flex;
	align-items: center;
	column-gap: 50px;
}

.wrapper header a {
	font-size: 18px;
	line-height: 22px;
	letter-spacing: -0.02em;
	color: #ffffff;
}

.wrapper header a.active {
	font-weight: 700;
	color: #FFC01C;
	position: relative;
	top: 0;
	left: 0;
}

.wrapper header a.active::after {
	content: url(../images/rock-market.svg);
	position: absolute;
	bottom: -30px;
	left: 50%;
	transform: translateX(-50%);
}

.wrapper header a.logo {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: -2px;
	height: 110px;
	width: 150px;
	background: url(../images/logo.svg) center / 100% no-repeat;
}


.wrapper main {
	padding: 140px 0 153px calc(50% + 29px);
	display: flex;
	flex-direction: column;
	row-gap: 120px;
}

.wrapper main .up {
	display: flex;
	flex-direction: column;
	row-gap: 40px;
	position: relative;
	top: 0;
	left: 0;
	z-index: 2;
}

.wrapper main .up h1 {
	max-width: 676px;
	font-family: Sancreek;
	font-size: 70px;
}

.wrapper main .up p {
	max-width: 690px;
	font-size: 24px;
	line-height: 29px;
}

.wrapper main .down {
	display: flex;
	flex-direction: column;
	row-gap: 50px;
	position: relative;
	top: 0;
	left: 0;
	z-index: 2;
}

.wrapper main .down p {
	font-size: 24px;
	line-height: 29px;
}

.wrapper main .down .buttons {
	display: flex;
	column-gap: 50px;
}

.wrapper main .down .buttons .google-play-button {
	width: 202px;
	height: 60px;
	background: url(../images/google-play-button.svg) center / 100% no-repeat;
}

.wrapper main .down .buttons .app-store-button {
	width: 202px;
	height: 60px;
	background: url(../images/appstore.svg) center / 100% no-repeat;
}

.wrapper main .phones {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.wrapper main .phones .portal {
	position: absolute;
	bottom: 62px;
	left: 104px;
	transform: scale(0.001);
	animation: portalVisible .5s ease .5s, portalPulse 2s ease-in-out 1s alternate infinite;
}

@keyframes portalVisible {
	from {
		transform: scale(0.001);
	}
	to {
		transform: none;
	}
}

@keyframes portalPulse {
	from {
		transform: none;
	}
	to {
		transform: scale(1.1);
	}
}

.wrapper main .phones .big-phone {
	position: absolute;
	background: url(../images/big-phone.svg) center top / auto no-repeat;
	left: 204px;
	bottom: 115px;
	height: 0;
	width: 290px;
	animation: bigPhoneVisible 1.5s cubic-bezier(0.18, 0.89, 0.32, 1.28) 1s forwards, bigPhoneFloat 2.5s ease-in-out 2.5s alternate infinite;
}

@keyframes bigPhoneVisible {
	from {
		height: 0;
	}
	to {
		height: 601px;
	}
}

@keyframes bigPhoneFloat {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(10px);
	}
}


.wrapper main .phones .left-phone {
	position: absolute;
	bottom: 158px;
	left: 76px;
	visibility: hidden;
	animation: leftPhoneVisible .5s ease 2.5s forwards, leftPhoneRotate 1.2s ease-in-out 3s alternate infinite;
}

@keyframes leftPhoneVisible {
	from {
		visibility: visible;
		opacity: 0;
		transform: translateX(150px) rotate(0);
	}
	to {
		visibility: visible;
		opacity: 1;
		transform: translateX(0) rotate(-12.42deg);
	}
}

@keyframes leftPhoneRotate {
	from {
		transform: rotate(-12.42deg) translate(0);
	}
	to {
		transform: rotate(-16.42deg) translate(10px, 10px);
	}
}


.wrapper main .phones .right-phone {
	position: absolute;
	bottom: 242px;
	left: 417px;
	visibility: hidden;
	animation: rightPhoneVisible .5s ease 2.5s forwards, rightPhoneRotate 1.6s ease-in-out 3s alternate infinite;
}

@keyframes rightPhoneVisible {
	from {
		visibility: visible;
		opacity: 0;
		transform: translateX(-150px) rotate(0);
	}
	to {
		visibility: visible;
		opacity: 1;
		transform: translateX(0) rotate(10.33deg);
	}
}

@keyframes rightPhoneRotate {
	from {
		transform: rotate(10.33deg) translate(0);
	}
	to {
		transform: rotate(14.33deg) translate(-10px, 10px);
	}
}


.wrapper .info {
	padding: 30px 0 10px;
	display: flex;
	flex-direction: column;
}

.wrapper .info h2 {
	font-family: Sancreek;
	font-size: 36px;
	line-height: 36px;
	margin-bottom: 30px;
}

.wrapper .info p {
	line-height: 19px;
}

.wrapper .info form {
	align-self: center;
	padding: 50px 0 80px;
	display: flex;
	flex-direction: column;
	row-gap: 40px;
	width: 500px;
}

.wrapper .info form .text-field {
	display: flex;
	flex-direction: column;
	row-gap: 10px;
	position: relative;
	top: 0;
	left: 0;
}

.wrapper .info form .text-field label {
	height: 16px;
	margin-left: 14px;
}

.wrapper .info form .text-field label span {
	font-weight: 700;
	font-size: 18px;
	line-height: 22px;
	color: #FF0080;
}

.wrapper .info form .text-field input,
.wrapper .info form .text-field textarea,
.wrapper .info form .captcha-field input {
	padding: 17px 15px;
	background-color: rgba(0, 0, 0, 0.56);
	font-size: 14px;
	line-height: 17px;
	color: #FFFFFF;
	border-radius: 10px;
	resize: none;
}

.wrapper .info form .text-field input::placeholder,
.wrapper .info form .text-field textarea::placeholder {
	font-size: 14px;
	line-height: 17px;
	color: #FFFFFF;
}

.wrapper .info form .text-field .resizeButton {
	position: absolute;
	bottom: -6px;
	right: -6px;
	width: 30px;
	height: 30px;
	padding: 10px;
	cursor: grab;
}

.wrapper .info form .text-field .resizeButton:active {
	cursor: grabbing;
}

.wrapper .info form .captcha-field {
	display: flex;
	column-gap: 30px;
	align-items: center;
}

.wrapper .info form .captcha-field .void {
	display: none;
	width: 20px;
}

.wrapper .info form button {
	width: 182px;
	height: 43px;
	position: relative;
	top: 0;
	left: 0;
	background-color: transparent;
}

.wrapper .info form button * {
	border-radius: 10px;
	width: 180px;
	height: 40px;
	position: absolute;
}

.wrapper .info form button .back {
	bottom: 0;
	right: 0;
	background: #F36325;
}

.wrapper .info form button .front {
	top: 0;
	left: 0;
	background: linear-gradient(0deg, #FF901D 0%, #FFB511 100%);
	font-weight: 700;
	font-size: 18px;
	line-height: 40px;
	color: #ffffff;
}

.wrapper .info .content {
	display: flex;
	flex-direction: column;
	row-gap: 30px;
	padding: 30px 0 45px;
}

.wrapper .info .content .block {
	display: flex;
	flex-direction: column;
	row-gap: 20px;
}

.wrapper .info .content .block ul {
	display: flex;
	flex-direction: column;
	row-gap: 0;
}

.wrapper .info .content .block ul li {
	font-size: 16px;
	line-height: 28px;
	letter-spacing: -0.02em;
}

.wrapper .info .content .block ul li::before {
	content: url(../images/li-marker.svg);
	margin: 0 10px 0 15px;
}

.wrapper .info .content h3 {
	height: 12px;
	font-weight: 700;
	font-size: 18px;
	line-height: 20px;
	letter-spacing: -0.02em;
}

.wrapper .info .content h4 {
	height: 11px;
	font-weight: 700;
	line-height: 20px;
}


.wrapper footer {
	height: 96px;
	display: flex;
	column-gap: 20px;
	align-items: center;
}

.wrapper footer p {
	font-size: 16px;
	line-height: 20px;
	letter-spacing: -0.02em;
}


@media (max-width: 1500px) {
	
	.wrapper {
		padding: 59px 30px 30px;
	}

	.wrapper main {
		padding: 140px 0 153px calc(50% - 1px);
	}

	.wrapper main .phones .portal {
		left: 91px;
	}

	.wrapper main .phones .big-phone {
		left: 191px;
	}

	.wrapper main .phones .left-phone {
		left: 63px;
	}

	.wrapper main .phones .right-phone {
		left: 404px;
	}
}

@media (max-width: 1440px) {

	.wrapper {
		background: radial-gradient(99.49% 86.44% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 1440px 1080px no-repeat,
			#2C2017;
	}

	.wrapper .second-bottom-background {
		width: 1440px;
		height: 682px;
		left: calc(50% - 720px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 1440px 682px no-repeat;
	}

}

@media (max-width: 1320px) {

	.wrapper main {
		padding: 140px 0 127px calc(50% + 13px);
		row-gap: 80px;
	}

	.wrapper main .up h1 {
		max-width: 557px;
		font-size: 60px;
		line-height: 70px;
	}

	.wrapper main .up p {
		max-width: 557px;
		font-size: 22px;
		line-height: 26px;
	}

	.wrapper main .down p {
		font-size: 22px;
		line-height: 26px;
	}


	.wrapper main .phones .portal {
		width: 350px;
		bottom: 171px;
		left: 115px;
	}

	.wrapper main .phones .big-phone {
		background: url(../images/big-phone.svg) center top / 209px 433px no-repeat;
		width: 209px;
		bottom: 209px;
		left: 182px;
	}
	
	@keyframes bigPhoneVisible {
		from {
			height: 0;
		}
		to {
			height: 433px;
		}
	}

	.wrapper main .phones .left-phone,
	.wrapper main .phones .right-phone {
		width: 145px;
	}

	.wrapper main .phones .left-phone {
		left: 90px;
		bottom: 241px;
	}

	.wrapper main .phones .right-phone {
		left: 336px;
		bottom: 302px;
	}

}

@media (max-width: 1200px) {
	
	.wrapper {
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 1200px 1007px no-repeat,
			#2C2017;
	}

	.wrapper .second-bottom-background {
		width: 1200px;
		height: 682px;
		left: calc(50% - 600px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 1200px 682px no-repeat;
	}

}

@media (max-width: 1140px) {

	.wrapper .wrapper-background {
		background: url(../images/tablet-romb-background.svg) center top / 1140px no-repeat;
	}
	
	.wrapper main {
		padding: 140px 0 156px calc(50% + 17px);
		row-gap: 130px;
	}

	.wrapper main .up {
		row-gap: 30px;
	}

	.wrapper main .up h1 {
		max-width: 465px;
		font-size: 50px;
		line-height: 50px;
	}

	.wrapper main .up p {
		max-width: 465px;
		font-size: 18px;
		line-height: 22px;
	}

	.wrapper main .down {
		row-gap: 19px;
	}

	.wrapper main .down p {
		font-size: 18px;
		line-height: 22px;
	}

	.wrapper main .down .buttons {
		column-gap: 30px;
	}

	.wrapper main .down .buttons .google-play-button {
		width: 140px;
		height: 42px;
	}

	.wrapper main .down .buttons .app-store-button {
		width: 140px;
		height: 42px;
	}

	.wrapper main .phones .portal {
		bottom: 136px;
		left: 45px;
	}

	.wrapper main .phones .big-phone {
		bottom: 174px;
		left: 112px;
	}

	.wrapper main .phones .left-phone {
		bottom: 206px;
		left: 20px;
	}

	.wrapper main .phones .right-phone {
		bottom: 267px;
		left: 266px;
	}


	.wrapper .info h2 {
		font-size: 32px;
		line-height: 36px;
	}

}

@media (max-width: 1024px) {

	.wrapper {
		background: radial-gradient(103.43% 86.44% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 1024px 962px no-repeat,
			#2C2017;
	}

	.wrapper .wrapper-background {
		background: url(../images/tablet-romb-background.svg) center top / auto no-repeat;
	}

	.wrapper .second-bottom-background {
		width: 1024px;
		height: 682px;
		left: calc(50% - 512px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 1024px 682px no-repeat;
	}

}

@media (max-width: 890px) {

	.wrapper {
		padding: 59px 20px 30px;
	}

	.wrapper header a.logo {
		width: 120px;
		height: 88px;
		top: 9px;
	}

	.wrapper main {
		padding: 473px 0 68px;
		align-items: center;
		row-gap: 70px;
		text-align: center;
	}

	.wrapper main .up {
		row-gap: 40px;
		align-items: center;
	}

	.wrapper main .up p {
		max-width: none;
	}

	.wrapper main .down {
		row-gap: 40px;
	}


	.wrapper main .phones .portal {
		width: 280px;
		left: calc(50% - 140px);
		bottom: auto;
		top: 363px;
	}

	.wrapper main .phones .big-phone {
		width: 167px;
		left: calc(50% - 84px);
		bottom: auto;
		top: 396px;
		background: url(../images/big-phone.svg) center top / 167px 346px no-repeat;
	}

	@keyframes bigPhoneVisible {
		from {
			top: 396px;
			height: 0;
		}
		to {
			top: 40px;
			height: 346px;
		}
	}

	.wrapper main .phones .left-phone {
		width: 116px;
		bottom: auto;
		top: 164px;
		left: calc(50% - 155px)
	}

	.wrapper main .phones .right-phone {
		width: 116px;
		bottom: auto;
		top: 115px;
		left: calc(50% + 41px)
	}

}

@media (max-width: 768px) {

	.wrapper {
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 768px 676px no-repeat,
			#2C2017;
	}

	.wrapper .first-bottom-background {
		bottom: -400px;
		width: 768px;
		height: 676px;
		left: calc(50% - 384px);
		transform: rotate(180deg);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center center / 768px 676px no-repeat;
	}

	.wrapper .second-bottom-background {
		width: 768px;
		height: 395px;
		left: calc(50% - 384px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 768px 395px no-repeat;
	}

}

@media (max-width: 710px) {

	.wrapper {
		padding: 40px 20px 30px;
	}

	.wrapper .wrapper-background {
		background: url(../images/tablet-romb-background.svg) center -20px / auto no-repeat;
	}

	.wrapper header {
		height: 200px;
		padding-top: 98px;
	}

	.wrapper header .left {
		width: 100%;
		justify-content: space-between;
	}

	.wrapper header .right {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		top: 98px;
		line-height: 102px;
		height: 102px;
	}
	
	.wrapper header a.logo {
        top: 0;
    }

	.wrapper main {
        padding: 443px 0 90px;
        row-gap: 90px;
    }

	.wrapper main .up h1 {
		font-size: 40px;
	}

	.wrapper main .phones .portal {
        top: 343px;
    }

	@keyframes bigPhoneVisible {
		from {
			top: 376px;
			height: 0;
		}
		to {
			top: 20px;
			height: 346px;
		}
	}

	.wrapper main .phones .left-phone {
        top: 144px;
    }

	.wrapper main .phones .right-phone {
        top: 95px;
    }


	.wrapper .info h2 {
		font-size: 28px;
		line-height: 36px;
	}


	.wrapper footer {
		row-gap: 40px;
		flex-direction: column;
		height: fit-content;
		text-align: center;
	}

}

@media (max-width: 540px) {

	.wrapper .info form {
		width: 100%;
	}

}

@media (max-width: 480px) {

	.wrapper {
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 480px 539px no-repeat,
			#2C2017;
	}

	.wrapper .first-bottom-background {
		bottom: -276px;
		width: 480px;
		height: 676px;
		left: calc(50% - 240px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center center / 480px 676px no-repeat;
	}

	.wrapper .wrapper-background {
		background: url(../images/mobile-romb-background.svg) center top / auto no-repeat;
	}

	.wrapper .second-bottom-background {
		width: 480px;
		height: 498px;
		left: calc(50% - 240px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 480px 498px no-repeat;
	}

}

@media (max-width: 450px) {

	.wrapper .info form .captcha-field {
		justify-content: center;
		flex-wrap: wrap;
		row-gap: 30px;
	}

	.wrapper .info form .captcha-field .void {
		display: block;
	}

	.wrapper .info form .captcha-field input {
		width: 100%;
	}

	.wrapper .info form button {
		align-self: center;
	}

}

@media (max-width: 390px) {

	.wrapper {
		padding: 40px 10px 30px;
	}
	
	.wrapper header {
		height: 223px;
		padding-top: 121px;
	}

	.wrapper header .right {
		top: 121px;
	}

	.wrapper header .right {
        transform: translateX(calc(-50% - 8px));
    }


	.wrapper main .up {
		row-gap: 30px;
	}

	.wrapper main .up h1 {
		font-size: 30px;
		line-height: 35px;
    }

	.wrapper main .up p {
		font-size: 14px;
		line-height: 17px;
	}

	.wrapper main .down {
		width: 100%;
	}

	.wrapper main .down p {
		font-size: 14px;
		line-height: 17px;
	}

	.wrapper main .down .buttons {
		width: 100%;
		justify-content: space-between;
		column-gap: 0;
	}

}

@media (max-width: 320px) {

	.wrapper {
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center top / 480px 511px no-repeat,
			#2C2017;
	}

	.wrapper .first-bottom-background {
		bottom: -349px;
		width: 320px;
		height: 676px;
		left: calc(50% - 160px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, #002F21 0%, #045B42 40.38%, #2C2017 100%) center center / 320px 676px no-repeat;
	}

	.wrapper .second-bottom-background {
		width: 320px;
		height: 498px;
		left: calc(50% - 160px);
		background: radial-gradient(103.43% 89.86% at 50% 10.14%, rgba(0, 83, 59, 0.5) 0%, rgba(0, 72, 51, 0.5) 40.38%, rgba(44, 32, 23, 0.5) 100%) center center / 320px 498px no-repeat;
	}

}