@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Black.eot');
    src: url('GraphikCompactLC-Black.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Light.eot');
    src: url('GraphikCompactLC-Light.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Regular.eot');
    src: url('GraphikCompactLC-Regular.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Bold.eot');
    src: url('GraphikCompactLC-Bold.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Medium.eot');
    src: url('GraphikCompactLC-Medium.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Extralight.eot');
    src: url('GraphikCompactLC-Extralight.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Extralight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Super.eot');
    src: url('GraphikCompactLC-Super.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Super.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Thin.eot');
    src: url('GraphikCompactLC-Thin.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik Compact LC';
    src: url('GraphikCompactLC-Semibold.eot');
    src: url('GraphikCompactLC-Semibold.eot?#iefix') format('embedded-opentype'),
        url('GraphikCompactLC-Semibold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Bold.eot');
    src: url('GraphikLC-Bold.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Black.eot');
    src: url('GraphikLC-Black.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Light.eot');
    src: url('GraphikLC-Light.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Extralight.eot');
    src: url('GraphikLC-Extralight.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Extralight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Regular.eot');
    src: url('GraphikLC-Regular.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Semibold.eot');
    src: url('GraphikLC-Semibold.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Semibold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Medium.eot');
    src: url('GraphikLC-Medium.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC Super';
    src: url('GraphikLC-Super.eot');
    src: url('GraphikLC-Super.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Super.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Graphik LC';
    src: url('GraphikLC-Thin.eot');
    src: url('GraphikLC-Thin.eot?#iefix') format('embedded-opentype'),
        url('GraphikLC-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

:root {
    --cursor-left: 50%;
    --cursor-top: 50%;

    --scroll: 0px;
    --sticky-fixed: 0vh;
    --sticky-fixed-start: 0;
    --sticky-fixed-end: 0;

    --progress: 0;
    --animated-type: screen;
    --animated-class: none;
    --animated-start: 0;
    --animated-end: 0;

    --shadow-20: 0 0 2.195vh 0 #2626261A;

    --scrollBy: 0;
}

#map {
    --scrollBy: 55;
}

#journey {
    --scrollBy: 214;
}

#hiway {
    --scrollBy: 395;
}

#myway {
    --scrollBy: 434;
}

#other {
    --scrollBy: 750;
}

#presence {
    --scrollBy: 750;
}

#dialogue {
    --scrollBy: 845;
}

#crowd {
    --scrollBy: 945;
}


* {
    -webkit-tap-highlight-color: transparent;
    outline: none;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    user-select: none;
}

html {
    height: 100vh;
}

body {
    font-family: 'Graphik LC', sans-serif;
    font-size: 1.944vh;
    background: #f6f5f4;
    color: #000;
    font-weight: 400;
    line-height: 140%;
    letter-spacing: -0.039vh;
}

.measure {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1;
    visibility: hidden;
}

/* preloader */

.preloader {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
    opacity: 0;
    animation: preloader-show 0.4s 0.4s 1 ease-in forwards;
}

.preloader svg {
    height: 4vh;
}

.preloader path {
    animation: preloader-fade 1.5s infinite ease-in-out;
}

.preloader path:nth-child(1) {
    animation-delay: 0.1s;
}

.preloader path:nth-child(2) {
    animation-delay: 0.2s;
}

.preloader path:nth-child(3) {
    animation-delay: 0.3s;
}

.preloader path:nth-child(4) {
    animation-delay: 0.4s;
}

.preloader path:nth-child(5) {
    animation-delay: 0.5s;
}

@keyframes preloader-show {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes preloader-fade {

    0%,
    100% {
        opacity: 0.2;
    }

    50% {
        opacity: 1;
    }
}

/* preloader */

/* button */
@property --btn-bg-pos-1 {
    syntax: '<integer>';
    initial-value: 0;
    inherits: false;
}

@property --btn-bg-pos-2 {
    syntax: '<integer>';
    initial-value: 0;
    inherits: false;
}

button {
    background-color: #fff;
    border: none;
    box-shadow: var(--shadow-20);
    border-radius: 5vh;
    cursor: pointer;
    height: 5.556vh;
    padding: 0.903vh 0;
    position: relative;
    pointer-events: all;

    --btn-bg-pos-1: 0;
    --btn-bg-pos-2: 0;
    --btn-bg-color: #cbcbcb;
    background-image: radial-gradient(circle at var(--cursor-left) var(--cursor-top),
            transparent calc(1% * var(--btn-bg-pos-1)),
            var(--btn-bg-color) calc(1% * var(--btn-bg-pos-1)),
            var(--btn-bg-color) calc(1% * var(--btn-bg-pos-2)),
            transparent calc(1% * var(--btn-bg-pos-2))) !important;
}

button.dark-theme {
    background: #262626;
}

button.anim {
    animation: btn-bg-amin 1.2s cubic-bezier(0.22, 0.61, 0.36, 1) 1;
}

@keyframes btn-bg-amin {
    0% {
        --btn-bg-pos-2: 0;
    }

    15% {
        --btn-bg-pos-1: 0;
    }

    70% {
        --btn-bg-pos-2: 100;
    }

    100% {
        --btn-bg-pos-1: 100;
    }
}

button img {
    display: block;
    height: 100%;
    margin: 0 3.056vh;
}

button span {
    display: block;
    margin: 0 3.056vh;
    text-align: center;
    min-width: 5vh;
}

button.menu {
    aspect-ratio: 1;
}

button.menu i {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 50%;
    height: 1px;
    background: #9298A0;
    transform: translate(-50%, 0) rotate(0deg);
    transition-duration: 0.8s;
    transition-property: transform;
}

.open-menu button.menu i {
    transform: translate(-50%, 0) rotate(135deg);
}

button.menu i:before,
button.menu i:after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: #9298A0;
    position: absolute;
    top: 0.694vh;
    transition-duration: 0.8s;
    transition-property: transform;
    transform: rotate(0deg);
}

button.menu i:after {
    top: -0.694vh;
}

.open-menu button.menu i:before {
    transform: translateY(-0.694vh) rotate(180deg);
}

.open-menu button.menu i:after {
    transform: translateY(0.694vh) rotate(90deg);
}

button * {
    pointer-events: none;
}

/* button */

/* main */

main {
    position: fixed;
    width: 100%;
    overflow: hidden;
    transform: translateY(var(--scroll));
}

.page main {
    padding-top: 20vh;
}

/* main */

/* phone */

.phone {
    position: absolute;
    z-index: 500;
    left: 0vh;
    top: 0vh;
    width: 100%;
    height: 400vh;
    display: flex;
    justify-content: center;
    pointer-events: none;
}

.phone.start-transition {
    transform: translateY(25vh);
}

.loaded .phone.start-transition {
    transform: translateY(0vh);
    transition-duration: 0.8s;
    transition-delay: 0.4s;
    transition-property: transform;
}

.open-slider .phone {
    opacity: 0;
}

.phone .container {
    --sticky-fixed-start: 60;
    --sticky-fixed-end: 650;
    position: absolute;
    top: 110vh;
    height: 64.444vh;
    transform: translateY(-50%);
}

.phone .container.sticky-fixed {
    position: fixed;
    top: 50vh;
    transform: translateY(calc(-50% + var(--scroll) * -1));
}

.phone .container.sticky-end {
    top: 700vh;
}

.phone .container>img {
    position: relative;
    display: block;
    /* width: 100%; */
    height: 100%;
    z-index: 2;
}

/* phone */

/* screen */

section.screen {
    --animated-type: scroll;
    --animated-start: 100;
    --animated-end: 200;


    position: absolute;
    z-index: 300;
    top: 0;
    left: 50%;
    width: 28vh;
    height: calc(100vh - 20vh * var(--progress));
    transform: translateX(-50%) translateY(calc(var(--scroll) * -1));
    clip-path: var(--clipPath);
    overflow: hidden;
    background: #f6f5f4;
}

.open-slider section.screen {
    --clipPath: circle(0);
}

section.screen .phone-widget {
    --sticky-fixed-start: 60;
    --sticky-fixed-end: 650;
    position: absolute;
    top: 110vh;
    left: 0;
    z-index: 100;
    height: 59.8vh;
    width: 100%;
    transform: translateY(-50%);
    pointer-events: none;
}

section.screen .phone-widget.widget-top {
    z-index: 20;
}

section.screen .phone-widget.sticky-fixed {
    position: absolute;
    top: 50vh;
    transform: translateY(calc(-50% + var(--scroll) * -1));
}

section.screen .phone-widget.sticky-end {
    top: 700vh;
}

section.screen .phone-widget img {
    position: absolute;
    width: 100%;
}

section.screen .phone-widget .time {
    position: absolute;
    z-index: 15;
    top: 1vh;
    left: 5.1vh;
    font-size: 1.3vh;
    font-weight: 500;
    letter-spacing: 0.03vh;
    text-align: center;
    transform: translateX(-50%);
}

section.screen .status-bar {
    z-index: 10;
}

section.screen .light-top,
section.screen .dark-top,
section.screen .light-top-bg {
    top: 0;
    pointer-events: all;
}

/* 
section.screen .light-top-bg {
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(calc(14vh + var(--scroll) * -1));
    z-index: 20;
    width: 100%;
} */

section.screen .light-top {
    --animated-type: scroll;
    --animated-start: 225;
    --animated-end: 235;

    transform: translateY(calc(-100% * var(--progress)));
    opacity: calc(1 - 1 * var(--progress));
}

section.screen .dark-top {
    --animated-type: scroll;
    --animated-start: 559;
    --animated-end: 600;

    opacity: calc(1 * var(--progress));
    transform: translateY(calc(-100% + 100% * var(--progress)));
}

section.screen .light-bottom-main,
section.screen .light-bottom-map,
section.screen .light-bottom-road,
section.screen .dark-bottom {
    pointer-events: all;
    bottom: 0;
}

section.screen .light-bottom-map {
    --animated-type: scroll;
    --animated-start: 200;
    --animated-end: 215;

    opacity: calc(1 - 1 * var(--progress));
}

section.screen .light-bottom-road {
    --animated-type: scroll;
    --animated-start: 200;
    --animated-end: 215;

    opacity: calc(1 * var(--progress));
}

section.screen .dark-bottom {
    --animated-type: scroll;
    --animated-start: 559;
    --animated-end: 600;

    opacity: calc(1 * var(--progress));
}

section.screen>.container {
    --animated-type: screen;
    height: 1000vh;
    overflow: hidden;
}

section.screen .app {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

section.screen .map {
    --animated-type: scroll;
    --animated-class: 232 fixed;

    top: 90vh;
}

section.screen .map.fixed {
    transform: translateY(calc(-232vh - var(--scroll)));
}

section.screen .dark {
    top: 280vh;
    height: 250vh;
}

section.screen .dark .map {
    --animated-class: 559 fixed, 650 stop;
    top: 0;
}

section.screen .dark .map.fixed {
    transform: translateY(calc(-559vh - var(--scroll)));
}

section.screen .dark .map.stop {
    transform: translateY(91vh);
}

section.screen .dark .phone-widget {
    --sticky-fixed-start: 400;
    --sticky-fixed-end: 650;
    top: 0vh;
}

section.screen .dark .phone-widget.sticky-fixed {
    position: absolute;
    top: -430vh;
    transform: translateY(calc(-50% + var(--scroll) * -1));
}

section.screen .dark .phone-widget.sticky-end {
    top: 220vh
}

/* screen */

/* App */
.app .pins {
    position: absolute;
    top: 99vh;
    height: 38.194vh;
    width: 100%;
    z-index: 15;
}

.app .pins img {
    display: block;
    height: 100%;
    margin: 0 auto;
}

.app .user-on-map {
    --animated-class: 40 show;
    --animated-start: 80;
    --animated-end: 40;

    position: absolute;
    top: 148vh;
    height: 31.250vh;
    left: 50%;
    transform: translateX(-50%);
    z-index: 15;
}

.app .user-on-map.show {
    --animated-class: 80 show;
}

.app .user-on-map img:not(.bg) {
    position: absolute;
}

.app .user-on-map img.bg {
    display: block;
    height: 100%;
    margin: 0 auto;
}

.app .user-on-map img.name {
    top: 18.879vh;
    left: 0;
    width: 100%;
    opacity: 0;
    transform: translateY(2vh);
}

.app .user-on-map.show img.name {
    transition-duration: 0.4s;
    transition-property: opacity, transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    opacity: 1;
    transform: translateY(0vh);
}

.app .user-on-map img.main {
    height: 13.093vh;
    top: 4.607vh;
    left: 6.432vh;
    z-index: 3;
    box-shadow: 0 0 0 0.3vh #fff;
    border-radius: 100%;
    transform: scale(0);
}

.app .user-on-map.show img.main {
    transition-duration: 0.7s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: scale(1);
}

.app .user-on-map img.circle {
    height: 13.703vh;
    top: 4.303vh;
    left: 6.128vh;
    z-index: 4;
    transform: scale(0);
}

.app .user-on-map.show img.circle {
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .user-on-map img.badge {
    height: 1.218vh;
    top: 10.544vh;
    left: 12.369vh;
    z-index: 5;
    transform: scale(0) rotate(-35deg) translateX(-6.8vh);
}

.app .user-on-map.show img.badge {
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1) rotate(-130deg) translateX(-6.8vh);
}

.app .user-on-map img.p1 {
    height: 6.242vh;
    top: 4.456vh;
    left: 2.703vh;
    z-index: 1;
    transform: scale(0);
}

.app .user-on-map.show img.p1 {
    transition-delay: 0.6s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .user-on-map img.p2 {
    height: 7.156vh;
    top: 5.140vh;
    right: 1.408vh;
    z-index: 1;
    transform: scale(0);
}

.app .user-on-map.show img.p2 {
    transition-delay: 0.65s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .user-on-map img.p3 {
    height: 6.851vh;
    top: 9.175vh;
    left: 1.181vh;
    z-index: 2;
    transform: scale(0);
}

.app .user-on-map.show img.p3 {
    transition-delay: 0.7s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .user-on-map img.p4 {
    height: 6.242vh;
    top: 9.860vh;
    right: 1.181vh;
    z-index: 2;
    transform: scale(0);
}

.app .user-on-map.show img.p4 {
    transition-delay: 0.75s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .user-on-map img.counter {
    height: 4.583vh;
    top: 3.877vh;
    right: 0.604vh;
    z-index: 2;
    transform: scale(0);
}

.app .user-on-map.show img.counter {
    transition-delay: 0.8s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0, 0, 0.27, 1.55);
    transform: scale(1);
}

.app .post {
    --animated-class: 40 show;
    --animated-start: 80;
    --animated-end: 40;

    position: absolute;
    top: 196vh;
    left: 50%;
    transform: translateX(-50%);
    height: 34.167vh;
    z-index: 15;
}

.app .post.show {
    --animated-class: 80 show;
}

.app .post img.bg {
    display: block;
    height: 100%;
    margin: 0 auto;
}

.app .post img.image {
    position: absolute;
    height: 20.556vh;
    top: 1.522vh;
    left: 1.250vh;
    /* transform: translateY(1vh); */
}

.app .post.show img.image {
    transition-delay: 0.2s;
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: translateY(0vh);
}

.app .post .button {
    position: absolute;
    bottom: 1.4vh;
    right: 7.0415vh;
    height: 2.740vh;
    width: 11.647vh;
    background: #C6EF10;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 400;
    font-size: 1.065vh;
    line-height: 1.371vh;
    letter-spacing: 0.021vh;
    border-radius: 2.436vh;
    white-space: nowrap;
    transform: translateX(50%) scaleX(0);
}

.app .post.show .button {
    transition-delay: 0.3s;
    transition-duration: 0.4s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: translateX(50%) scaleX(1);
}

.app .post .button span {
    position: absolute;
    top: 0.65vh;
    opacity: 0;
    transform: translateY(1vh);
}

.app .post.show .button span {
    transition-delay: 0.7s;
    transition-duration: 0.8s;
    transition-property: transform, opacity;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: translateY(0vh);
    opacity: 1;
}

.app .journey {
    --animated-class: 30 fixed;
    --animated-start: 50;
    --animated-end: 30;

    position: absolute;
    top: 262.3vh;
    width: 100%;

    z-index: 25;
}

.app .journey .container {
    transform: translateY(calc(2vh * var(--progress)));
}

.app .journey.fixed .container {
    transform: translateY(calc(-230vh - var(--scroll)))
}

.app .journey .container div {
    overflow: hidden;
}

.app .journey .container>img:first-child {
    margin-top: calc(-7vh * var(--progress));
}

.app .journey .container div img {
    margin-top: calc(-14vh * var(--progress));
}

.app .journey img {
    display: block;
    width: 100%;
    margin-bottom: -1px;
}

.app .notes {
    --animated-type: scroll;
    --animated-class: 460 show 500;
    position: relative;
    top: 11vh;
    z-index: 15;
}

.app .notes.show {
    --animated-class: 410 show 500;
}

.app .notes img {
    display: block;
    height: 34.792vh;
    margin: 0 auto;
}

.app .notes svg {
    position: absolute;
    height: 6vh;
    top: 11.5vh;
    left: 4.5vh;
}

.app .notes svg path {
    stroke-dashoffset: 100;
    opacity: 0;
}

.app .notes.show svg path {
    transition-property: stroke-dashoffset;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition-duration: 0.8s;
    stroke-dashoffset: 0;
    opacity: 1;
}

.app .chat {
    --animated-type: scroll;
    --animated-start: 450;
    --animated-end: 480;

    position: relative;
    top: 12.472vh;
    transform: translateY(calc(20vh - 20vh * var(--progress)));

    z-index: 15;
}

.app .chat img {
    display: block;
    height: 32.222vh;
    margin: 0 auto;
}

.app .sheet {
    --animated-type: scroll;
    --animated-class: 559 fixed, 650 stop;
    --animated-start: 559;
    --animated-end: 600;

    position: relative;
    top: 53vh;
    z-index: 15;
}

.app .sheet.fixed {
    transform: translateY(calc(-565vh - var(--scroll) - 6vh * var(--progress)));
}

.app .sheet.fixed.stop {
    transform: translateY(80vh);
}

.app .sheet img {
    display: block;
    height: 50.139vh;
    margin: 0 auto;
}

/* App */

/* header */

header {
    position: fixed;
    top: 0;
    width: 100%;
    height: 8vh;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    z-index: 900;
    pointer-events: none;
}

header.start-transition {
    opacity: 0;
    transform: translateY(-100%);
}

.loaded header.start-transition {
    transition-duration: .8s;
    transition-property: transform, opacity;
    transform: translateY(0);
    opacity: 1;
}

header .container {
    display: flex;
    width: 113.611vh;
    height: 5.556vh;
    justify-content: space-between;
    align-items: center;
    margin-top: 3.056vh;
}

header .container .logo {
    position: relative;
    pointer-events: all;
}

body:not(.page) header .container .logo {
    --animated-type: scroll;
    --animated-class: 480 revers;
    --animated-start: 472.7;
    --animated-end: 475.7;
}

body:not(.page) header .container .logo.revers {
    --animated-start: 742.5;
    --animated-end: 745.5;
}

header .container .logo img {
    display: block;
    height: 2.972vh;
}

header .container .logo img:nth-child(1) {
    clip-path: rect(0% 100% calc(100% - 100% * var(--progress)) 0%);
}

header .container .logo img:nth-child(2) {
    position: absolute;
    top: 0;
    left: 0;
    clip-path: rect(calc(100% - 100% * var(--progress)) 100% 100% 0%);
}

header .container .logo.revers img:nth-child(1) {
    clip-path: rect(calc(100% - 100% * var(--progress)) 100% 100% 0%);
}

header .container .logo.revers img:nth-child(2) {
    clip-path: rect(0% 100% calc(100% - 100% * var(--progress)) 0%);
}

header .buttons {
    display: flex;
    align-items: center;
    grid-gap: 1.389vh;
}

header .buttons button:not(.menu) {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 19.167vh;
}

header .buttons button:nth-child(2) {
    width: 20.833vh;
}

header .buttons button img {
    height: 3.160vh;
    margin: 0;
}

/* header */

/* Верхний блок */

.top {
    --animated-type: scroll;
    --animated-start: 20;
    --animated-end: 40;

    height: 90vh;
    display: flex;
    flex-direction: column;
    justify-content: center;

    filter: blur(calc(4px * var(--progress)));
}

.page .top {
    height: 45vh;
}

.top .icon {
    display: block;
    height: 8.750vh;
    margin: 0 auto;
    margin-bottom: 3.140vh;
}

.top .text {
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 10.833vh;
    line-height: 80%;
    text-align: center;
    margin-bottom: 4.542vh;
    letter-spacing: -0.325vh;
}

.top .text span{
    display: inline-block;
}

.top .images {
    position: relative;
    width: min-content;
    margin: 0 auto;
    margin-bottom: 2.271vh;
}

.top .images img,
.top .images svg {
    position: relative;
    display: block;
    height: 18.686vh;
}

.top .images img:not(:nth-child(1)),
.top .images svg:not(:nth-child(1)) {
    position: absolute;
    top: 0;
    left: 0;
}

.top p {
    font-weight: 400;
    font-size: 2.778vh;
    line-height: 95%;
    text-align: center;
    margin-bottom: 3.333vh;
    letter-spacing: -0.056vh;
}

.top .qr {
    height: 15.139vh;
}

.top.start-transition .text span,
.top.start-transition .images img {
    opacity: 0;
    transform: translateY(5vh);
    transition-duration: 0.8s;
    transition-property: transform, opacity;
}

.top.start-transition .text span:nth-child(1),
.top.start-transition .images img:nth-child(1) {
    transition-delay: 0.2s;
}

.top.start-transition .text span:nth-child(2),
.top.start-transition .images img:nth-child(2) {
    transition-delay: 0.3s;
}

.top.start-transition .text span:nth-child(3),
.top.start-transition .images img:nth-child(3) {
    transition-delay: 0.6s;
}

.top.start-transition p {
    opacity: 0;
    transition-duration: 0.8s;
    transition-property: opacity;
    transition-delay: 0.7s;
}

.top.start-transition .qr {
    opacity: 0;
    transition-duration: 0.8s;
    transition-property: opacity;
    transition-delay: 0.8s;
}

.loaded .top.start-transition .text span,
.loaded .top.start-transition .images img {
    transform: translateY(0vh);
    opacity: 1;
}

.loaded .top.start-transition p,
.loaded .top.start-transition .qr {
    opacity: 1;
}

/* Верхний блок */

/* Карта */

.map {
    position: relative;
    z-index: 10;
    height: 200vh;
}

.map.start-transition {
    transform: translateY(20vh);
}

.loaded .map.start-transition {
    transition-duration: 1s;
    transition-property: transform;
    transform: translateY(0vh);
}

.map>img,
.map .border>img {
    display: block;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    height: 172.361vh;
    top: 0;
}

/* Карта */

/* Попап */

.popup {
    background: #fff;
    position: absolute;
    top: 0vh;
    box-shadow: var(--shadow-20);
    border-radius: 4.444vh;
    padding: 4.167vh;
    max-width: calc(50vw - var(--screen-width) / 2 - 20vh / 2);
}

.popup.right {
    left: 50%;
    transform: translateX(20vh);
}

.popup.left {
    right: 50%;
    transform: translateX(-20vh);
}

.popup.center {
    left: 50%;
    transform: translateX(-50%);
}

.popup .title {
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 6.667vh;
    line-height: 80%;
    letter-spacing: -0.200vh;
    margin-bottom: 2.222vh;
    opacity: 0;
    transform: translateY(4.167vh);
}

.popup.show .title {
    transition-duration: 0.8s;
    transition-property: opacity, transform;
    opacity: 1;
    transform: translateY(0vh);
}

.popup .text {
    overflow: hidden;
    opacity: 0;
    transform: translateY(4.167vh);
}

.popup.show .text {
    transition-duration: 0.8s;
    transition-delay: 0.2s;
    transition-property: opacity, transform;
    opacity: 1;
    transform: translateY(0vh);
}

.popup.pins {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    top: 20.972vh;
    opacity: calc(1 * var(--progress));

    transform: translateX(50%) translateY(calc(10vh - 10vh * var(--progress)));

    width: 49.861vh;
}

.popup.pins.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    transform: translateX(50%);
    opacity: calc(1 * var(--progress));
}

.popup.pins.blur {
    --animated-start: 20;
    --animated-end: 0;
    filter: blur(calc(4px * var(--progress)));
    top: 20.972vh;
    opacity: 1;
}

.popup.pins.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #fff;
    z-index: 1000;
    pointer-events: none;
}

.popup.pins .title {
    padding-right: 17vh;
}

.popup.pins .images {
    position: absolute;
    display: flex;
    top: 4.167vh;
    right: 0;
    padding-right: 2.778vh;
    padding-left: 2.731vh;
    overflow: hidden;
}

.popup.pins .images img {
    display: block;
    height: 5.462vh;
    aspect-ratio: 1;
    margin-left: -2.731vh;
    opacity: 0;
    transform: translateX(7vh);
}

.popup.pins.show .images img {
    transition-duration: 0.4s;
    transition-property: opacity, transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    opacity: 1;
    transform: translateX(0vh);
}

.popup.pins.show .images img:nth-child(1) {
    transition-delay: 0.4s;
}

.popup.pins.show .images img:nth-child(2) {
    transition-delay: 0.5s;
}

.popup.pins.show .images img:nth-child(3) {
    transition-delay: 0.6s;
}

.popup.pins.show .images img:nth-child(4) {
    transition-delay: 0.7s;
}

.popup.pins.show .images img:nth-child(5) {
    transition-delay: 0.8s;
}

.popup.user-on-map {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    top: 68.194vh;
    opacity: calc(1 * var(--progress));
    transform: translateX(-50%) translateY(calc(10vh - 10vh * var(--progress)));

    width: 47.778vh;
}

.popup.user-on-map.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    transform: translateX(-50%);
    opacity: calc(1 * var(--progress));
}

.popup.user-on-map.blur {
    --animated-start: 20;
    --animated-end: 0;
    filter: blur(calc(4px * var(--progress)));
    opacity: 1;
}

.popup.user-on-map.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #fff;
    z-index: 1000;
    pointer-events: none;
}

.popup.user-on-map {
    padding-left: 13.889vh;
}

.popup.user-on-map.show .text {
    transition-delay: 0s;
}

.popup.user-on-map .userpic {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: absolute;
    top: 1.944vh;
    left: 3.611vh;
    opacity: 0;
    transform: translateY(1.5vh);
}

.popup.user-on-map.show .userpic {
    transition-duration: 0.4s;
    transition-delay: 0.4s;
    transition-property: opacity, transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    opacity: 1;
    transform: translateY(0vh);
}

.popup.user-on-map .userpic img {
    margin-bottom: -0.5vh;
    width: 6.667vh;
}

.popup.user-on-map .userpic span {
    position: relative;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 400;
    font-size: 1.667vh;
    line-height: 2.222vh;
    letter-spacing: 0;
    box-shadow: var(--shadow-20);
    padding: 0.556vh 0.833vh;
    border-radius: 3.333vh;
    opacity: 0;
    top: 0vh;
    transform: translateY(1.5vh);
}

.popup.user-on-map.show .userpic span {
    transition-duration: 0.4s;
    transition-delay: 0.45s;
    transition-property: opacity, transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    opacity: 1;
    transform: translateY(0vh);

}

.popup.post {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    padding: 2.500vh 5.694vh;
    padding-left: 13.889vh;

    top: 113.056vh;
    opacity: calc(1 * var(--progress));
    transform: translateX(50%) translateY(calc(10vh - 10vh * var(--progress)));

    width: 47.778vh;
}

.popup.post.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    transform: translateX(50%);
    opacity: calc(1 * var(--progress));
}

.popup.post.blur {
    --animated-start: 20;
    --animated-end: 0;

    filter: blur(calc(4px * var(--progress)));
    opacity: 1;
}

.popup.post.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #fff;
    z-index: 1000;
    pointer-events: none;
}

.popup.post .text {
    top: 2.500vh;
}

.popup.post.show .text {
    transition-delay: 0s;
    top: 0vh;
}

.popup.post .images {
    position: absolute;
    top: 2.083vh;
    left: 3.333vh;
}

.popup.post .images img {
    display: block;
    position: absolute;
    height: 6.528vh;
    transform: scale(0);
}

.popup.post.show .images img {
    transition-duration: 0.4s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform: scale(1);
}

.popup.post .images img:nth-child(1) {
    position: relative;
    height: 2.500vh;
    z-index: 3;
}

.popup.post.show .images img:nth-child(1) {
    transition-delay: 0.4s;
}

.popup.post .images img:nth-child(2) {
    top: 0.972vh;
    left: 1.457vh;
    z-index: 2;
}

.popup.post.show .images img:nth-child(2) {
    transition-delay: 0.2s;
}

.popup.post .images img:nth-child(3) {
    top: 4.217vh;
    left: -0.556vh;
    z-index: 1;
}

.popup.journey {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    top: 178.888vh;
    transform: translateX(-50%) translateY(calc(10vh - 10vh * var(--progress)));
    opacity: calc(1 * var(--progress));

    width: 49.861vh;
}

.popup.journey.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    transform: translateX(-50%);
    opacity: calc(1 * var(--progress));
}

.popup.journey.blur {
    --animated-start: 20;
    --animated-end: 0;

    filter: blur(calc(4px * var(--progress)));
    opacity: 1;
}

.popup.journey.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #fff;
    z-index: 1000;
    pointer-events: none;
}

.popup.journey .emoji {
    position: absolute;
    transform: translateY(0vh);
    top: 0;
    right: 2.287vh;
}

.popup.journey.show .emoji img {
    transition-timing-function: cubic-bezier(0, 1.25, 0.71, 1.45);
    transition-duration: 0.8s;
    transition-property: transform, opacity;
}

.popup.journey .emoji img:nth-child(1) {
    display: block;
    position: relative;
    height: 8.194vh;
    transform: translateY(-50%) translateY(3vh);
    opacity: 0;
}

.popup.journey.show .emoji img:nth-child(1) {
    transition-delay: 0.2s;

    opacity: 1;
    transform: translateY(-50%) translateY(0vh);
}

.popup.journey .emoji img:nth-child(2) {
    position: absolute;
    height: 6.444vh;
    transform: translateY(3vh);
    left: 8.3vh;
    top: 0;
    opacity: 0;
}

.popup.journey.show .emoji img:nth-child(2) {
    transition-delay: 0.4s;

    opacity: 1;
    transform: translateY(-6vh);
}

.popup.story {
    --animated-class: none;
    --animated-type: scroll;
    --animated-start: 325;
    --animated-end: 350;

    top: 19.5vh;
    padding: 9.583vh 5.694vh 2.778vh 2.778vh;
    width: 31.250vh;
    opacity: 0;
    pointer-events: all;
    z-index: 20;
    transform: translateX(17vh) translateY(6vh);
    transition-duration: 0.8s;
    transition-delay: 0.2s;
    transition-property: opacity, transform;
}

.slider.open .popup.story {
    transform: translateX(17vh) translateY(0vh);
    opacity: 1;
}

.slider.close .popup.story {
    transition-duration: initial;
    transition-delay: initial;
    transition-property: initial;
    transform: translateX(17vh) translateY(calc(-40vh * var(--progress)));
    filter: blur(calc(4px * var(--progress)));
    opacity: 1;
}

.dark .slider.close .popup.story {
    /* --type-in: scroll;
    --start-in: 690;
    --end-in: 700;

    margin-top: 0; */
}

.popup.story .images {
    display: flex;
    grid-gap: 0.578vh;
    position: absolute;
    top: -3.333vh;
    left: 2.639vh;
}

.popup.story .images img {
    display: block;
    height: 11.2vh;
}

.slider.light .popup.story .images img {
    transform: translateY(4vh);
    opacity: 0;
}

.slider.light .popup.story .images img {
    transition-duration: 0.8s;
    transition-property: opacity, transform;
}

.slider.light.open .popup.story .images img,
.slider.light.close .popup.story .images img {
    transform: translateY(0vh);
    opacity: 1;
}

.slider.light.open .popup.story .images img:nth-child(1) {
    transition-delay: 0.2s;
}

.slider.light.open .popup.story .images img:nth-child(2) {
    transition-delay: 0.3s;
}

.slider.light.open .popup.story .images img:nth-child(3) {
    transition-delay: 0.4s;
}

.slider .popup.story .text {
    transition-duration: 0.8s;
    transition-delay: 0.2s;
    opacity: 0;
    transition-property: opacity, transform;
}

.slider.open .popup.story .text,
.slider.close .popup.story .text {
    opacity: 1;
    transform: translateY(0vh);
}

.dark .popup {
    background: #212121;
    color: #fff;
}

.dark .popup.story {
    padding: 8.194vh 4.583vh 2.778vh 2.917vh;
}

.dark .popup.story .images {
    top: 2.083vh;
    left: 2.917vh;
    grid-gap: 0vh;
}

.dark .popup.story .images img {
    position: relative;
    height: 4.646vh;
    margin-right: -2.323vh;
    left: 0vh;
    transform: translateX(6vh);
    opacity: 0;
}

.dark .slider .popup.story .images img {
    transition-duration: 0.8s;
    transition-property: opacity, transform;
}

.dark .slider.open .popup.story .images img,
.dark .slider.close .popup.story .images img {
    transform: translateX(0vh);
    opacity: 1;
}

.dark .slider.open .popup.story .images img:nth-child(1) {
    transition-delay: 0.2s;
}

.dark .slider.open .popup.story .images img:nth-child(2) {
    transition-delay: 0.4s;
}

.dark .slider.open .popup.story .images img:nth-child(3) {
    transition-delay: 0.6s;
}

.dark .slider.open .popup.story .images img:nth-child(4) {
    transition-delay: 0.8s;
}

.dark .slider.fixed.close .container {
    transform: translateY(80vh);
}

.popup.notes {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    padding: 3.611vh 3.889vh 3.750vh 14.306vh;
    top: 30vh;
    transform: translateX(20vh) translateY(calc(10vh - 10vh * var(--progress)));
    width: 47.917vh;
    opacity: calc(1 * var(--progress));
}

.popup.notes.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    opacity: calc(1 * var(--progress));
    transform: translateX(20vh) translateY(calc(10vh - 10vh * var(--progress)));
}

.popup.notes.blur {
    --animated-start: 20;
    --animated-end: 0;
    filter: blur(calc(4px * var(--progress)));
    transform: translateX(20vh) translateY(0vh);
    opacity: 1;
}

.popup.notes.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #212121;
    z-index: 1000;
    pointer-events: none;
}

.popup.notes .images {
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.popup.notes .images svg:nth-child(1) {
    height: 7vh;
    transform: scaleX(-1);
    position: absolute;
    top: -1.3vh;
    left: -0.5vh;
}

.popup.notes .images svg:nth-child(2) {
    height: 6vh;
    position: absolute;
    bottom: 0;
    left: 0.55vh;
}

.popup.notes .images svg:nth-child(3) {
    height: 10vh;
    position: absolute;
    top: 1.4vh;
    left: 6vh;
}

.popup.notes .images svg path {
    transition-duration: 0s;
    stroke-dashoffset: 100;
    opacity: 0;
}

.popup.notes.show .images svg path {
    transition-property: stroke-dashoffset;
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition-duration: 0.8s;
    stroke-dashoffset: 0;
    opacity: 1;
}

.popup.chat {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    padding: 2.639vh 2.361vh 3.750vh 9.722vh;
    top: 59vh;
    transform: translateX(-20vh) translateY(calc(10vh - 10vh * var(--progress)));
    width: 43.333vh;
    opacity: calc(1 * var(--progress));
}

.popup.chat.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;

    opacity: calc(1 * var(--progress));
    transform: translateX(-20vh) translateY(0vh);
}

.popup.chat.blur {
    --animated-start: 20;
    --animated-end: 0;
    filter: blur(calc(4px * var(--progress)));
    transform: translateX(-20vh) translateY(0vh);
    opacity: 1;
}

.popup.chat.blur:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.7 * var(--progress));
    border-radius: 4.444vh;
    background: #212121;
    z-index: 1000;
    pointer-events: none;
}

.popup.chat .images {
    position: absolute;
    background: #141414;
    width: 6.667vh;
    height: 6.667vh;
    top: 1.111vh;
    left: 1.111vh;
    border-radius: 100%;
    transform: scale(0);
}

.popup.chat.show .images {
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition-duration: 0.8s;
    transition-property: transform;
    transform: scale(1);
}

.popup.chat .images img {
    position: absolute;
    height: 3.333vh;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
}

.popup.chat.show .images img {
    transition-timing-function: cubic-bezier(0, 1.25, 0.71, 1.45);
    transition-duration: 0.8s;
    transition-delay: 0.1s;
    transition-property: transform;
    transform: translate(-50%, -50%) scale(1);
}

.popup.chat.show .images img:nth-child(2) {
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition-delay: 0.2s;
}

/* Попап */

/* Слайдер */

.slider {
    --animated-type: scroll;
    --animated-class: 180 fixed, 275 open 325, 325 close, 460 stop;

    height: 300vh;
    pointer-events: none;
    margin-top: -110vh;

    position: relative;
    z-index: 1;
}

.dark .slider {
    --animated-class: 500 fixed, 600 open 650, 650 close;
}

.slider .container {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100vh;
}

.slider.fixed .container {
    transform: translateY(calc(-180vh - var(--scroll)))
}

.dark .slider.fixed .container {
    transform: translateY(calc(-570vh - var(--scroll)));
}

.slider.stop .container {
    transform: translateY(350vh);
}

.slider .items {
    position: relative;
}

.slider .items .item {
    position: relative;
    transform-origin: 50% 150%;
    transform: translate(0vh, 0vh) rotate(0deg);
    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.39, 0.58, 0.57, 1);
    pointer-events: all;
}

.slider .items .item:nth-child(1) {
    z-index: 10;
}

.slider .items .item:not(:nth-child(1)) {
    position: absolute;
    top: 0;
    left: 0;
}

.slider.open .items .item:nth-child(2) {
    transform: translate(22vh, 0vh) rotate(30deg);
}

.slider.open .items .item:nth-last-child(1) {
    transform: translate(-22vh, 0vh) rotate(-30deg);
}

.slider .items .item>img {
    display: block;
    position: relative;
    height: 64.444vh;
    z-index: 2;
}

.slider .items .item>div {
    position: absolute;
    z-index: 1;
    width: 87%;
    height: 93%;
    top: 2vh;
    left: 1.9vh;
    border-radius: 4vh;
    overflow: hidden;
}

.slider .items .item>div img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}

.slider .items .item>div canvas {
    display: block;
    width: 100%;
    height: 100%;
}

.slider .buttons {
    position: absolute;
    bottom: 5vh;
    display: flex;
    grid-gap: 1.111vh;
    transform: translateY(20vh);

    transition-duration: 0.8s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(0.39, 0.58, 0.57, 1);
}

.slider.open .buttons {
    transform: translateY(0vh);
}

.slider .buttons button {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1;
    padding: 0;
}

.slider .buttons button img {
    width: 2.222vh;
    margin: 0;
}

.slider .events {
    position: absolute;
    top: 11vh;
    left: 0;
    width: 100vw;
    height: 76vh;
    z-index: 100;
}

.open-slider .slider {
    z-index: 30;
}

.open-slider .slider .events {
    pointer-events: all;
}

.slider .events div {
    flex: 1 50%;
}

/* Слайдер */

/* Меню */

.panel-menu {
    position: fixed;
    z-index: 900;
    width: 100vw;
}

.panel-menu .overlay {
    position: fixed;
    top: 0vh;
    left: 0;
    width: 100vw;
    height: 100vh;
    visibility: hidden;
    backdrop-filter: blur(0px);
    transition-duration: 0.8s;
    transition-property: visibility, backdrop-filter;
}

.open-menu .panel-menu .overlay {
    visibility: visible;
    backdrop-filter: blur(8px);
}

.panel-menu .container {
    position: relative;
    width: 113.611vh;
    margin: 0 auto;
}

.panel-menu .popup {
    position: absolute;
    top: 13vh;
    right: 0;
    z-index: 20;
    padding: 5.708vh;
    background: #FFF;
    box-shadow: rgba(0, 0, 0, 0.08) 0px 0px 2.195vh;
    border-radius: 3.513vh;
    display: flex;
    visibility: hidden;
    flex-direction: column;
    align-items: flex-start;
    transition-duration: 0.8s;
    transform: translateY(8vh);
    transition-property: opacity, transform, visibility;
    opacity: 0;
}

.panel-menu .popup .buttons {
    display: none;
}

.open-menu .panel-menu .popup {
    visibility: visible;
    transform: translateY(0vh);
    pointer-events: all;
    opacity: 1;
}

.panel-menu .popup a {
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 4.391vh;
    line-height: 80%;
    letter-spacing: -0.132vh;
    color: rgb(38, 38, 38);
    margin-bottom: 3.513vh;
    text-decoration: none;
}

.panel-menu .popup a:nth-child(5) {
    line-height: 110%;
}

.panel-menu .popup a:hover,
.panel-menu .popup a.active {
    color: rgb(168, 202, 19);
}

.panel-menu .popup a span {
    font-weight: 700;
    font-size: 2.634vh;
    line-height: 120%;
    letter-spacing: -0.079vh;
    text-transform: uppercase;
}

.panel-menu .popup .lang {
    margin-top: 3.513vh;
    padding: 0 5vh;
}

.panel-menu .popup .lang b {
    font-size: 4vh;
    font-weight: 400;
    line-height: 0;
}

/* Меню */

/* dark */

.dark {
    position: relative;
    color: #fff;
    background: #141414;
    z-index: 200;
    overflow: hidden;
    height: 270vh;
}

.dark .map {
    pointer-events: none;
}

.dark .map .border>img,
.dark .map>img {
    height: 136.361vh;
}

/* dark */

/* Переключатель */

.way {
    --animated-type: scroll;
    --animated-class: 350 show, 350 fixed, 434 stop;
    --animated-start: 225;
    --animated-end: 235;

    position: absolute;
    width: 100vw;
    height: 100vh;
    pointer-events: none;
    top: 350vh;
    z-index: 20;
}

.way.fixed {
    transform: translateY(calc(-350vh - var(--scroll)));
}

.way.fixed.stop {
    transform: translateY(100vh);
}

.way.show {
    --animated-class: 300 show, 350 fixed, 434 stop;
}

.way>div {
    --animated-type: screen;
    --animated-start: 100;
    --animated-end: 80;

    background: #fff;
    position: absolute;
    bottom: 20vh;
    right: 50%;
    transform: translateX(-20vh);
    box-shadow: var(--shadow-20);
    border-radius: 4.444vh;
    padding: 4.167vh;
    pointer-events: all;

    opacity: calc(1 * var(--progress));
}

.way .title {
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 6.667vh;
    line-height: 80%;
    letter-spacing: -0.200vh;
    margin-bottom: 3vh;
    position: relative;
    opacity: 0;
    top: 0;
    transform: translateY(2vh);
}

.way.show>div .title {
    transition-duration: 0.8s;
    transition-property: opacity, transform;
    opacity: 1;
    transform: translateY(0vh);
}

.way .switch {
    position: absolute;
    top: 4.110vh;
    right: 4.167vh;
    width: 9.362vh;
    height: 5.492vh;
    background: #EEFAB7;
    border-radius: 10vh;
    opacity: 0;
    transform: translateY(2vh);
}

.way.show>div .switch {
    transition-duration: 0.8s;
    transition-property: opacity, transform;
    transform: translateY(0vh);
    opacity: 1;
    z-index: 10;
    cursor: pointer;
}

.way .switch span {
    --animated-type: scroll;
    --animated-start: 410;
    --animated-end: 437;

    display: flex;
    width: 5.492vh;
    height: 5.492vh;
    background: #C6EF10;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 500;
    font-size: 1.497vh;
    line-height: 1.997vh;
    letter-spacing: 0.060vh;
    text-align: center;
    vertical-align: middle;
    text-transform: uppercase;
    color: #262626;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    box-shadow: 0 0 0 0.499vh #c6ef10;
    position: relative;
    transform: translateX(calc(3.87vh * var(--progress)));
    left: 0;
}

.way .text {
    position: relative;
    opacity: 0;
    transform: translateY(2vh);
}

.way.show>div .text {
    transition-duration: 0.8s;
    transition-delay: 0.2s;
    transition-property: opacity, transform;
    opacity: 1;
    transform: translateY(0vh);
}

.way p:nth-child(1) {
    margin-bottom: 3vh;
}

.way p:nth-child(2) {
    opacity: 0.2;
}

.dark .way {
    overflow: hidden;
    top: 0vh;
}

.dark .way.fixed {
    transform: translateY(0);
}

.dark .way>div {
    --animated-start: 0;
    --animated-end: 20;

    background: #212121;
    filter: blur(calc(4px * (1 - var(--progress))));
    opacity: 1;
    bottom: inherit;
}

.dark .way>div:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: calc(0.8 - 0.8 * var(--progress));
    border-radius: 4.444vh;
    background: #212121;
    z-index: 1000;
    pointer-events: none;
}

.dark .way.fixed>div {
    transform: translateX(-20vh) translateY(calc(-428vh - var(--scroll)));
}

.dark .way.fixed.stop>div {
    transform: translateX(-20vh) translateY(6vh);
}

.dark .way .switch {
    background: #141414;
}

.dark .way .switch span {
    color: #B9DD41;
    background: #262626;
    box-shadow: 0 0 0 0.499vh #262626;
}

.dark .way p:nth-child(1) {
    opacity: 0.2;
}

.dark .way p:nth-child(2) {
    opacity: 1;
}

/* Переключатель */

/* Зелень */

.light.green {
    position: relative;
    border-radius: 0 0 8.889vh 8.889vh;
    background: #A8CA13;
    z-index: 20;
    overflow: hidden;
}

.light.green .content {
    position: relative;
    width: 113.611vh;
    margin: 0 auto;
    display: flex;
    justify-content: flex-end;
}

.light.green .content .menu {
    --animated-type: scroll;
    --animated-class: 747 fixed, 700 a1 800, 800 a2 890, 890 a3 1200, 1048 stop;
    --animated-start: 650;
    --animated-end: 747;

    --dynamic-class: ;
    --sticky-start: 800vh;
    --sticky-stop: 1100vh;
    --start-in: 100;
    --end-in: 20;

    position: absolute;
    left: 0;
    top: 8.5vh;
    display: flex;
    flex-direction: column;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 6.667vh;
    line-height: calc(410% - 300% * var(--progress));
    letter-spacing: -0.200vh;
    margin-left: -0.27vh;
}

.light.green .content .menu.fixed {
    transform: translateY(calc(-747vh - var(--scroll)));
}

.light.green .content .menu.fixed.stop {
    transform: translateY(301vh);
}

.light.green .content .menu a {
    display: block;
    color: #000;
    text-decoration: none;
    opacity: 0.3;
    transition-property: opacity;
    transition-duration: 0.8s;
    transition-timing-function: cubic-bezier(0.39, 0.58, 0.57, 1);
}

.light.green .content .menu.a1 a:nth-child(1),
.light.green .content .menu.a2 a:nth-child(2),
.light.green .content .menu.a3 a:nth-child(3) {
    opacity: 1;
}

.light.green .content .slides .slide {
    height: 100vh;
    display: flex;
    align-items: center;
}

.light.green .content .slides .slide>div {
    width: 56.944vh;
    height: 75.000vh;
    background: #FFFFFF;
    box-shadow: var(--shadow-20);
    border-radius: 4.444vh;
    padding: 4.028vh 1.389vh 0;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 300;
    font-size: 3.333vh;
    line-height: 125%;
    letter-spacing: 0;
    text-align: center;
    position: relative;
}

.light.green .content .slides .slide img {
    position: absolute;
    bottom: 0;
}

.light.green .content .slides .slide:nth-child(1) img {
    height: 52.361vh;
    left: -16.111vh;
}

.light.green .content .slides .slide:nth-child(2) img {
    height: 53.750vh;
    left: -15.694vh;
}

.light.green .content .slides .slide:nth-child(3) img {
    height: 52.361vh;
    left: -14.028vh;
}

.light.green .content .slides .slide:nth-child(4) img {
    height: 62.222vh;
    left: -6.389vh;
    bottom: -14.028vh;
}

.light.green .content .slides .slide p {
    --animated-start: 100;
    --animated-end: 60;

    position: relative;
    opacity: calc(1 * var(--progress));
    transform: translateY(calc(10vh - 10vh * var(--progress)));
}

.light.green .content .slides .slide p b {
    font-weight: 600;
}

.popup.green-slide {
    --animated-class: 80 show;
    --animated-start: 100;
    --animated-end: 80;

    top: inherit;
    left: 0;
    padding: 2.639vh 1.250vh 2.222vh 14.306vh;
    width: 47.917vh;
    bottom: 12.6vh;
    transform: translateY(calc(5vh - 5vh * var(--progress)));
    /* opacity: calc(1 * var(--progress)); */
}

.popup.green-slide.show {
    --animated-class: 80 show;
    --animated-start: 20;
    --animated-end: 0;

    transform: translateY(0vh);
    opacity: 1;
    filter: blur(calc(4px * var(--progress)));
}

.popup.green-slide img {
    position: absolute;
    height: 8.056vh;
    top: 2.778vh;
    left: 2.778vh;
    transform: scale(0);
}

.popup.green-slide.show .text {
    transition-delay: 0s;
}

.popup.green-slide.show img {
    transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition-duration: 0.8s;
    transition-delay: 0.1s;
    transition-property: transform;
    transform: scale(1);
}

/* Зелень */

/* Мы */

.we {
    position: relative;
    --animated-type: scroll;
    --animated-class: 1155 fixed, 1250 stop;

    height: 200vh;
}

.we .area {
    width: 100vw;
    position: absolute;
    top: 0;
}

.we.fixed .area {
    transform: translateY(calc(-1155vh - var(--scroll)));
}

.we.stop .area {
    transform: translateY(94vh);
}

.we .text {
    --animated-type: screen;
    --animated-start: 100;
    --animated-end: 20;

    margin-top: 15.694vh;
    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 700;
    font-size: 6.667vh;
    line-height: calc(280% - 200% * var(--progress));
    letter-spacing: -0.200vh;
    text-align: center;
    margin-bottom: 7.917vh;
}

.we .qr>div {
    position: relative;
}

.we .qr>div>img {
    display: block;
    position: relative;
    height: 64.444vh;
    z-index: 2;
}

.we .qr>div .dqrb {
    display: none;
}

.we .qr>div>div {
    position: absolute;
    z-index: 1;
    width: 87%;
    height: 93%;
    top: 2vh;
    left: 2.1vh;
    border-radius: 4vh;
    overflow: hidden;
}

.we .qr>div>div>img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}

.we .images {
    display: flex;
    justify-content: center;
}

.we .array {
    position: absolute;
    left: 50%;
    margin-left: 16vh;
}

.we .array:nth-child(1) {
    flex-direction: row-reverse;
    margin-left: -16vh;
}

.we .images .array img {
    display: block;
    height: 43.056vh;
    aspect-ratio: 0.580;
    border-radius: 2.634vh;
    object-fit: cover;
    object-position: center;
    margin-bottom: 1.389vh;
}

.we .images .array {
    display: flex;
    grid-gap: 1.389vh;
    height: 0vh;
    width: 0vw;
    padding-top: 8.333vh;
}

.we .images .array>div {
    position: relative;
    top: 0;
}

.we .images {
    --animated-type: scroll;
    --animated-start: 1110;
    --animated-end: 1155;

    --top: calc(13.333vh - 5vh * var(--progress));
}

.we .images .array>div:nth-child(2) {
    transform: translateY(calc(var(--top) * 1));
}

.we .images .array>div:nth-child(3) {
    transform: translateY(calc(var(--top) * 2));
}

.we .images .array>div:nth-child(4) {
    transform: translateY(calc(var(--top) * 3));
}

.we .images .array>div:nth-child(5) {
    transform: translateY(calc(var(--top) * 4));
}

.we .images .array>div:nth-child(6) {
    transform: translateY(calc(var(--top) * 5));
}

/* fixed */

.we .images .array>div:nth-child(1) {
    --animated-start: 1155;
    --animated-end: 1185;
}

.we .images .array>div:nth-child(2) {
    --animated-start: 1170;
    --animated-end: 1200;
}

.we .images .array>div:nth-child(3) {
    --animated-start: 1185;
    --animated-end: 1215;
}

.we .images .array>div:nth-child(4) {
    --animated-start: 1200;
    --animated-end: 1230;
}

.we .images .array>div:nth-child(5) {
    --animated-start: 1215;
    --animated-end: 1250;
}

.we .images .array>div:nth-child(6) {
    --animated-start: 1230;
    --animated-end: 1250;
}

.we.fixed .images .array>div {
    --scale: calc(1 - 0.4 * var(--progress));
    --top: calc(8.333vh - 5.277vh * var(--progress));
    --left: calc(32% * var(--progress) * -1);
}

.we.fixed .array:nth-child(1)>div {
    --left: calc(32% * var(--progress));
}

.we.fixed .images .array>div:nth-child(1) {
    transform: translateY(0vh) scale(var(--scale)) translateX(var(--left));
}

.we.fixed .images .array>div:nth-child(2) {
    transform: translateY(calc(var(--top) * 1)) scale(var(--scale)) translateX(calc(var(--left) * 3));
}

.we.fixed .images .array>div:nth-child(3) {
    transform: translateY(calc(var(--top) * 2)) scale(var(--scale)) translateX(calc(var(--left) * 5));
}

.we.fixed .images .array>div:nth-child(4) {
    transform: translateY(calc(var(--top) * 3)) scale(var(--scale)) translateX(calc(var(--left) * 7));
}

.we.fixed .images .array>div:nth-child(5) {
    transform: translateY(calc(var(--top) * 4)) scale(var(--scale)) translateX(calc(var(--left) * 9));
}

.we.fixed .images .array>div:nth-child(6) {
    transform: translateY(calc(var(--top) * 5)) scale(var(--scale)) translateX(calc(var(--left) * 11));
}

/* .we.fixed .images .array>div:nth-child(1) {
    --start-in: 1202;
    --end-in: 1230;
    --start-out: 1215;
    --end-out: 1230;
}

.we.fixed .images .array>div:nth-child(2) {
    --start-in: 1215;
    --end-in: 1245;
    --start-out: 1230;
    --end-out: 1245;
}

.we.fixed .images .array>div:nth-child(3) {
    --start-in: 1230;
    --end-in: 1260;
    --start-out: 1245;
    --end-out: 1260;
}

.we.fixed .images .array>div:nth-child(4) {
    --start-in: 1245;
    --end-in: 1275;
    --start-out: 1260;
    --end-out: 1275;
}

.we.fixed .images .array>div:nth-child(5) {
    --start-in: 1260;
    --end-in: 1290;
    --start-out: 1275;
    --end-out: 1290;
}

.we.fixed .images .array>div:nth-child(6) {
    --start-in: 1275;
    --end-in: 1300;
    --start-out: 1290;
    --end-out: 1300;
}

.we.fixed .images .array img {
    height: calc(43.056vh - 18.723vh * var(--progress-in));
    margin-left: calc(4vh * var(--progress-in) - 4vh * var(--progress-out));
    margin-right: calc(4vh * var(--progress-in) - 4vh * var(--progress-out));
} */

/* stop */

/* .we.stop .images .array>div {
    --top: 3.056vh;
}

.we.stop .images .array img {
    height: 24.333vh;
} */

/* Мы */

/* footer */

footer {
    --animated-start: 100;
    --animated-end: 50;

    width: 100vw;
    overflow: hidden;
    height: 50vh;

    filter: blur(0px);
    transition-duration: 0.8s;
    transition-property: filter;
    transition-timing-function: ease-in-out;
}

footer .content {
    transform: translateY(calc(-50vh + 50vh * var(--progress)));
}

footer img.logo {
    display: block;
    width: 113.611vh;
    margin: 7.639vh auto 5.556vh auto;
}

footer .buttons {
    display: flex;
    width: 113.611vh;
    margin: 0 auto;
    justify-content: space-between;
    align-items: flex-start;
}

footer .buttons .icon img {
    height: 8.736vh;
}

footer .buttons a {
    text-decoration: none;
    color: rgb(0, 0, 0);
    display: flex;
    align-items: center;
    grid-gap: 1vh;
}

footer .buttons a img {
    display: block;
    height: 2.361vh;
    aspect-ratio: 1;
}

footer .buttons>div {
    display: flex;
    align-items: center;
    grid-gap: 8.889vh;
}

/* footer */

/* desktop */

.desktop .top .buttons,
.desktop .slider .nav,
.desktop .narrow-app,
.desktop .visible-narrow {
    display: none !important;
}



/* desktop */

/* page-content */

.page-content {
    max-width: 113.611vh;
    width: 90%;
    margin: 0 auto;

    font-family: 'Graphik Compact LC', sans-serif;
    font-weight: 300;
    font-size: 2.222vh;
    line-height: 140%;
    letter-spacing: -0.044vh;
    margin-bottom: 13.889vh;
}

.page-content * {
    user-select: text;
}

.page-content .between {
    display: flex;
    justify-content: space-between;
}

.page-content h2,
.page-content h3 {
    display: block;
    font-weight: 400;
    font-size: 2.778vh;
    line-height: 100%;
    letter-spacing: -0.056vh;
    text-align: center;
}

.page-content h3 {
    font-size: 2.222vh;
    letter-spacing: -0.044vh;
    margin: 4.444vh 0;
}

.page-content .company {
    display: block;
    text-align: center;
    margin: 4.444vh 0;
}

.page-content div {
    margin: 4.444vh 0;
}

.page-content a {
    text-decoration: none;
    color: inherit;
}

.page-content a:hover {
    text-decoration: underline;
}

.page-content div>b:first-child {
    width: auto;
    display: block;
}

.page-content div>span:first-child {
    width: auto;
    display: block;
}

.narrow .page-content div {
    display: block;
    margin: 3vh 0;
}

.narrow .page-content div>b:first-child,
.narrow .page-content div>span:first-child {
    margin-right: 1vh;
}

/* page-content */

/* narrow */

body.narrow {
    font-size: 1.724vh;
    letter-spacing: -0.034vh;
}

.narrow header .buttons button:nth-child(1),
.narrow header .buttons button:nth-child(2),
.narrow .top .qr,
.narrow section.screen .app .user-on-map,
.narrow section.screen .app .post,
.narrow section.screen .app .notes svg,
.narrow .slider .buttons,
.narrow .visible-desktop {
    display: none !important;
}

.narrow header .buttons button {
    height: 4.926vh;
}

.narrow header .container {
    margin: 2.623vh 1.478vh 0;
    width: 52.083vh;
}

.narrow header .container .logo img {
    display: block;
    height: 2.635vh;
}

.narrow .top {
    height: 65vh;
}

.narrow.page .top {
    height: 35vh;
}

.narrow .top .icon {
    height: 7.759vh;
    margin-bottom: 3.286vh;
}

.narrow .top .images {
    margin-bottom: 1.576vh;
}

.narrow .top .images,
.narrow .top .images img,
.narrow .top .images svg {
    height: 13.547vh;
}

.narrow .top p {
    font-size: 2.463vh;
    letter-spacing: -0.049vh;
    margin-bottom: 3.941vh;
}

.narrow .top .buttons {
    display: flex;
    justify-content: center;
    grid-gap: 1vh;
}

.narrow .top .buttons button {
    height: 4.926vh;
    width: 16.256vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.narrow .top .buttons button img {
    height: 93%;
    margin: 0;
}

.narrow .top .buttons.start-transition button.dark-theme {
    background: transparent;
    box-shadow: none;
}

.narrow .top .buttons.start-transition button {
    opacity: 0;
}

.narrow .top .buttons.start-transition button:before {
    content: '';
    background: #262626;
    box-shadow: var(--shadow-20);
    position: absolute;
    top: 0;
    left: 50%;
    width: 25%;
    height: 100%;
    transform: translateX(-50%);
    border-radius: 5vh;
    transition-duration: 0.8s;
    transition-delay: 0.4s;
    transition-property: width;
    opacity: 1;
}

.narrow.loaded .top .buttons.start-transition button {
    transition-duration: 0.8s;
    transition-delay: 0.4s;
    transition-property: opacity;
    opacity: 1;
}

.narrow.loaded .top .buttons.start-transition button:before {
    width: 100%;
}

.narrow .top .buttons.start-transition button img {
    transform: translateY(2vh);
    opacity: 0;
}

.narrow.loaded .top .buttons.start-transition button img {
    transition-duration: 0.8s;
    transition-delay: 0.6s;
    transition-property: transform, opacity;
    transform: translateY(0vh);
    opacity: 1;
}

.narrow .phone .container {
    --sticky-fixed-start: 45;
    --sticky-fixed-end: 595;
    top: 85vh;
    height: 57.143vh;
}

.narrow .container.sticky-end {
    top: 635vh;
}

.narrow section.screen .phone-widget {
    --animated-class: 65 hidden, 330 show-dark, 450 hidden-dark;
    --animated-type: scroll;
    --animated-start: 45;
    --animated-end: 65;

    --sticky-fixed-start: 45;
    --sticky-fixed-end: 595;
    top: 85vh;
    height: 53.4vh;
}

.narrow section.screen .phone-widget.sticky-end {
    top: 235vh;
}

.narrow .phone .container.sticky-fixed {
    top: 0vh;
    transform: translateY(calc(12vh + var(--scroll) * -1));
}

.narrow section.screen .phone-widget.sticky-fixed {
    top: 0vh;
    transform: translateY(calc(14vh + var(--scroll) * -1)) scale(calc(1 + 1.5 * var(--progress)));
}

.narrow section.screen .phone-widget.sticky-fixed.hidden {
    --animated-start: 130;
    --animated-end: 150;
    transform: translateY(calc(14vh + var(--scroll) * -1)) scale(calc(2.5 - 1.5 * var(--progress)));
}

.narrow section.screen .phone-widget.sticky-fixed.show-dark {
    --animated-start: 332;
    --animated-end: 360;
    transform: translateY(calc(14vh + var(--scroll) * -1)) scale(calc(1 + 1.5 * var(--progress)));
}

.narrow section.screen .map {
    --animated-class: 192 fixed;
    top: 65vh;
}

.narrow section.screen .map.fixed {
    transform: translateY(calc(-192vh - var(--scroll)));
}

.narrow .phone.start-transition {
    transform: translateY(10vh);
}

.narrow.loaded .phone.start-transition {
    transform: translateY(0vh);
    transition-duration: 0.8s;
    transition-delay: 0s;
    transition-property: transform;
}

.narrow .map.start-transition {
    transform: translateY(20vh);
    opacity: 0;
}

.narrow.loaded .map.start-transition {
    transition-duration: 1s;
    transition-property: transform, opacity;
    transform: translateY(0vh);
    opacity: 1;
}

.narrow .app .pins {
    top: 73vh;
}

.narrow .app.start-transition {
    opacity: 0;
}

.narrow.loaded .app.start-transition {
    transition-duration: 1s;
    transition-property: opacity;
    opacity: 1;
    z-index: 20;
}

.narrow .popup {
    border-radius: 3.941vh;
    padding: 2.956vh;
}

.narrow .popup .title {
    font-size: 4.926vh;
    letter-spacing: -0.148vh;
    margin-bottom: 1.970vh;
}

.narrow .popup.pins {
    --animated-class: 90 show, 70 blur;
    --animated-start: 100;
    --animated-end: 80;
    top: 49.972vh;
    opacity: calc(1 * var(--progress));
    transform: translateX(-50%) translateY(calc(10vh - 10vh * var(--progress)));
    width: 43.227vh;
}

.narrow .popup.pins.blur {
    --animated-start: 70;
    --animated-end: 60;
    filter: blur(0px);
    transform: translateX(-50%) translateY(0vh);
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.pins .images {
    top: 2.956vh;
    right: 0;
    padding-right: 2.956vh;
    padding-left: 1.9705vh;
    overflow: hidden;
}

.narrow .popup.pins .images img {
    height: 3.941vh;
    margin-left: -1.9705vh;
}

.narrow .map>img,
.narrow .map .border>img {
    height: 152.833vh;
}

.narrow .phone .container>img {
    --animated-class: 65 hidden, 332 show-dark, 450 hidden-dark;
    --animated-type: scroll;
    --animated-start: 45;
    --animated-end: 65;
    transform: scale(calc(1 + 1.5 * var(--progress)));
}

.narrow .phone .container>img.hidden {
    --animated-start: 130;
    --animated-end: 150;
    transform: scale(calc(2.5 - 1.5 * var(--progress)));
}

.narrow .phone .container>img.show-dark {
    --animated-start: 332;
    --animated-end: 360;
    transform: scale(calc(1 + 1.5 * var(--progress)));
}

.narrow .phone .container>img.hidden-dark {
    --animated-start: 450;
    --animated-end: 480;
    transform: scale(calc(2.5 - 1.5 * var(--progress)));
}

.narrow section.screen {
    --animated-class: 65 hidden, 332 show-dark, 400 hidden-dark, 580 mini;
    --animated-type: scroll;
    --animated-start: 45;
    --animated-end: 65;

    opacity: calc(1 - 1 * var(--progress));

    width: 100vw;
    height: 100vh;
}

.narrow section.screen.mini {
    height: 90vh;
}

.narrow section.screen>.container {
    position: relative;
    width: 24.7vh;
    margin: 0 auto;
    overflow: visible;
}

.narrow section.screen.hidden {
    --animated-start: 130;
    --animated-end: 150;
    opacity: calc(1 * var(--progress));
}

.narrow section.screen.show-dark {
    --animated-start: 332;
    --animated-end: 360;
    /* opacity: calc(1 - 1 * var(--progress)); */
    opacity: 1;
}

.narrow section.screen.hidden-dark {
    --animated-start: 480;
    --animated-end: 485;
    opacity: calc(1 * var(--progress));
}


.narrow .desktop .narrow-app {
    display: block;
}

.narrow .app .user-on-map {
    --animated-class: 40 show, 20 hidden;
    --animated-start: 60;
    --animated-end: 40;
    top: 35vh;
    opacity: calc(1 * var(--progress));
}

.narrow .app .user-on-map.show {
    --animated-class: 60 show, 20 hidden;
}

.narrow .app .user-on-map.hidden {
    --animated-start: 20;
    --animated-end: 10;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.user-on-map {
    transform: translateX(50%) translateY(calc(10vh - 10vh * var(--progress)));
    padding: 3vh 4vh 4vh 11.823vh;
    width: 43.227vh;
}

.narrow .popup.user-on-map.show {
    --animated-class: 100 show, 30 hidden;
    transform: translateX(50%);
}

.narrow .popup.user-on-map.hidden {
    --animated-start: 30;
    --animated-end: 20;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.user-on-map .userpic img {
    width: 5.911vh;
}

.narrow .popup.user-on-map .userpic {
    top: 1.724vh;
    left: 3.202vh;
}

.narrow .popup.user-on-map .userpic span {
    font-size: 1.478vh;
}

.narrow .app .post {
    --animated-class: 30 show, 20 hidden;
    --animated-start: 50;
    --animated-end: 30;
    top: 82vh;
    opacity: calc(1 * var(--progress));
}

.narrow .app .post.show {
    --animated-class: 100 show, 20 hidden;
}

.narrow .app .post.hidden {
    --animated-start: 20;
    --animated-end: 10;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.post {
    --animated-class: 100 show, 20 hidden;
    top: 119.056vh;
    transform: translateX(-50%) translateY(calc(10vh - 10vh * var(--progress)));
    width: 43.227vh;
    padding-left: 13.547vh;
}

.narrow .popup.post.show {
    --animated-class: 100 show, 40 hidden;
    transform: translateX(-50%) translateY(0vh);
}

.narrow .popup.post.hidden {
    --animated-start: 40;
    --animated-end: 34;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .app .journey {
    --animated-type: scroll;
    --animated-class: 150 show, 191 fixed;
    --animated-start: 191;
    --animated-end: 215;
    position: absolute;
    top: 218vh;
    width: 100%;
    opacity: 0;
}

.narrow .app .journey.show {
    opacity: 1;
}

.narrow .app .journey .container>img:first-child {
    margin-top: calc(-8.4vh * var(--progress));
}

.narrow .app .journey .container {
    transform: translateY(calc(6vh * var(--progress)));
}

.narrow .app .journey.fixed .container {
    transform: translateY(calc(-191.5vh - var(--scroll)));
}

.narrow .slider {
    --animated-class: 145 fixed, 215 open 265, 265 close, 300 stop;
    height: 260vh;
    margin-top: -125vh;
}

.narrow .slider .items .item>img {
    height: 57.143vh;
}

.narrow .slider.fixed .container {
    transform: translateY(calc(-149.5vh - var(--scroll)));
}

.narrow .slider.stop {
    opacity: 0;
}

.narrow section.screen .light-top {
    --animated-start: 192;
    --animated-end: 215;
}

.narrow section.screen .light-bottom-map,
.narrow section.screen .light-bottom-road{
    --animated-start: 160;
    --animated-end: 175;
}

.narrow .popup.journey {
    --animated-class: 90 show, 0 blur;
    --animated-start: 100;
    --animated-end: 90;
    top: 197.888vh;
    transform: translateX(50%) translateY(calc(10vh - 10vh * var(--progress)));
    opacity: calc(1 * var(--progress));
    width: 43.227vh;
}

.narrow .popup.journey.show {
    --animated-class: 100 show, 0 blur;
    --animated-start: 70;
    --animated-end: 60;
    transform: translateX(50%) translateY(0vh);
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.journey .emoji img:nth-child(1) {
    height: 6vh;
}

.narrow .popup.journey .emoji img:nth-child(2) {
    height: 5vh;
    left: 6.1vh;
}

.narrow .popup.journey.show .emoji img:nth-child(2) {
    transform: translateY(-5vh);
}

.narrow .slider .items .item:nth-child(2) {
    transform: translate(60vh, 0vh) rotate(0deg);
}

.narrow .slider .items .item:nth-last-child(1) {
    transform: translate(-60vh, 0vh) rotate(0deg);
}

.narrow .slider.open .items .item:nth-child(2) {
    transform: translate(30vh, 0vh) rotate(0deg);
}

.narrow .slider.open .items .item:nth-last-child(1) {
    transform: translate(-30vh, 0vh) rotate(0deg);
}

.narrow .popup.story {
    --animated-start: 265;
    --animated-end: 275;

    top: 86vh;
    transform: translateX(-50%) translateY(5vh);
    padding-top: 8.374vh;
}

.narrow .dark-images .popup.story {
    top: 84vh;
}

.narrow .slider.open .popup.story {
    transform: translateX(-50%) translateY(0vh);
    opacity: 1;
}

.narrow .popup.story .images img {
    height: 10.246vh;
}

.narrow .slider.close .popup.story {
    transition-duration: initial;
    transition-delay: initial;
    transition-property: initial;
    transform: translateX(-50%) translateY(0vh);
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .way {
    --animated-type: scroll;
    --animated-class: 285 show, 287 fixed, 332.5 stop;
    --animated-start: 300;
    --animated-end: 330;
    top: 300vh;
}

.narrow .way>div {
    transform: translateX(50%);
    width: 43.227vh;
    padding: 4.167vh 4vh;
}

.narrow .way .switch {
    width: 8.374vh;
    height: 3.941vh;
}

.narrow .way .switch span {
    --animated-start: 300;
    --animated-end: 330;
    width: 3.941vh;
    height: 3.941vh;
    box-shadow: 0 0 0 0.7385vh #c6ef10;
    font-size: 1.232vh;
    transform: translateX(calc(3.87vh * var(--progress)));
}

.narrow .way.fixed {
    transform: translateY(calc(-287.145vh - var(--scroll)));
}

.narrow .way.fixed.stop {
    transform: translateY(45vh);
}

.narrow .dark .way.fixed.stop {
    transform: translateY(0vh);
}

.narrow .way .title {
    font-size: 4.926vh;
    letter-spacing: -0.148vh;
    margin-bottom: 2vh;
}

.narrow .way p:nth-child(1) {
    margin-bottom: 1.970vh;
}

.narrow .dark .way {
    transform: translateY(0);
    top: 0vh;
}

.narrow .dark .way.fixed>div {
    transform: translateX(50%) translateY(calc(-330.5vh - var(--scroll)));
}

.narrow .dark .way .switch span {
    box-shadow: 0 0 0 0.7385vh #262626;
}

.narrow .dark .way.fixed.stop {
    --animated-start: 330;
    --animated-end: 350;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .dark .way.fixed.stop>div {
    transform: translateX(50%) translateY(2vh);
}

.narrow section.screen .dark .map {
    top: 0;
}

.narrow section.screen .dark {
    top: 200vh;
    height: 265vh;
    overflow: visible;
}

body:not(.page).narrow header .container .logo {
    --animated-class: 480 revers;
    --animated-start: 393.3;
    --animated-end: 396;
}

.narrow .app.narrow-app {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.narrow .app .notes {
    --animated-class: 350 show 400;
    --animated-start: 330;
    --animated-end: 360;
    opacity: calc(1 * var(--progress));
}

.narrow .app .notes.show {
    --animated-class: 326 show 432;
}

.narrow .app .notes svg {
    left: 4vh;
}

.narrow .popup.notes {
    top: 50vh;
    width: 43.227vh;
    transform: translateX(-50%) translateY(calc(10vh - 10vh * var(--progress)));
    padding-left: 13.424vh;
}

.narrow .popup.notes.show {
    transform: translateX(-50%) translateY(0vh);
}

.narrow .popup.notes.blur {
    --animated-start: 50;
    --animated-end: 40;
    filter: blur(0px);
    transform: translateX(-50%) translateY(0vh);
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .app .chat {
    --animated-class: 420 hidden;
    --animated-start: 400;
    --animated-end: 420;
    top: 12.472vh;
    transform: translateY(calc(20vh - 20vh * var(--progress)));
    opacity: calc(1 * var(--progress));
    width: 27vh;
}

.narrow .app .chat.hidden {
    --animated-start: 450;
    --animated-end: 460;
    opacity: calc(1 - 1 * var(--progress));
    transform: translateY(0vh);
}

.narrow .popup.chat {
    --animated-class: 60 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;
    padding: 2.956vh 2.956vh 2.956vh 8.621vh;
    top: 83.441vh;
    transform: translateX(50%) translateY(calc(10vh - 10vh * var(--progress)));
    width: 43.227vh;
    opacity: calc(1 * var(--progress));
}

.narrow .popup.chat.show {
    --animated-class: 100 show, 50 blur;
    --animated-start: 100;
    --animated-end: 60;
    opacity: calc(1 * var(--progress));
    transform: translateX(50%) translateY(0vh);
}

.narrow .popup.chat.blur {
    --animated-start: 30;
    --animated-end: 20;
    filter: blur(0px);
    transform: translateX(50%) translateY(0vh);
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.chat .images {
    width: 5.911vh;
    height: 5.911vh;
}

.narrow section.screen .dark .map {
    --animated-class: 488 fixed, 595 stop;
    top: 0;
}

.narrow section.screen .dark .map.fixed {
    transform: translateY(calc(-488vh - var(--scroll)));
}

.narrow section.screen .dark .map.stop {
    transform: translateY(106vh);
}

.narrow .app .sheet {
    --animated-class: 488 fixed, 595 stop;
    --animated-start: 488;
    --animated-end: 520;
    position: relative;
    top: 53vh;
    z-index: 10;
}

.narrow .app .sheet img {
    height: 45.139vh;
}

.narrow .app .sheet.fixed {
    transform: translateY(calc(-491vh - var(--scroll) - 7vh * var(--progress)));
}

.narrow section.screen .dark .phone-widget.sticky-fixed {
    top: 0vh;
    transform: translateY(calc(-386vh + var(--scroll) * -1));
    opacity: 0;
}

.narrow section.screen.hidden-dark .dark .phone-widget.sticky-fixed {
    opacity: 1;
}

.narrow .app .user-on-map img.pin {
    position: absolute;
    top: 0;
    left: 50%;
    height: 8.867vh;
    transform: translate(-50%, -100%) scale(0);
}

.narrow .app .user-on-map.show img.pin {
    transform: translate(-50%, -100%) scale(1);
    transition-timing-function: cubic-bezier(0, 1.25, 0.71, 1.45);
    transition-duration: 0.8s;
    transition-property: transform;
}

.narrow section.screen .dark-top {
    --animated-start: 488;
    --animated-end: 520;
}

.narrow section.screen .dark-bottom {
    --animated-start: 494;
    --animated-end: 520;
    opacity: 1;
    transform: translateY(calc(91% - 91% * var(--progress)));
}

.narrow .dark .slider {
    --animated-class: 400 fixed, 545 open 595, 595 close;
}

.narrow .dark .slider.fixed .container {
    transform: translateY(calc(-484.5vh - var(--scroll)));
}

.narrow .dark .slider.fixed.close .container {
    transform: translateY(110vh);
}

.narrow .app .sheet.fixed.stop {
    transform: translateY(96.5vh);
}

.narrow .dark .popup.story {
    padding: 2.956vh 2.956vh 2.956vh 16.749vh;
    width: 43.227vh;
}

.narrow .dark .popup.story .images {
    top: 3.3vh;
    left: 2.917vh;
}

.narrow .dark .popup.story .images img {
    height: 3.941vh;
    margin-right: -1.9705vh;
}

body:not(.page).narrow header .container .logo.revers {
    --animated-start: 663.1;
    --animated-end: 665.8;
}

.narrow .light.green .content {
    width: 33.498vh;
    justify-content: center;
}

.narrow .light.green .content .menu {
    --animated-type: scroll;
    --animated-class: 670 fixed, 600 a1 725, 725 a2 805, 805 a3 1200, 930 stop;
    --animated-start: 610;
    --animated-end: 650;
    --dynamic-class: ;
    --sticky-start: 800vh;
    --sticky-stop: 1100vh;
    --start-in: 100;
    --end-in: 20;
    left: 0;
    top: 8.5vh;
    font-size: 4.433vh;
    letter-spacing: -0.133vh;
    margin-left: -0.27vh;
    line-height: 110%;
    z-index: 10;
}

.narrow .light.green .content .slides .slide>div {
    width: 33.498vh;
    height: 43.842vh;
    font-size: 1.724vh;
    padding: 2.463vh 2.389vh 0;
}

.narrow .light.green .content .slides .slide:nth-child(1) img {
    height: 26.108vh;
    left: -4.755vh;
}

.narrow .light.green .content .slides .slide:nth-child(2) img {
    height: 33.542vh;
    left: -9.6vh;
}

.narrow .light.green .content .slides .slide:nth-child(3) img {
    height: 28.911vh;
    left: -6.943vh;
}

.narrow .light.green .content .slides .slide:nth-child(4) img {
    height: 39.525vh;
    left: -4vh;
    bottom: -8.98vh;
}

.narrow .light.green .content .slides .slide p br {
    display: none;
}

.narrow .light.green .content .menu.fixed {
    transform: translateY(calc(-670vh - var(--scroll)));
}

.narrow .light.green .content .menu.stop {
    transform: translateY(260vh);
}

.narrow .light.green .content .slides .slide:last-child {
    opacity: 1;
}

.narrow .light.green .content .slides {
    margin-top: 30vh;
}

.narrow .light.green .content .slides .slide {
    --animated-type: screen;
    --animated-start: 10;
    --animated-end: 0;
    height: 80vh;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .popup.green-slide {
    width: 43.227vh;
    bottom: 2.6vh;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
    padding-left: 12.562vh;
}

.narrow .popup.green-slide img {
    height: 7.143vh;
    top: 2.956vh;
    left: 2.956vh;
}

.narrow .we .text {
    font-size: 4.433vh;
    letter-spacing: -0.133vh;
}

.narrow .we .text br:nth-child(2) {
    display: none;
}

.narrow .we {
    --animated-class: 1022 fixed, 1120 stop;
}

.narrow .we.fixed .area {
    transform: translateY(calc(-1022vh - var(--scroll)));
}

.narrow .we .images .array img {
    height: 25.493vh;
}

.narrow .we .images .array {
    padding-top: 2vh;
    z-index: 2;
}

.narrow .we .qr {
    --animated-type: scroll;
    --animated-start: 1040;
    --animated-end: 1090;
    opacity: calc(1 - 1 * var(--progress));
}

.narrow .we .images {
    --animated-type: scroll;
    --animated-start: 1040;
    --animated-end: 1090;
}

.narrow .we .array:nth-child(1) {
    transform: translateX(calc(15.3vh * var(--progress)));
}

.narrow .we .array:nth-child(3) {
    transform: translateX(calc(-15.3vh * var(--progress)));
}

.narrow .we.fixed .images .array>div {
    --animated-type: scroll;
    --animated-start: 1040;
    --animated-end: 1090;
    transform: none;
}

.narrow .we .images .array img {
    height: calc(25.493vh - 4.8vh * var(--progress));
}

.narrow .light.green {
    border-radius: 0 0 3.079vh 3.079vh;
}

.narrow .we.stop .area {
    transform: translateY(97vh);
}

.narrow footer img.logo {
    width: auto;
    height: 6.692vh;
    margin: 1.478vh auto 4.926vh auto;
}

.narrow footer .buttons {
    width: auto;
    align-items: center;
    flex-direction: column;
}

.narrow .slider .nav {
    position: absolute;
    top: 80vh;
    left: 50vw;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    grid-gap: 0.985vh;
    opacity: 0;
    transition-duration: .8s;
    transition-property: opacity;
}

.narrow .slider.open .nav {
    opacity: 1;
}

.narrow .slider .nav span {
    display: block;
    width: 0.985vh;
    height: 0.985vh;
    background: #B1B5BB;
    border-radius: 100%;
    transition-duration: .8s;
    transition-property: background;
}

.narrow .slider .nav span.active {
    background: #C6EF10;
}

.narrow .slider.stop .container {
    transform: translateY(350vh);
}

.narrow footer .buttons .icon img {
    height: 7.389vh;
    margin-bottom: 6.897vh;
}

.narrow footer .buttons>div {
    grid-gap: 4vh;
}

.narrow .panel-menu .container {
    width: auto;
}

.narrow .panel-menu .popup {
    width: 43.182vh;
    left: 50%;
    transform: translate(-50%) translateY(8vh);
    padding: 6.404vh 3.941vh 3.941vh 3.941vh;
    top: 9.833vh;
}

.narrow.open-menu .panel-menu .popup {
    transform: translate(-50%) translateY(0vh);
}

.narrow .panel-menu .popup a {
    font-size: 4.187vh;
    line-height: 80%;
    margin-bottom: 3.448vh;
}

.narrow .panel-menu .popup a:nth-child(5) {
    line-height: 110%;
}

.narrow .panel-menu .popup .lang {
    padding: 0 3vh;
}

.narrow .panel-menu .popup .buttons {
    display: flex;
    margin-top: 5.911vh;
    width: 100%;
    justify-content: space-between;
}

.narrow .panel-menu .popup .buttons button {
    height: 4.8vh;
    width: 16.256vh;
    display: flex;
    justify-content: center;
}

.narrow .panel-menu .popup .buttons button img {
    height: 93%;
    margin: 0;
}

.narrow .we .qr>div .dqr {
    display: none;
}

.narrow .we .qr>div .dqrb {
    display: flex;
    background: #fff;
    height: 100%;
    flex-direction: column;
    align-items: center;
}

.narrow .we .qr>div .dqrb>img {
    display: block;
    height: 7.389vh;
    margin-top: 11.330vh;
    margin-bottom: 6.773vh;
    align-items: center;
}

.narrow .we .qr>div .dqrb button {
    width: 22vh;
    margin-bottom: 0.985vh;
}

.narrow #map {
    --scrollBy: 36;
}

.narrow #journey {
    --scrollBy: 171;
}

.narrow #hiway {
    --scrollBy: 305;
}

.narrow #myway {
    --scrollBy: 331.5;
}

.narrow #other {
    --scrollBy: 685;
}

.narrow #presence {
    --scrollBy: 685;
}

.narrow #dialogue {
    --scrollBy: 760;
}

.narrow #crowd {
    --scrollBy: 840;
}

.narrow .top .text {
    font-size: 7.882vh;
}

.narrow .map .border {
    overflow: hidden;
    border-radius: 0 0 5.665vh 5.665vh;
}

/* narrow */