html {
    box-sizing: border-box;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

*,
*:before,
*:after {
    box-sizing: inherit
}

body {
    margin: 0;
    font: 16px/1 sans-serif;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased
}

h1,
h2,
h3,
p {
    margin: 0;
    padding: 0
}

h1,
h2,
h3 {
    font-size: inherit
}

strong {
    font-weight: bold
}

a,
button {
    color: inherit;
    transition: .3s
}

a {
    text-decoration: none
}

button {
    overflow: visible;
    border: 0;
    font: inherit;
    -webkit-font-smoothing: inherit;
    letter-spacing: inherit;
    background: none;
    cursor: pointer
}

::-moz-focus-inner {
    padding: 0;
    border: 0
}

:focus {
    outline: 0
}

img {
    max-width: 100%;
    height: auto;
    border: 0
}

/*! normalize.css v4.2.0 | MIT License | github.com/necolas/normalize.css */

img {
    border-style: none
}

svg:not(:root) {
    overflow: hidden
}

button {
    font-family: sans-serif;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button {
    overflow: visible
}

button {
    text-transform: none
}

button,
html [type="button"] {
    -webkit-appearance: button
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring,
[type="button"]:-moz-focusring {
    outline: 1px dotted ButtonText
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

.bg-theme-2:not(.tile-open) {
    background-color: #fff
}

.bg-theme-2:not(.tile-open) h3,
.bg-theme-2:not(.tile-open) p,
.bg-theme-2:not(.tile-open) a {
    color: #c8102e
}

.bg-theme-2:not(.tile-open).tile {
    background: none
}

.bg-theme-2:not(.tile-open).tile>.tile-container {
    background-color: #fff
}

.bg-theme-2:not(.tile-open).tile>.tile-container>.tile-sub::after {
    background-color: #d7776d
}

.bg-theme-2:not(.tile-open).tile>.tile-container>.tile-sub>p {
    color: #000
}

.bg-theme-3:not(.tile-open) {
    background-color: #c8102e
}

.bg-theme-3:not(.tile-open) h3,
.bg-theme-3:not(.tile-open) p,
.bg-theme-3:not(.tile-open) a {
    color: #fff
}

.bg-theme-3:not(.tile-open).tile {
    background: none
}

.bg-theme-3:not(.tile-open).tile>.tile-container {
    background-color: #c8102e
}

.bg-theme-3:not(.tile-open).tile>.tile-container>.tile-sub::after {
    background-color: #d7776d
}

.row {
    width: 100%
}

@media (min-width: 1024px) {
    .row {
        display: flex;
        flex: 0 1 auto;
        flex-wrap: wrap;
        width: calc(100% + 24px)
    }
}

@media (max-width: 1023px) {
    .grid-col {
        width: 100%;
        margin-bottom: 16px
    }
}

@media (min-width: 1024px) {

    .grid-col-4 {
        flex-direction: column;
        width: calc((100% / 12 * 4) - 24px - 0.1px);
        margin-right: 24px
    }

    .grid-col-8 {
        flex-direction: column;
        width: calc((100% / 12 * 8) - 24px - 0.1px);
        margin-right: 24px
    }
}

html {
    font-size: 100%
}

body {
    font-family: "Avalon", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 1rem;
    line-height: 1.375;
    background-color: #fff
}

@media screen and (min-width: 768px) {
    body {
        font-size: 1rem;
        line-height: 1.375
    }
}

h1 {
    font-size: 1.875rem;
    line-height: 1;
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 700
}

@media screen and (min-width: 768px) {

    h1 {
        font-size: 3.125rem;
        line-height: 1
    }
}

h2 {
    font-size: 1.25rem;
    line-height: 1.08;
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 700;
    margin-bottom: 15px;
}

@media screen and (min-width: 768px) {

    h2 {
        font-size: 1.875rem;
        line-height: 1.08
    }
}

h3 {
    font-size: 1rem;
    line-height: 1.08;
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 700
}

@media screen and (min-width: 768px) {

    h3 {
        font-size: 1.25rem;
        line-height: 1.08
    }
}

p {
    font-size: .875rem;
    line-height: 1.571;
    margin-bottom: 8px
}

@media screen and (min-width: 768px) {
    p {
        font-size: .875rem;
        line-height: 1.571
    }
}

a {
    text-decoration: none;
    cursor: pointer
}

a:hover,
a:focus {
    text-decoration: underline
}

strong {
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif
}

.vertical-rhythm h3 {
    margin-top: 15px;
    margin-bottom: 12px
}

.vertical-rhythm p {
    margin-top: 0;
    margin-bottom: 16px
}

@media (min-width: 768px) {

    .vertical-rhythm h3 {
        margin-top: 20px;
        margin-bottom: 12px
    }

    .vertical-rhythm p {
        margin-bottom: 16px
    }
}

.vertical-rhythm>*:first-child {
    margin-top: 0
}

svg {
    fill: currentColor;
    stroke: transparent;
    stroke-linecap: round;
    stroke-linejoin: round;
    will-change: fill, stroke
}

.svg-icon {
    position: relative;
    display: inline-block;
    max-width: 100%;
    max-height: 100%;
    width: 24px;
    height: 24px;
    flex-shrink: 0
}

button {
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif
}

.align-top-center img {
    -o-object-fit: cover;
    font-family: "object-fit:cover;object-position:top center";
    object-fit: cover;
    -o-object-position: top center;
    object-position: top center;
    width: 100%
}

.align-center-center img {
    -o-object-fit: cover;
    font-family: "object-fit:cover;object-position:center center";
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
    width: 100%
}

.flex-on-print {
    display: none !important
}

@page {
    margin: 40pt 30pt 40pt
}

@media print {
    * {
        font-family: "Avalon", "Helvetica Neue", Helvetica, Arial, sans-serif
    }

    h1,
    h2,
    h3 {
        page-break-after: avoid
    }

    h1,
    h2,
    h3,
    h3 * {
        font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif
    }

    strong {
        font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif
    }

    .flex-on-print {
        display: flex !important
    }

    @page :blank {
        @top-center {
            content: "This page is intentionally left blank."
        }
    }
}

@media print {
    body {
        font: 12pt Georgia, "Times New Roman", Times, serif;
        line-height: 1.3
    }

    h1 {
        font-size: 24pt
    }

    h2 {
        font-size: 14pt;
        margin-top: 25px
    }

    img {
        border: none
    }
}

::-webkit-input-placeholder {
    color: #808183
}

::-moz-placeholder {
    color: #808183
}

:-ms-input-placeholder {
    color: #808183 !important
}

::-ms-input-placeholder {
    color: #808183
}

@font-face {
    font-family: 'swiper-icons';
    src: url("") format("woff");
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: $themeColor
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    box-sizing: content-box
}

.swiper-wrapper {
    transform: translate3d(0px, 0, 0)
}

.swiper-container-free-mode>.swiper-wrapper {
    transition-timing-function: ease-out;
    margin: 0 auto
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform
}

.accordion-base {
    margin: 32px 0 24px
}

.tile {
    margin-bottom: 24px;
    position: relative
}

.tile,
.tile .tile-container {
    transition: all 0.5s ease-in-out
}

.tile .tile-container {
    background-color: #fff;
    border-radius: 10px;
    position: relative
}

.tile .tile-main {
    overflow: hidden;
    border-radius: 10px 10px 0 0;
    position: relative;
    display: flex
}

.tile>.tile-container {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2), 0 5px 15px rgba(0, 0, 0, 0.2)
}

.tile>.tile-container>.tile-main {
    height: 300px
}

.tile .tile-link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

.tile .tile-link * {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: none
}

.tile .tile-sub {
    padding: 12px 20px 20px;
    border-radius: 0 0 10px 10px
}

.tile .tile-sub p {
    font-size: 1rem;
    line-height: 1.571;
    margin-bottom: 0
}

@media screen and (min-width: 768px) {
    .tile .tile-sub p {
        font-size: 1rem;
        line-height: 1.571
    }
}

.tile .tile-title {
    margin-bottom: 8px
}

.tile.tile-type-text {
    background: none
}

.tile.tile-type-text>.tile-container>.tile-main {
    position: relative;
    min-height: 300px;
    height: auto
}

.tile.tile-type-text>.tile-container>.tile-main .tile-title {
    font-size: 1.25rem;
    line-height: 1.08;
    font-family: "Avalon Bold", "HelveticaNeue-Bold", "Helvetica Neue Bold", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 700;
    padding: 24px 20px 20px
}

@media screen and (min-width: 768px) {
    .tile.tile-type-text>.tile-container>.tile-main .tile-title {
        font-size: 1.875rem;
        line-height: 1.08
    }
}

.tile.tile-type-text>.tile-container .tile-sub {
    position: relative
}

.tile.tile-type-text>.tile-container .tile-sub::after {
    position: absolute;
    top: 0;
    left: 20px;
    width: calc(100% - (20px * 2));
    height: 2px;
    display: block;
    content: ''
}

@media (min-width: 1024px) {
    .tile>.tile-container>.tile-main {
        min-height: 300px
    }
}

.key-takeaways-read {
    background: #6e7ca0;
    color: #fff;
    padding: 2px 4px 2px 8px;
    margin-top: 4px;
    margin-bottom: 10px;
    border-radius: 6px;
    display: inline-block
}

.key-takeaways-read .svg-icon {
    color: #fff;
    margin-bottom: -7px;
    margin-left: 3px;
}

.c-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(236, 234, 233, 0.9);
    overflow: auto;
    display: flex;
    z-index: 5;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.c-modal::-webkit-scrollbar {
    display: none
}

.c-modal .modal-container {
    margin-right: auto;
    margin-left: auto;
    width: 100%;
    max-width: 1248px;
    padding: 0 16px
}

@media (min-width: 768px) {
    .c-modal .modal-container {
        padding: 0 24px
    }
}

@media (min-width: 1600px) {
    .c-modal .modal-container {
        padding: 0 32px
    }
}

.detail-content {
    padding: 32px 32px
}

.detail-content p {
    font-size: 1rem;
    line-height: 1.375
}

@media screen and (min-width: 768px) {

    .detail-content p {
        font-size: 1rem;
        line-height: 1.375
    }
}

@media (min-width: 1024px) {
    .detail-content {
        padding: 64px 76px 30px;
    }

    .detail-content-with-sidebar .detail-content-container {
        margin-right: -16px
    }
}

.detail-image {
    overflow: hidden;
    border-radius: 0;
    position: relative;
    display: flex;
    transition: all 0.5s ease-in-out
}

@media (max-width: 1023px) {
    .detail-image {
        position: relative;
        height: 0;
        width: 100%;
        background-color: #a6a8aa;
        padding-bottom: 42.85714%
    }

    .detail-image img {
        position: absolute;
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        font-family: "object-fit:cover;object-position:center center";
        object-fit: cover;
        -o-object-position: center center;
        object-position: center center;
        width: 100%
    }
}

@media (min-width: 1024px) {
    .detail-image {
        border-radius: 10px 10px 0 0;
        height: 475px
    }
}

.detail-related-container {
    margin-top: 48px
}

.detail-related-heading {
    text-align: center;
    padding-top: 24px;
    padding-bottom: 15px;
    border-top: 1px solid #aca39a
}

@media (min-width: 1024px) {
    .detail-related-heading {
        text-align: left;
        border-top: none
    }

    .detail-related-container {
        padding-left: 48px;
        margin-top: 0
    }
}

.detail-next {
    background-color: #eceae9;
    overflow: hidden
}

.detail-next .tile {
    height: 100%;
    margin-bottom: 0
}

.detail-next .detail-next-container {
    padding: 32px 32px
}

.detail-next .detail-next-heading {
    text-align: center;
    margin-bottom: 32px
}

.detail-next .detail-next-item {
    width: 283px;
    height: auto
}

.detail-next .detail-next-slider {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    overflow: hidden;
    padding-right: 24px;
    padding-bottom: 24px;
}

@media (min-width: 1024px) {
    .detail-next {
        border-radius: 0 0 10px 10px
    }

    .detail-next-heading {
        text-align: left
    }

    .detail-next-container {
        padding: 64px 76px;
        margin-top: 0
    }

    .detail-next-item {
        width: 330px
    }
}

.detail-title {
    margin-bottom: 24px
}

.detail-title-heading {
    margin-bottom: 8px
}

.detail-title-subheading {
    color: #c8102e
}

@media (min-width: 1024px) {
    .detail-title {
        margin-bottom: 32px
    }

    .detail-title-heading {
        padding-right: 0
    }
}

.detail-print-layout-header {
    margin-bottom: 48px;
    display: flex;
    align-items: center
}

.detail-print-layout-logo {
    height: 2cm
}

.detail-print-layout-contact {
    flex-grow: 1;
    text-align: right;
    margin-bottom: -12px;
    padding-left: 16px
}

.detail-print-layout-contact-spacing {
    margin-left: 12px;
    margin-right: 12px
}

@-webkit-keyframes fadeInDown {
    0% {
        opacity: 0;
        transform: translateY(-20px)
    }

    100% {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        transform: translateY(-20px)
    }

    100% {
        opacity: 1;
        transform: translateY(0)
    }
}

.detail-header {
    position: absolute;
    top: 12px
}

.detail-header .logo-close {
    padding: 0
}

.detail-header img {
    width: 120px
}

.detail {
    transition: all 0.5s ease-in-out;
    background-color: #fff;
    border-radius: 0;
    position: relative;
    margin: 75px -24px;
    -webkit-animation: fadeInDown 800ms;
    animation: fadeInDown 800ms;
    min-height: 100%
}

@media (min-width: 1024px) {
    .detail-header img {
        width: 180px
    }

    .detail {
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2), 0 5px 15px rgba(0, 0, 0, 0.2);
        height: auto;
        border-radius: 10px;
        margin: 112px 0 30px
    }
}

.ReactModal__Body--open {
    overflow-y: hidden
}

@font-face {
    font-family: gsc;
    src: url("") format('embedded-opentype');
    font-weight: 400;
    font-style: normal
}

@font-face {
    font-family: gsc;
    src: url("") format('truetype');
    font-weight: 400;
    font-style: normal
}

@font-face {
    font-family: emoji;
    src: local('Apple Color Emoji'), local('Android Emoji'), local('Segoe UI'), local(EmojiSymbols), local(Symbola);
    unicode-range: U+1F300-1F5FF, U+1F600-1F64F, U+1F680-1F6FF, U+2600-26FF
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        transform: translateY(-20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.commits {
    margin-top: 15px;
    font-family: 'Roboto', sans-serif;
    font-size: 16px;
}

.commits__title {
    margin-bottom: 15px;
    font-size: 24px;
}

.commits__item.hide .commits__add {
    display: none;
}

.commits__item+.commits__item {
    padding-top: 15px;
    margin-top: 10px;
    border-top: 1px solid #eaeaea;
}

.commits__item:first-child {
    padding-top: 0;
}

.commits__head {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}

.commits__face {
    width: 50px;
    height: 50px;
    margin-right: 10px;
    background-color: gray;
    overflow: hidden;
}

.commits__face img {
    display: block;
    width: 100%;
}

.commits__name {
    font-size: 14px;
}

.commits__date {
    font-size: 12px;
}

.commits__description {
    color: #000;
    line-height: 22px;
    font-size: 14px;
}

.commits__media {
    margin-top: 10px;
}

.commits__success {
    display: inline-block;
    padding: 5px 15px;
    margin-top: 20px;
    font-style: italic;
    font-size: 12px;
    background-color: #e2e2e2;
}

.commits__media img {
    display: block;
    max-width: 100%;
}

.commits__add-title {
    margin-bottom: 10px;
}

.commits__field-name {
    display: block;
    width: 100%;
    max-width: 500px;
    margin-bottom: 10px;
    padding: 5px;
    box-sizing: border-box;
    border: 1px solid #b9b7b7;
}

.commits__field-message {
    display: block;
    width: 100%;
    height: 100px;
    max-width: 500px;
    margin-bottom: 10px;
    padding: 5px;
    resize: none;
    box-sizing: border-box;
    border: 1px solid #b9b7b7;
}

.commits__item_hide {
    display: none;
}

.commits_error {
    border-color: red;
}

.commits__sucses {
    background-color: #a1caa6;
    color: #fff;
    display: inline-block;
    padding: 7px 20px;
    margin-top: 15px;
    font-style: italic;
}

.commits__add-btn {
    display: inline-block;
    padding: 10px 25px;
    font-size: 12px;
    color: #ffffff;
    background-color: #b10000;
    text-decoration: none;
    opacity: .9;
    text-transform: uppercase;
    outline: 0;
    border: 0;
    cursor: pointer;
}

.commits__add-btn:hover {
    transform: scale(.98);
    opacity: 1;
}

.mybtn {
    display: inline-block;
    padding: 10px 25px;
    font-size: 12px;
    color: #ffffff;
    background-color: #b10000;
    text-decoration: none;
    opacity: .9;
    text-transform: uppercase;
    margin-top: 15px;
}

.send-message {
    margin-top: 20px;
}

.mybtn:hover {
    transform: scale(.98);
    opacity: 1;
}

@media(max-width: 480px) {
    .commits__description {
        font-size: 14px;
    }

    .commits__sucses {
        font-size: 12px;
    }

    .detail {
        margin-bottom: 0;
    }
}

@media (max-width: 480px) {
    .detail-title-heading {
        font-size: 26px;
    }
}

.all-form {
    font-family: sans-serif;
    width: 100%;
    max-width: 620px;
    color: #000;
    font-size: 16px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 30px;
    margin-bottom: 30px;
}

.all-form__time {
    text-align: center;
    font-size: 20px;
    font-weight: 700;
}

.all-form__time>span {
    display: block;
}

.all-form__count {
    color: red;
    margin-top: 15px;
}

.all-form__body {
    padding: 25px 45px;
    margin-top: 15px;
    background-color: #fff;
    -webkit-box-shadow: 4px 5px 10px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 4px 5px 10px 0px rgba(0, 0, 0, 0.25);
}

.all-form__title {
    font-size: 33px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 20px;
    line-height: 40px;
}

.all-form__title span {
    color: #50b27c;
}

.all-form__label>span {
    display: block;
    margin-bottom: 5px;
}

.all-form__label+.all-form__label {
    margin-top: 20px;
}

.all-form__field {
    display: block;
    width: 100%;
    height: 50px;
    border: 1px solid #d1d1d1;
    border-radius: 3px;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.all-form__footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -ms-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
}

.all-form__btn {
    width: 100%;
    max-width: 320px;
    flex: 1 0 100%;
    padding: 15px 40px;
    border-radius: 3px;
    text-align: center;
    color: #fff;
    text-transform: uppercase;
    margin: 10px 20px 10px 0;
    background-color: #53b57f;
    background: rgb(90, 188, 134);
    background: -o-linear-gradient(top, rgba(90, 188, 134, 1) 0%, rgba(66, 163, 110, 1) 50%);
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(90, 188, 134, 1)), color-stop(50%, rgba(66, 163, 110, 1)));
    background: linear-gradient(180deg, rgba(90, 188, 134, 1) 0%, rgba(66, 163, 110, 1) 50%);
    -webkit-transition: .3s;
    -o-transition: .3s;
    transition: .3s;
    cursor: pointer;
    border: 0;
    font-size: 16px;
}

.all-form__btn:hover {
    text-indent: 10px;
    padding-right: 30px;
    -webkit-box-shadow: inset 10px 0px 20px 0px rgba(0, 0, 0, .4);
    box-shadow: inset 10px 0px 20px 0px rgba(0, 0, 0, .4);
}

.all-form__prices {
    max-width: 180px;
    flex: 1 0 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.all-form__price-new {
    margin-right: 15px;
    color: #49aa75;
    font-size: 20px;
    max-width: 80px;
    flex: 1 0 100%;
}

.all-form__price-old {
    font-size: 14px;
    color: #8c8c8c;
    text-decoration: line-through;
    max-width: 60px;
    flex: 1 0 100%;
}

@media (max-width: 576px) {
    .all-form__footer {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .all-form__btn {
        margin-right: 0;
        font-size: 15px;
    }

    .all-form__body {
        padding: 25px;
    }
}

footer {
    text-align: center;
    padding-bottom: 15px;
}