@font-face {
    font-family: "Avenir Next";
    font-weight: 100;
    src: url(/fonts/AvenirNextCyr-UltraLight.woff) format("woff"), url(/fonts/AvenirNextCyr-UltraLight.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 100;
    src: url(/fonts/AvenirNextCyr-UltraLightIt.woff) format("woff"), url(/fonts/AvenirNextCyr-UltraLightIt.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 200;
    src: url(/fonts/AvenirNextCyr-Thin.woff) format("woff"), url(/fonts/AvenirNextCyr-Thin.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 200;
    src: url(/fonts/AvenirNextCyr-ThinItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-ThinItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 300;
    src: url(/fonts/AvenirNextCyr-Light.woff) format("woff"), url(/fonts/AvenirNextCyr-Light.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 300;
    src: url(/fonts/AvenirNextCyr-LightItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-LightItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 400;
    src: url(/fonts/AvenirNextCyr-Regular.woff) format("woff"), url(/fonts/AvenirNextCyr-Regular.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 400;
    src: url(/fonts/AvenirNextCyr-Italic.woff) format("woff"), url(/fonts/AvenirNextCyr-Italic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 500;
    src: url(/fonts/AvenirNextCyr-Medium.woff) format("woff"), url(/fonts/AvenirNextCyr-Medium.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 500;
    src: url(/fonts/AvenirNextCyr-MediumItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-MediumItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 600;
    src: url(/fonts/AvenirNextCyr-Demi.woff) format("woff"), url(/fonts/AvenirNextCyr-Demi.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 600;
    src: url(/fonts/AvenirNextCyr-DemiItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-DemiItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 700;
    src: url(/fonts/AvenirNextCyr-Bold.woff) format("woff"), url(/fonts/AvenirNextCyr-Bold.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 700;
    src: url(/fonts/AvenirNextCyr-BoldItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-BoldItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-weight: 800;
    src: url(/fonts/AvenirNextCyr-Heavy.woff) format("woff"), url(/fonts/AvenirNextCyr-Heavy.woff2) format("woff2")
}

@font-face {
    font-family: "Avenir Next";
    font-style: italic;
    font-weight: 800;
    src: url(/fonts/AvenirNextCyr-HeavyItalic.woff) format("woff"), url(/fonts/AvenirNextCyr-HeavyItalic.woff2) format("woff2")
}

@font-face {
    font-family: "Bodoni Svty Two ITCTT";
    font-style: italic;
    font-weight: 400;
    src: url(/fonts/BodoniC-Italic.woff) format("woff"), url(/fonts/BodoniC-Italic.woff2) format("woff2")
}

@font-face {
    font-family: Bodoni;
    font-style: italic;
    font-weight: 400;
    src: url(/fonts/BodoniC-Italic_ru.woff) format("woff"), url(/fonts/BodoniC-Italic_ru.woff2) format("woff2")
}

@font-face {
    font-family: "Minion Pro";
    font-weight: 400;
    src: url(/fonts/MinionPro-Regular.woff) format("woff"), url(/fonts/MinionPro-Regular.woff2) format("woff2")
}

* {
    padding: 0;
    margin: 0
}

body, html {
    width: 100vw;
    height: 100%;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -webkit-tap-highlight-color: transparent;
    cursor: default;
    overflow: hidden;
    overflow-y: auto
}

body._long, html._long {
    height: auto
}

body {
    font: normal 14px/1.4 "Avenir Next";
    color: #fff;
    background: #191919
}

html._mobile body {
    -webkit-text-size-adjust: 100%
}

._newproject body {
    background-color: #360ab3
}

html._loading {
    overflow: hidden
}

html._page-animating {
    pointer-events: none
}

fieldset, img {
    border: 0
}

fieldset legend {
    display: none
}

li, ul {
    list-style-type: none
}

img {
    vertical-align: top
}

table {
    border: 0;
    border-collapse: collapse
}

table td {
    padding: 0;
    vertical-align: top
}

input, select, textarea {
    box-sizing: border-box
}

input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type=number] {
    -moz-appearance: textfield
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration, input[type=search]::-webkit-search-results-button, input[type=search]::-webkit-search-results-decoration {
    display: none
}

input[type=search] {
    -webkit-appearance: textfield
}

::-moz-selection {
    background: #5f5f5f;
    color: #fff;
    text-shadow: none
}

::selection {
    background: #5f5f5f;
    color: #fff;
    text-shadow: none
}

::-moz-selection {
    background: #5f5f5f;
    color: #fff;
    text-shadow: none
}

._desktop._win ::-webkit-scrollbar {
    width: 6px;
    height: 6px;
    background: #eaedf1
}

._desktop._win ::-webkit-scrollbar-button {
    display: none
}

._desktop._win ::-webkit-scrollbar-track {
    background: #eaedf1
}

._desktop._win ::-webkit-scrollbar-thumb {
    background: #5f5f5f
}

._desktop._win ::-webkit-scrollbar-thumb:hover {
    background: #333
}

#__bs_notify__ {
    padding: 2px !important;
    font-size: 10px !important;
    opacity: .75;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    pointer-events: none
}

a[href^=tel] {
    color: inherit;
    text-decoration: none
}

.body a:active, .body a:hover, .body a:link, .body a:visited {
    color: #fff;
    text-decoration: none
}

a._active {
    pointer-events: none
}

._hidden, html._loading .footer, html._loading .header, html._loading .main, html._loading .overlays {
    opacity: 0;
    visibility: 0;
    overflow: hidden;
    max-height: 0;
    max-width: 0
}

.clearfix, .row {
    zoom: 1
}

.clearfix:after, .row:after {
    content: " ";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
    font-size: 0
}

._hidden, .no-select, html._loading .footer, html._loading .header, html._loading .main, html._loading .overlays {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

._hidden, .no-pe, html._loading .footer, html._loading .header, html._loading .main, html._loading .overlays {
    pointer-events: none
}

.dragging, .dragging * {
    cursor: ew-resize;
    cursor: grabbing;
    cursor: -webkit-grabbing;
    cursor: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAgMAAABinRfyAAAACVBMVEUAAAD///8AAABzxoNxAAAAAXRSTlMAQObYZgAAADFJREFUCNdjQAeLuhgYmCJTFzAwhYbOYGCYGhrBwAQiOEMhRAJIIgEk0cDAoAoj4AAA6jIM345/MPUAAAAASUVORK5CYII=), auto
}

.draggable, .draggable a {
    cursor: ew-resize;
    cursor: grab;
    cursor: -webkit-grab;
    cursor: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAgMAAABinRfyAAAADFBMVEUAAAD///8AAADAwMAJ6vS1AAAAAXRSTlMAQObYZgAAAEVJREFUCNctxLENgDAMRcEndxkkFfMYQUeTAqZwCQN8j8CcxBLFHVhMzwXtHFHd2D7eKlnkScpXJN/oPmt/B1YhD+gV8AEVfxL3aRgilwAAAABJRU5ErkJggg==), auto
}

.animated, .control-lang__item:before, .form-input__border, .form-input__label, .header__link._close, .nav-scroll-down, .newproject__submit, .slide-nav__btn, .transition-active {
    transition: color .4s ease-out, opacity .4s ease-out, background .4s ease-out, border-color .4s ease-out, transform .4s ease-out
}

.animated:hover, .control-lang__item._active:before, .header__link._close:hover, .nav-scroll-down:hover, .newproject__submit:hover, .slide-nav__btn:hover, .transition-hover {
    transition: none
}

.force3D {
    transform: translate3d(0, 0, 0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.main, .main__pages, .page {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: auto
}

.slideback {
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    pointer-events: none;
    overflow: hidden
}

.slideback svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    pointer-events: none
}

.preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    background: #191919;
    z-index: 99;
    opacity: 0;
    transition: opacity .5s ease-out
}

.preloader._started {
    opacity: 1
}

.preloader._started .preloader__logo i {
    -ms-transform: scaleY(1);
    transform: scaleY(1)
}

.preloader._back-1 .preloader__side {
    background: #ff00fc
}

.preloader._back-2 .preloader__side {
    background: #001eff
}

.preloader._back-3 .preloader__side {
    background: red
}

.preloader._back-4 .preloader__side {
    background: #fcff00
}

.preloader._back-5 .preloader__side {
    background: #0dd01b
}

.preloader__logo {
    position: absolute;
    width: 424px;
    height: 300px;
    top: 50%;
    left: 50%;
    margin-left: -212px;
    margin-top: -150px;
    -ms-transform: scale(1);
    transform: scale(1);
    transition: transform .15s ease-out
}

@media only screen and (max-width: 767px) {
    .preloader__logo {
        -ms-transform: scale(.5);
        transform: scale(.5)
    }
}

@media only screen and (max-width: 640px) {
    .preloader__logo {
        -ms-transform: scale(.5);
        transform: scale(.5)
    }
}

@media only screen and (max-width: 320px) {
    .preloader__logo {
        -ms-transform: scale(.25);
        transform: scale(.25)
    }
}

@media only screen and (max-width: 200px) {
    .preloader__logo {
        -ms-transform: scale(.1);
        transform: scale(.1)
    }
}

.preloader__logo i {
    position: absolute;
    left: 0;
    top: 0;
    width: 100px;
    height: 300px;
    background: #303030;
    -ms-transform: scaleY(0);
    transform: scaleY(0);
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
    transition: transform .45s ease-out;
    transition-delay: .25s
}

.preloader__logo i:nth-child(1) {
    left: 108px;
    transition-delay: .35s
}

.preloader__logo i:nth-child(2) {
    left: 216px;
    transition-delay: .45s
}

.preloader__logo i:nth-child(3) {
    left: 324px;
    height: 100px;
    transition: transform .15s ease-out;
    transition-delay: .55s
}

.preloader__logo i:nth-child(4) {
    left: 324px;
    top: 108px;
    height: 192px;
    transition: transform .35s ease-out;
    transition-delay: .68s
}

.preloader__side {
    position: absolute;
    top: 0;
    width: 50%;
    height: 100%;
    background: #32fd2f;
    overflow: hidden
}

.preloader__side._left {
    left: 0
}

.preloader__side._left .preloader__side-content {
    left: 0
}

.preloader__side._right {
    right: 0
}

.preloader__side._right .preloader__side-content {
    right: 0
}

.preloader__side .preloader__logo i {
    background: #000
}

.preloader__side-content {
    position: absolute;
    top: 0;
    width: 100vw;
    height: 100%
}

.main {
    min-height: 100%;
    overflow: hidden;
    transition: -webkit-filter .35s ease-out;
    transition: filter .35s ease-out;
    transition: filter .35s ease-out, -webkit-filter .35s ease-out;
    -webkit-filter: grayscale(0);
    filter: grayscale(0)
}

.main__particles {
    position: fixed;
    top: -10px;
    left: -10px;
    right: -10px;
    bottom: -10px;
    overflow: hidden;
    z-index: 0
}

.main__pages {
    min-height: 100%;
    z-index: 1
}

.main__animation {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10
}

.main__animation .animation__side {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh
}

._newproject .main {
    width: 100%;
    overflow: initial
}

.page {
    min-height: 100%
}

.page._noscroll {
    height: 100%;
    overflow: hidden
}

.page._newproject {
    position: relative
}

.skin {
    width: 100%;
    max-width: 1065px;
    margin: 0 auto
}

.center {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    white-space: nowrap;
    font-size: 0;
    padding: 0 90px;
    box-sizing: border-box
}

@media only screen and (max-width: 768px) {
    .center {
        padding: 0 20px
    }
}

.center:before {
    display: inline-block;
    position: relative;
    content: ' ';
    width: 0;
    height: 100%;
    vertical-align: middle
}

.center__content {
    display: inline-block;
    position: relative;
    text-align: left;
    vertical-align: middle;
    white-space: normal;
    font-size: 14px;
    padding: 75px 0 65px 0;
    box-sizing: border-box
}

.center._no-padding {
    padding: 0
}

.center._no-padding > .center__content {
    padding: 0
}

.row {
    position: relative;
    margin-left: -40px;
    margin-right: -40px
}

@media only screen and (max-width: 1399px) {
    .row {
        margin-left: -40px;
        margin-right: -40px
    }
}

@media only screen and (max-width: 999px) {
    .row {
        margin-left: -40px;
        margin-right: -40px
    }
}

@media only screen and (max-width: 767px) {
    .row {
        margin-left: -40px;
        margin-right: -40px
    }
}

.col-lg-1, .col-md-1, .col-sm-1, .col-xs-1 {
    box-sizing: border-box
}

.col-lg-2, .col-md-2, .col-sm-2, .col-xs-2 {
    box-sizing: border-box
}

.col-lg-3, .col-md-3, .col-sm-3, .col-xs-3 {
    box-sizing: border-box
}

.col-lg-4, .col-md-4, .col-sm-4, .col-xs-4 {
    box-sizing: border-box
}

.col-lg-5, .col-md-5, .col-sm-5, .col-xs-5 {
    box-sizing: border-box
}

.col-lg-6, .col-md-6, .col-sm-6, .col-xs-6 {
    box-sizing: border-box
}

.col-lg-7, .col-md-7, .col-sm-7, .col-xs-7 {
    box-sizing: border-box
}

.col-lg-8, .col-md-8, .col-sm-8, .col-xs-8 {
    box-sizing: border-box
}

.col-lg-9, .col-md-9, .col-sm-9, .col-xs-9 {
    box-sizing: border-box
}

.col-lg-10, .col-md-10, .col-sm-10, .col-xs-10 {
    box-sizing: border-box
}

.col-lg-11, .col-md-11, .col-sm-11, .col-xs-11 {
    box-sizing: border-box
}

.col-lg-12, .col-md-12, .col-sm-12, .col-xs-12 {
    box-sizing: border-box
}

.col-lg-1 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-2 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-3 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-4 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-5 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-6 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-7 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-8 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-9 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-10 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-11 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-12 {
    padding-left: 40px;
    padding-right: 40px
}

.col-lg-1 {
    display: block;
    float: left;
    width: 8.33333%
}

.col-lg-2 {
    display: block;
    float: left;
    width: 16.66667%
}

.col-lg-3 {
    display: block;
    float: left;
    width: 25%
}

.col-lg-4 {
    display: block;
    float: left;
    width: 33.33333%
}

.col-lg-5 {
    display: block;
    float: left;
    width: 41.66667%
}

.col-lg-6 {
    display: block;
    float: left;
    width: 50%
}

.col-lg-7 {
    display: block;
    float: left;
    width: 58.33333%
}

.col-lg-8 {
    display: block;
    float: left;
    width: 66.66667%
}

.col-lg-9 {
    display: block;
    float: left;
    width: 75%
}

.col-lg-10 {
    display: block;
    float: left;
    width: 83.33333%
}

.col-lg-11 {
    display: block;
    float: left;
    width: 91.66667%
}

.col-lg-12 {
    display: block;
    float: left;
    width: 100%
}

@media only screen and (max-width: 1399px) {
    .col-md-1 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-2 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-3 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-4 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-5 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-6 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-7 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-8 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-9 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-10 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-11 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-12 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-md-1 {
        display: block;
        float: left;
        width: 8.33333%
    }

    .col-md-2 {
        display: block;
        float: left;
        width: 16.66667%
    }

    .col-md-3 {
        display: block;
        float: left;
        width: 25%
    }

    .col-md-4 {
        display: block;
        float: left;
        width: 33.33333%
    }

    .col-md-5 {
        display: block;
        float: left;
        width: 41.66667%
    }

    .col-md-6 {
        display: block;
        float: left;
        width: 50%
    }

    .col-md-7 {
        display: block;
        float: left;
        width: 58.33333%
    }

    .col-md-8 {
        display: block;
        float: left;
        width: 66.66667%
    }

    .col-md-9 {
        display: block;
        float: left;
        width: 75%
    }

    .col-md-10 {
        display: block;
        float: left;
        width: 83.33333%
    }

    .col-md-11 {
        display: block;
        float: left;
        width: 91.66667%
    }

    .col-md-12 {
        display: block;
        float: left;
        width: 100%
    }
}

@media only screen and (max-width: 999px) {
    .col-sm-1 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-2 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-3 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-4 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-5 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-6 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-7 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-8 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-9 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-10 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-11 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-12 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-sm-1 {
        display: block;
        float: left;
        width: 8.33333%
    }

    .col-sm-2 {
        display: block;
        float: left;
        width: 16.66667%
    }

    .col-sm-3 {
        display: block;
        float: left;
        width: 25%
    }

    .col-sm-4 {
        display: block;
        float: left;
        width: 33.33333%
    }

    .col-sm-5 {
        display: block;
        float: left;
        width: 41.66667%
    }

    .col-sm-6 {
        display: block;
        float: left;
        width: 50%
    }

    .col-sm-7 {
        display: block;
        float: left;
        width: 58.33333%
    }

    .col-sm-8 {
        display: block;
        float: left;
        width: 66.66667%
    }

    .col-sm-9 {
        display: block;
        float: left;
        width: 75%
    }

    .col-sm-10 {
        display: block;
        float: left;
        width: 83.33333%
    }

    .col-sm-11 {
        display: block;
        float: left;
        width: 91.66667%
    }

    .col-sm-12 {
        display: block;
        float: left;
        width: 100%
    }
}

@media only screen and (max-width: 767px) {
    .col-xs-1 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-2 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-3 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-4 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-5 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-6 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-7 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-8 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-9 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-10 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-11 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-12 {
        padding-right: 40px;
        padding-left: 40px
    }

    .col-xs-1 {
        display: block;
        float: left;
        width: 8.33333%
    }

    .col-xs-2 {
        display: block;
        float: left;
        width: 16.66667%
    }

    .col-xs-3 {
        display: block;
        float: left;
        width: 25%
    }

    .col-xs-4 {
        display: block;
        float: left;
        width: 33.33333%
    }

    .col-xs-5 {
        display: block;
        float: left;
        width: 41.66667%
    }

    .col-xs-6 {
        display: block;
        float: left;
        width: 50%
    }

    .col-xs-7 {
        display: block;
        float: left;
        width: 58.33333%
    }

    .col-xs-8 {
        display: block;
        float: left;
        width: 66.66667%
    }

    .col-xs-9 {
        display: block;
        float: left;
        width: 75%
    }

    .col-xs-10 {
        display: block;
        float: left;
        width: 83.33333%
    }

    .col-xs-11 {
        display: block;
        float: left;
        width: 91.66667%
    }

    .col-xs-12 {
        display: block;
        float: left;
        width: 100%
    }
}

.offset-lg-0 {
    margin-left: 0
}

.offset-lg-1 {
    margin-left: 8.33333%
}

.offset-lg-2 {
    margin-left: 16.66667%
}

.offset-lg-3 {
    margin-left: 25%
}

.offset-lg-4 {
    margin-left: 33.33333%
}

.offset-lg-5 {
    margin-left: 41.66667%
}

.offset-lg-6 {
    margin-left: 50%
}

.offset-lg-7 {
    margin-left: 58.33333%
}

.offset-lg-8 {
    margin-left: 66.66667%
}

.offset-lg-9 {
    margin-left: 75%
}

.offset-lg-10 {
    margin-left: 83.33333%
}

.offset-lg-11 {
    margin-left: 91.66667%
}

.offset-lg-12 {
    margin-left: 100%
}

@media only screen and (max-width: 1399px) {
    .offset-md-0 {
        margin-left: 0
    }

    .offset-md-1 {
        margin-left: 8.33333%
    }

    .offset-md-2 {
        margin-left: 16.66667%
    }

    .offset-md-3 {
        margin-left: 25%
    }

    .offset-md-4 {
        margin-left: 33.33333%
    }

    .offset-md-5 {
        margin-left: 41.66667%
    }

    .offset-md-6 {
        margin-left: 50%
    }

    .offset-md-7 {
        margin-left: 58.33333%
    }

    .offset-md-8 {
        margin-left: 66.66667%
    }

    .offset-md-9 {
        margin-left: 75%
    }

    .offset-md-10 {
        margin-left: 83.33333%
    }

    .offset-md-11 {
        margin-left: 91.66667%
    }

    .offset-md-12 {
        margin-left: 100%
    }
}

@media only screen and (max-width: 999px) {
    .offset-sm-0 {
        margin-left: 0
    }

    .offset-sm-1 {
        margin-left: 8.33333%
    }

    .offset-sm-2 {
        margin-left: 16.66667%
    }

    .offset-sm-3 {
        margin-left: 25%
    }

    .offset-sm-4 {
        margin-left: 33.33333%
    }

    .offset-sm-5 {
        margin-left: 41.66667%
    }

    .offset-sm-6 {
        margin-left: 50%
    }

    .offset-sm-7 {
        margin-left: 58.33333%
    }

    .offset-sm-8 {
        margin-left: 66.66667%
    }

    .offset-sm-9 {
        margin-left: 75%
    }

    .offset-sm-10 {
        margin-left: 83.33333%
    }

    .offset-sm-11 {
        margin-left: 91.66667%
    }

    .offset-sm-12 {
        margin-left: 100%
    }
}

@media only screen and (max-width: 767px) {
    .offset-xs-0 {
        margin-left: 0
    }

    .offset-xs-1 {
        margin-left: 8.33333%
    }

    .offset-xs-2 {
        margin-left: 16.66667%
    }

    .offset-xs-3 {
        margin-left: 25%
    }

    .offset-xs-4 {
        margin-left: 33.33333%
    }

    .offset-xs-5 {
        margin-left: 41.66667%
    }

    .offset-xs-6 {
        margin-left: 50%
    }

    .offset-xs-7 {
        margin-left: 58.33333%
    }

    .offset-xs-8 {
        margin-left: 66.66667%
    }

    .offset-xs-9 {
        margin-left: 75%
    }

    .offset-xs-10 {
        margin-left: 83.33333%
    }

    .offset-xs-11 {
        margin-left: 91.66667%
    }

    .offset-xs-12 {
        margin-left: 100%
    }
}

@media only screen and (max-width: 767px) {
    .hidden-xs {
        display: none
    }
}

.visible-xs {
    display: none
}

@media only screen and (max-width: 767px) {
    .visible-xs {
        display: block
    }
}

.hover-blob {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -2;
    transition: all .35s ease-out;
    pointer-events: none;
    will-change: all
}

.hover-blob .blob {
    position: absolute;
    top: 50%;
    left: 50%;
    border-radius: 100px;
    transition: background .35s ease-out;
    pointer-events: none
}

.hover-blob .blob._rectangular {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 0
}

._color-1:hover {
    color: #ff00fc !important
}

._color-2:hover {
    color: #001eff !important
}

._color-3:hover {
    color: red !important
}

._color-4:hover {
    color: #fcff00 !important
}

._color-5:hover {
    color: #0dd01b !important
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 20px;
    font-weight: 700;
    font-family: "Avenir Next";
    font-size: 0;
    text-align: justify;
    z-index: 10;
    box-sizing: border-box
}

.header:after {
    content: '';
    display: inline-block;
    height: 0;
    width: 100%
}

@supports (display:flex) {
    .header {
        text-align: left;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: center;
        align-items: center
    }

    .header:after {
        display: none
    }
}

.header__item {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    width: auto;
    font-size: 12px
}

@media only screen and (max-width: 768px) {
    .header__item {
        opacity: .5
    }
}

@media only screen and (max-width: 350px) {
    .header__item {
        font-size: 10px
    }
}

.header__item._logo {
    font-size: 0
}

@media only screen and (max-width: 768px) {
    .header__item._logo {
        opacity: 1
    }
}

@media only screen and (max-width: 767px) {
    .header__item._new {
        display: none
    }
}

@media only screen and (max-width: 768px) {
    .header__item._new {
        opacity: 1
    }
}

.header__link {
    position: relative;
    line-height: 20px;
    display: inline-block;
    padding: 0 5px
}

.header__link._logo {
    padding: 0
}

.header__link._logo._active {
    pointer-events: all
}

.header__link._close {
    display: none;
    position: absolute;
    z-index: 1;
    top: -9px;
    left: 50%;
    width: 43px;
    height: 43px;
    padding: 0;
    opacity: .75;
    -ms-transform: translateX(-50%);
    transform: translateX(-50%)
}

.header__link._close:after, .header__link._close:before {
    display: block;
    content: " ";
    position: absolute;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 1px;
    height: 60px;
    margin: auto;
    background-color: #fff
}

.header__link._close:after {
    -ms-transform: rotate(45deg);
    transform: rotate(45deg)
}

.header__link._close:before {
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

.header__link._close:hover {
    opacity: 1
}

._newproject .header__link._close {
    display: block
}

._newproject .header__link._newproject {
    opacity: .3;
    pointer-events: none
}

.logo {
    position: relative;
    display: block;
    width: 41px;
    height: 31px
}

.burger {
    position: relative;
    display: inline-block;
    cursor: pointer;
    width: 23px;
    height: 13px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.burger i {
    position: absolute;
    display: block;
    content: '';
    width: 23px;
    height: 1px;
    left: 0;
    top: 7px;
    transition: all .35s ease-out;
    background-color: #fff;
    will-change: transform
}

.burger i:nth-child(1) {
    transform: translate3d(0, -6px, 0)
}

.burger i:nth-child(2) {
    transform: translate3d(0, -2px, 0)
}

.burger i:nth-child(3) {
    transform: translate3d(0, 2px, 0)
}

.burger i:nth-child(4) {
    transform: translate3d(0, 6px, 0);
    background: 0 0
}

.burger i:nth-child(4):before {
    position: absolute;
    display: block;
    content: '';
    width: 19px;
    height: 1px;
    left: 0;
    background: #fff
}

.burger i:nth-child(4):after {
    position: absolute;
    display: block;
    content: '';
    width: 2px;
    height: 1px;
    left: 21px;
    background: #fff
}

.burger._opened i:nth-child(1) {
    transform: translate3d(0, 0, 0);
    opacity: 0
}

.burger._opened i:nth-child(2) {
    transform: translate3d(0, 0, 0);
    opacity: 0
}

.burger._opened i:nth-child(3) {
    transform: translate3d(0, 0, 0) rotate(45deg)
}

.burger._opened i:nth-child(4) {
    transform: translate3d(0, 0, 0) rotate(-45deg)
}

.nav-scroll-down {
    position: absolute;
    cursor: pointer;
    bottom: 80px;
    left: 50%;
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    font-family: "Avenir Next";
    font-size: 11px;
    letter-spacing: .1em;
    font-weight: 700;
    text-transform: uppercase;
    will-change: opacity;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.nav-scroll-down:after {
    display: block;
    content: " ";
    position: absolute;
    top: 30px;
    left: 0;
    right: 0;
    height: 100px;
    width: 1px;
    margin: auto;
    background-color: #959595;
    image-rendering: optimizeSpeed
}

.nav-right {
    position: absolute;
    z-index: 3;
    right: 0;
    top: 50%;
    margin-top: -40px
}

@media only screen and (max-width: 768px) {
    .nav-right {
        display: none
    }
}

.nav-right__item {
    width: 64px;
    height: 1px;
    background-color: #747474;
    cursor: pointer;
    -ms-transform: translateX(50%);
    transform: translateX(50%);
    transition: transform .15s ease-out, background-color .15s ease-out
}

.nav-right__item:before {
    display: block;
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 20px;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%)
}

.nav-right__item:not(:last-child) {
    margin-bottom: 19px
}

.nav-right__item:hover {
    -ms-transform: translateX(30%);
    transform: translateX(30%)
}

.nav-right__item._active {
    background-color: #fff;
    -ms-transform: translateX(0);
    transform: translateX(0);
    transition: none;
    pointer-events: none
}

._desktop .nav-scroll-down:hover {
    opacity: .6
}

.services {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    height: 100%;
    width: 100%;
    font-family: "Avenir Next";
    font-size: 0
}

.services__item {
    vertical-align: middle;
    white-space: normal;
    text-align: left;
    display: inline-block;
    width: 33.33%;
    padding-left: 40px;
    padding-right: 40px;
    max-width: 355px
}

@media only screen and (max-width: 1024px) {
    .services__item {
        display: inline-block;
        width: 95%;
        max-width: 425px;
        white-space: normal;
        float: none;
        opacity: .5
    }
}

@media only screen and (max-width: 767px) {
    .services__item {
        width: 70%;
        padding-right: 0;
        padding-left: 35px
    }
}

@media only screen and (orientation: landscape) {
    .services__item {
        width: 100%;
        margin-bottom: 40px
    }
}

.services__item._active {
    opacity: 1
}

.services__num {
    margin-bottom: 2px;
    color: #8d8d8d;
    font-family: "Bodoni Svty Two ITCTT", Bodoni;
    font-size: 24px;
    font-weight: 700
}

@media only screen and (max-width: 999px) {
    .services__num {
        margin-bottom: 8px;
        font-size: 20px
    }
}

@media only screen and (max-width: 767px) {
    .services__num {
        margin-bottom: 4px;
        font-size: 24px
    }
}

@media (max-height: 450px) and (min-width: 1024px) {
    .services__num {
        margin-bottom: 8px;
        font-size: 20px
    }
}

@media (max-height: 350px) and (min-width: 1024px) {
    .services__num {
        margin-bottom: 4px;
        font-size: 18px
    }
}

@media only screen and (orientation: landscape) {
    .services__num {
        margin-bottom: 4px;
        font-size: 18px
    }
}

.services__title {
    margin-bottom: 20px;
    color: #fff;
    font-size: 36px;
    font-weight: 700;
    line-height: 30px
}

@media only screen and (max-width: 999px) {
    .services__title {
        margin-bottom: 25px;
        font-size: 31px;
        line-height: 25px
    }
}

@media only screen and (max-width: 767px) {
    .services__title {
        margin-bottom: 23px;
        font-size: 36px;
        line-height: .85em
    }
}

@media only screen and (max-width: 420px) {
    .services__title {
        font-size: 30px
    }
}

@media only screen and (max-width: 340px) {
    .services__title {
        font-size: 24px
    }
}

@media (max-height: 450px) and (min-width: 1024px) {
    .services__title {
        margin-bottom: 25px;
        font-size: 31px;
        line-height: 25px
    }
}

@media (max-height: 350px) and (min-width: 1024px) {
    .services__title {
        margin-bottom: 15px;
        font-size: 26px
    }
}

@media only screen and (orientation: landscape) {
    .services__title {
        margin-bottom: 15px;
        font-size: 26px
    }
}

.services__info {
    margin-bottom: 34px;
    color: #c4c4c4;
    font-size: 16px;
    font-weight: 400;
    line-height: 30px
}

@media only screen and (max-width: 999px) {
    .services__info {
        margin-bottom: 30px;
        font-size: 14px;
        line-height: 25px
    }
}

@media only screen and (max-width: 767px) {
    .services__info {
        margin-bottom: 20px
    }
}

@media (max-height: 450px) and (min-width: 1024px) {
    .services__info {
        margin-bottom: 30px;
        font-size: 14px;
        line-height: 25px
    }
}

@media (max-height: 350px) and (min-width: 1024px) {
    .services__info {
        margin-bottom: 20px;
        font-size: 13px;
        line-height: 1.5em
    }
}

@media only screen and (orientation: landscape) {
    .services__info {
        margin-bottom: 20px;
        font-size: 13px;
        line-height: 1.5em
    }
}

.services__desc {
    font-size: 18px;
    font-weight: 500;
    line-height: 30px
}

@media only screen and (max-width: 999px) {
    .services__desc {
        font-size: 16px;
        line-height: 25px
    }
}

@media only screen and (max-width: 340px) {
    .services__desc {
        font-size: 14px
    }
}

@media (max-height: 450px) and (min-width: 1024px) {
    .services__desc {
        font-size: 16px;
        line-height: 25px
    }
}

@media (max-height: 350px) and (min-width: 1024px) {
    .services__desc {
        font-size: 15px
    }
}

@media only screen and (orientation: landscape) {
    .services__desc {
        font-size: 15px
    }
}

.test-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    z-index: 2;
    overflow: hidden;
    padding: 75px 0 65px;
    box-sizing: border-box
}

.test-slide._long {
    overflow: auto
}

.test-slide._blur {
    -webkit-filter: blur(5px);
    filter: blur(5px)
}

.slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    overflow: hidden;
    padding: 75px 0 65px;
    box-sizing: border-box
}

.slide__title {
    display: inline-block;
    vertical-align: middle;
    width: 100%;
    max-width: 1260px;
    font-family: "Bodoni Svty Two ITCTT", Bodoni;
    font-size: 4.5vw;
    font-weight: 300;
    text-align: center
}

@media only screen and (max-width: 768px) {
    .slide__title {
        font-size: 5.5vh
    }
}

@media only screen and (max-width: 320px) {
    .slide__title {
        font-size: 5vh
    }
}

.slide._blur {
    -webkit-filter: blur(5px);
    filter: blur(5px)
}

.newproject {
    max-width: 685px;
    margin: 0 auto;
    padding: 150px 10px 115px;
    text-align: center
}

@media only screen and (max-width: 767px) {
    .newproject {
        padding-top: 65px
    }
}

.newproject__title {
    margin-bottom: 10px;
    font-size: 36px;
    font-weight: 700;
    line-height: 30px
}

.newproject__subtitle {
    margin-bottom: 65px;
    font-family: "Bodoni Svty Two ITCTT", Bodoni;
    font-size: 24px;
    font-weight: 300;
    font-style: italic
}

.newproject__subtitle-text {
    opacity: .5
}

.newproject__subtitle-link {
    position: relative
}

.newproject__subtitle-link:after {
    display: block;
    content: " ";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0;
    left: 0;
    background-color: #fff
}

.newproject__submit {
    position: relative;
    min-width: 165px;
    letter-spacing: .015em
}

.newproject__btn {
    width: 165px;
    height: 58px;
    margin: auto;
    margin-top: 40px
}

.newproject-form {
    will-change: opacity;
    opacity: 1
}

.newproject-form .row {
    text-align: left;
    margin-left: -10px;
    margin-right: -10px
}

.newproject-form__group {
    margin-bottom: 30px;
    padding-left: 10px;
    padding-right: 10px
}

.newproject-form__input {
    width: 100%
}

.newproject-form__title {
    margin-top: 30px;
    margin-bottom: 25px;
    font-size: 24px;
    font-weight: 700;
    line-height: 30px
}

.newproject-form__dropzone {
    margin-bottom: 55px
}

.newproject-form._loading {
    pointer-events: none
}

.newproject-form._loading .newproject-btn, .newproject-form._loading .newproject-form__group, .newproject-form._loading .newproject-form__title {
    opacity: .5
}

.newproject-btn {
    position: relative;
    cursor: pointer
}

.newproject-btn__text {
    position: absolute;
    left: 50%;
    top: 50%;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 600;
    font-family: "Avenir Next";
    color: #fff;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.newproject-btn__input {
    position: absolute;
    display: block;
    z-index: 2;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    border: 0;
    opacity: 0
}

.newproject-btn__input:focus {
    outline: 0
}

.newproject-btn._disabled {
    opacity: .2;
    pointer-events: none
}

.newproject-alert {
    display: none;
    max-width: 450px;
    margin: 55px auto 30px;
    font-size: 18px;
    color: #9b85d9
}

.newproject-alert__icon {
    vertical-align: middle;
    margin-right: 5px;
    width: 28px;
    height: 28px
}

.newproject-alert__link {
    position: relative
}

.newproject-alert__link:before {
    display: block;
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background-color: #fff
}

.newproject-agree {
    margin: 25px auto 10px;
    font-size: 18px;
    color: rgba(255, 255, 255, .5)
}

.newproject-bg {
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none
}

.newproject-bg__inner {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 25%
}

.newproject-bg__inner._left {
    left: 0
}

.newproject-bg__inner._right {
    right: 0
}

.newproject-bg__round {
    position: absolute;
    border-radius: 100%;
    transition: width .35s ease-out, height .35s ease-out
}

.newproject-bg__round._orange {
    width: 355px;
    height: 355px;
    background-color: #ed5938
}

@media only screen and (max-width: 767px) {
    .newproject-bg__round._orange {
        width: 120px;
        height: 120px
    }
}

.newproject-bg__round._pink {
    width: 600px;
    height: 600px;
    background-color: #d93294
}

@media only screen and (max-width: 767px) {
    .newproject-bg__round._pink {
        width: 200px;
        height: 200px
    }
}

.newproject-bg__round._blue {
    width: 460px;
    height: 460px;
    background-color: #6aeafc
}

@media only screen and (max-width: 767px) {
    .newproject-bg__round._blue {
        width: 155px;
        height: 155px
    }
}

.newproject-bg__round._green {
    width: 600px;
    height: 600px;
    background-color: #60cd41
}

@media only screen and (max-width: 767px) {
    .newproject-bg__round._green {
        height: 200px;
        width: 200px
    }
}

._desktop .newproject__submit:hover {
    border-color: transparent
}

._desktop .newproject-agree__link:hover {
    text-decoration: underline
}

.i-text {
    display: block;
    width: 100%;
    max-width: 100%;
    -webkit-appearance: none;
    border-radius: 0;
    background-color: transparent;
    padding: 10px 5px;
    box-sizing: border-box;
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .3);
    font-size: 18px;
    font-weight: 500;
    line-height: 30px;
    color: #fff;
    font-family: "Avenir Next"
}

.i-text:placeholder {
    color: rgba(255, 255, 255, .5)
}

.i-text:focus {
    outline: 0;
    border-bottom-color: #fff
}

.i-select {
    display: block;
    width: 100%;
    padding: 5px
}

.i-textarea {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 5px;
    overflow: auto
}

.i-radio {
    position: relative
}

.i-checkbox {
    position: relative;
    text-align: center
}

.i-checkbox__input {
    position: absolute;
    left: -9999px
}

.i-checkbox__input:checked ~ .i-checkbox__text {
    border-color: #fff;
    background: #fff;
    color: #000
}

.i-checkbox__text {
    display: block;
    width: 100%;
    padding: 9px 5px;
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
    border-radius: 2px;
    border: 1px solid rgba(255, 255, 255, .2);
    box-sizing: border-box;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.i-checkbox__text:hover {
    border: 1px solid rgba(255, 255, 255, .3)
}

.btn {
    position: relative;
    display: inline-block;
    padding: 18px 25px;
    border: 2px solid #fff;
    background-color: transparent;
    text-transform: uppercase;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    font-family: "Avenir Next";
    color: #fff
}

.btn:active, .btn:focus {
    outline: 0
}

.btn__arrow {
    position: absolute;
    right: -2px;
    bottom: -2px;
    top: -2px;
    width: 52px;
    padding: 17px 0;
    border: 2px solid #fff;
    text-align: center
}

.btn._gray {
    border-color: #575757
}

.btn._gray .btn__arrow {
    border-color: #575757
}

.btn._with-arrow {
    padding-right: 75px
}

.dropzone {
    position: relative;
    border-radius: 15px;
    border: 2px dashed rgba(255, 255, 255, .5);
    font-size: 18px;
    font-weight: 400;
    line-height: 30px
}

.dropzone__text {
    display: inline-block;
    padding: 60px 0
}

.dropzone__upload {
    position: relative;
    cursor: pointer;
    color: #00edff
}

.dropzone__upload:after {
    display: block;
    content: " ";
    position: absolute;
    width: 100%;
    height: 1px;
    left: 0;
    bottom: 0;
    background-color: #00edff
}

.dropzone__input {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    opacity: 0;
    z-index: -1
}

.dropzone .dz-message {
    display: none
}

.dropzone-list {
    padding: 20px;
    text-align: left;
    font-size: 0;
    line-height: 1
}

.dropzone-list__item {
    vertical-align: top;
    display: inline-block;
    width: 33.33%;
    padding: 20px;
    box-sizing: border-box
}

.dropzone-file {
    position: relative;
    text-transform: uppercase;
    font-size: 14px
}

.dropzone-file__del {
    position: absolute;
    z-index: 1;
    cursor: pointer;
    right: 35px;
    top: 35px
}

.dropzone-file__del:before {
    display: block;
    content: " ";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 30px;
    height: 30px;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.dropzone-file__del-icon {
    width: 15px;
    height: 15px;
    stroke: #fff;
    stroke-width: 5px
}

.dropzone-file__preview {
    margin-bottom: 10px;
    padding-bottom: 100%;
    background-color: #fff;
    background-position: top center;
    background-size: cover;
    background-repeat: no-repeat
}

.dropzone-file__name {
    margin-bottom: 5px;
    font-weight: 700
}

.dropzone-file__progress {
    opacity: .5
}

.form-input {
    position: relative;
    overflow: hidden;
    padding-bottom: 15px
}

.form-input__input {
    padding: .5em 0 .45em;
    border: 0;
    font-size: 24px
}

.form-input__input._filled + .form-input__label, .form-input__input:focus + .form-input__label {
    opacity: 0;
    transform: translate3d(0, -1.25em, 0) scale3d(.8, .88, 1)
}

.form-input__input._filled ~ .form-input__border, .form-input__input:focus ~ .form-input__border {
    transform: translate3d(-66.6%, 0, 0)
}

.form-input__input._error + .form-input__label {
    color: rgba(255, 0, 0, .65)
}

.form-input__input._error ~ .form-input__border {
    stroke: rgba(255, 0, 0, .75)
}

.form-input__label {
    position: absolute;
    display: block;
    cursor: text;
    top: 0;
    left: 0;
    width: 100%;
    padding: 0;
    color: rgba(255, 255, 255, .5);
    font-size: 18px;
    font-family: "Avenir Next";
    -ms-transform-origin: 0 0;
    transform-origin: 0 0
}

.form-input__span {
    display: inline-block;
    width: 100%;
    padding: 1.15em 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.form-input__border {
    position: absolute;
    z-index: -1;
    bottom: 15px;
    left: 0;
    width: 300%;
    height: 100%;
    fill: none;
    stroke: rgba(255, 255, 255, .3);
    transform: translate3d(0, 0, 0)
}

.form-input__error {
    position: absolute;
    display: none;
    bottom: 0;
    color: #ff4c29;
    font-size: 15px
}

.form-input._filled .form-input__label {
    transform: translate3d(0, -1.25em, 0) scale3d(.8, .88, 1)
}

.form-input._filled .form-input__border {
    transform: translate3d(-66.6%, 0, 0)
}

.form-input._required {
    padding-right: 8px
}

.form-input._required:after {
    content: '*';
    position: absolute;
    opacity: .5;
    top: 18px;
    right: 0;
    font-size: 18px;
    font-weight: 700
}

.form-input._error .form-input__input {
    color: #ff4c29
}

.form-input._error .form-input__error {
    display: block
}

.contacts {
    position: relative;
    text-align: center
}

.contacts__email {
    position: relative;
    margin-bottom: 15px;
    font-family: "Minion Pro";
    font-size: 120px;
    line-height: 1;
    font-weight: 400
}

@media only screen and (max-width: 767px) {
    .contacts__email {
        font-size: 16vw
    }
}

.contacts__email-svg {
    width: 100%;
    max-width: 650px
}

.contacts__email-text {
    position: absolute;
    top: -12px;
    left: -2px;
    right: 0;
    color: transparent;
    text-align: center;
    letter-spacing: .004em
}

.contacts__address {
    font-family: "Avenir Next";
    font-size: 24px;
    font-weight: 500
}

.blackout {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, .5);
    opacity: 0;
    pointer-events: none;
    will-change: opacity
}

.popups-wrapper {
    position: fixed;
    display: none;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    z-index: 5;
    overflow: auto;
    white-space: nowrap;
    font-size: 0;
    background-color: rgba(54, 10, 179, .8);
    box-sizing: border-box
}

.popups-wrapper:before {
    display: inline-block;
    position: relative;
    content: ' ';
    width: 0;
    height: 100%;
    vertical-align: middle
}

.popups-wrapper__content {
    display: inline-block;
    position: relative;
    padding: 20px 0;
    text-align: left;
    vertical-align: middle;
    white-space: normal;
    font-size: 14px
}

.popup {
    position: relative;
    padding: 20px
}

.newproject-sending {
    position: relative;
    max-width: 580px;
    text-align: center
}

.newproject-sending__container {
    position: relative;
    margin-bottom: 55px;
    padding: 40px 60px
}

.newproject-sending__container:before {
    display: block;
    content: " ";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(50% - 90px);
    height: 100%;
    border-radius: 15px 0 0 15px;
    border: 1px solid rgba(255, 255, 255, .2);
    border-right: 0
}

.newproject-sending__container:after {
    display: block;
    content: " ";
    position: absolute;
    top: 0;
    right: 0;
    width: calc(50% - 90px);
    height: 100%;
    border-radius: 0 15px 15px 0;
    border: 1px solid rgba(255, 255, 255, .2);
    border-left: 0
}

.newproject-sending__title {
    position: absolute;
    top: 0;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-weight: 700;
    letter-spacing: .3em;
    text-transform: uppercase
}

.newproject-sending__info {
    font-size: 24px;
    font-weight: 700
}

.newproject-sending__info:after {
    display: block;
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -2px;
    width: 178px;
    margin: auto;
    border-bottom: 1px solid rgba(255, 255, 255, .2)
}

.newproject-sending__loader {
    position: relative;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase
}

.newproject-sent {
    text-align: center
}

.newproject-sent__title {
    margin-bottom: 30px;
    font-size: 36px;
    font-weight: 700
}

.newproject-sent__info {
    max-width: 400px;
    margin: 0 auto 35px;
    font-size: 24px;
    line-height: 26px
}

.newproject-sent__btn {
    padding: 15px;
    min-width: 160px
}

.newproject-sent__btn-icon {
    width: 20px;
    height: 15px
}

.menu-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    display: none;
    z-index: 2
}

.menu-wrapper:before {
    content: ' ';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    background-color: rgba(0, 0, 0, .85);
    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABQAAAALQAQMAAAD1s08VAAAABlBMVEUAAAAAAAClZ7nPAAAAAnRSTlMAgewsfo4AAAQeSURBVHjazM6BAAAADAShOb2/wUFNowi6cH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHO6bnQMBAAAAhkFQ9zcY1DWKID8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB+MJwfHM4PhvODw/nBcH5wOD8Yzg8O5wfD+cHh/GA4PzicHwznB4fzg+H84HB88Ek/LCEpIRd3AAAAAElFTkSuQmCC)
}

.menu-wrapper__content {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    text-align: center;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.menu {
    position: relative
}

.menu__item:not(:last-child) {
    margin-bottom: 6.6vh
}

@media only screen and (max-width: 767px) {
    .menu__item:not(:last-child) {
        margin-bottom: 6vh
    }
}

.menu__item._mobile {
    display: none
}

@media only screen and (max-width: 767px) {
    .menu__item._mobile {
        display: block
    }
}

.menu__link {
    cursor: pointer;
    font-family: "Minion Pro";
    font-size: 72px;
    font-size: 8vh;
    line-height: 1em;
    font-weight: 400;
    transition: color .35s ease-out
}

@media only screen and (max-width: 767px) {
    .menu__link {
        font-size: 8vh
    }
}

.menu__link:hover {
    transition: color .25s ease-out
}

.menu__link._active {
    pointer-events: none;
    opacity: .25
}

.works-slider {
    position: relative;
    vertical-align: middle;
    display: inline-block;
    height: 100%;
    width: 100%;
    font-size: 0;
    white-space: nowrap;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.works-slider__item {
    position: relative;
    display: inline-block;
    width: 100%;
    max-width: 1110px;
    height: 100%;
    font-size: 14px;
    vertical-align: top;
    white-space: normal;
    transition: -webkit-filter .35s ease-out;
    transition: filter .35s ease-out;
    transition: filter .35s ease-out, -webkit-filter .35s ease-out
}

@media only screen and (max-width: 1300px) {
    .works-slider__item {
        max-width: 1090px
    }
}

.work-preview {
    position: relative;
    display: block;
    width: 75vw;
    height: 430px;
    max-width: 960px;
    z-index: 1
}

@media only screen and (max-width: 999px) {
    .work-preview {
        height: 55vh
    }
}

@media only screen and (max-width: 767px) {
    .work-preview {
        width: 100vw;
        height: 100vh
    }
}

.work-preview__img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat
}

.work-preview__img._liquid {
    background: 0 0 !important
}

.work-preview-info {
    width: 115%;
    margin-left: -15%;
    padding: 0;
    z-index: 10;
    font-family: "Avenir Next"
}

@media only screen and (max-width: 767px) {
    .work-preview-info {
        margin-left: 0;
        width: 100%
    }
}

.work-preview-info__content {
    width: 100%;
    padding: 0 30px;
    box-sizing: border-box
}

@media only screen and (max-width: 999px) {
    .work-preview-info__content {
        vertical-align: top
    }
}

@media only screen and (max-width: 767px) {
    .work-preview-info__content {
        vertical-align: middle;
        padding: 0 20px
    }
}

.work-preview-info__categories {
    position: relative;
    margin-top: 7vh;
    font-size: 16px;
    font-weight: 500
}

@media only screen and (max-width: 999px) {
    .work-preview-info__categories {
        margin-top: 5.5vh
    }
}

@media only screen and (max-width: 767px) {
    .work-preview-info__categories {
        margin-top: 24vh;
        font-size: 14px
    }
}

.work-preview-info__title {
    position: relative;
    margin-top: 2vh;
    font-size: 72px;
    letter-spacing: .6em;
    font-weight: 700;
    line-height: 1.3888;
    text-transform: uppercase
}

@media only screen and (max-width: 999px) {
    .work-preview-info__title {
        font-size: 50px
    }
}

@media only screen and (max-width: 767px) {
    .work-preview-info__title {
        margin-top: 1.5vh;
        font-size: 25px
    }
}

.slide-nav {
    position: absolute;
    bottom: 7.5vh;
    left: 0;
    right: 0;
    max-width: 960px;
    margin: auto;
    text-align: center;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

@media only screen and (max-width: 999px) {
    .slide-nav {
        bottom: 12vh
    }
}

@media only screen and (max-width: 767px) {
    .slide-nav {
        bottom: 2vh
    }
}

.slide-nav__btn {
    position: absolute;
    right: 0;
    top: -3px;
    padding: 14px 41px;
    text-transform: uppercase
}

@media only screen and (max-width: 999px) {
    .slide-nav__btn {
        position: relative;
        padding: 12px 30px;
        margin-top: 5.5vh;
        display: none
    }
}

.slide-nav__btn:after {
    display: block;
    content: " ";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 150%;
    height: 150%;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.slide-nav__btn:hover {
    background-color: #f43f3d;
    border-color: #f43f3d;
    border-radius: 10px
}

.slide-nav._services {
    display: none
}

@media only screen and (max-width: 1024px) {
    .slide-nav._services {
        display: block
    }
}

@media only screen and (max-width: 999px) {
    .slide-nav._services {
        bottom: 2vh
    }
}

@media only screen and (orientation: landscape) {
    .slide-nav._services {
        bottom: 20px
    }
}

.slide-controls {
    position: relative;
    width: 44px;
    margin: auto;
    text-align: center
}

.slide-controls__count {
    display: inline-block;
    vertical-align: middle
}

.slide-controls__arrow {
    cursor: pointer;
    position: absolute;
    top: 19px
}

@media only screen and (max-width: 767px) {
    .slide-controls__arrow {
        top: 18px
    }
}

.slide-controls__arrow:before {
    display: block;
    content: " ";
    position: absolute;
    width: 120%;
    height: 40px;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.slide-controls__arrow svg {
    width: 140px;
    height: 5px;
    stroke: #fff
}

@media only screen and (max-width: 767px) {
    .slide-controls__arrow svg {
        width: 50px;
        stroke-width: 3px
    }
}

.slide-controls__arrow._prev {
    right: 95px
}

@media only screen and (max-width: 767px) {
    .slide-controls__arrow._prev {
        right: 62px
    }
}

.slide-controls__arrow._next {
    left: 95px
}

@media only screen and (max-width: 767px) {
    .slide-controls__arrow._next {
        left: 62px
    }
}

.slide-controls__arrow._unactive {
    posinter-events: none;
    opacity: .5
}

.slide-controls__count {
    margin: 0
}

.slide-count {
    position: relative;
    height: 44px;
    width: 44px
}

@media only screen and (max-width: 767px) {
    .slide-count {
        height: 42px;
        width: 42px
    }
}

.slide-count:before {
    display: block;
    content: " ";
    position: absolute;
    top: 21px;
    left: -9px;
    width: 62px;
    height: 1px;
    background-color: #747474;
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

@media only screen and (max-width: 767px) {
    .slide-count:before {
        width: 58px;
        background-color: #fff
    }
}

.slide-count__num {
    position: absolute;
    font-size: 16px;
    line-height: 1;
    font-weight: 900
}

@media only screen and (max-width: 767px) {
    .slide-count__num {
        font-size: 12px
    }
}

.slide-count__num._current {
    top: 0;
    left: 0
}

.slide-count__num._all {
    right: 0;
    bottom: 0
}

.footer {
    position: fixed;
    bottom: 0;
    padding: 22px 20px;
    font-size: 0;
    z-index: 10;
    box-sizing: border-box
}

.footer._left {
    left: 0
}

.footer._right {
    right: 0;
    text-align: right
}

.networks {
    position: relative;
    font-size: 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

@media only screen and (max-width: 767px) {
    .networks {
        text-align: center
    }
}

.networks__item {
    display: inline-block;
    vertical-align: middle
}

@media only screen and (max-width: 767px) {
    .networks__item {
        display: block
    }
}

.networks__item:not(:last-child) {
    margin-right: 30px
}

@media only screen and (max-width: 767px) {
    .networks__item:not(:last-child) {
        margin-right: 0;
        margin-bottom: 18px
    }
}

.networks__link {
    position: relative;
    display: inline-block
}

.networks__link:before {
    display: block;
    content: " ";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.networks__icon {
    position: relative
}

.networks__icon._fb {
    width: 9px;
    height: 16px
}

.networks__icon._insta {
    width: 18px;
    height: 18px
}

.networks__icon._tw {
    width: 16px;
    height: 13px
}

.controls {
    position: relative;
    font-size: 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.controls__item {
    position: relative;
    display: inline-block;
    vertical-align: middle
}

.control-lang__item {
    cursor: pointer;
    position: relative;
    display: inline-block;
    vertical-align: middle;
    font-size: 12px;
    font-weight: 700
}

.control-lang__item:before {
    display: block;
    content: " ";
    position: absolute;
    z-index: -1;
    opacity: 0;
    top: 50%;
    left: 50%;
    width: 32px;
    height: 32px;
    border-radius: 100%;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background-color: #fff
}

.control-lang__item._active {
    display: none;
    color: #000
}

.control-lang__item._active:before {
    opacity: 1
}

.control-audio {
    margin-right: 20px;
    cursor: pointer
}

@media only screen and (max-width: 767px) {
    .control-audio {
        display: none
    }
}

.control-audio:before {
    display: block;
    content: " ";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 32px;
    height: 32px;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.control-audio__icon {
    width: 18px;
    height: 16px
}

.control-audio._disabled:after {
    display: block;
    content: " ";
    position: absolute;
    top: 8px;
    left: -6px;
    width: 31px;
    height: 1px;
    background-color: #fff;
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

.preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    background: #191919;
    z-index: 99;
    opacity: 0;
    transition: opacity .5s ease-out
}

.preloader._started {
    opacity: 1
}

.preloader._started .preloader__logo i {
    -ms-transform: scaleY(1);
    transform: scaleY(1)
}

.preloader._back-1 .preloader__side {
    background: #ff00fc
}

.preloader._back-2 .preloader__side {
    background: #001eff
}

.preloader._back-3 .preloader__side {
    background: red
}

.preloader._back-4 .preloader__side {
    background: #fcff00
}

.preloader._back-5 .preloader__side {
    background: #0dd01b
}

.preloader__logo {
    position: absolute;
    width: 424px;
    height: 300px;
    top: 50%;
    left: 50%;
    margin-left: -212px;
    margin-top: -150px;
    -ms-transform: scale(1);
    transform: scale(1);
    transition: transform .15s ease-out
}

@media only screen and (max-width: 767px) {
    .preloader__logo {
        -ms-transform: scale(.5);
        transform: scale(.5)
    }
}

@media only screen and (max-width: 640px) {
    .preloader__logo {
        -ms-transform: scale(.5);
        transform: scale(.5)
    }
}

@media only screen and (max-width: 320px) {
    .preloader__logo {
        -ms-transform: scale(.25);
        transform: scale(.25)
    }
}

@media only screen and (max-width: 200px) {
    .preloader__logo {
        -ms-transform: scale(.1);
        transform: scale(.1)
    }
}

.preloader__logo i {
    position: absolute;
    left: 0;
    top: 0;
    width: 100px;
    height: 300px;
    background: #303030;
    -ms-transform: scaleY(0);
    transform: scaleY(0);
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
    transition: transform .45s ease-out;
    transition-delay: .25s
}

.preloader__logo i:nth-child(1) {
    left: 108px;
    transition-delay: .35s
}

.preloader__logo i:nth-child(2) {
    left: 216px;
    transition-delay: .45s
}

.preloader__logo i:nth-child(3) {
    left: 324px;
    height: 100px;
    transition: transform .15s ease-out;
    transition-delay: .55s
}

.preloader__logo i:nth-child(4) {
    left: 324px;
    top: 108px;
    height: 192px;
    transition: transform .35s ease-out;
    transition-delay: .68s
}

.preloader__side {
    position: absolute;
    top: 0;
    width: 50%;
    height: 100%;
    background: #32fd2f;
    overflow: hidden
}

.preloader__side._left {
    left: 0
}

.preloader__side._left .preloader__side-content {
    left: 0
}

.preloader__side._right {
    right: 0
}

.preloader__side._right .preloader__side-content {
    right: 0
}

.preloader__side .preloader__logo i {
    background: #000
}

.preloader__side-content {
    position: absolute;
    top: 0;
    width: 100vw;
    height: 100%
}

/*
     FILE ARCHIVED ON 15:17:33 Jul 16, 2020 AND RETRIEVED FROM THE
     INTERNET ARCHIVE ON 08:46:21 Oct 16, 2020.
     JAVASCRIPT APPENDED BY WAYBACK MACHINE, COPYRIGHT INTERNET ARCHIVE.

     ALL OTHER CONTENT MAY ALSO BE PROTECTED BY COPYRIGHT (17 U.S.C.
     SECTION 108(a)(3)).
*/
/*
playback timings (ms):
  LoadShardBlock: 254.48 (3)
  PetaboxLoader3.datanode: 465.149 (5)
  CDXLines.iter: 32.928 (3)
  esindex: 0.019
  load_resource: 500.41 (2)
  exclusion.robots: 0.306
  exclusion.robots.policy: 0.286
  RedisCDXSource: 2.768
  PetaboxLoader3.resolve: 126.132 (2)
  captures_list: 296.106
*/

/*
     FILE ARCHIVED ON 01:44:45 Dec 02, 2021 AND RETRIEVED FROM THE
     INTERNET ARCHIVE ON 00:52:13 Mar 14, 2026.
     JAVASCRIPT APPENDED BY WAYBACK MACHINE, COPYRIGHT INTERNET ARCHIVE.

     ALL OTHER CONTENT MAY ALSO BE PROTECTED BY COPYRIGHT (17 U.S.C.
     SECTION 108(a)(3)).
*/
/*
playback timings (ms):
  captures_list: 0.645
  exclusion.robots: 0.064
  exclusion.robots.policy: 0.053
  esindex: 0.009
  cdx.remote: 147.801
  LoadShardBlock: 110.627 (3)
  PetaboxLoader3.datanode: 152.723 (5)
  load_resource: 132.05
  PetaboxLoader3.resolve: 76.114
  loaddict: 28.291
*/