/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

main {
    display: block
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: 0;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    -moz-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b, strong {
    font-weight: bolder
}

code, kbd, samp {
    font-family: monospace, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 60%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button, input, optgroup, select, textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button, input {
    overflow: visible
}

button, select {
    text-transform: none
}

[type=button], [type=reset], [type=submit], 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 {
    padding: .35em .75em .625em
}

legend {
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox], [type=radio] {
    -moz-box-sizing: border-box;
    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-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none
}

@font-face {
    font-family: Manrope;
    src: url(../fonts/Manrope-Medium.woff2) format("woff2"), url(../fonts/Manrope-Medium.woff) format("woff");
    font-weight: 500;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Manrope;
    src: url(../fonts/Manrope-Light.woff2) format("woff2"), url(../fonts/Manrope-Light.woff) format("woff");
    font-weight: 300;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Manrope;
    src: url(../fonts/Manrope-Regular.woff2) format("woff2"), url(../fonts/Manrope-Regular.woff) format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Manrope;
    src: url(../fonts/Manrope-Bold.woff2) format("woff2"), url(../fonts/Manrope-Bold.woff) format("woff");
    font-weight: 700;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Manrope;
    src: url(../fonts/Manrope-SemiBold.woff2) format("woff2"), url(../fonts/Manrope-SemiBolds.woff) format("woff");
    font-weight: 600;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Icons;
    src: url(../fonts/Icons.eot);
    src: url(../fonts/Icons.eot?#iefix) format("embedded-opentype"), url(../fonts/Icons.woff) format("woff"), url(../fonts/Icons.ttf) format("truetype"), url(../fonts/Icons.svg#Icons) format("svg");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

.icon {
    font-family: Icons, sans-serif;
    display: inline-block;
    font-style: normal;
    font-weight: 400;
    line-height: 1;
    vertical-align: middle;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-variant: normal;
    text-rendering: auto
}

.reset {
    margin: 0;
    padding: 0;
    list-style: none
}

.hidden {
    display: none
}

.show {
    display: block !important
}

.no-margin {
    margin: 0 !important
}

.no-padding {
    padding: 0 !important
}

.no-bg {
    background: 0 0 !important
}

.no-border {
    border: 0 !important
}

.bold {
    font-weight: 700
}

.italic {
    font-style: italic
}

.underline {
    text-decoration: underline
}

.pointer {
    cursor: pointer
}

.uppercase {
    text-transform: uppercase
}

.lowercase {
    text-transform: lowercase
}

.disabled {
    cursor: default !important;
    opacity: .3;
    filter: alpha(opacity=30)
}

.text-center {
    text-align: center
}

.text-left {
    text-align: left
}

.text-right {
    text-align: right
}

.text-justify {
    text-align: justify
}

.w-1 {
    width: 1%
}

.w-2 {
    width: 2%
}

.w-3 {
    width: 3%
}

.w-4 {
    width: 4%
}

.w-5 {
    width: 5%
}

.w-6 {
    width: 6%
}

.w-7 {
    width: 7%
}

.w-8 {
    width: 8%
}

.w-9 {
    width: 9%
}

.w-10 {
    width: 10%
}

.w-11 {
    width: 11%
}

.w-12 {
    width: 12%
}

.w-13 {
    width: 13%
}

.w-14 {
    width: 14%
}

.w-15 {
    width: 15%
}

.w-16 {
    width: 16%
}

.w-17 {
    width: 17%
}

.w-18 {
    width: 18%
}

.w-19 {
    width: 19%
}

.w-20 {
    width: 20%
}

.w-21 {
    width: 21%
}

.w-22 {
    width: 22%
}

.w-23 {
    width: 23%
}

.w-24 {
    width: 24%
}

.w-25 {
    width: 25%
}

.w-26 {
    width: 26%
}

.w-27 {
    width: 27%
}

.w-28 {
    width: 28%
}

.w-29 {
    width: 29%
}

.w-30 {
    width: 30%
}

.w-31 {
    width: 31%
}

.w-32 {
    width: 32%
}

.w-33 {
    width: 33%
}

.w-34 {
    width: 34%
}

.w-35 {
    width: 35%
}

.w-36 {
    width: 36%
}

.w-37 {
    width: 37%
}

.w-38 {
    width: 38%
}

.w-39 {
    width: 39%
}

.w-40 {
    width: 40%
}

.w-41 {
    width: 41%
}

.w-42 {
    width: 42%
}

.w-43 {
    width: 43%
}

.w-44 {
    width: 44%
}

.w-45 {
    width: 45%
}

.w-46 {
    width: 46%
}

.w-47 {
    width: 47%
}

.w-48 {
    width: 48%
}

.w-49 {
    width: 49%
}

.w-50 {
    width: 50%
}

.w-51 {
    width: 51%
}

.w-52 {
    width: 52%
}

.w-53 {
    width: 53%
}

.w-54 {
    width: 54%
}

.w-55 {
    width: 55%
}

.w-56 {
    width: 56%
}

.w-57 {
    width: 57%
}

.w-58 {
    width: 58%
}

.w-59 {
    width: 59%
}

.w-60 {
    width: 60%
}

.w-61 {
    width: 61%
}

.w-62 {
    width: 62%
}

.w-63 {
    width: 63%
}

.w-64 {
    width: 64%
}

.w-65 {
    width: 65%
}

.w-66 {
    width: 66%
}

.w-67 {
    width: 67%
}

.w-68 {
    width: 68%
}

.w-69 {
    width: 69%
}

.w-70 {
    width: 70%
}

.w-71 {
    width: 71%
}

.w-72 {
    width: 72%
}

.w-73 {
    width: 73%
}

.w-74 {
    width: 74%
}

.w-75 {
    width: 75%
}

.w-76 {
    width: 76%
}

.w-77 {
    width: 77%
}

.w-78 {
    width: 78%
}

.w-79 {
    width: 79%
}

.w-80 {
    width: 80%
}

.w-81 {
    width: 81%
}

.w-82 {
    width: 82%
}

.w-83 {
    width: 83%
}

.w-84 {
    width: 84%
}

.w-85 {
    width: 85%
}

.w-86 {
    width: 86%
}

.w-87 {
    width: 87%
}

.w-88 {
    width: 88%
}

.w-89 {
    width: 89%
}

.w-90 {
    width: 90%
}

.w-91 {
    width: 91%
}

.w-92 {
    width: 92%
}

.w-93 {
    width: 93%
}

.w-94 {
    width: 94%
}

.w-95 {
    width: 95%
}

.w-96 {
    width: 96%
}

.w-97 {
    width: 97%
}

.w-98 {
    width: 98%
}

.w-99 {
    width: 99%
}

.w-16 {
    width: 16.666666667%
}

.w-33 {
    width: 33.3333%
}

.w-37 {
    width: 37.5%
}

.w-67 {
    width: 66.6666%
}

.w-100 {
    width: 100%
}

.flex-row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row wrap;
    -moz-box-orient: horizontal;
    -moz-box-direction: normal;
    flex-flow: row wrap;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -moz-box-pack: start;
    justify-content: flex-start;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -moz-box-align: start;
    align-items: flex-start;
    margin: 0 -12.5px
}

@media (max-width: 576px) {
    .flex-row {
        margin: 0 -5.5px
    }
}

.flex-row.is-stretch {
    -webkit-box-align: stretch;
    -webkit-align-items: stretch;
    -moz-box-align: stretch;
    align-items: stretch
}

.flex-row .flex-row-item {
    padding: 0 12.5px
}

@media (max-width: 576px) {
    .flex-row .flex-row-item {
        padding: 0 5.5px
    }
}

.flex-between {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -moz-box-pack: justify;
    justify-content: space-between
}

.f-row-item {
    float: left;
    margin-bottom: 15px;
    padding: 0 15px
}

.ajax-loader {
    background-color: rgba(255, 255, 255, .9);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: auto;
    z-index: 1000
}

.ajax-loader div {
    position: absolute;
    top: 50%;
    left: 50%;
    margin: 0;
    text-align: center;
    z-index: 1000;
    -webkit-transform: translateX(-50%) translateY(-50%);
    -moz-transform: translateX(-50%) translateY(-50%);
    -o-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
    width: 3rem;
    height: 3rem;
    font-size: 1em
}

.ajax-loader div:after, .ajax-loader div:before {
    width: 3rem;
    height: 3rem;
    margin: 0 0 0 -1.5rem
}

.ajax-loader div:before {
    position: absolute;
    content: "";
    top: 0;
    left: 50%;
    border-radius: 500rem;
    border: .3em solid rgba(0, 0, 0, .1)
}

.ajax-loader div:after {
    position: absolute;
    content: "";
    top: 0;
    left: 50%;
    -webkit-animation: loader .6s linear;
    -moz-animation: loader .6s linear;
    animation: loader .6s linear;
    -webkit-animation-iteration-count: infinite;
    -moz-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    border-radius: 500rem;
    border-color: #767676 transparent transparent;
    border-style: solid;
    border-width: .3em;
    box-shadow: 0 0 0 1px transparent
}

@-webkit-keyframes loader {
    from {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@-moz-keyframes loader {
    from {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        transform: rotate(0)
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes loader {
    from {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0)
    }
    to {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.scrollbar-styled::-webkit-scrollbar {
    width: 6px;
    height: 6px
}

.scrollbar-styled::-webkit-scrollbar-thumb {
    background: #bdbdbd;
    border-radius: 6px
}

.scrollbar-styled::-webkit-scrollbar-track {
    background: #e0e0e0;
    border-radius: 6px
}

@media (max-width: 991px) {
    .is-desktop {
        display: none !important
    }
}

@media (min-width: 993px) {
    .is-tablet {
        display: none !important
    }
}

@media (min-width: 577px) {
    .is-mobile {
        display: none !important
    }
}

.h1, h1 {
    font-weight: 700;
    font-size: 3.6875rem;
    line-height: 1.35;
    margin: 1.6em 0
}

@media (max-width: 1200px) {
    .h1, h1 {
        margin: 1.2em 0
    }
}

@media (max-width: 992px) {
    .h1, h1 {
        font-size: 2rem
    }
}

.h2, h2 {
    font-weight: 700;
    font-size: 3rem;
    line-height: 1.35;
    margin: 1.875rem 0
}

@media (max-width: 1200px) {
    .h2, h2 {
        margin: 1.2em 0
    }
}

@media (max-width: 992px) {
    .h2, h2 {
        font-size: 1.75rem
    }
}

.h3, h3 {
    font-weight: 600;
    font-size: 1.5rem;
    line-height: 1.285714286;
    margin: 1.6em 0
}

@media (max-width: 1200px) {
    .h3, h3 {
        margin: 1.2em 0
    }
}

.h4, .h5, .h6, h4, h5, h6 {
    font-weight: 500;
    font-size: .875rem;
    margin: 1.6em 0
}

@media (max-width: 1200px) {
    .h4, .h5, .h6, h4, h5, h6 {
        margin: 1.2em 0
    }
}

.price-text {
    font-weight: 500;
    font-size: 2.5rem;
    line-height: 1;
    color: #000
}

.h2 > .title-page__count {
    margin-left: .625rem
}

.g-main-text {
    font-size: .875rem;
    line-height: 1.43;
    color: #000
}

.g-main-text--width-big {
    max-width: 66.25rem
}

.g-description {
    font-size: .875rem;
    line-height: 1.43;
    color: #000
}

.g-seconadry-text {
    font-size: .75rem;
    line-height: 1.33;
    color: #000
}

.g-seconadry-text--elements {
    font-weight: 500
}

.g-link {
    color: #2fbeff;
    text-decoration: none
}

.g-link:hover {
    text-decoration: none;
    color: #2fbeff
}

.card-text {
    font-size: 1rem;
    line-height: 112%;
    letter-spacing: -.03em;
    color: #000
}

a {
    color: #2fbeff;
    text-decoration: none
}

a:hover {
    text-decoration: none;
    color: #2fbeff
}

a:hover {
    text-decoration: underline
}

a:focus {
    outline: 0
}

textarea {
    overflow: auto
}

input.placeholder, textarea.placeholder {
    color: #000
}

input:-moz-placeholder, textarea:-moz-placeholder {
    color: #000
}

input::-moz-placeholder, textarea::-moz-placeholder {
    opacity: 1;
    color: #000
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
    color: #000
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
    color: #000
}

input:focus.placeholder, textarea:focus.placeholder {
    color: transparent !important
}

input:focus:-moz-placeholder, textarea:focus:-moz-placeholder {
    color: transparent !important
}

input:focus::-moz-placeholder, textarea:focus::-moz-placeholder {
    opacity: 1;
    color: transparent !important
}

input:focus::-webkit-input-placeholder, textarea:focus::-webkit-input-placeholder {
    color: transparent !important
}

input:focus:-ms-input-placeholder, textarea:focus:-ms-input-placeholder {
    color: transparent !important
}

button:active, input[type=button]:active, input[type=reset]:active, input[type=submit]:active {
    outline: 0
}

img {
    max-width: 100%
}

.switch {
    position: relative;
    display: inline-block;
    height: 15px;
    width: 15px;
    vertical-align: middle;
    cursor: pointer;
    top: -1px;
    margin-right: 3px
}

.switch input {
    vertical-align: middle;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 15px;
    width: 15px
}

.switch input:checked, .switch input:not(:checked) {
    opacity: 0;
    filter: alpha(opacity=0);
    z-index: 1;
    cursor: pointer
}

.switch input[type=radio]:checked + i, .switch input[type=radio]:not(:checked) + i {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 30px 30px 30px 30px
}

.switch input[type=checkbox]:checked + i, .switch input[type=checkbox]:not(:checked) + i {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    border-radius: 3px 3px 3px 3px;
    border: 1px solid #ccc
}

.switch input[type=radio]:checked + i {
    background: #ccc;
    box-shadow: 0 0 0 3px #fff inset;
    border: 1px solid #ccc
}

.switch input[type=checkbox]:checked + i {
    background: #ccc;
    box-shadow: 0 0 0 3px #fff inset;
    border: 1px solid #ccc
}

.switch input[type=radio]:checked + i:hover, label:hover .switch input[type=radio]:checked + i {
    opacity: .85
}

.switch input[type=radio] + i:hover, label:hover .switch input[type=radio] + i {
    opacity: .85
}

.switch input[type=checkbox]:checked + i:hover, label:hover .switch input[type=checkbox]:checked + i {
    opacity: .85
}

.switch input[type=checkbox] + i:hover, label:hover .switch input[type=checkbox] + i {
    opacity: .85
}

* {
    -webkit-tap-highlight-color: transparent
}

.gray-text {
    color: #828282
}

.size-small {
    font-size: .75rem
}

select.select {
    visibility: hidden
}

.is-color-red {
    color: #2fbeff !important
}

.is-color-green {
    color: #219653 !important
}

.is-color-blue {
    color: #2f80ed !important
}

.is-color-grey {
    color: #828282
}

.is-color-grey-second {
    color: #4f4f4f
}

.w-medium {
    font-weight: 500
}

.show-more {
    font-size: .875rem;
    line-height: 1.43;
    color: #828282;
    border-bottom: .0625rem dotted #828282;
    padding-bottom: .125rem;
    cursor: pointer;
    font-weight: 400
}

.show-more--red-text {
    color: #2fbeff
}

.show-more:hover {
    text-decoration: none
}

.advantages__grid {
    display: -ms-grid;
    display: grid;
    gap: 24px;
    -ms-grid-columns:(1fr) [ 3 ];
    grid-template-columns:repeat(3, 1fr)
}

@media (max-width: 992px) {
    .advantages__grid {
        -ms-grid-columns: 100%;
        grid-template-columns:100%
    }
}

.advantages__grid--alt {
    gap: 0 40px;
    max-width: 1028px;
    margin-left: auto;
    margin-right: auto
}

@media (max-width: 992px) {
    .advantages__grid--alt {
        -ms-grid-columns:(1fr) [ 2 ];
        grid-template-columns:repeat(2, 1fr);
        gap: 0
    }
}

.advantages__item {
    position: relative
}

.advantages__item::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: -webkit-calc(100% + 2px);
    width: -moz-calc(100% + 2px);
    width: calc(100% + 2px);
    height: -webkit-calc(100% + 2px);
    height: -moz-calc(100% + 2px);
    height: calc(100% + 2px);
    z-index: 1;
    border-radius: 8px;
    background: -webkit-gradient(linear, left top, left bottom, from(#0068b5), color-stop(80%, rgba(0, 185, 255, 0)));
    background: -webkit-linear-gradient(top, #0068b5 0, rgba(0, 185, 255, 0) 80%);
    background: -moz-linear-gradient(top, #0068b5 0, rgba(0, 185, 255, 0) 80%);
    background: linear-gradient(180deg, #0068b5 0, rgba(0, 185, 255, 0) 80%)
}

.advantages__item--clear::before {
    display: none
}

.advantages__item--center .advantages__item-inner {
    padding: 40px 8px;
    border-radius: 0
}

@media (max-width: 992px) {
    .advantages__item--center .advantages__item-inner {
        padding: 16px 2px
    }
}

.advantages__item--center .advantages__item-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto;
    margin-bottom: 24px
}

@media (max-width: 992px) {
    .advantages__item--center .advantages__item-icon {
        width: 56px;
        height: 56px;
        margin-bottom: 8px
    }
}

.advantages__item--center .advantages__subtitle {
    text-align: center
}

.advantages__subtitle {
    font-size: 1.125rem;
    font-weight: 500;
    color: #080808;
    line-height: 136%
}

@media (max-width: 992px) {
    .advantages__subtitle {
        font-size: .875rem
    }
}

.advantages__col:nth-child(3n+1) .advantages__item::before {
    background: -webkit-linear-gradient(220deg, #00b9ff 0, rgba(0, 104, 181, 0) 45%);
    background: -moz-linear-gradient(220deg, #00b9ff 0, rgba(0, 104, 181, 0) 45%);
    background: linear-gradient(-130deg, #00b9ff 0, rgba(0, 104, 181, 0) 45%)
}

.advantages__col:nth-child(3n+3) .advantages__item::before {
    background: -webkit-linear-gradient(303deg, #00b9ff 0, rgba(0, 104, 181, 0) 68%);
    background: -moz-linear-gradient(303deg, #00b9ff 0, rgba(0, 104, 181, 0) 68%);
    background: linear-gradient(-213deg, #00b9ff 0, rgba(0, 104, 181, 0) 68%)
}

.advantages__item-inner {
    position: relative;
    z-index: 5;
    background: #fff;
    border-radius: 8px;
    padding: 40px 32px
}

@media (max-width: 992px) {
    .advantages__item-inner {
        padding: 24px
    }
}

.advantages__item-icon {
    width: 100px;
    height: 100px;
    margin-bottom: 40px
}

@media (max-width: 992px) {
    .advantages__item-icon {
        width: 80px;
        height: 80px;
        margin-bottom: 24px
    }
}

.advantages__item-title {
    margin-bottom: 8px;
    color: #080808
}

@media (max-width: 992px) {
    .advantages__item-title {
        font-size: 1.125rem
    }
}

.advantages__item-descr {
    font-size: .875rem;
    line-height: 160%;
    color: #2b2b2b
}

html {
    font-size: 16px
}

body, html {
    font-family: Manrope, Arial, sans-serif;
    height: 100%;
    width: 100%;
    color: #2b2b2b;
    background: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    position: relative
}

#app {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -moz-box-orient: vertical;
    -moz-box-direction: normal;
    flex-direction: column;
    min-height: 100%
}

#app .content {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -moz-box-flex: 1;
    flex: 1;
    min-height: 0
}

body {
    font-size: 1rem
}

.container {
    width: 100%;
    max-width: -webkit-calc(1284px + 78px + 78px);
    max-width: -moz-calc(1284px + 78px + 78px);
    max-width: calc(1284px + 78px + 78px);
    padding-left: 78px;
    padding-right: 78px;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0 auto
}

.container--small {
    max-width: -webkit-calc(1066px + 78px + 78px);
    max-width: -moz-calc(1066px + 78px + 78px);
    max-width: calc(1066px + 78px + 78px)
}

@media (max-width: 992px) {
    .container--small {
        max-width: 100%
    }
}

@media (max-width: 1380px) {
    .container {
        padding-left: 48px;
        padding-right: 48px;
        max-width: -webkit-calc(1284px + 48px + 48px);
        max-width: -moz-calc(1284px + 48px + 48px);
        max-width: calc(1284px + 48px + 48px)
    }
}

@media (max-width: 992px) {
    .container {
        padding-left: 16px;
        padding-right: 16px;
        width: 100%;
        max-width: 100%
    }
}

.main-content {
    margin-top: 218px
}

@media (max-width: 992px) {
    .main-content {
        margin-top: 120px
    }
}

.btn {
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -moz-inline-box;
    display: inline-flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    gap: 8px;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 16px 31px;
    border-radius: 8px;
    background-color: #2fbeff;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 140%;
    font-style: normal;
    -webkit-transition: all .24s ease;
    -o-transition: all .24s ease;
    -moz-transition: all .24s ease;
    transition: all .24s ease;
    outline: 0;
    cursor: pointer;
    border: 1px solid #2fbeff;
    text-decoration: none;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

@media (max-width: 992px) {
    .btn {
        font-size: 14px;
        padding: 9px 28px;
        min-width: unset
    }
}

.btn__icon {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex
}

.btn__icon .icon {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    width: 1rem;
    height: 1rem
}

.btn:hover {
    text-decoration: none;
    background: #13a3ef;
    color: #fff
}

.btn:active {
    color: #fff;
    background: #0e5ea4;
    text-decoration: none
}

.btn:disabled {
    color: #fff;
    background: #b5e8ff;
    text-decoration: none;
    pointer-events: none
}

.btn:focus {
    color: #fff;
    background: #2fbeff;
    text-decoration: none;
    outline-offset: 4px;
    outline-style: solid;
    outline-width: 1px;
    outline-color: #2fbeff
}

.btn-icon {
    width: 48px;
    height: 48px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    cursor: pointer
}

.btn-icon__item {
    width: 24px;
    height: 24px
}

.btn-icon__item .icon {
    width: 24px;
    height: 24px
}

.btn-icon__item .icon svg {
    width: 100%;
    height: 100%
}

.contacts-information {
    margin-top: 56px
}

@media (max-width: 992px) {
    .contacts-information {
        margin-top: 24px
    }
}

.contacts-information__head {
    margin-bottom: 24px
}

.contacts-information__title {
    max-width: 227px;
    font-size: 16px;
    font-weight: 600;
    color: #080808
}

@media (max-width: 992px) {
    .contacts-information__title {
        max-width: 100%
    }
}

.contacts-information__item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 8px
}

.contacts-information__item:not(:last-child) {
    margin-bottom: 24px
}

.contacts-information__ico {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    width: 24px;
    -webkit-box-flex: 1;
    -webkit-flex: 1 0 24px;
    -moz-box-flex: 1;
    flex: 1 0 24px;
    max-width: 24px;
    color: #2fbeff
}

.contacts-information__ico .icon {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    width: 24px;
    height: 24px
}

.contacts-information__text {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -moz-box-flex: 1;
    flex: 1;
    min-width: 0;
    font-size: 1rem;
    color: #2b2b2b;
    line-height: 160%
}

.contacts-grid {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 40px;
    gap: 24px
}

@media (max-width: 992px) {
    .contacts-grid {
        margin-bottom: 24px
    }
}

.contacts-grid__form {
    max-width: 687px;
    width: 100%
}

@media (max-width: 1200px) {
    .contacts-grid__form {
        width: auto
    }
}

@media (max-width: 992px) {
    .contacts-grid__form {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.contacts-grid__info {
    margin-right: auto
}

@media (max-width: 1200px) {
    .contacts-grid__info {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -moz-box-flex: 1;
        flex: 1;
        min-width: 0;
        min-width: 308px
    }
}

@media (max-width: 992px) {
    .contacts-grid__info {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%;
        margin-left: 0;
        min-width: unset
    }
}

.contacts-map {
    width: 100%;
    height: 387px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex
}

.contacts-map iframe {
    width: 100%;
    height: 100%
}

.contacts-map__img img {
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    height: 100%
}

.contacts-form {
    background: #f9f9f9;
    border-radius: 8px;
    padding: 40px;
    width: 100%;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

@media (max-width: 992px) {
    .contacts-form {
        padding: 24px 16px
    }
}

.form-title {
    margin-bottom: 24px;
    margin-top: 0
}

@media (max-width: 992px) {
    .form-title {
        margin-bottom: 16px
    }
}

.form-row:not(:last-child) {
    margin-bottom: 24px
}

@media (max-width: 992px) {
    .form-row:not(:last-child) {
        margin-bottom: 16px
    }
}

.form-row--action {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    justify-content: flex-end
}

.form-row--flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 16px
}

.form-row--2-cols .form__item {
    width: -webkit-calc(50% - 12px);
    width: -moz-calc(50% - 12px);
    width: calc(50% - 12px);
    -webkit-box-flex: 1;
    -webkit-flex: 1 0 -webkit-calc(50% - 12px);
    -moz-box-flex: 1;
    flex: 1 0 calc(50% - 12px);
    max-width: -webkit-calc(50% - 12px);
    max-width: -moz-calc(50% - 12px);
    max-width: calc(50% - 12px)
}

@media (max-width: 992px) {
    .form-row--2-cols .form__item {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.form__item {
    width: 100%;
    -webkit-box-flex: 1;
    -webkit-flex: 1 0 100%;
    -moz-box-flex: 1;
    flex: 1 0 100%;
    max-width: 100%
}

.form__label {
    display: block;
    font-size: 14px;
    margin-bottom: 8px;
    color: #080808
}

.form__input {
    width: 100%;
    font-size: 14px;
    margin-bottom: 8px;
    color: #080808;
    background: #fff;
    border-radius: 4px;
    border: 1px solid #ddd;
    padding: 15px 16px;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

.form__input::-webkit-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__input::-moz-placeholder {
    opacity: 1;
    color: #080808
}

.form__input:-ms-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__input::-ms-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__input::placeholder {
    opacity: 1;
    color: #080808
}

.form__textarea {
    width: 100%;
    font-size: 14px;
    margin-bottom: 8px;
    color: #080808;
    background: #fff;
    border-radius: 4px;
    border: 1px solid #ddd;
    padding: 15px 16px;
    resize: unset;
    height: 132px;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

.form__textarea::-webkit-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__textarea::-moz-placeholder {
    opacity: 1;
    color: #080808
}

.form__textarea:-ms-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__textarea::-ms-input-placeholder {
    opacity: 1;
    color: #080808
}

.form__textarea::placeholder {
    opacity: 1;
    color: #080808
}

.footer {
    padding-top: 56px;
    background: #0e0e0e
}

@media (max-width: 992px) {
    .footer {
        padding-top: 48px
    }
}

.footer__top {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 56px
}

@media (max-width: 992px) {
    .footer__top {
        gap: 48px;
        margin-bottom: 48px
    }
}

.footer__logo {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex
}

.footer__logo-image {
    max-width: 200px;
    -o-object-fit: contain;
    object-fit: contain
}

.footer__nav {
    margin-left: auto
}

@media (max-width: 992px) {
    .footer__nav {
        margin-left: 0;
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.footer__nav-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    gap: 16px 32px;
    padding: 0;
    margin: 0
}

@media (max-width: 992px) {
    .footer__nav-list {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -moz-box-orient: vertical;
        -moz-box-direction: normal;
        flex-direction: column;
        gap: 16px;
        -webkit-box-align: start;
        -webkit-align-items: flex-start;
        -moz-box-align: start;
        align-items: flex-start
    }
}

.footer__nav-item {
    list-style: none;
    position: relative
}

.footer__nav-item.is-active .header__nav-link {
    color: #2fbeff !important
}

.footer__nav-link {
    color: #fff;
    text-decoration: none;
    -webkit-transition: all .24s ease;
    -o-transition: all .24s ease;
    -moz-transition: all .24s ease;
    transition: all .24s ease
}

@media (max-width: 992px) {
    .footer__nav-link {
        font-size: .875rem;
        text-align: left
    }
}

.footer__nav-link:hover {
    color: #2fbeff
}

.footer__bot {
    border-top: 1px solid #202020;
    padding: 24px 0
}

@media (max-width: 992px) {
    .footer__bot {
        padding: 16px 0
    }
}

.copyright {
    font-size: .875rem;
    line-height: 160%;
    color: #d8d8d8
}

.header {
    padding-top: 24px;
    position: absolute;
    top: 0;
    width: 100%;
    left: 0;
    z-index: 50
}

@media (max-width: 992px) {
    .header {
        padding-top: 16px
    }
}

.header__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    gap: 16px;
    border-radius: 20px;
    padding: 16px 24px;
    background: rgba(8, 8, 8, .9);
    position: relative
}

@media (max-width: 992px) {
    .header__inner {
        padding: 8px 20px;
        border-radius: 16px;
        position: relative
    }
}

.header__logo {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex
}

.header__logo-image {
    max-width: 200px;
    -o-object-fit: contain;
    object-fit: contain
}

@media (max-width: 992px) {
    .header__logo-image {
        max-width: 160px
    }
}

.header__nav {
    margin-left: auto
}

@media (max-width: 992px) {
    .header__nav {
        position: absolute;
        left: 0;
        bottom: -8px;
        -webkit-transition: all .36s ease;
        -o-transition: all .36s ease;
        -moz-transition: all .36s ease;
        transition: all .36s ease;
        background: #080808;
        padding: 16px;
        border-radius: 16px;
        width: 100%;
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -o-transform: translateY(100%);
        transform: translateY(100%);
        -moz-box-sizing: border-box;
        box-sizing: border-box
    }

    .header__nav:not(.is-active) {
        -webkit-transform: translateY(-webkit-calc(100% - 40px));
        -moz-transform: translateY(-moz-calc(100% - 40px));
        -o-transform: translateY(calc(100% - 40px));
        transform: translateY(calc(100% - 40px));
        pointer-events: none;
        opacity: 0
    }
}

.header__nav-list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    gap: 16px 48px;
    margin: 0;
    padding: 0
}

@media (max-width: 992px) {
    .header__nav-list {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -moz-box-orient: vertical;
        -moz-box-direction: normal;
        flex-direction: column;
        gap: 0
    }
}

.header__nav-item {
    list-style: none;
    position: relative
}

.header__nav-item:not(:last-child)::before {
    content: '';
    width: 1px;
    height: 16px;
    right: -24px;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    background: #333
}

.header__nav-item.is-active .header__nav-link {
    color: #2fbeff
}

@media (max-width: 992px) {
    .header__nav-item {
        padding: 16px 0
    }

    .header__nav-item::before {
        display: none
    }
}

.header__nav-link {
    color: #fff;
    text-decoration: none;
    -webkit-transition: all .24s ease;
    -o-transition: all .24s ease;
    -moz-transition: all .24s ease;
    transition: all .24s ease
}

.header__nav-link:hover {
    color: #2fbeff
}

@media (max-width: 992px) {
    .header__nav-link {
        font-size: 1rem;
        line-height: 160%;
        color: #fff;
        text-align: center
    }
}

.header__actions {
    display: none;
    margin-left: auto
}

@media (max-width: 992px) {
    .header__actions {
        display: block
    }
}

.btn-menu.is-active .btn-menu__show {
    display: none
}

.btn-menu:not(.is-active) .btn-menu__hide {
    display: none
}

.info-block {
    width: 100%;
    position: relative;
    background: #0e0e0e;
    color: #fff;
    overflow: hidden
}

.info-block--banner.section {
    padding-top: 218px
}

@media (max-width: 992px) {
    .info-block--banner.section {
        padding-top: 120px
    }
}

.info-block__image {
    width: 119.24%;
    height: 0;
    padding-top: 70%;
    position: absolute;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -moz-box-align: start;
    align-items: flex-start;
    left: 0;
    top: 0;
    background: #0e0e0e
}

@media (max-width: 992px) {
    .info-block__image {
        width: 1361px;
        height: 799px;
        padding-top: 0
    }
}

.info-block__image img {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 50%;
    top: -10%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
    -o-object-fit: cover;
    object-fit: cover
}

.info-block__inner {
    position: relative;
    z-index: 4;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap
}

.info-block__info {
    -webkit-box-flex: 1;
    -webkit-flex: 1 0 739px;
    -moz-box-flex: 1;
    flex: 1 0 739px;
    width: 739px;
    max-width: 739px
}

@media (max-width: 992px) {
    .info-block__info {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.info-block__info--alt {
    -webkit-box-flex: 1;
    -webkit-flex: 1 0 630px;
    -moz-box-flex: 1;
    flex: 1 0 630px;
    width: 630px;
    max-width: 630px
}

@media (max-width: 992px) {
    .info-block__info--alt {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.info-block__bread {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -moz-box-flex: 1;
    flex: 1
}

@media (max-width: 992px) {
    .info-block__bread {
        width: 100%;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 100%;
        -moz-box-flex: 1;
        flex: 1 0 100%;
        max-width: 100%
    }
}

.info-block__bread-item {
    color: #fff
}

.info-block__title {
    margin: 0;
    margin-bottom: 80px
}

@media (max-width: 992px) {
    .info-block__title {
        margin-bottom: 24px
    }
}

.info-block__descr {
    font-size: 1.375rem;
    color: #d8d8d8;
    line-height: 160%
}

@media (max-width: 992px) {
    .info-block__descr {
        font-size: 1rem
    }
}

.info-block__descr p {
    margin-bottom: 24px
}

.info-block__descr p:last-child {
    margin-bottom: 0
}

.info-block__descr p:first-child {
    margin-top: 0
}

.info-block__action {
    margin-top: 80px
}

@media (max-width: 992px) {
    .info-block__action {
        margin-top: 24px
    }
}

.main-banner {
    width: 100%;
    position: relative;
    min-height: 700px
}

@media (max-width: 992px) {
    .main-banner {
        min-height: unset
    }
}

.main-banner__image {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0
}

.main-banner__image::before {
    content: '';
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, .8)), color-stop(60%, rgba(0, 0, 0, 0)));
    background: -webkit-linear-gradient(left, rgba(0, 0, 0, .8) 0, rgba(0, 0, 0, 0) 60%);
    background: -moz-linear-gradient(left, rgba(0, 0, 0, .8) 0, rgba(0, 0, 0, 0) 60%);
    background: linear-gradient(90deg, rgba(0, 0, 0, .8) 0, rgba(0, 0, 0, 0) 60%);
    z-index: 6;
    position: absolute
}

.main-banner__image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.main-banner__inner {
    padding-top: 220px;
    padding-bottom: 80px;
    z-index: 10;
    position: relative;
    max-width: 739px
}

@media (max-width: 992px) {
    .main-banner__inner {
        padding-top: 160px;
        padding-bottom: 80px
    }
}

.main-banner__title {
    margin: 0;
    color: #fff;
    margin-bottom: 24px
}

.main-banner__description {
    margin-bottom: 24px;
    max-width: 609px;
    font-size: 18px;
    color: #fff;
    line-height: 160%
}

@media (max-width: 992px) {
    .main-banner__description {
        font-size: 1rem
    }
}

.mentors.section {
    padding-top: 24px
}

@media (max-width: 992px) {
    .mentors.section {
        padding-top: 0
    }
}

.mentors__inner {
    width: 100%;
    padding: 80px 78px;
    border-radius: 20px;
    background: #f9f9f9;
    position: relative;
    overflow: hidden;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

@media (max-width: 992px) {
    .mentors__inner {
        padding: 40px 24px
    }
}

.mentors__inner-image {
    position: absolute;
    width: 803px;
    height: 920px;
    right: -240px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%)
}

@media (max-width: 992px) {
    .mentors__inner-image {
        width: 409px;
        height: 468px;
        top: unset;
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -o-transform: translateY(0);
        transform: translateY(0);
        bottom: -146px;
        right: -99px
    }
}

.popup {
    max-width: 412px;
    margin: auto
}

.popup .mfp-close {
    display: none
}

.popup__inner {
    padding: 32px 24px;
    border-radius: 8px;
    background: #fff;
    width: 100%;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

.popup__icon {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    margin-bottom: 16px
}

.popup__content:not(:last-child) {
    margin-bottom: 32px
}

.popup__title {
    text-align: center;
    font-size: 1.125rem;
    font-weight: 500;
    color: #080808;
    text-align: center;
    line-height: 160%
}

.popup__title:not(:last-child) {
    margin-bottom: 8px;
    font-size: 1rem
}

.popup__text {
    text-align: center;
    font-size: .875rem;
    color: #999;
    line-height: 160%
}

.popup__action {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
}

@media (max-width: 992px) {
    .popup__action .btn {
        min-width: 295px
    }
}

@media (max-width: 900px) {
    .mfp-container {
        padding-left: 16px;
        padding-right: 16px
    }
}

.section {
    padding: 112px 0
}

@media (max-width: 992px) {
    .section {
        padding: 40px 0
    }
}

.section--top {
    padding-top: 0
}

@media (max-width: 992px) {
    .section--small-mobile {
        padding-bottom: 0;
        padding-top: 0;
        margin: 40px 0
    }
}

.section__head:not(:last-child) {
    margin-bottom: 56px
}

@media (max-width: 992px) {
    .section__head:not(:last-child) {
        margin-bottom: 24px
    }
}

.section__head--center {
    text-align: center
}

@media (max-width: 992px) {
    .section__head--center {
        text-align: left
    }
}

.section__head--center .section__title {
    margin-left: auto;
    margin-right: auto;
    max-width: 848px
}

.section__head--center .section__descr {
    margin-left: auto;
    margin-right: auto;
    max-width: 630px
}

.section__bread-item {
    font-size: 1.5rem;
    font-weight: 300;
    color: #fff;
    text-transform: capitalize
}

@media (max-width: 992px) {
    .section__bread-item {
        font-size: 1.125rem;
        font-weight: 400
    }
}

.section__bread-slash {
    padding-right: 8px;
    color: #38b7fe
}

.section__bread {
    margin-bottom: 24px
}

.section__bread-item--dark .section__bread-name {
    color: #080808
}

.section__title {
    max-width: 900px;
    margin: 0
}

.section__title:not(:last-child) {
    margin-bottom: 24px
}

.section__descr {
    font-size: 1.125rem;
    color: #2b2b2b;
    line-height: 160%;
    max-width: 739px
}

@media (max-width: 992px) {
    .section__descr {
        font-size: 1rem
    }
}

.section__descr p {
    margin-bottom: 24px
}

.section__descr p:last-child {
    margin-bottom: 0
}

.section__descr p:first-child {
    margin-top: 0
}

.section__action {
    margin-top: 24px
}

.section__title-alt {
    font-size: 3rem;
    font-weight: 700;
    color: #080808
}

@media (max-width: 992px) {
    .section__title-alt {
        font-size: 1.75rem
    }
}

.section__title-alt-slash {
    padding-right: 8px;
    color: #2fbeff
}

.slider-vendors {
    display: -ms-grid;
    display: grid;
    gap: 8px;
    -ms-grid-columns:(1fr) [ 8 ];
    grid-template-columns:repeat(8, 1fr)
}

@media (max-width: 1400px) {
    .slider-vendors {
        -ms-grid-columns:(1fr) [ 6 ];
        grid-template-columns:repeat(6, 1fr)
    }
}

@media (max-width: 992px) {
    .slider-vendors {
        -ms-grid-columns:(1fr) [ 4 ];
        grid-template-columns:repeat(4, 1fr)
    }
}

.slider-vendors__item {
    height: 216px;
    background: #f3f3f3;
    border-radius: 8px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
}

@media (max-width: 992px) {
    .slider-vendors__item {
        height: 100px
    }
}

.slider-vendors__image {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center
}

.slider-vendors__image img {
    max-width: -webkit-calc(100% - 16px);
    max-width: -moz-calc(100% - 16px);
    max-width: calc(100% - 16px)
}
/* Група CTA */
.cta-group{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}
@media (max-width: 992px){
    .cta-group{ flex-direction:column; align-items:stretch; }
    .cta-group .btn{ width:100%; }
}

/* Світлий outline під темний банер */
.btn--outline-light{
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,.85);
}
.btn--outline-light:hover{
    background: rgba(255,255,255,.1);
    color:#fff;
    border-color:#fff;
}
.btn--outline-light:active{
    background: rgba(255,255,255,.18);
}

/* «Скляна» кнопка (легка неонова підсвітка) */
.btn--glass{
    background: rgba(255,255,255,.08);
    color:#fff;
    border-color: rgba(255,255,255,.16);
    box-shadow: 0 6px 24px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.12);
    backdrop-filter: blur(4px);
}
.btn--glass:hover{
    background: rgba(255,255,255,.14);
    border-color: rgba(255,255,255,.24);
}
.btn--glass:active{
    background: rgba(255,255,255,.22);
}

/* Якорі — відступ під фіксований хедер */
#more, #what-we-do, #values { scroll-margin-top: 80px; }
/* плавна прокрутка */
html, body, .wrapper, .page, .layout, .site { scroll-behavior: smooth; }

/* ===========================
   TYPOGRAPHY OVERRIDES (Transcendar)
   Додати в КІНЕЦЬ main.css
   =========================== */

/* Базова читабельність */
body { font-size: 1rem; line-height: 1.6; }

/* Заголовки: компактніші, адаптивні */
.h1, h1 {
    font-size: clamp(2.0rem, 1.3rem + 2.5vw, 2.75rem); /* ~32–44px */
    line-height: 1.2;
    margin: 0 0 0.75em;
}

.h2, h2 {
    font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2.0rem);  /* ~24–32px */
    line-height: 1.25;
    margin: 0 0 0.75em;
}

.h3, h3 {
    font-size: clamp(1.125rem, 1.05rem + 0.7vw, 1.375rem); /* ~18–22px */
    line-height: 1.3;
    margin: 0 0 0.75em;
}

/* Банерні заголовки (якщо треба ще трохи менше за дефолтний h1) */
.main-banner__title {
    font-size: clamp(2.0rem, 1.2rem + 2.2vw, 2.5rem); /* ~32–40px */
    line-height: 1.2;
    margin: 0 0 0.75em;
}

/* Текст у банері */
.main-banner__description {
    font-size: clamp(1.0rem, 0.98rem + 0.35vw, 1.0625rem); /* ~16–17px */
    line-height: 1.6;
}

/* Описові блоки — були завеликі */
.info-block__descr,
.section__descr,
.g-main-text,
.g-description {
    font-size: clamp(1.0rem, 0.98rem + 0.4vw, 1.125rem); /* ~16–18px */
    line-height: 1.6;
}

/* Заголовок у info-block (це ваші H2) */
.info-block__title {
    font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2.0rem); /* ~24–32px */
    line-height: 1.25;
}

/* Дрібні службові написи */
.section__bread-item,
.gray-text,
.g-seconadry-text {
    font-size: clamp(0.875rem, 0.84rem + 0.2vw, 0.9375rem); /* ~14–15px */
    line-height: 1.5;
}

/* Кнопки: залишаємо розмір, але текст можна трохи зменшити */
.btn { font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem); /* ~15–16px */ }

/* === HERO на всю висоту екрана === */
.main-banner{
    /* працює всюди */
    min-height: 100vh;
    /* краще для мобільних з плаваючою адресною стрічкою */
    min-height: 100svh;
}

/* найточніше — нові dynamic viewport units */
@supports (height: 100dvh){
    .main-banner{ min-height: 100dvh; }
}


/*dropdown menu*/

.header__nav-content {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}
.header__nav-item {
    position: relative;
}
.header__nav-content .header__nav-link {
    flex: 1;
    min-width: 0;
}

.header__nav-drop {
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(110%);
    opacity: 0;
    pointer-events: none;
    transition: all .36s ease;
    padding-top: 10px;
    width: 200px;
    min-width: 100%;
}
.header__nav-item.is-show .header__nav-drop {
    transform: translateY(100%);
    opacity: 1;
    pointer-events: auto;
}
.header__nav-item:hover .header__nav-drop {

}
.header__nav-drop-inner {
    border-radius: 16px;
    padding: 16px ;
    background: rgba(8, 8, 8, .9);
}
.header__nav-drop-list {
    padding: 0;
    margin: 0;
}
.header__nav-icon svg {
    transition: all .36s ease;
}
.header__nav-item.is-show .header__nav-icon svg{
    transform: scaleY(-1);
}
.header__nav-drop-list .header__nav-item:not(:last-child) {
    margin-bottom: 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.header__nav-drop-list .header__nav-item:before {
    display: none;
}

@media (max-width: 992px) {
    .header__nav-drop {
        position: static;
        border-radius: 0;
        transform: unset;
        display: none;
    }
    .header__nav-drop-inner {
        padding: 0;
        border-radius: 0;
    }
    .header__nav-item.is-show .header__nav-drop {
        transform: unset;
        opacity: 1;
        pointer-events: auto;
        display: block;
    }
    .header__nav-drop {
        width: 100%;
    }
}

/* ===== Info-block light variant (тільки де є .info-block--plain) ===== */
.info-block--plain{
    background: #fff;        /* прибираємо темний фон */
    color: #080808;          /* базовий колір тексту в секції */
}

/* сховати фонову картинку саме в цьому варіанті */
.info-block--plain .info-block__image{ display: none; }

/* текстові кольори, які в базі були «забиті» під темну тему */
.info-block--plain .info-block__title,
.info-block--plain .info-block__bread-item,
.info-block--plain .section__bread-name{
    color: #080808;
}

/* опис у info-block має власний світло-сірий — робимо темнішим під світлий фон */
.info-block--plain .info-block__descr{
    color: #2b2b2b;
}

/* синій слеш у «хлібних крихтах» залишаємо брендованим */
.info-block--plain .section__bread-slash{ color: #2fbeff; }

/* ===== Tables (site-wide) ===== */
.table-responsive{
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-top: 20px;
}

.table{
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    color: #080808;
    font-size: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem); /* ~15–16px */
    line-height: 1.5;
}

.table th, .table td{
    border: 1px solid #e0e0e0;
    padding: 12px 16px;
    vertical-align: top;
}

/* Шапка в корпоративному стилі */
.table--support thead th{
    background: #2fbeff;      /* темно-блакитний як у вашому градієнті */
    color: #fff;
    font-weight: 600;
}

/* Перша колонка — фіксована ширина й nowrap */
.table--support th[scope="row"],
.table--support tbody th{
    white-space: nowrap;
    width: 240px;
    font-weight: 600;
}

/* Списки всередині клітинок */
.table--support td ul{
    margin: 0;
    padding-left: 18px;
}
.table--support td li{
    margin: 4px 0;
}

/* Невеликий сабтекст під таблицею */
.table-note{
    margin-top: 8px;
    color: #4f4f4f;
    font-size: 0.875rem;
}

/* На мобільних даємо більше повітря і дозволяємо першій колонці рости */
@media (max-width: 992px){
    .table--support th[scope="row"], .table--support tbody th{
        width: 180px;
        white-space: normal;
    }
    .table th, .table td{ padding: 10px 12px; }
}

/* ===== Footer: колонки в одному ряду ===== */
.footer__nav-list { align-items: flex-start; } /* лише футер */

.footer__nav-item--group{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    min-width: 220px; /* щоб колонка не стискалась у 1 слово */
}

.footer__nav-heading{
    color: #fff;
    font-weight: 600;
    font-size: 1rem;
    line-height: 1.2;
    margin: 0;
}

.footer__subnav{
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* На мобільних футер стає стовпчиком */
@media (max-width: 992px){
    .footer__nav-item--group{ min-width: unset; }
}

.info-block__inner--alt {
    display: block;
    flex: 1 0 100%;
    width: 100%;
    max-width: 100%;
    text-align: justify;
}

@media (max-width: 992px) {
    .info-block__inner--alt {
        text-align: start;
    }
}

.info-block__inner--alt .info-block__info--alt {
    flex: 1 0 100%;
    width: 100%;
    max-width: 100%;
}
.info-block__bread-item {
    display: flex;
    align-items: center;
}
.info-block__bread-name img {
    width: 48px;
    margin-right: 8px;
    display: inline-block;
    object-fit: contain;
}
