/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
    display: block
}

audio, canvas, progress, video {
    display: inline-block
}

audio:not([controls]) {
    display: none;
    height: 0
}

progress {
    vertical-align: baseline
}

[hidden], template {
    display: none
}

a {
    background-color: transparent;
    -webkit-text-decoration-skip: objects
}

a:active, a:hover {
    outline-width: 0
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b, strong {
    font-weight: inherit
}

b, strong {
    font-weight: bolder
}

dfn {
    font-style: italic
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

mark {
    background-color: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

svg:not(:root) {
    overflow: hidden
}

code, kbd, pre, samp {
    font-family: monospace, monospace;
    font-size: 1em
}

figure {
    margin: 1em 40px
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

button, input, select, textarea {
    font: inherit;
    margin: 0
}

optgroup {
    font-weight: 700
}

button, input {
    overflow: visible
}

button, select {
    text-transform: none
}

[type=reset], [type=submit], button, html [type=button] {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    border: 1px solid silver;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

textarea {
    overflow: auto
}

[type=checkbox], [type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-cancel-button, [type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-input-placeholder {
    color: inherit;
    opacity: .54
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

.mfp-bg {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1042;
    overflow: hidden;
    position: fixed;
    background: #0b0b0b;
    opacity: .8
}

.mfp-wrap {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1043;
    position: fixed;
    outline: 0 !important;
    -webkit-backface-visibility: hidden
}

.mfp-container {
    text-align: center;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    padding: 0 8px;
    box-sizing: border-box
}

.mfp-container:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle
}

.mfp-align-top .mfp-container:before {
    display: none
}

.mfp-content {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    margin: 0 auto;
    text-align: left;
    z-index: 1045
}

.mfp-ajax-holder .mfp-content, .mfp-inline-holder .mfp-content {
    width: 100%;
    cursor: auto
}

.mfp-ajax-cur {
    cursor: progress
}

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
    cursor: -moz-zoom-out;
    cursor: -webkit-zoom-out;
    cursor: zoom-out
}

.mfp-zoom {
    cursor: pointer;
    cursor: -webkit-zoom-in;
    cursor: -moz-zoom-in;
    cursor: zoom-in
}

.mfp-auto-cursor .mfp-content {
    cursor: auto
}

.mfp-arrow, .mfp-close, .mfp-counter, .mfp-preloader {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.mfp-loading.mfp-figure {
    display: none
}

.mfp-hide {
    display: none !important
}

.mfp-preloader {
    color: #ccc;
    position: absolute;
    top: 50%;
    width: auto;
    text-align: center;
    margin-top: -.8em;
    left: 8px;
    right: 8px;
    z-index: 1044
}

.mfp-preloader a {
    color: #ccc
}

.mfp-preloader a:hover {
    color: #fff
}

.mfp-s-ready .mfp-preloader {
    display: none
}

.mfp-s-error .mfp-content {
    display: none
}

button.mfp-arrow, button.mfp-close {
    overflow: visible;
    cursor: pointer;
    background: 0 0;
    border: 0;
    -webkit-appearance: none;
    display: block;
    outline: 0;
    padding: 0;
    z-index: 1046;
    box-shadow: none;
    touch-action: manipulation
}

button::-moz-focus-inner {
    padding: 0;
    border: 0
}

.mfp-close {
    width: 44px;
    height: 44px;
    line-height: 44px;
    position: absolute;
    right: 0;
    top: 0;
    text-decoration: none;
    text-align: center;
    opacity: .65;
    padding: 0 0 18px 10px;
    color: #fff;
    font-style: normal;
    font-size: 28px;
    font-family: Arial, Baskerville, monospace
}

.mfp-close:focus, .mfp-close:hover {
    opacity: 1
}

.mfp-close:active {
    top: 1px
}

.mfp-close-btn-in .mfp-close {
    color: #333
}

.mfp-iframe-holder .mfp-close, .mfp-image-holder .mfp-close {
    color: #fff;
    right: -6px;
    text-align: right;
    padding-right: 6px;
    width: 100%
}

.mfp-counter {
    position: absolute;
    top: 0;
    right: 0;
    color: #ccc;
    font-size: 12px;
    line-height: 18px;
    white-space: nowrap
}

.mfp-arrow {
    position: absolute;
    opacity: .65;
    margin: 0;
    top: 50%;
    margin-top: -55px;
    padding: 0;
    width: 90px;
    height: 110px;
    -webkit-tap-highlight-color: transparent
}

.mfp-arrow:active {
    margin-top: -54px
}

.mfp-arrow:focus, .mfp-arrow:hover {
    opacity: 1
}

.mfp-arrow:after, .mfp-arrow:before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent
}

.mfp-arrow:after {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px
}

.mfp-arrow:before {
    border-top-width: 21px;
    border-bottom-width: 21px;
    opacity: .7
}

.mfp-arrow-left {
    left: 0
}

.mfp-arrow-left:after {
    border-right: 17px solid #fff;
    margin-left: 31px
}

.mfp-arrow-left:before {
    margin-left: 25px;
    border-right: 27px solid #3f3f3f
}

.mfp-arrow-right {
    right: 0
}

.mfp-arrow-right:after {
    border-left: 17px solid #fff;
    margin-left: 39px
}

.mfp-arrow-right:before {
    border-left: 27px solid #3f3f3f
}

.mfp-iframe-holder {
    padding-top: 40px;
    padding-bottom: 40px
}

.mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px
}

.mfp-iframe-holder .mfp-close {
    top: -40px
}

.mfp-iframe-scaler {
    width: 100%;
    height: 0;
    overflow: hidden;
    padding-top: 56.25%
}

.mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, .6);
    background: #000
}

img.mfp-img {
    width: auto;
    max-width: 100%;
    height: auto;
    display: block;
    line-height: 0;
    box-sizing: border-box;
    padding: 40px 0 40px;
    margin: 0 auto
}

.mfp-figure {
    line-height: 0
}

.mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, .6);
    background: #444
}

.mfp-figure small {
    color: #bdbdbd;
    display: block;
    font-size: 12px;
    line-height: 14px
}

.mfp-figure figure {
    margin: 0
}

.mfp-bottom-bar {
    margin-top: -36px;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    cursor: auto
}

.mfp-title {
    text-align: left;
    line-height: 18px;
    color: #f3f3f3;
    word-wrap: break-word;
    padding-right: 36px
}

.mfp-image-holder .mfp-content {
    max-width: 100%
}

.mfp-gallery .mfp-image-holder .mfp-figure {
    cursor: pointer
}

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
    .mfp-img-mobile .mfp-image-holder {
        padding-left: 0;
        padding-right: 0
    }

    .mfp-img-mobile img.mfp-img {
        padding: 0
    }

    .mfp-img-mobile .mfp-figure:after {
        top: 0;
        bottom: 0
    }

    .mfp-img-mobile .mfp-figure small {
        display: inline;
        margin-left: 5px
    }

    .mfp-img-mobile .mfp-bottom-bar {
        background: rgba(0, 0, 0, .6);
        bottom: 0;
        margin: 0;
        top: auto;
        padding: 3px 5px;
        position: fixed;
        box-sizing: border-box
    }

    .mfp-img-mobile .mfp-bottom-bar:empty {
        padding: 0
    }

    .mfp-img-mobile .mfp-counter {
        right: 5px;
        top: 3px
    }

    .mfp-img-mobile .mfp-close {
        top: 0;
        right: 0;
        width: 35px;
        height: 35px;
        line-height: 35px;
        background: rgba(0, 0, 0, .6);
        position: fixed;
        text-align: center;
        padding: 0
    }
}

@media all and (max-width: 900px) {
    .mfp-arrow {
        -webkit-transform: scale(.75);
        transform: scale(.75)
    }

    .mfp-arrow-left {
        -webkit-transform-origin: 0;
        transform-origin: 0
    }

    .mfp-arrow-right {
        -webkit-transform-origin: 100%;
        transform-origin: 100%
    }

    .mfp-container {
        padding-left: 6px;
        padding-right: 6px
    }
}

@font-face {
    font-family: swiper-icons;
    src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: #007aff
}

.swiper {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1
}

.swiper-vertical > .swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    box-sizing: content-box
}

.swiper-android .swiper-slide, .swiper-wrapper {
    transform: translate3d(0, 0, 0)
}

.swiper-pointer-events {
    touch-action: pan-y
}

.swiper-pointer-events.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-3d, .swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide, .swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: rgba(0, 0, 0, .15)
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}

.swiper-css-mode > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-centered > .swiper-wrapper::before {
    content: '';
    flex-shrink: 0;
    order: 9999
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
    height: 100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
    width: 100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: center center
}

.swiper-virtual .swiper-slide {
    -webkit-backface-visibility: hidden;
    transform: translateZ(0)
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
    height: 1px;
    width: var(--swiper-virtual-size)
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
    width: 1px;
    height: var(--swiper-virtual-size)
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-next, .swiper-button-prev {
    position: absolute;
    top: 50%;
    width: calc(var(--swiper-navigation-size) / 44 * 27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
    opacity: 0;
    cursor: auto;
    pointer-events: none
}

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
    display: none !important
}

.swiper-button-next:after, .swiper-button-prev:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none !important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: 10px;
    right: auto
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    content: 'prev'
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: 10px;
    left: auto
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    content: 'next'
}

.swiper-button-lock {
    display: none
}

.swiper-pagination {
    position: absolute;
    text-align: center;
    transition: .3s opacity;
    transform: translate3d(0, 0, 0);
    z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
    display: none !important
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 10px;
    left: 0;
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    overflow: hidden;
    font-size: 0
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transform: scale(.33);
    position: relative
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(.33)
}

.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    display: inline-block;
    border-radius: 50%;
    background: var(--swiper-pagination-bullet-inactive-color, #000);
    opacity: var(--swiper-pagination-bullet-inactive-opacity, .2)
}

button.swiper-pagination-bullet {
    border: none;
    margin: 0;
    padding: 0;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none !important
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
    right: 10px;
    top: 50%;
    transform: translate3d(0, -50%, 0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
    display: block
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: .2s transform, .2s top
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s left
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s right
}

.swiper-pagination-progressbar {
    background: rgba(0, 0, 0, .25);
    position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 100%;
    height: 4px;
    left: 0;
    top: 0
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
    width: 4px;
    height: 100%;
    left: 0;
    top: 0
}

.swiper-pagination-lock {
    display: none
}

.swiper-scrollbar {
    border-radius: 10px;
    position: relative;
    -ms-touch-action: none;
    background: rgba(0, 0, 0, .1)
}

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
    display: none !important
}

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
    position: absolute;
    left: 1%;
    bottom: 3px;
    z-index: 50;
    height: 5px;
    width: 98%
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
    position: absolute;
    right: 3px;
    top: 1%;
    z-index: 50;
    width: 5px;
    height: 98%
}

.swiper-scrollbar-drag {
    height: 100%;
    width: 100%;
    position: relative;
    background: rgba(0, 0, 0, .5);
    border-radius: 10px;
    left: 0;
    top: 0
}

.swiper-scrollbar-cursor-drag {
    cursor: move
}

.swiper-scrollbar-lock {
    display: none
}

.swiper-zoom-container {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain
}

.swiper-slide-zoomed {
    cursor: move
}

.swiper-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: transparent
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0)
    }
    100% {
        transform: rotate(360deg)
    }
}

.swiper .swiper-notification {
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none;
    opacity: 0;
    z-index: -1000
}

.swiper-free-mode > .swiper-wrapper {
    transition-timing-function: ease-out;
    margin: 0 auto
}

.swiper-grid > .swiper-wrapper {
    flex-wrap: wrap
}

.swiper-grid-column > .swiper-wrapper {
    flex-wrap: wrap;
    flex-direction: column
}

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-cube {
    overflow: visible
}

.swiper-cube .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1;
    visibility: hidden;
    transform-origin: 0 0;
    width: 100%;
    height: 100%
}

.swiper-cube .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-cube.swiper-rtl .swiper-slide {
    transform-origin: 100% 0
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-next + .swiper-slide, .swiper-cube .swiper-slide-prev {
    pointer-events: auto;
    visibility: visible
}

.swiper-cube .swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-cube .swiper-cube-shadow {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: .6;
    z-index: 0
}

.swiper-cube .swiper-cube-shadow:before {
    content: '';
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    filter: blur(50px)
}

.swiper-flip {
    overflow: visible
}

.swiper-flip .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1
}

.swiper-flip .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-flip .swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-creative .swiper-slide {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden;
    transition-property: transform, opacity, height
}

.swiper-cards {
    overflow: visible
}

.swiper-cards .swiper-slide {
    transform-origin: center bottom;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden
}

.mfp-bg {
    background: #000
}

.mfp-zoom-in .mfp-with-anim {
    opacity: 0;
    -webkit-transition: all .2s ease-in-out;
    -o-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    -webkit-transform: scale(.8);
    -ms-transform: scale(.8);
    transform: scale(.8)
}

.mfp-zoom-in.mfp-bg {
    opacity: 0;
    -webkit-transition: all .4s ease-out;
    -o-transition: all .4s ease-out;
    transition: all .4s ease-out
}

.mfp-zoom-in.mfp-ready .mfp-with-anim {
    opacity: 1;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1)
}

.mfp-zoom-in.mfp-ready.mfp-bg {
    opacity: .75
}

.mfp-zoom-in.mfp-removing .mfp-with-anim {
    -webkit-transform: scale(.8);
    -ms-transform: scale(.8);
    transform: scale(.8);
    opacity: 0
}

.mfp-zoom-in.mfp-removing.mfp-bg {
    opacity: 0
}

.mfp-container.mfp-inline-holder {
    padding: 0 20px
}

@media (max-width: 575px) {
    .mfp-container.mfp-inline-holder {
        padding: 0 15px
    }
}

.mfp-figure:after {
    -webkit-box-shadow: none;
    box-shadow: none;
    background: #fff
}

.mfp-title {
    color: #fff
}

.mfp-arrow {
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.mfp-iframe-scaler iframe {
    -webkit-box-shadow: none;
    box-shadow: none
}

.mfp-zoom-out-cur {
    cursor: default
}

.mfp-inline-holder .mfp-close {
    font-size: 0;
    width: 74px;
    height: 74px;
    background: #1757c3 url(../img/icons/close.svg) no-repeat center;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.mfp-inline-holder .mfp-close:hover {
    background-color: #b10b0d
}

@media (max-width: 1199px) {
    .mfp-inline-holder .mfp-close {
        width: 54px;
        height: 54px
    }
}

.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
    cursor: pointer
}

.mfp-close-btn-in .mfp-close {
    opacity: 1;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.mfp-close-btn-in .mfp-close:hover {
    color: #b10b0d
}

.swiper-button-next, .swiper-button-prev {
    display: block;
    margin-top: -37px;
    width: 74px;
    height: 74px;
    background: #1757c3 no-repeat center;
    opacity: 1;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.swiper-button-next:after, .swiper-button-prev:after {
    display: none
}

.swiper-button-next:hover, .swiper-button-prev:hover {
    background-color: #07347f
}

@media (max-width: 1199px) {
    .swiper-button-next, .swiper-button-prev {
        margin-top: -27px;
        width: 54px;
        height: 54px
    }
}

.swiper-button-prev {
    background-image: url(../img/icons/arrow-left.svg)
}

.swiper-button-next {
    background-image: url(../img/icons/arrow-right.svg)
}

.swiper-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 30px
}

@media (max-width: 991px) {
    .swiper-nav {
        display: none
    }
}

.swiper-nav .swiper-button-next, .swiper-nav .swiper-button-prev {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    margin: 0
}

.swiper-nav .swiper-button-prev {
    margin-right: 30px
}

@font-face {
    font-family: SuisseIntl;
    font-weight: 400;
    font-style: normal;
    src: url(../fonts/SuisseIntl-Regular/SuisseIntl-Regular.woff2) format("woff2"), url(../fonts/SuisseIntl-Regular/SuisseIntl-Regular.woff) format("woff")
}

@font-face {
    font-family: SuisseIntl;
    font-weight: 500;
    font-style: normal;
    src: url(../fonts/SuisseIntl-Medium/SuisseIntl-Medium.woff2) format("woff2"), url(../fonts/SuisseIntl-Medium/SuisseIntl-Medium.woff) format("woff")
}

@font-face {
    font-family: SuisseIntl;
    font-weight: 600;
    font-style: normal;
    src: url(../fonts/SuisseIntl-SemiBold/SuisseIntl-SemiBold.woff2) format("woff2"), url(../fonts/SuisseIntl-SemiBold/SuisseIntl-SemiBold.woff) format("woff")
}

@font-face {
    font-family: SuisseIntl;
    font-weight: 700;
    font-style: normal;
    src: url(../fonts/SuisseIntl-Bold/SuisseIntl-Bold.woff2) format("woff2"), url(../fonts/SuisseIntl-Bold/SuisseIntl-Bold.woff) format("woff")
}

@font-face {
    font-family: IBMPlexMono;
    font-weight: 400;
    font-style: normal;
    src: url(../fonts/IBMPlexMono-Regular/IBMPlexMono-Regular.woff2) format("woff2"), url(../fonts/IBMPlexMono-Regular/IBMPlexMono-Regular.woff) format("woff")
}

@font-face {
    font-family: IBMPlexMono;
    font-weight: 500;
    font-style: normal;
    src: url(../fonts/IBMPlexMono-Medium/IBMPlexMono-Medium.woff2) format("woff2"), url(../fonts/IBMPlexMono-Medium/IBMPlexMono-Medium.woff) format("woff")
}

@font-face {
    font-family: IBMPlexMono;
    font-weight: 700;
    font-style: normal;
    src: url(../fonts/IBMPlexMono-Bold/IBMPlexMono-Bold.woff2) format("woff2"), url(../fonts/IBMPlexMono-Bold/IBMPlexMono-Bold.woff) format("woff")
}

*, :after, :before {
    outline: 0 !important;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

::-webkit-input-placeholder {
    opacity: 1
}

::-moz-placeholder {
    opacity: 1
}

:-ms-input-placeholder {
    opacity: 1
}

::-ms-input-placeholder {
    opacity: 1
}

::placeholder {
    opacity: 1
}

body, html {
    font-size: 15px
}

body {
    position: relative;
    overflow-x: hidden;
    min-width: 320px;
    background: #cfd2da;
    font-family: SuisseIntl, sans-serif;
    line-height: 1.55;
    color: #060e18
}

a {
    text-decoration: underline;
    color: inherit
}

a:hover {
    text-decoration: none
}

button {
    cursor: pointer
}

strong {
    font-weight: 600
}

b {
    font-weight: 700
}

h1, h2, h3, h4, h5, h6, ol, p, ul {
    margin: 0 0 30px
}

blockquote {
    margin: 50px 0;
    padding: 100px 0 30px;
    border-top: 2px solid #1757c3;
    border-bottom: 2px solid #1757c3;
    background: url(../img/icons/quote.svg) no-repeat 0 30px;
    font-style: italic
}

blockquote > :first-child {
    margin-top: 0
}

blockquote > :last-child {
    margin-bottom: 0
}

.quote-author {
    text-align: right;
    font-style: normal
}

.quote-author > * {
    margin-bottom: 10px
}

.quote-author > :last-child {
    margin-bottom: 0
}

h1, h2 {
    text-transform: uppercase;
    font-family: IBMPlexMono, monospace;
    line-height: 1.2;
    font-weight: 500;
    font-size: 69px
}

h3 {
    text-transform: uppercase;
    line-height: 1.4;
    font-weight: 600;
    font-size: 32px
}

h4 {
    line-height: 1.4;
    font-weight: 600;
    font-size: 24px
}

h5 {
    line-height: 1.4;
    font-weight: 600;
    font-size: 20px
}

h6 {
    font-weight: 600;
    font-size: 1em
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0
}

table td, table th {
    vertical-align: top;
    padding: 30px 15px;
    border-bottom: 1px solid #1757c3;
    text-align: left
}

table td:first-child, table th:first-child {
    padding-left: 0
}

table td:last-child, table th:last-child {
    padding-left: 0
}

table th {
    text-transform: uppercase;
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500
}

table tr:first-child td, table tr:first-child th {
    padding-top: 0
}

img {
    display: inline-block;
    vertical-align: middle;
    width: auto;
    height: auto;
    max-width: 100%
}

#page {
    overflow: hidden;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    min-height: 100vh
}

#page__main {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
    width: 100%
}

.clearfix:after {
    content: "";
    display: table;
    clear: both
}

.container {
    width: 1320px;
    margin: 0 auto;
    padding: 0 20px
}

.img-box {
    position: relative
}

.img-box img {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%
}

._tt-upper {
    text-transform: uppercase
}

._tt-none {
    text-transform: none
}

._c-main {
    color: #1757c3
}

.sect {
    margin: 90px 0
}

.sect + .sect {
    margin-top: 180px
}

.sect._mt-0 {
    margin-top: 0 !important
}

.sect._mb-0 {
    margin-bottom: 0 !important
}

.title {
    margin-bottom: 50px
}

.content > :first-child {
    margin-top: 0
}

.content > :last-child {
    margin-bottom: 0
}

.content li {
    margin-bottom: 15px
}

.content li:last-child {
    margin-bottom: 0
}

.content ol, .content ul {
    padding: 0;
    list-style: none
}

.content ol ol, .content ol ul, .content ul ol, .content ul ul {
    margin: 15px 0
}

.content ul > li {
    position: relative;
    padding-left: 23px
}

.content ul > li:before {
    content: "";
    position: absolute;
    top: .77em;
    left: 0;
    margin-top: -4px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #1757c3
}

.content ol {
    counter-reset: myCounter
}

.content ol > li:before {
    display: inline-block;
    min-width: 23px;
    margin-right: .2em;
    counter-increment: myCounter;
    content: counter(myCounter) ".";
    font-weight: 700;
    color: #1757c3
}

.content-img {
    margin: 50px 0
}

.content-img img {
    display: block
}

.content-img figcaption {
    margin-top: 15px
}

.subtitle {
    position: relative;
    margin: 0 0 20px;
    padding: 0 0 0 1.2em;
    text-transform: uppercase;
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500
}

.subtitle:before {
    content: "/";
    position: absolute;
    top: 0;
    left: 0;
    font-weight: 700;
    color: #07347f
}

.subtitle._light:before {
    color: #1757c3
}

.quote-descr {
    position: relative;
    padding-left: 30px;
    max-width: 540px;
    -webkit-box-shadow: inset 2px 0 0 #1757c3;
    box-shadow: inset 2px 0 0 #1757c3
}

.breadcrumbs {
    text-transform: uppercase;
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500
}

.breadcrumbs ul {
    margin: 0;
    padding: 0;
    list-style: none
}

.breadcrumbs li {
    position: relative;
    display: inline-block;
    padding: 0 0 0 1.2em
}

.breadcrumbs li:before {
    content: "/";
    position: absolute;
    top: 0;
    left: 0;
    font-weight: 700;
    color: #07347f
}

.breadcrumbs a {
    text-decoration: none;
    opacity: .3;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.breadcrumbs a:hover {
    opacity: 1
}

.pagination {
    margin-top: 90px
}

.pagination__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 15px
}

.pagination__list a, .pagination__list span {
    display: block;
    padding: 5px 0;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    line-height: 1.2;
    opacity: .5;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.pagination__list a {
    text-decoration: none
}

.pagination__list a:hover {
    opacity: 1
}

.pagination__list a.active {
    opacity: 1;
    -webkit-box-shadow: inset 0 -2px 0 #1757c3;
    box-shadow: inset 0 -2px 0 #1757c3
}

.pagination__list span {
    cursor: default
}

.pagination__list ._arrow {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 74px;
    height: 74px;
    background: #1757c3 no-repeat center;
    opacity: 1
}

.pagination__list ._arrow:hover {
    background-color: #07347f
}

.pagination__list ._prev {
    margin-right: 40px;
    background-image: url(../img/icons/arrow-left.svg)
}

.pagination__list ._next {
    margin-left: 40px;
    background-image: url(../img/icons/arrow-right.svg)
}

.link, .menu a {
    overflow: hidden;
    position: relative;
    z-index: 10;
    display: inline-block;
    border: none;
    background: 0 0;
    text-decoration: none
}

.link [data-text], .menu a [data-text] {
    display: block;
    position: relative;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.link [data-text]:after, .menu a [data-text]:after {
    content: attr(data-text);
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%
}

.link:hover [data-text], .menu a:hover [data-text] {
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%)
}

.btn {
    cursor: pointer;
    display: inline-block;
    position: relative;
    padding: 28px 40px;
    background: #1757c3;
    border: none;
    border-radius: 0;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    font-size: 15px;
    color: #fff;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.btn i {
    display: inline-block;
    vertical-align: middle;
    margin: -.15em 0 0 .8em;
    width: 1em;
    height: 1em;
    -webkit-transition: -webkit-transform .4s;
    transition: -webkit-transform .4s;
    -o-transition: transform .4s;
    transition: transform .4s;
    transition: transform .4s, -webkit-transform .4s
}

.btn i._arrow {
    background: url(../img/icons/btn-arrow.svg) no-repeat center
}

.btn:hover {
    background: #07347f
}

.btn:hover i._arrow {
    -webkit-transform: translateX(.5em);
    -ms-transform: translateX(.5em);
    transform: translateX(.5em)
}

.big-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    z-index: 5;
    width: 100%;
    min-height: 86px;
    margin: 50px 0 0;
    padding: 15px;
    border: 2px solid #07347f;
    background: 0 0;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    font-size: 15px;
    color: inherit;
    -webkit-transition: color .4s;
    -o-transition: color .4s;
    transition: color .4s
}

.big-btn:before {
    content: "";
    position: absolute;
    z-index: -1;
    left: 0;
    right: 0;
    bottom: 0;
    height: 0;
    background: #07347f;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.big-btn:hover {
    color: #fff
}

.big-btn:hover:before {
    height: 100%
}

.big-btn._light {
    border-color: #1757c3
}

.big-btn._light:before {
    background-color: #1757c3
}

.ellips-btn {
    position: relative;
    z-index: 5;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 12px;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    text-decoration: none;
    text-transform: uppercase;
    text-align: center;
    font-family: IBMPlexMono, monospace;
    line-height: 1.2;
    font-weight: 500;
    font-size: 15px;
    color: #fff
}

.ellips-btn:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background: #b10b0d;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.ellips-btn span {
    display: block;
    width: 100%
}

.ellips-btn:hover:before {
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1)
}

.ellips-btn._social {
    width: 100px;
    height: 100px
}

.ellips-btn._social:before {
    border: 2px solid #1757c3;
    background-color: #07347f
}

.ellips-btn._social img {
    max-width: 32px;
    max-height: 32px
}

.ellips-btn._vk:before {
    background-color: #07347f
}

.social .subtitle {
    margin-bottom: 50px
}

.social__grid {
    margin: 0 -12px -15px;
    cursor: default
}

.social__grid .ellips-btn {
    margin: 0 12px 15px
}

.close-btn {
    position: absolute;
    z-index: 100;
    top: 0;
    right: 0;
    padding: 0;
    width: 74px;
    height: 74px;
    border: none;
    background: #1757c3 url(../img/icons/close.svg) no-repeat center;
    font-size: 20px;
    color: inherit;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.close-btn:hover {
    background-color: #b10b0d
}

.form-item {
    position: relative;
    display: block;
    width: 100%;
    margin-bottom: 35px;
    padding-top: 20px
}

.form-item__place {
    pointer-events: none;
    cursor: text;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0;
    padding: 15px 0 0;
    -webkit-transition: .2s;
    -o-transition: .2s;
    transition: .2s;
    text-align: left;
    line-height: 1.4;
    font-size: 15px
}

.form-item.focus .form-item__place, .form-item.focus-imp .form-item__place {
    padding: 0;
    font-size: 12px;
    opacity: .7
}

.form-field {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: block;
    width: 100%;
    padding: 0 0 8px;
    background: 0 0;
    border: none;
    border-bottom: 2px solid #cfd2da;
    border-radius: 0;
    line-height: 1.4;
    font-weight: 400;
    font-size: 15px;
    color: inherit
}

textarea.form-field {
    resize: none
}

textarea.form-field:not([rows]) {
    height: 130px
}

.form-option {
    text-align: left
}

.form-option label {
    cursor: pointer;
    display: inline-block;
    vertical-align: middle;
    line-height: 1.4;
    font-weight: 400;
    font-size: 15px
}

.form-option input {
    width: 1px;
    height: 1px;
    position: absolute;
    top: 39px;
    left: 19px;
}

.form-option input:checked ~ span:before {
    border-color: #1757c3;
    background-color: #1757c3
}

.form-option input:checked ~ span:after {
    opacity: 1
}

.form-option span {
    display: block;
    position: relative;
    padding: 9px 0 0 70px;
    min-height: 40px
}

.form-option span:after, .form-option span:before {
    content: "";
    position: absolute;
    -webkit-transition: .15s;
    -o-transition: .15s;
    transition: .15s
}

.form-option span:before {
    top: 0;
    left: 0;
    width: 40px;
    height: 40px;
    border: 2px solid currentColor
}

.form-option span:after {
    top: 13px;
    left: 13px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #fff;
    opacity: 0
}

.form-action {
    margin-top: 50px
}

.form-action .form-option {
    margin: 0 0 50px
}

.tab-btns {
    margin-bottom: 90px
}

.tab-btns__grid {
    position: relative;
    z-index: 5;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    gap: 40px;
    min-width: 100%
}

.tab-btns__grid:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-top: 1px solid #07347f;
    border-bottom: 1px solid #07347f
}

.tab-btn {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 15px;
    min-height: 74px;
    text-transform: uppercase;
    text-decoration: none;
    text-align: center;
    font-family: IBMPlexMono, monospace;
    line-height: 1.2;
    font-weight: 500;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.tab-btn:hover {
    background-color: rgba(7, 52, 127, .1)
}

.tab-btn.active {
    background-color: #07347f;
    color: #fff
}

.logo {
    display: inline-block;
    vertical-align: middle;
    white-space: nowrap;
    text-decoration: none
}

.logo img {
    display: inline-block;
    vertical-align: middle;
    max-height: 80px
}

.logo img:nth-child(n+2) {
    margin-left: 3px
}

.menu {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns:(1fr) [ 3 ];
    grid-template-columns:repeat(3, 1fr);
    gap: 8px 15px;
    margin: 0;
    padding: 0;
    list-style: none;
    line-height: 1.2;
    font-weight: 600
}

.menu ul {
    display: none
}

.sandwich {
    display: inline-block;
    vertical-align: middle;
    border: none;
    border-radius: 50%;
    background: #b10b0d;
    width: 54px;
    height: 54px;
    color: #fff;
    -webkit-transition: .25s;
    -o-transition: .25s;
    transition: .25s
}

.sandwich span {
    display: block;
    background: currentColor;
    margin: 0 auto;
    width: 20px;
    height: 2px;
    -webkit-transition: .25s margin .25s, .25s background, .25s -webkit-transform;
    transition: .25s margin .25s, .25s background, .25s -webkit-transform;
    -o-transition: .25s margin .25s, .25s transform, .25s background;
    transition: .25s margin .25s, .25s transform, .25s background;
    transition: .25s margin .25s, .25s transform, .25s background, .25s -webkit-transform
}

.sandwich span:nth-child(1) {
    margin-bottom: 4px
}

.sandwich span:nth-child(2) {
    -webkit-transition: .1s;
    -o-transition: .1s;
    transition: .1s;
    -webkit-transition-delay: .25s;
    -o-transition-delay: .25s;
    transition-delay: .25s
}

.sandwich span:nth-child(3) {
    margin-top: 4px
}

.sandwich.active span {
    -webkit-transition: .25s margin, .25s background .25s, .25s -webkit-transform .25s;
    transition: .25s margin, .25s background .25s, .25s -webkit-transform .25s;
    -o-transition: .25s margin, .25s transform .25s, .25s background .25s;
    transition: .25s margin, .25s transform .25s, .25s background .25s;
    transition: .25s margin, .25s transform .25s, .25s background .25s, .25s -webkit-transform .25s
}

.sandwich.active span:nth-child(1) {
    margin-top: 0;
    margin-bottom: -2px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg)
}

.sandwich.active span:nth-child(2) {
    opacity: 0;
    -webkit-transition: .1s;
    -o-transition: .1s;
    transition: .1s;
    -webkit-transition-delay: 0s;
    -o-transition-delay: 0s;
    transition-delay: 0s
}

.sandwich.active span:nth-child(3) {
    margin-top: -2px;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg)
}

.mob-menu {
    display: none;
    position: fixed;
    z-index: 95;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    -webkit-transition: -webkit-transform .5s;
    transition: -webkit-transform .5s;
    -o-transition: transform .5s;
    transition: transform .5s;
    transition: transform .5s, -webkit-transform .5s;
    font-size: 14px
}

.mob-menu._show {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%)
}

.mob-menu__wrapper {
    position: relative;
    padding: 205px 90px 90px
}

.mob-menu .menu {
    -ms-grid-columns: 1fr;
    grid-template-columns:1fr;
    gap: 30px;
    text-transform: uppercase;
    font-size: 32px
}

.header {
    position: relative;
    z-index: 100;
    padding: 25px 0;
    background: -webkit-gradient(linear, left top, left bottom, from(#0e326e), color-stop(60%, #1757c3));
    background: -o-linear-gradient(top, #0e326e, #1757c3 60%);
    background: linear-gradient(to bottom, #0e326e, #1757c3 60%);
    color: #fff
}

.header__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.header__grid .logo {
    margin-right: 210px
}

.header__grid .menu {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.header__grid .sandwich {
    display: none;
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-left: 30px
}

.header__lang {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-left: 30px;
    position: relative;
    z-index: 5;
    display: inline-block;
    width: 84px;
    height: 84px;
    line-height: 84px;
    border-radius: 50%;
    text-decoration: none;
    text-align: center;
    font-family: IBMPlexMono, monospace;
    font-weight: 500
}

.header__lang:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background: #b10b0d;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.header__lang:hover:before {
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1)
}

.bann {
    position: relative;
    z-index: 5;
    padding: 40px 0 60px;
    min-height: 675px;
    background: #1757c3;
    color: #fff
}

.bann:before {
    content: "";
    position: absolute;
    z-index: -10;
    top: 100px;
    left: 50%;
    margin-left: 120px;
    width: 500px;
    height: 500px;
    background: -o-radial-gradient(50% 50%, 50% 50%, #f61b05 0, rgba(23, 87, 195, 0) 100%);
    background: radial-gradient(50% 50% at 50% 50%, #f61b05 0, rgba(23, 87, 195, 0) 100%);
    opacity: .85
}

.bann__img {
    position: absolute;
    z-index: -1;
    top: 0;
    left: 50%;
    margin-left: -85px;
    max-width: none;
    max-height: 91%
}

.bann__wrap {
    max-width: 600px
}

.bann__head {
    margin-bottom: 0
}

.bann__head span {
    display: block
}

.bann__head span:first-child {
    display: inline-block;
    -webkit-box-shadow: inset 0 -7px 0 #07347f;
    box-shadow: inset 0 -7px 0 #07347f
}

.bann__head span:nth-child(2) {
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: 1px currentColor
}

.bann__descr {
    margin-top: 50px;
    max-width: 400px
}

@-webkit-keyframes rotate {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes rotate {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.b-about {
    position: relative;
    margin-bottom: 180px
}

.b-about:before {
    content: "";
    position: absolute;
    z-index: -5;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-height: 740px;
    background: #07347f
}

.b-about__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    max-width: 1190px;
    padding: 180px 0 50px;
    color: #fff
}

.b-about__top .subtitle {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 50px 50px 0 0
}

.b-about__title {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 580px
}

.b-about__title > * {
    margin-bottom: 50px
}

.b-about__title > :last-child {
    margin-bottom: 0
}

.b-about__wrap {
    max-width: 1130px;
    margin-left: auto
}

.b-about__img {
    overflow: hidden;
    position: relative;
    z-index: 1;
    margin-bottom: 50px;
    height: 680px;
    background: #060e18 no-repeat center/cover;
    color: #fff
}

.b-about__img-quote {
    position: absolute;
    top: 40px;
    left: 60px;
    width: 400px;
    padding: 80px 0 0 30px;
    background: url(../img/about/quote.svg) no-repeat 0 0
}

.b-about__quote {
    position: relative;
    padding-right: 180px
}

.b-about__quote:before {
    content: "";
    position: absolute;
    top: 0;
    left: -50px;
    bottom: 0;
    border-right: 2px solid #1757c3
}

.b-about__quote-head span {
    color: #1757c3
}

.b-about__quote-content {
    max-width: 560px
}

.b-about__quote .ellips-btn {
    position: absolute;
    right: 0;
    bottom: -75px
}

.b-about .about-numbers {
    margin-top: 10px
}

.about-numbers {
    margin: 0;
    padding: 155px 0 90px;
    list-style: none
}

.about-numbers li {
    position: relative;
    margin-bottom: 215px;
    height: 1px;
    background: #07347f
}

.about-numbers li:last-child {
    margin-bottom: 0
}

.about-number {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 180px;
    height: 180px;
    border: 2px solid #1757c3;
    border-radius: 50%;
    background: #07347f;
    text-align: center;
    font-weight: 600;
    color: #fff
}

.about-number span {
    display: block;
    width: 100%;
    margin-bottom: 20px
}

.about-number span:first-child {
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    font-size: 40px
}

.about-number span:last-child {
    margin-bottom: 0
}

.about-number._years {
    left: 50%;
    margin-left: -30px;
    width: 310px;
    height: 310px
}

.about-number._years span:first-child {
    font-size: 78px
}

.about-number._proj {
    left: 50%;
    margin-left: -640px;
    width: 360px;
    height: 360px
}

.about-number._proj span:first-child {
    font-size: 100px
}

.about-number._team {
    left: 50%;
    margin-left: 360px
}

.about-number._dir {
    left: 50%;
    margin-left: -110px
}

.about-number._dir span:first-child {
    font-size: 57px
}

.about-numbers._light li {
    background-color: #cfd2da
}

.about-numbers._light .about-number {
    border-color: #07347f;
    background-color: #cfd2da;
    color: #07347f
}

.parallax-img {
    overflow: hidden;
    position: relative;
    z-index: 1;
    height: 680px;
    color: #fff
}

/*
.parallax-img._about:after, .parallax-img._about:before {
    content: "";
    position: absolute;
    border-radius: 50%;
    background: #0055e5;
    opacity: .7
}
*/
.parallax-img._about:before {
    top: -125px;
    right: -110px;
    width: 260px;
    height: 260px
}

.parallax-img._about:after {
    left: -250px;
    bottom: -220px;
    width: 530px;
    height: 530px
}

.big-proj {
    margin-top: 180px
}

.big-proj__head {
    position: relative;
    z-index: 5;
    min-height: 1.8em;
    margin-bottom: -1.8em;
    color: #fff
}

.big-proj .parallax-img:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #061b3d;
    opacity: .5
}

.big-proj__content {
    position: absolute;
    z-index: 5;
    top: 170px;
    left: 48%;
    width: 490px
}

.directions {
    padding: 180px 0 90px;
    background: #1757c3;
    color: #fff
}

.directions .b-about__top {
    margin: 0 0 50px;
    padding: 0;
    background: 0 0;
    color: inherit
}

.directions .big-btn {
    margin-top: 30px
}

.dir-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 30px
}

.dir-item:last-child {
    margin-bottom: 0
}

.dir-item__number {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-right: 70px;
    width: 86px;
    height: 86px;
    border: 2px solid currentColor;
    border-radius: 50%;
    text-align: center;
    line-height: 82px;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    font-size: 15px
}

.dir-item__content {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0 120px 0 0
}

.dir-item__head {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin: 0;
    width: 670px
}

.dir-item._obj {
    padding-bottom: 30px;
    border-bottom: 1px solid #1757c3
}

.dir-item._obj:last-child {
    padding-bottom: 0;
    border-bottom: none
}

.dir-item._obj .dir-item__number {
    border-color: #1757c3;
    background-color: #1757c3;
    color: #fff
}

.date-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.date-box__main {
    line-height: 1.2;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    font-size: 57px;
    color: #1757c3
}

.date-box__info {
    margin-left: 10px;
    text-align: right
}

.b-news__title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 50px
}

.b-news__title .subtitle {
    margin: 50px 0 0 50px;
    -webkit-box-ordinal-group: 11;
    -ms-flex-order: 10;
    order: 10
}

.b-news__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0
}

.b-news__sizer {
    width: 1%
}

.b-news-item {
    width: 39%
}

.b-news-item__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-top: 25px;
    margin-bottom: 25px;
    border-top: 2px solid #1757c3
}

.b-news-item__top .date-box {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    margin: 0 0 0 30px
}

.b-news-item__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0;
    overflow: hidden;
    position: relative;
    max-height: 2.8em;
    line-height: 1.4
}

.b-news-item__img {
    position: relative;
    max-width: 355px;
    height: 470px;
    background: #060e18 no-repeat center/cover
}

.b-news-item__img .btn {
    position: absolute;
    right: 0;
    bottom: 0
}

.b-news-item:nth-child(n+3) {
    margin-top: 100px
}

.b-news-item:nth-child(4n+2), .b-news-item:nth-child(4n+3) {
    margin-left: 8%;
    width: 53%
}

.b-news-item:nth-child(4n+2) .b-news-item__img {
    max-width: none;
    height: 370px
}

.b-news-item:nth-child(4n+3) .b-news-item__img {
    margin-left: auto;
    max-width: 455px;
    height: 520px
}

.b-news-item:nth-child(4n+4) .b-news-item__img {
    max-width: none;
    height: 420px
}

.b-contacts {
    position: relative;
    margin: 40px 0 0;
    max-height: 750px
}

.b-contacts__img {
    position: absolute;
    z-index: 2;
    top: 50px;
    right: 50%;
    margin-right: 190px;
    max-width: none
}

.b-contacts__wrapper {
    overflow: hidden;
    padding: 0 0 90px;
    min-height: 890px
}

.b-contacts__wrap {
    margin-left: 48%;
    max-width: 520px
}

.b-contacts__title {
    margin-bottom: 50px
}

.b-contacts__title > :last-child {
    margin-bottom: 0
}

.b-contacts__items {
    margin: 0;
    padding: 0;
    list-style: none
}

.b-contacts__items li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 25px
}

.b-contacts__items li:last-child {
    margin-bottom: 0
}

.b-contacts__items li > div {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.b-contacts__items li > div.img-box {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-right: 15px;
    width: 25px;
    height: 25px
}

.b-contacts__items a {
    text-decoration: none;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.b-contacts__items a:hover {
    color: #1757c3
}

.b-contacts__lines {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 130px 0 80px;
    list-style: none
}

.b-contacts__lines li {
    position: relative;
    margin-bottom: 160px;
    height: 1px;
    background: #1757c3
}

.b-contacts__lines li:last-child {
    margin-bottom: 0
}

.b-contacts__lines li:before {
    content: "";
    position: absolute;
    z-index: -10;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #07347f
}

.b-contacts__lines li .ellips-btn {
    right: calc(50% - 530px)
}

.b-contacts__lines .ellips-btn {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 222px;
    height: 222px;
    padding: 0 42px
}

.footer {
    padding: 140px 0 50px;
    background: #07347f;
    color: #fff
}

.footer__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.footer__grid._bot {
    margin-top: 40px;
    padding-top: 40px;
    border-top: 2px solid #1757c3
}

.footer__grid .logo {
    margin-right: 210px
}

.footer__grid .menu {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.footer__copy, .footer__dev {
    text-transform: uppercase;
    font-family: IBMPlexMono, monospace;
    font-weight: 500
}

.footer__dev {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.footer__dev a {
    text-decoration: none;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.footer__dev a:hover {
    opacity: .75
}

.footer__copy {
    margin-left: 30px
}

.inn-bann {
    padding: 70px 0 90px;
    background: #1757c3;
    color: #fff
}

.inn-bann__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.inn-bann__grid .breadcrumbs {
    margin: 50px 0 0 50px
}

.inn-bann__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0
}

.inn-title {
    margin-bottom: 90px
}

.inn-title__head {
    display: inline-block;
    border-bottom: 7px solid #07347f;
    margin-bottom: 0
}

.inn-title .quote-descr {
    margin-top: 50px
}

.about-info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 90px
}

.about-info__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin-right: 100px
}

.about-info__head span {
    color: #1757c3
}

.about-info .content {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 50%
}

.about-numbers-wrap {
    padding: 1px 0 90px;
    background: #1757c3;
    color: #fff
}

.about-numbers-wrap .about-numbers {
    margin-top: -70px
}

.about-numbers-head {
    position: relative;
    z-index: 5;
    min-height: 1.8em;
    margin: -1.8em 0 50px
}

.about-numbers-descr {
    max-width: 520px
}

.services {
    padding: 90px 0;
    background: #07347f;
    color: #fff
}

.serv-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: 1px solid #1757c3
}

.serv-item:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none
}

.serv-item__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0
}

.serv-item__content {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 52%;
    margin-left: 100px
}

.team-grid {
    margin: 0 -20px
}

.team-grid__col {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 33.33%;
    padding: 0 20px
}

.team-grid__col._title {
    min-height: 445px
}

.team-grid__col:nth-child(3) {
    margin-top: 180px
}

.team-grid__col:nth-child(n+4) {
    margin-top: 90px
}

.team-item__img {
    display: block;
    max-width: 400px;
    background: #060e18 no-repeat center/cover
}

.team-item__img:before {
    content: "";
    display: block;
    width: 100%;
    padding-bottom: 117.5%
}

.team-item__content {
    margin-top: 30px;
    padding-left: 20px;
    -webkit-box-shadow: inset 2px 0 0 #1757c3;
    box-shadow: inset 2px 0 0 #1757c3
}

.team-item__content > * {
    margin-bottom: 20px
}

.team-item__content > :last-child {
    margin-bottom: 0
}

.icon-btns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.icon-btn {
    display: inline-block;
    padding: 0;
    width: 74px;
    height: 74px;
    border: none;
    background: #1757c3;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.icon-btn:hover {
    background-color: #07347f
}

.icon-btn img {
    max-width: 24px;
    max-height: 24px
}

.icon-btn._black {
    background-color: #060e18
}

.icon-btn._black:hover {
    background-color: #07347f
}

.docs-grid {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns:(1fr) [ 4 ];
    grid-template-columns:repeat(4, 1fr);
    gap: 40px
}

.docs-grid._2 {
    -ms-grid-columns:(1fr) [ 2 ];
    grid-template-columns:repeat(2, 1fr)
}

.doc-item {
    display: block;
    overflow: hidden;
    position: relative;
    z-index: 3;
    padding: 20px;
    height: 370px;
    background: no-repeat 50% 0/cover;
    color: #fff
}

.doc-item:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background: -webkit-gradient(linear, left top, left bottom, from(#060e18), color-stop(59.9%, rgba(6, 14, 24, .66)), color-stop(83.85%, rgba(6, 14, 24, .35)), to(rgba(6, 14, 24, 0)));
    background: -o-linear-gradient(top, #060e18 0, rgba(6, 14, 24, .66) 59.9%, rgba(6, 14, 24, .35) 83.85%, rgba(6, 14, 24, 0) 100%);
    background: linear-gradient(180deg, #060e18 0, rgba(6, 14, 24, .66) 59.9%, rgba(6, 14, 24, .35) 83.85%, rgba(6, 14, 24, 0) 100%)
}

.doc-item__date {
    position: absolute;
    top: 20px;
    right: 20px;
    margin: 0
}

.doc-item__ext {
    margin: 0;
    color: #1757c3
}

.doc-item__head {
    max-width: 480px;
    text-transform: uppercase;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    line-height: 1.2
}

.doc-item .icon-btns {
    position: absolute;
    right: 0;
    bottom: 0
}

.direction-item {
    margin-bottom: 30px;
    -webkit-box-shadow: inset 0 -1px 0 #1757c3;
    box-shadow: inset 0 -1px 0 #1757c3
}

.direction-item:last-child {
    margin-bottom: 0
}

.direction-item__toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    position: relative;
    width: 100%;
    min-height: 74px;
    padding: 0 100px 18px 0;
    border: none;
    background: 0 0;
    text-align: left;
    line-height: 1.4;
    font-weight: 600;
    font-size: 24px;
    color: inherit
}

.direction-item__toggle:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 74px;
    height: 74px;
    background: #1757c3 url(../img/icons/arrow-down.svg) no-repeat center;
    -webkit-transition: background .4s;
    -o-transition: background .4s;
    transition: background .4s
}

.direction-item__toggle span {
    display: block;
    width: 100%
}

.direction-item__toggle:hover:after {
    background-color: #07347f
}

.direction-item__toggle.active:after {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg)
}

.direction-item__hidden {
    --img: "";
    display: none;
    padding: 0 100px 30px 70px
}

.direction-item__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.direction-item__img {
    width: auto;
    height: auto;
    max-height: 240px;
    max-width: 360px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    margin-left: 30px;
    margin-right: 80px
}

.direction-item__img img {
    min-width: 100%;
    min-height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.year-tabs {
    margin-bottom: 90px
}

.year-tabs__grid {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 20px 60px;
    min-width: 100%
}

.year-tab {
    display: inline-block;
    padding: 0;
    border: none;
    background: 0 0;
    white-space: nowrap;
    line-height: 1.4;
    font-weight: 600;
    font-size: 24px;
    color: inherit;
    opacity: .2;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.year-tab:hover {
    opacity: .5
}

.year-tab.active {
    opacity: 1;
    color: #1757c3
}

.year-item:nth-child(n+2) {
    display: none
}

.year-item td:nth-child(1) {
    width: 110px
}

.year-item td:nth-child(2) {
    width: 25%
}

.year-item td:last-child {
    width: 180px
}

.news__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 90px 0;
    margin: 0 -20px
}

.news__grid .news-item {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 33.33%;
    padding: 0 20px
}

.news-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
}

.news-item__top {
    margin-bottom: 30px
}

.news-item__top > :last-child {
    margin-bottom: 0
}

.news-item__date {
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid #1757c3;
    line-height: 1.4
}

.news-item__img {
    margin-top: auto;
    position: relative;
    max-width: 400px;
    height: 370px;
    background: #060e18 no-repeat center/cover
}

.news-item__img .btn {
    position: absolute;
    right: 0;
    bottom: 0
}

.post {
    margin-bottom: 90px
}

.post-info {
    position: relative;
    z-index: 3;
    padding-top: 70px;
    margin-bottom: 50px;
    color: #fff
}

.post-info:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-height: 680px;
    background: #1757c3
}

.post-info__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 30px;
    gap: 30px
}

.post-info__date {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none
}

.post-info__head {
    margin: 0;
    padding-bottom: 90px
}

.post-info__img img {
    display: block;
    width: 100%
}

.post-content {
    max-width: 900px;
    margin: 0 auto
}

.post-quote {
    padding-left: 50px;
    margin-bottom: 50px;
    border-left: 2px solid #1757c3
}

.gallery-slider .swiper-slide {
    display: block
}

.gallery-slider .swiper-slide img {
    display: block;
    width: 100%
}

.bim-info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: -170px
}

.bim-info__img {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-right: 110px;
    position: relative;
    z-index: 5;
    width: 500px;
    background: #060e18 no-repeat center/cover;
    height: 680px
}

.bim-info__main {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    padding-bottom: 190px
}

.bim-info__main > :last-child {
    margin-bottom: 0
}

.container:last-child .bim-info:last-child {
    margin-bottom: 0
}

.bim-proj {
    padding: 260px 0 1px;
    background: #1757c3;
    color: #fff
}

.bim-proj__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding-bottom: 90px
}

.bim-proj__top-head {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 48%;
    margin: 0;
    padding-right: 100px
}

.bim-proj__top-content {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.bim-proj__head {
    position: relative;
    z-index: 5;
    margin: 0 0 -1.8em;
    min-height: 1.8em
}

.bim-gall {
    position: relative;
    margin-top: 90px;
    padding-bottom: 90px
}

.bim-gall__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 50px
}

.bim-gall__top-head {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 48%;
    margin: 0;
    padding-right: 100px
}

.bim-gall__top-content {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.bim-gall__back {
    position: absolute;
    z-index: -1;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 350px;
    max-height: 100%;
    background: #07347f
}

.bim-gall .swiper-button-next:hover, .bim-gall .swiper-button-prev:hover {
    background-color: #1e68e4
}

.geography {
    position: relative
}

.geography__map {
    height: 680px
}

.geography__box {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 515px;
    padding: 90px 40px;
    background: #07347f;
    -webkit-box-shadow: 0 20px 20px rgba(0, 0, 0, .11);
    box-shadow: 0 20px 20px rgba(0, 0, 0, .11);
    color: #fff
}

.geography-slider {
    margin-top: 30px
}

.geography-item {
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 30px 20px 30px 30px;
    background: #1757c3;
    color: #fff;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.geography-item__head {
    margin-bottom: 30px
}

.geography-item__more {
    position: relative;
    display: inline-block;
    -ms-flex-item-align: start;
    align-self: flex-start;
    padding: 0 0 10px;
    text-transform: uppercase;
    font-family: IBMPlexMono, monospace;
    font-weight: 500;
    line-height: 1.2
}

.geography-item__more:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #07347f;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.geography-item__more:after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    margin: -.15em 0 0 1.2em;
    width: 1em;
    height: 1em;
    background: url(../img/icons/btn-arrow.svg) no-repeat center
}

.geography-item:hover {
    background-color: #07347f
}

.geography-item:hover .geography-item__more:before {
    background-color: #1757c3
}

.main-map {
    position: relative
}

.main-map:before {
    content: "";
    position: absolute;
    z-index: -5;
    top: 0;
    left: 0;
    right: 0;
    bottom: 185px;
    background: #1757c3
}

.main-map__box {
    height: 625px
}

.contacts__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 50px
}

.contacts__grid .social {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    padding-right: 80px;
    width: 48%
}

.contacts__list {
    margin: 0;
    padding: 0;
    list-style: none
}

.contacts__list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 50px
}

.contacts__list li:last-child {
    margin-bottom: 0
}

.contacts__list li > div {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0
}

.contacts__list ._head {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin: 0 30px 0 0;
    width: 230px;
    color: #1757c3
}

.contacts__list a {
    text-decoration: none;
    -webkit-transition: .4s;
    -o-transition: .4s;
    transition: .4s
}

.contacts__list a:hover {
    color: #1757c3
}

.main-form {
    position: relative;
    z-index: 2;
    padding: 90px 0;
    background: #07347f;
    min-height: 710px;
    color: #fff
}

.main-form__img {
    position: absolute;
    z-index: -1;
    top: 275px;
    right: 50%;
    margin-right: 175px;
    max-width: none;
    max-height: 600px
}

.main-form__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.main-form__head {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin-right: 50px
}

.main-form__form {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 53%
}

.main-form .btn:hover {
    background-color: #1e68e4
}

.b-error {
    min-height: 590px
}

.b-error__wrap {
    position: relative;
    margin-left: 610px;
    max-width: 620px
}

.b-error__img {
    position: absolute;
    z-index: 2;
    top: -60px;
    right: 100%;
    margin-right: 65px;
    max-width: none
}

.b-error__content {
    margin-bottom: 0;
    padding-left: 50px;
    border-left: 2px solid #1757c3
}

.b-error__content span {
    color: #1757c3
}

.b-error__lines {
    position: relative;
    z-index: 1;
    margin: 50px 0 0;
    padding: 80px 0 155px;
    list-style: none
}

.b-error__lines li {
    position: relative;
    margin-bottom: 215px;
    height: 1px;
    background: #1757c3
}

.b-error__lines li:last-child {
    margin-bottom: 0
}

.b-error__lines .ellips-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: 380px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%)
}

.b-error__lines .about-number {
    left: 50%;
    margin-left: -30px;
    width: 310px;
    height: 310px
}

.b-error__lines .about-number span:first-child {
    font-size: 78px
}

.popup {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 1280px;
    background: #07347f;
    margin: 20px auto;
    padding: 110px 50px 60px;
    color: #fff
}

.popup .btn:hover {
    background-color: #1e68e4
}

.form-popup__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.form-popup__title {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0;
    margin: 0 50px 0 0
}

.form-popup__title span {
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: 1px currentColor
}

.form-popup__main {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: 53%
}

@media (max-width: 1319px) {
    .container {
        width: 1200px
    }

    .tab-btns__grid {
        gap: 20px
    }

    .header__grid .logo {
        margin-right: 100px
    }

    .b-about__top {
        max-width: none
    }

    .b-about__wrap {
        max-width: 1060px
    }

    .about-number._proj {
        left: 20px;
        margin-left: 0
    }

    .about-number._team {
        left: auto;
        right: 45px;
        margin-left: 0
    }

    .dir-item__head {
        width: 580px
    }

    .b-contacts__lines li:nth-child(3) .ellips-btn {
        left: auto;
        right: 20px;
        margin: 0
    }

    .footer__grid .logo {
        margin-right: 160px
    }

    .about-info__head {
        margin-right: 75px
    }

    .serv-item__content {
        margin-left: 50px
    }

    .docs-grid {
        gap: 30px 20px
    }

    .news__grid {
        gap: 50px 0;
        margin: 0 -10px
    }

    .news__grid .news-item {
        padding: 0 10px
    }

    .bim-info__img {
        margin-right: 80px
    }

    .contacts__list ._head {
        width: 200px
    }

    .b-error__wrap {
        margin-left: auto
    }

    .b-error__lines .about-number {
        margin-left: -40px
    }
}

@media (max-width: 1199px) {
    .container {
        width: 100%
    }

    h1, h2, h3, h4, h5, h6, ol, p, ul {
        margin: 0 0 15px
    }

    blockquote {
        margin: 30px 0
    }

    table td, table th {
        padding: 30px 10px
    }

    h1, h2 {
        font-size: 40px
    }

    h3, h4 {
        font-size: 20px
    }

    .sect + .sect {
        margin-top: 90px
    }

    .close-btn {
        width: 54px;
        height: 54px
    }

    .form-item {
        margin-bottom: 15px
    }

    .form-action {
        margin-top: 30px
    }

    .quote-descr {
        max-width: 530px;
        padding-left: 20px
    }

    .title {
        margin-bottom: 30px
    }

    .content-img {
        margin: 30px 0
    }

    .breadcrumbs {
        display: none
    }

    .big-btn {
        margin-top: 30px;
        min-height: 64px
    }

    .ellips-btn {
        width: 110px;
        height: 110px
    }

    .tab-btns {
        overflow: auto;
        margin: 0 -20px 50px
    }

    .tab-btns__grid {
        gap: 0;
        padding: 0 20px
    }

    .tab-btns__grid:before {
        left: 20px;
        right: 20px
    }

    .tab-btn {
        display: inline-block;
        padding: 20px 30px;
        min-height: 0;
        white-space: nowrap
    }

    .subtitle {
        margin-bottom: 10px
    }

    .header {
        padding: 30px 0
    }

    .header__grid .logo {
        margin-right: auto
    }

    .header__grid .menu {
        display: none
    }

    .header__grid .sandwich {
        display: block
    }

    .header__lang {
        width: auto;
        height: auto;
        line-height: inherit;
        -webkit-transition: .4s;
        -o-transition: .4s;
        transition: .4s
    }

    .header__lang:before {
        display: none
    }

    .header__lang:hover {
        opacity: .75
    }

    .b-contacts {
        max-height: 585px
    }

    .bann {
        padding: 50px 0 60px;
        min-height: 460px
    }

    .bann:before {
        top: 80px;
        margin-left: -50px;
        width: 400px;
        height: 400px;
        opacity: .7
    }

    .bann__wrap {
        max-width: 355px
    }

    .bann__img {
        margin-left: -65px
    }

    .bann__head span:first-child {
        -webkit-box-shadow: inset 0 -3px 0 #07347f;
        box-shadow: inset 0 -3px 0 #07347f
    }

    .bann__descr {
        margin-top: 30px
    }

    .b-about {
        margin-bottom: 90px
    }

    .b-about__top {
        padding: 90px 0 30px
    }

    .b-about__top .subtitle {
        margin: 25px 30px 0 0
    }

    .b-about__title {
        width: 55%
    }

    .b-about__title > * {
        margin-bottom: 30px
    }

    .b-about__img {
        margin-bottom: 30px;
        height: 600px
    }

    .b-about__quote {
        padding-right: 140px
    }

    .b-about__quote:before {
        display: none
    }

    .b-about__quote .ellips-btn {
        bottom: -15px
    }

    .b-about__quote-content {
        position: relative;
        padding-left: 20px
    }

    .b-about__quote-content:before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        border-right: 2px solid #1757c3
    }

    .parallax-img {
        height: 520px
    }

    .parallax-img._about:before {
        top: -85px;
        right: -55px;
        width: 190px;
        height: 190px
    }

    .parallax-img._about:after {
        left: -230px;
        bottom: -380px
    }

    .big-proj {
        margin-top: 90px
    }

    .big-proj__head {
        max-width: 800px
    }

    .big-proj__img .parallax-img:after {
        left: -160px;
        bottom: -310px
    }

    .big-proj__content {
        top: 100px;
        left: auto;
        right: 20px;
        width: 50%
    }

    .directions {
        padding: 90px 0
    }

    .directions .b-about__title {
        width: 49%
    }

    .dir-item__number {
        margin-right: 30px;
        width: 66px;
        height: 66px;
        line-height: 62px
    }

    .dir-item__content {
        margin-right: 40px
    }

    .dir-item__head {
        width: 49%
    }

    .date-box__main {
        font-size: 48px
    }

    .b-news__title {
        margin-bottom: 30px
    }

    .b-news__title .subtitle {
        margin: 25px 0 0 30px
    }

    .b-news-item__top {
        padding-top: 15px;
        margin-bottom: 15px
    }

    .b-news-item__top .date-box {
        margin-left: 20px
    }

    .b-news-item {
        width: 42%
    }

    .b-news-item:nth-child(4n+2), .b-news-item:nth-child(4n+3) {
        margin-left: 5%
    }

    .b-contacts {
        margin-top: 90px
    }

    .b-contacts__img {
        margin-right: 140px;
        max-height: 630px
    }

    .b-contacts__wrapper {
        padding: 0;
        min-height: 645px
    }

    .b-contacts__wrap {
        margin-left: 45%
    }

    .b-contacts__title {
        margin-bottom: 30px
    }

    .b-contacts__items li {
        margin-bottom: 15px
    }

    .b-contacts__lines {
        padding: 100px 0 60px
    }

    .b-contacts__lines li {
        margin-bottom: 120px
    }

    .b-contacts__lines li .ellips-btn {
        left: auto;
        right: 85px;
        width: 160px;
        height: 160px
    }

    .footer {
        padding: 90px 0 25px
    }

    .footer__grid._bot {
        margin-top: 20px;
        padding-top: 20px
    }

    .footer__grid .logo img:nth-child(n+2) {
        display: none
    }

    .inn-bann {
        padding: 50px 0
    }

    .inn-bann + .sect {
        margin-top: 50px
    }

    .inn-title {
        margin-bottom: 50px
    }

    .inn-title__head {
        border-bottom-width: 3px
    }

    .inn-title .quote-descr {
        margin-top: 30px
    }

    .about-info {
        margin-bottom: 50px
    }

    .about-info__head {
        margin-right: 50px
    }

    .about-info .content {
        width: 60%
    }

    .about-numbers-wrap {
        padding: 1px 0 50px
    }

    .about-numbers-wrap .about-numbers {
        margin-top: 0
    }

    .serv-item__content {
        width: 60%
    }

    .services {
        padding: 50px 0 90px
    }

    .team-grid {
        margin: 0 -10px
    }

    .team-grid__col {
        padding: 0 10px
    }

    .team-grid__col:nth-child(3) {
        margin-top: 90px
    }

    .team-grid__col._title {
        min-height: 320px
    }

    .team-item__content > * {
        margin-bottom: 15px
    }

    .icon-btn {
        width: 54px;
        height: 54px
    }

    .icon-btn img {
        max-width: 20px;
        max-height: 20px
    }

    .docs-grid {
        -ms-grid-columns:(1fr) [ 3 ];
        grid-template-columns:repeat(3, 1fr)
    }

    .direction-item__toggle {
        padding: 0 75px 15px 0;
        min-height: 54px;
        font-size: 20px
    }

    .direction-item__toggle:after {
        width: 54px;
        height: 54px
    }

    .direction-item__hidden {
        padding: 0 75px 30px 30px
    }

    .direction-item__img {
        max-width: 290px;
        margin-right: 20px
    }

    .year-tabs {
        overflow: auto;
        margin: 0 -20px 50px
    }

    .year-tabs__grid {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        gap: 60px;
        padding: 0 20px
    }

    .year-tab {
        font-size: 20px
    }

    .year-item td:last-child, .year-item td:nth-child(2) {
        width: auto
    }

    .pagination {
        margin-top: 50px
    }

    .pagination__list ._arrow {
        width: 54px;
        height: 54px
    }

    .pagination__list ._prev {
        margin-right: 20px
    }

    .pagination__list ._next {
        margin-left: 20px
    }

    .post-info {
        padding-top: 20px
    }

    .post-info:before {
        max-height: none
    }

    .post-info__top {
        margin-bottom: 10px
    }

    .post-info__head {
        padding-bottom: 50px
    }

    .post-info__img {
        margin: 0 -20px
    }

    .bim-info {
        margin-bottom: -80px
    }

    .bim-info__img {
        margin-right: 50px;
        width: 355px;
        height: 520px
    }

    .bim-info__main {
        padding-bottom: 100px
    }

    .bim-proj {
        padding-top: 130px
    }

    .bim-proj__top {
        padding-bottom: 50px
    }

    .bim-proj__top-head {
        margin-right: 50px;
        padding-right: 0;
        width: 355px
    }

    .bim-gall {
        margin: 50px 0 90px;
        padding: 0
    }

    .bim-gall__back {
        display: none
    }

    .bim-gall__top {
        display: block;
        margin-bottom: 30px
    }

    .bim-gall__top-head {
        width: auto;
        margin: 0 0 30px;
        padding: 0
    }

    .geography__map {
        height: 520px
    }

    .geography__box {
        top: 20px;
        right: 20px;
        width: 440px;
        padding: 40px
    }

    .geography__box .content > :first-child {
        padding-right: 20px
    }

    .main-map:before {
        bottom: 120px
    }

    .social .subtitle {
        margin-bottom: 40px
    }

    .contacts__grid {
        margin-top: 30px
    }

    .contacts__grid .social {
        width: 43%;
        padding-right: 40px
    }

    .contacts__list li {
        margin-bottom: 30px
    }

    .contacts__list ._head {
        margin-right: 20px;
        width: 165px
    }

    .main-form__img {
        top: 195px;
        margin-right: 140px
    }

    .main-form__grid {
        display: block
    }

    .main-form__head {
        margin: 0 0 30px
    }

    .main-form__form {
        width: 480px;
        margin-left: auto
    }

    .b-error {
        min-height: 535px
    }

    .b-error__img {
        top: -12px;
        margin-right: 25px;
        max-height: 610px
    }

    .b-error__wrap {
        margin-left: 45%;
        max-width: 375px
    }

    .b-error__content {
        padding-left: 20px
    }

    .b-error__lines {
        padding-bottom: 130px
    }

    .b-error__lines .ellips-btn {
        left: auto;
        right: 40px;
        margin: 0;
        width: 160px;
        height: 160px
    }

    .b-error__lines .about-number {
        width: 260px;
        height: 260px
    }

    .b-error__lines .about-number span:first-child {
        font-size: 72px
    }

    .popup {
        padding: 60px 40px
    }

    .form-popup__grid {
        display: block
    }

    .form-popup__title {
        margin: 0 0 45px
    }

    .form-popup__main {
        width: auto
    }
}

@media (max-width: 991px) {
    .table-wrap {
        overflow: auto;
        margin: 0 -20px
    }

    .table-wrap table {
        margin: 0 20px;
        width: 1000px
    }

    .b-about:before {
        display: none
    }

    .b-about__top {
        margin: 0 -20px;
        padding: 90px 20px 30px;
        background: #07347f
    }

    .b-about__img {
        margin: 0 -20px 30px;
        height: 520px
    }

    .b-about__img:before {
        top: -250px;
        left: -60px
    }

    .b-about__img:after {
        width: 160px;
        height: 160px
    }

    .b-about__img-quote {
        top: 25px;
        left: 20px
    }

    .b-about__quote-content {
        max-width: 375px
    }

    .about-numbers {
        padding: 70px 0 80px
    }

    .about-number {
        width: 160px;
        height: 160px
    }

    .about-number span {
        margin-bottom: 10px
    }

    .about-number span:first-child {
        font-size: 32px
    }

    .about-number._years {
        width: 220px;
        height: 220px
    }

    .about-number._years span:first-child {
        font-size: 64px
    }

    .about-number._proj {
        width: 260px;
        height: 260px
    }

    .about-number._proj span:first-child {
        font-size: 72px
    }

    .about-number._dir {
        margin-left: -30px
    }

    .about-number._dir span:first-child {
        font-size: 48px
    }

    .b-news__title {
        display: block
    }

    .b-news__title .subtitle {
        margin: 0 0 10px
    }

    .b-news-item:nth-child(n) {
        width: 100%;
        margin: 0
    }

    .b-news-item:nth-child(n) .b-news-item__img {
        max-width: 800px;
        height: 370px
    }

    .b-news-item:nth-child(n+2) {
        margin-top: 50px
    }

    .footer__grid .logo {
        margin-right: 70px
    }

    .about-info {
        display: block
    }

    .about-info__head {
        margin: 0 0 30px
    }

    .about-info .content {
        width: auto
    }

    .about-numbers-head {
        margin-bottom: 30px
    }

    .about-numbers-descr {
        max-width: 350px
    }

    .about-numbers-wrap .about-numbers {
        margin-top: 20px
    }

    .serv-item {
        display: block
    }

    .serv-item__head {
        margin: 0 0 15px
    }

    .serv-item__content {
        width: auto;
        margin: 0
    }

    .team-grid__col {
        width: 50%
    }

    .team-grid__col:nth-child(n+3) {
        margin-top: 90px
    }

    .team-grid__col._title {
        min-height: 130px
    }

    .doc-item {
        height: 260px
    }

    .doc-item:before {
        height: 55%
    }

    .doc-item._review:before {
        height: 85%
    }

    .doc-item._review .doc-item__head {
        margin-bottom: 10px;
        padding-bottom: 10px;
        border-bottom: 2px solid #1757c3
    }

    .news__grid .news-item {
        width: 50%
    }

    .post-info {
        margin-bottom: 30px
    }

    .post-quote {
        padding-left: 0;
        margin-bottom: 30px;
        border-left: none
    }

    .post-quote:before {
        display: none
    }

    .gallery-slider {
        overflow: visible
    }

    .gallery-slider .swiper-slide {
        width: 410px
    }

    .bim-info__img {
        margin-right: 20px
    }

    .bim-proj__top-head {
        margin-right: 20px
    }

    .geography__box {
        top: auto;
        right: 0;
        bottom: 0;
        width: 100%
    }

    .geography-slider {
        overflow: visible
    }

    .geography-slider .swiper-slide {
        width: 300px
    }
}

@media (max-width: 767px) {
    .btn {
        padding: 20px 30px
    }

    .ellips-btn._social {
        width: 64px;
        height: 64px
    }

    .mob-menu__wrapper {
        padding: 135px 40px 40px
    }

    .mob-menu .menu {
        font-size: 20px
    }

    .header {
        padding: 20px 0
    }

    .bann:before {
        display: none
    }

    .bann__img {
        margin-left: 35px
    }

    .b-about__top {
        display: block
    }

    .b-about__top .subtitle {
        margin: 0 0 10px
    }

    .b-about__title {
        width: auto
    }

    .b-about__img {
        height: 420px
    }

    .b-about__quote {
        padding-right: 0
    }

    .b-about__quote .ellips-btn {
        bottom: -40px
    }

    .b-about .about-numbers {
        margin-top: 50px
    }

    .parallax-img {
        height: 400px
    }

    .big-proj .parallax-img {
        height: 400px
    }

    .big-proj .parallax-img:after {
        left: -95px;
        bottom: -180px;
        width: 290px;
        height: 290px
    }

    .big-proj__content {
        left: 20px;
        width: auto
    }

    .directions .b-about__title {
        width: auto
    }

    .dir-item {
        display: block;
        margin-bottom: 50px
    }

    .dir-item__content, .dir-item__number {
        margin: 0 0 15px
    }

    .dir-item__head {
        width: auto
    }

    .dir-item._obj {
        padding-bottom: 0;
        border-bottom: none
    }

    .b-contacts {
        max-height: unset
    }

    .b-contacts__lines {
        padding: 100px 0 80px
    }

    .b-contacts__img {
        display: none
    }

    .b-contacts__wrapper {
        min-height: 0
    }

    .b-contacts__wrap {
        margin-left: 0;
        max-width: none
    }

    .b-contacts__lines li:nth-child(2) .ellips-btn {
        left: 20px
    }

    .footer {
        padding: 60px 0 25px
    }

    .footer__grid._main {
        display: block
    }

    .footer__grid._bot {
        margin-top: 30px;
        padding-top: 30px
    }

    .footer__grid .logo {
        margin-bottom: 30px
    }

    .about-numbers-descr {
        max-width: none
    }

    .about-numbers-wrap .about-numbers {
        margin-top: 70px
    }

    .direction-item__content {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        padding-right: 0
    }

    .direction-item__img {
        max-width: 360px;
        margin: 30px auto 0
    }

    .docs-grid {
        grid-template-columns:repeat(auto-fill, minmax(240px, 1fr))
    }

    .doc-item {
        height: 340px
    }

    .docs-grid._2 {
        -ms-grid-columns: 1fr;
        grid-template-columns:1fr
    }

    .news-item__img {
        overflow: hidden;
        height: auto;
        max-height: 370px
    }

    .news-item__img:before {
        content: "";
        display: block;
        width: 100%;
        padding-bottom: 85%
    }

    .gallery-slider .swiper-slide {
        width: 230px
    }

    .bim-info {
        display: block;
        margin-bottom: 50px
    }

    .bim-info__img {
        margin: 0 0 30px;
        width: 100%;
        max-width: 400px;
        height: auto
    }

    .bim-info__img:before {
        content: "";
        display: block;
        width: 100%;
        padding-bottom: 117%
    }

    .bim-info__main {
        padding-bottom: 0
    }

    .bim-proj {
        padding-top: 50px
    }

    .bim-proj__top {
        display: block
    }

    .bim-proj__top-head {
        width: auto;
        margin: 0 0 15px
    }

    .bim-gall__top-head {
        margin-bottom: 15px
    }

    .main-map:before {
        bottom: 80px
    }

    .main-map__box {
        height: 380px
    }

    .social .subtitle {
        margin-bottom: 30px
    }

    .social__grid {
        margin: 0 -5px -12px
    }

    .social__grid .ellips-btn {
        margin: 0 5px 12px
    }

    .contacts__grid {
        display: block
    }

    .contacts__grid .social {
        width: auto;
        margin: 0 0 30px;
        padding: 0
    }

    .main-form {
        padding: 60px 0;
        min-height: 0
    }

    .main-form__img {
        display: none
    }

    .main-form__head {
        margin-bottom: 20px
    }

    .main-form__form {
        width: auto
    }

    .b-error {
        min-height: 0
    }

    .b-error__img {
        display: none
    }

    .b-error__wrap {
        margin: 0
    }

    .b-error__lines .about-number {
        left: 20px;
        margin: 0
    }
}

@media (max-width: 575px) {
    .container {
        padding: 0 15px
    }

    body, html {
        font-size: 12px
    }

    h1, h2 {
        font-size: 32px
    }

    h3, h4 {
        font-size: 20px
    }

    h5 {
        font-size: 15px
    }

    blockquote {
        padding: 90px 0 30px;
        background-size: auto 42px
    }

    .table-wrap {
        overflow: auto;
        margin: 0 -15px
    }

    .table-wrap table {
        margin: 0 15px;
        width: 700px
    }

    .sect {
        margin: 60px 0
    }

    .sect + .sect {
        margin-top: 60px
    }

    .mob-menu__wrapper {
        padding: 135px 15px 60px
    }

    .mob-menu .menu {
        font-size: 15px
    }

    .btn {
        font-size: 12px
    }

    .big-btn {
        border-width: 1px;
        min-height: 54px;
        font-size: 12px
    }

    .form-option label {
        font-size: 12px
    }

    .form-option span {
        padding: 7px 0 0 45px;
        min-height: 30px
    }

    .form-option span:before {
        width: 30px;
        height: 30px
    }

    .form-option span:after {
        top: 10px;
        left: 10px;
        width: 10px;
        height: 10px
    }

    .tab-btns {
        margin: 0 -15px 50px
    }

    .tab-btns__grid {
        padding: 0 15px
    }

    .tab-btns__grid:before {
        left: 15px;
        right: 15px
    }

    .tab-btn {
        padding: 16px 20px
    }

    .sandwich {
        width: 46px;
        height: 46px
    }

    .logo img {
        max-height: 46px
    }

    .logo img:nth-child(n+2) {
        display: none
    }

    .ellips-btn {
        padding: 0 7px;
        width: 80px;
        height: 80px;
        font-size: 12px
    }

    .menu {
        -ms-grid-columns:(1fr) [ 2 ];
        grid-template-columns:repeat(2, 1fr);
        gap: 12px 15px
    }

    .header {
        padding: 15px 0
    }

    .header__grid .sandwich, .header__lang {
        margin-left: 15px
    }

    .bann {
        padding: 30px 0 60px;
        min-height: 300px
    }

    .bann__img {
        top: 100px;
        left: 230px;
        margin: 0;
        max-height: 200px
    }

    .bann__wrap {
        max-width: 290px
    }

    .bann__descr {
        max-width: 220px
    }

    .bann__ellips {
        right: 50%;
        bottom: -50px;
        margin-right: -50px
    }

    .b-about {
        margin-bottom: 60px
    }

    .b-about__top {
        margin: 0 -15px;
        padding: 55px 15px 30px
    }

    .b-about__img {
        margin: 0 -15px 30px;
        height: 340px
    }

    .b-about__img:before {
        top: -320px;
        left: 50%;
        margin-left: -275px
    }

    .b-about__img:after {
        right: -35px;
        bottom: -45px;
        width: 85px;
        height: 85px
    }

    .b-about__img-quote {
        top: 15px;
        left: 0;
        right: 0;
        width: 420px;
        max-width: 100%;
        margin: 0 auto;
        background-position: 15px 0;
        background-size: auto 42px;
        padding: 52px 15px 0 40px
    }

    .b-about__quote-content {
        max-width: 270px
    }

    .b-about__quote .ellips-btn {
        bottom: -70px
    }

    .about-numbers {
        padding: 55px 0
    }

    .about-numbers li {
        margin-bottom: 120px
    }

    .about-number {
        width: 104px;
        height: 104px;
        border-width: 1px
    }

    .about-number span {
        margin-bottom: 5px
    }

    .about-number._years {
        margin-left: -45px;
        width: 110px;
        height: 110px
    }

    .about-number._years span:first-child {
        font-size: 36px
    }

    .about-number._proj {
        left: 15px;
        width: 150px;
        height: 150px
    }

    .about-number._proj span:first-child {
        font-size: 42px
    }

    .about-number._team {
        right: 10px
    }

    .about-number._dir span:first-child {
        font-size: 32px
    }

    .parallax-img {
        height: 340px
    }

    .big-proj {
        margin-top: 60px
    }

    .big-proj__head {
        min-height: 0;
        margin: 0 0 15px
    }

    .big-proj__content {
        top: 30px;
        left: 15px;
        right: 15px
    }

    .directions {
        padding: 60px 0
    }

    .date-box__main {
        font-size: 40px
    }

    .b-news-item__top {
        display: block
    }

    .b-news-item__top .date-box {
        margin: 0 0 15px
    }

    .b-news-item:nth-child(n) .b-news-item__img {
        height: 240px
    }

    .b-contacts {
        margin-top: 60px
    }

    .b-contacts__items li > div.img-box {
        width: 20px;
        height: 20px
    }

    .b-contacts__lines {
        padding: 60px 0 53px
    }

    .b-contacts__lines li {
        margin-bottom: 85px
    }

    .b-contacts__lines li .ellips-btn {
        width: 104px;
        height: 104px;
        padding: 0;
        right: 15px
    }

    .b-contacts__lines li .ellips-btn img {
        max-width: 30px;
        max-height: 30px
    }

    .about-info__head {
        margin-bottom: 15px
    }

    .parallax-img._about:before {
        display: none
    }

    .parallax-img._about:after {
        left: 50%;
        margin-left: -265px
    }

    .about-numbers-head {
        margin-top: -2.7em;
        min-height: 2.7em
    }

    .about-numbers-wrap .about-numbers {
        margin-top: 30px
    }

    .services {
        padding: 50px 0 60px
    }

    .team-grid__col {
        width: 100%
    }

    .team-grid__col:nth-child(n+2) {
        margin-top: 50px
    }

    .team-grid__col._title {
        min-height: 0
    }

    .direction-item__hidden {
        padding: 15px 0 30px 0
    }

    .direction-item__hidden ul {
        padding-left: 20px
    }

    .year-tabs {
        margin: 0 -15px 50px
    }

    .year-tabs__grid {
        padding: 0 15px
    }

    .year-item td:nth-child(1) {
        width: 80px
    }

    .news__grid .news-item {
        width: 100%
    }

    .pagination__list {
        gap: 9px
    }

    .pagination__list ._prev {
        margin-right: 10px
    }

    .pagination__list ._next {
        margin-left: 10px
    }

    .post {
        margin-bottom: 60px
    }

    .post-info {
        padding-top: 30px
    }

    .bim-proj__head {
        margin: 0 0 15px;
        min-height: 0
    }

    .bim-gall {
        margin: 50px 0 60px
    }

    .geography__map {
        height: 340px
    }

    .geography__box {
        padding: 10px
    }

    .geography__box .content h4 {
        font-size: 12px
    }

    .geography__box .content li {
        margin-bottom: 3px
    }

    .geography__box .content > * {
        margin-bottom: 10px
    }

    .geography__box .content > :last-child {
        margin-bottom: 0
    }

    .geography__box .content > :first-child {
        padding-right: 60px
    }

    .geography-slider .swiper-slide {
        width: 215px
    }

    .contacts__list ._head {
        width: 120px
    }

    .b-error__lines {
        padding: 52px 0 75px
    }

    .b-error__lines li {
        margin-bottom: 135px
    }

    .b-error__lines .ellips-btn {
        right: 35px;
        width: 105px;
        height: 105px
    }

    .b-error__lines .about-number {
        left: 15px;
        width: 150px;
        height: 150px
    }

    .b-error__lines .about-number span:first-child {
        font-size: 42px
    }

    .popup {
        margin: 15px auto;
        padding: 60px 15px
    }

    .form-popup__title {
        margin-bottom: 15px
    }
}

@media (min-width: 1200px) {
    .form-action._grid {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    .form-action._grid .form-option {
        -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
        flex: 1 0 0;
        margin: 0 30px 0 0
    }

    .bim-info__main .subtitle {
        margin-bottom: 30px
    }
}