* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --index: calc(1vw + 1vh); /* (выводим единицу размера) */
    --gutter: 30px; /* (расстояние от фрейма до центра) */
    --side-small: 26; /* (для пропорций изображений) */
    --side-big: 36;
    --depth: 18500px;  /* (высота(глубина) сайта)  */
    --transition: .75s cubic-bezier(.075, .5, 0, 1);
}

@font-face {
    font-family: raleway_c;
    src: url(../fonts/raleway-v22-cyrillic-300.woff2);
    font-weight: 300;
}

@font-face {
    font-family: raleway_c;
    src: url(../fonts/raleway-v22-cyrillic-100.woff2);
    font-weight: 100;
}

.body {
    background-color: #000;
    color: #fff;
    font-size: calc(var(--index) * .8);
    font-family: raleway_c, sans-serif; 
    font-weight: 300;
    line-height: 1.75;
    height: var(--depth);
}

.container {
    width: 100%;
    height: 100%;
    position: fixed;
    perspective: 1500px;
}

.gallery {
    transform-style: preserve-3d; /* (необходимое свойство для обьединения родительского блока(container с перспективой) и дочерних элементов) */
    height: 100%;
}

.frame {
    width: 100%;
    height: 100%;
    position: absolute; /* (рамки получатся одна под другой) */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition), opacity .75s ease;
    will-change: transform;
    transform-style: preserve-3d; /* (добавляем, чтобы шрифты не размывались при увеличении) */
}

h1, h2, h3, h4 {
    text-transform: uppercase;
    font-weight: 100;
    width: min-content; /* (сориентирует ширину по ширине самого длинного слова в строке) */
    line-height: 1;
}

.frame h2 {
    text-align: center;
    font-size: calc(var(--index) * 3.3);
}

.frame-media {
    position: relative;
    width: calc(var(--index) * var(--side-small));
    height: calc(var(--index) * var(--side-big));
    background-position: center;
    background-size: cover;
}

.frame-media_left {
    right: calc(var(--side-small) / 2 * var(--index) + var(--gutter));
}

.frame-media_right {
    left: calc(var(--side-small) / 2 * var(--index) + var(--gutter));
}

.frame_bg {
    background-color: rgb(0 0 0 / .87)
}

video.frame-media {
    width: calc(var(--index) * var(--side-big));
    height: calc(var(--index) * var(--side-small));
}

video.frame-media_right {
    left: calc(var(--side-big) / 2 * var(--index) + var(--gutter));
}

video.frame-media_left {
    right: calc(var(--side-big) / 2 * var(--index) + var(--gutter));
}

.text-right > * { /* (все прямые потомки) */
    position: relative;
    left: 18vw;
}

.text-left > * { 
    position: relative;
    right: 18vw;
}

.frame h3 {
    font-size: calc(var(--index) * 3);
}

.frame p {
    max-width: 30vw;
    margin-top: 5vh;
}

.soundbutton {
    position: fixed;
    bottom: 5vh;
    right: 5vw;
    cursor: pointer;
    width: 24px;
    transition: .25s ease;
}

.soundbutton.paused {
    opacity: .25;
}