@font-face {
    font-family: Montserrat-Regular;
    src: url(../fonts/Montserrat-Regular.ttf) format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Caption;
    src: url(../fonts/1873.woff) format('woff'), url(../fonts/1873.ttf) format('truetype'), url(../fonts/1873.svg) format('svg');
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Bold;
    src: url(../fonts/8141.woff) format('woff'), url(../fonts/8141.ttf) format('truetype'), url(../fonts/8141.svg) format('svg');
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: Regular;
    src: url(../fonts/8143.woff) format('woff'), url(../fonts/8143.ttf) format('truetype'), url(../fonts/8143.svg) format('svg');
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: PTSans Caption;
    src: url(../fonts/2218.ttf) format('truetype'),font-weight: normal;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: PTSans;
    src: url(../fonts/ptsans.woff2) format('woff2'), url(../fonts/ptsans.woff) format('woff'), url(../fonts/ptsans.ttf) format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

@font-face {
    font-family: 'PTSans Bold';
    src: url(../fonts/ptsansbold.woff2) format('woff2'), url(../fonts/ptsansbold.woff) format('woff'), url(../fonts/ptsansbold.ttf) format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap
}

a, abbr, acronym, address, applet, b, big, blockquote, body, caption, center, cite, code, dd, del, dfn, div, dl, dt, em, fieldset, font, form, h1, h2, h3, h4, h5, h6, html, i, iframe, img, ins, kbd, label, legend, li, object, ol, pre, q, s, samp, small, span, strike, strong, sub, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, var {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0
}

a {
    color: #f60
}

a:hover {
    text-decoration: none
}

input, textarea {
    outline: 0
}

input[type=number], input[type=text] {
    -webkit-appearance: none
}

label {
    font-weight: 400
}

b {
    font-family: Bold;
    font-weight: 400
}

div[id^=bx_incl_area_], div[id^=bxdynamic_] {
    display: inline;
    margin: 0 !important;
    padding: 0 !important
}

.tablebodytext {
    display: none
}

.clear {
    clear: both
}

.center {
    text-align: center;
    padding-bottom: .9em
}

.flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around
}

body {
    padding: 0;
    margin: 0;
    font-family: Regular;
    font-size: 13px;
    background: url(../images/background2.webp) center top repeat-y;
    position: relative;
    text-align: center;
    background-attachment: fixed;
    background-size: cover
}
.mobile-only{
  display: none;
}
.wrapper {
    max-width: 1100px;
    margin: 0 auto;
    text-align: left;
    position: relative
}

.white-bg p {
    font-size: 114%;
    color: #000
}

.icon-bar {
    position: fixed !important;
    top: 50% !important;
    right: -20px !important;
    -webkit-transform: translateY(-50%) !important;
    -ms-transform: translateY(-50%) !important;
    z-index: 999 !important;
    background: 0 0 !important;
    padding: 0 !important
}

.icon-bar:hover {
    background: 0 0 !important
}

.icon-bar a {
    display: block;
    text-align: center;
    transition: all .3s ease;
    transition-property: all;
    transition-duration: .3s;
    transition-timing-function: ease;
    transition-delay: 0s;
    color: #fff;
    font-size: 30px;
    width: 80px;
    height: 80px
}

.zayavka-button {
    font-family: Caption;
    font-size: 137%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    display: block;
    text-align: center;
    line-height: .9;
    background: url(/local/templates/main/css/../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 0;
    letter-spacing: .03em;
    position: relative;
    margin: 20px 0 0 0
}
.t585__accordion .t585__textwrapper a{
  color : #ffffff;
}
.recall-containter {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 100
}

.recall-button {
    display: inline-block;
    font-size: 90%;
    line-height: 1;
    color: #fff;
    background: #f60;
    padding: 5px 17px;
    text-decoration: none;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

.recall-button:hover {
    background: #fc3
}

header {
    position: relative;
    width: 100%;
    margin-bottom: 10px;
    padding-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    background: url(/local/templates/main/css/../images/line-hs.svg) bottom left no-repeat;
    background-size: 100% 20px
}

header .children {
    display: block;
    width: 299px;
    height: 206px;
    background: url(../images/children.webp) left top no-repeat;
    font-size: 0;
    text-decoration: none
}

header .logo {
    display: block;
    width: 489px;
    height: 206px;
    background: url(../images/logo_3.webp) left top no-repeat;
    font-size: 0;
    text-decoration: none
}

header .menu-sandwich {
    display: none;
    font-family: Caption;
    font-size: 26px;
    text-align: center;
    color: #fff;
    text-shadow: 0 2px 1px #000;
    width: 130px;
    margin-top: 10px
}

header .contacts {
    background: url(/local/templates/main/css/../images/line-v.png) top left no-repeat;
    background-size: auto 100%;
    padding: 14px 0 14px 20px;
    margin-top: 20px
}

header .contacts li {
    list-style: none;
    font-family: Regular;
    font-size: 18px;
    color: #fff;
    text-shadow: 0 2px 1px #000;
    line-height: 1.2
}

header .contacts li a {
    font-family: Bold;
    font-weight: Bold;
    font-size: 27px;
    color: #fff;
    text-decoration: none;
    line-height: 1.1;
    text-shadow: 0 2px 1px #000
}

header .contacts li a.mail {
    font-family: Caption;
    font-weight: 400
}

header .main-menu {
    width: 100%;
    padding: 22px 0 10px;
    margin: 10px 0 0;
    background: url(/local/templates/main/css/../images/line-hs.svg) top left no-repeat;
    background-size: 100% 20px
}

header .main-menu ul.simplemenu {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around
}

header .main-menu ul li {
    list-style: none
}

header .main-menu ul li a, header .main-menu ul li span {
    font-family: Caption, 'Open Sans Condensed';
    font-size: 26px;
    line-height: 32px;
    text-decoration: none;
    color: #fff;
    display: block;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

header .main-menu ul li span {
    cursor: default
}

header .main-menu ul li a:hover, header .main-menu ul li.active a, header .main-menu ul li.active span, header .main-menu ul li:hover a {
    color: #fc3
}

header .main-menu ul.sub {
    position: absolute;
    z-index: 20;
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    box-sizing: border-box;
    padding: 14px 24px;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s;
    transform: translate3d(-30px, 0, 0);
    -webkit-transform: translate3d(-30px, 0, 0);
    -moz-transform: translate3d(-30px, 0, 0);
    -o-transform: translate3d(-30px, 0, 0)
}

header .main-menu li:hover ul.sub {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0)
}

header .main-menu ul.sub li {
    float: none;
    margin: 0
}

header .main-menu ul.sub li a, header .main-menu ul.sub li span {
    font-family: Caption;
    font-size: 140%;
    text-decoration: none;
    color: #5c8d89;
    display: block;
    position: relative;
    padding: 0;
    white-space: nowrap
}

header .main-menu ul.sub li a:hover, header .main-menu ul.sub li.active a, header .main-menu ul.sub li.active span {
    color: #fc3
}

.footmain .submenu, main .mobile-title {
    font-family: Caption;
    font-size: 26px;
    color: #fff;
    text-align: center
}

main .mobile-menu ul {
    padding: 0 20px;
    text-shadow: 0 2px 1px #000
}

main .mobile-menu ul li {
    list-style: none
}

main .mobile-menu ul li::before {
    display: none
}

main .mobile-menu ul li a, main .mobile-menu ul li span {
    font-family: Caption;
    font-size: 26px;
    line-height: 32px;
    text-decoration: none;
    color: #fff;
    display: none;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

.totop {
    font-family: Caption;
    font-size: 30px;
    color: #fff;
    font-weight: 400;
    position: fixed;
    right: 5%;
    bottom: 5%;
    text-decoration: none;
    opacity: 0;
    visibility: hidden;
    transition: color .2s;
    -webkit-transition: color .2s;
    -moz-transition: color .2s;
    -o-transition: color .2s
}

.totop:hover {
    color: #fc3
}

.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 50;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

.modal.active {
    opacity: 1;
    visibility: visible
}

.modal .modal-bg {
    background: rgba(0, 0, 0, .55);
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1
}

.modal .modal-body {
    position: absolute;
    top: 15%;
    left: 50%;
    z-index: 2;
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    box-sizing: border-box;
    padding: 25px;
    width: 350px;
    margin-left: -175px
}

.modal .modal-body .close {
    color: #fff;
    text-decoration: none;
    font-size: 43px;
    position: absolute;
    right: -27px;
    top: -44px;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

.modal .modal-body .close:hover {
    color: #f90
}

.modal .modal-body h3 {
    font-family: Caption;
    font-size: 190%;
    text-transform: uppercase;
    text-decoration: none;
    color: #004234;
    text-align: center;
    letter-spacing: .03em;
    position: relative;
    border: 0;
    display: block;
    margin: 0 0 14px;
    font-weight: 400
}

.modal .modal-body .message {
    text-align: center
}

.modal .modal-body form .form-group {
    margin: 10px 0
}

.modal .modal-body form .form-group label {
    font-size: 100%;
    color: #222
}

.modal .modal-body form .form-group input[type=text] {
    display: block;
    width: 100%;
    padding: 8px 10px;
    box-sizing: border-box;
    font-size: 100%;
    background: #f3f3f3;
    border-radius: 2px;
    color: #402600;
    text-align: left;
    border: 0;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .3)
}

.modal .modal-body .close-b, .modal .modal-body form .form-group button, .modal .modal-body form .form-group input[type=submit] {
    font-family: Caption;
    font-size: 165%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    text-align: center;
    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 0;
    letter-spacing: .03em;
    position: relative;
    border: 0;
    display: block;
    width: 100%;
    margin: 30px 0 0 0
}

.youtube {
    background-position: center;
    background-repeat: no-repeat;
    object-fit: none;
    position: relative;
    display: inline-block;
    overflow: hidden;
    transition: all .2s ease-out;
    cursor: pointer;
    width: 100%;
    height: auto
}

.youtube img {
    max-width: 20%
}

.youtube .play {
    background: url(/images/youtube-play-btn.png) no-repeat;
    background-position: 0 -50px;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    position: absolute;
    height: 50px;
    width: 69px;
    transition: none;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto
}

.youtube:hover .play {
    background-position: 0 0
}

@media screen and (max-width: 1024px) {
    .youtube {
        width: 100%;
        height: auto;
        max-height: 100%
    }
}

main {
    display: inline-block;
    width: calc(100% - 275px);
    vertical-align: top;
    padding-bottom: 0
}

main.footmain {
    width: 100%
}

main table {
    border-collapse: collapse
}

main table td {
    padding: 10px;
    width: 33%
}

aside .white-bg, main .white-bg {
    margin: 15px 0 17px 0;
    box-sizing: border-box;
    padding: 20px 40px 20px;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 100% 100%;
    /*background-color: #fff;*/
}

aside .white-bg {
    padding: 20px;
    background-image: url(../images/content-bg.svg)
}

main .white-bg-small {
    background-image: url(../images/content-bg.svg)
}

main .white-bg-medium {
    background-image: url(../images/content-medium-bg.svg)
}

main .white-bg-large {
    background-image: url(../images/content-large-bg.svg)
}

main .h1, main h1 {
    color: #004234;
    font-weight: 400;
    font-family: Caption;
    font-size: 230%;
    display: block;
    position: relative;
    text-transform: uppercase;
    text-align: center;
    padding: 15px 0 10px 0
}
main .zayavka h1 {
	padding: 15px 0 10px 36%;
}
main .zayavka .success {
	padding-left: 40%;
}
main .page-image {
    width: 100%;
    position: relative;
    line-height: 0
}

main .page-image::before {
    content: "";
    display: block;
    width: 104%;
    height: 105%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 0;
    background: url(../images/maskl.svg) left top no-repeat;
    background-size: 100% 100%
}

main .page-image img {
    width: 100%
}

aside .h2, main .h2, main h2 {
    color: #f60;
    font-weight: 400;
    font-family: Caption;
    font-size: 170%;
    display: block;
    position: relative;
    margin: 20px 0 10px 0
}

aside .h2, main .h2 {
    margin-top: 0;
    color: #333
}

main .h3, main h3 {
    color: #f60;
    font-weight: 400;
    font-family: Caption;
    font-size: 138%;
    display: block;
    position: relative;
    margin: 20px 0 10px 0
}

main p {
    font-size: 100%;
    line-height: 1.2;
    color: #000
}

main ul {
    font-size: 120%;
    line-height: 1.4;
    margin: 10px 0 20px
}

main ul li {
    list-style: none;
    letter-spacing: -.02em
}

main ul li::before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    background: url(../images/icons.png) -375px -24px no-repeat;
    width: 10px;
    height: 12px;
    margin: 0 10px 0 0
}

main ul.color_green li::before {
    filter: hue-rotate(44deg)
}

main .italic {
    font-size: 30px;
    text-align: center;
    margin: 20px auto;
    padding: 10px 20px;
    background: url(../images/content-yellow.svg) left top no-repeat;
    font-family: Caption;
    color: #000;
    display: block
}

main .green, main h2.green, main p.green {
    color: #004234
}

.light_green {
    color: #669901
}

.purple {
    color: #cb01cb
}

main .home .banners {
    position: relative;
    /*max-width: 730px;*/
    margin: 6px auto 0
}

main .banners.pl {
    position: relative
}

main .banners .next, main .banners .prev {
    font-family: Caption;
    text-decoration: none;
    position: absolute;
    top: 44%;
    color: #fff;
    font-size: 50px;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

main .banners .next:hover, main .banners .prev:hover {
    color: #f60
}

main .banners .prev {
    left: 10px
}

main .banners .next {
    right: 10px
}

main .banners .item {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    line-height: 0
}

main .banners .item:first-child {
    position: relative;
    opacity: 1;
    visibility: visible
}

main .banners .item a {
    display: block;
    position: relative
}

aside .bordered a::before, main .banners .item a::before, main .banners.pl .item::before {
    content: "";
    display: block;
    width: 105%;
    height: 105%;
    position: absolute;
    left: -3%;
    top: -3%;
    z-index: 0;
    background: url(../images/maskl.svg) left top no-repeat;
    background-size: 100% 100%
}

main .banners .item img {
    width: 100%;
    margin-top: 3px;
    margin-bottom: 3px;
}

main .images-list {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direcrion: column;
    -webkit-flex-direcrion: column;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between
}

main .images-list li {
    width: calc(33.33% - 7px);
    box-sizing: border-box;
    padding: 0;
    background: #fff;
    margin: 5px 0;
    display: block;
    position: relative;
    text-decoration: none;
    line-height: 0;
    font-size: 0
}

main .images-list li:before {
    display: none
}

main .images-list li a {
    display: block;
    position: relative;
    overflow: hidden;
    height: auto
}

main .images-list li a::before {
    content: "";
    display: block;
    width: 104%;
    height: 104%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 2;
    background: url(../images/mask.svg) left top no-repeat;
    background-size: 100% 100%
}

main .images-list li a img {
    width: 100%;
    transition: .5s;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    -o-transition: .5s;
    transform-origin: center;
    -webkit-transform-origin: center;
    -moz-transform-origin: center;
    -o-transform-origin: center;
    position: relative;
    z-index: 1;
    height: 100%
}

main .images-list li a:hover img {
    transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2)
}

main .staff-description, main .workshops-description {
    color: #004234;
    line-height: 1.2
}

main .workshops-description .banners {
    margin: 0 -15px
}

main .staff-description p, main .workshops-description p {
    font-size: 138%;
    color: #004234
}

main .staff-description .image, main .workshops-description .image {
    float: left;
    margin: 0 20px 0 0;
    max-width: 100%
}

main .staff-description .item-1 {
    float: right;
    width: 200px;
    margin: 30px 0 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between
}

main .staff-description .item-1 .text {
    width: 120px
}

main .staff-description .item-1::before {
    content: "";
    display: block;
    vertical-align: top;
    background: url(../images/icons.png) -461px -122px no-repeat;
    width: 66px;
    height: 67px
}

main .workshops-description .item-1 {
    display: block;
    width: 221px;
    float: right;
    margin: -10px 0 0 0
}

main .workshops-list, main .workshops-list div[id^=bx_incl_area_] {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direcrion: column;
    -webkit-flex-direcrion: column;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    margin: 30px 0 0 0;
    padding: 40px 35px;
    position: relative
}

main .workshops-list h2 {
    background: #004233;
    color: #fff;
    text-align: center;
    padding: 10px 20px;
    font-size: 24px;
    margin: 0;
    position: absolute;
    line-height: 1;
    transform: rotate(-10deg);
    -webkit-transform: rotate(-10deg);
    -moz-transform: rotate(-10deg);
    -o-transform: rotate(-10deg);
    opacity: .9;
    top: -140px;
    right: 12%
}

.workshops-description .workshops-list {
    margin: 0;
    padding-top: 0;
    padding-left: 0;
    padding-right: 0
}

main .workshops-list h2::before {
    content: "";
    display: block;
    width: 104%;
    height: 104%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 0;
    background: url(../images/maskl.svg) left top no-repeat;
    background-size: 100% 100%
}

@media (max-width: 770px) and (min-width: 760px) {
    main .workshops-list h2 {
        top: -211px;
        right: -4%
    }
}

@media (max-width: 767px) {
    .submenu .reviews {
        padding-top: 40px;
    }
.main-page_flex {
    display: flex;
    flex-direction:row;
	width:100% !important
}
.main-page_flex div {
    width: 100% !important;
}
    .mob_picture00 {
        padding-bottom: 1em
    }

    .all-program .new_btn_a {
        width: 100% !important;
    }
	.tourism img {
    width: 70% !important;
}
}

main .workshops-list .item {
    width: 100%;
    max-width: 340px;
    padding: 5px;
    box-sizing: border-box
}

main .workshops-list .item img {
    float: left;
    margin: 0 15px 5px 0
}

main .workshops-list .item .name {
    font-family: Caption;
    font-size: 170%;
    color: #f60;
    padding: 0 0 5px
}

main .workshops-list .item .description {
    font-size: 100%;
    color: #004234;
    line-height: 1.4
}

.workshops-list.large {
    padding-bottom: 15%
}

main .staff-list {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-direcrion: column;
    -webkit-flex-direcrion: column;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between
}

main .staff-list.slick-slider {
    padding: 0 20px
}

main .staff-list .item {
    width: 32%;
    box-sizing: border-box;
    padding: 20px;
    background: #fff;
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    margin: 1% 0;
    display: block;
    position: relative;
    text-decoration: none;
    color: #000
}

main .staff-list#main-staff .item {
    width: 100%;
    height: 332px;
    background: 0 0
}

main .staff-list .item .image {
    display: block;
    position: relative;
    text-align: center
}

main .staff-list .item .image::before {
    content: "";
    display: block;
    width: 103%;
    height: 102%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 1;
    background: url(../images/mask.svg) left top no-repeat;
    background-size: 100% 100%
}

main .staff-list .item .image img {
    width: 100%
}

main .staff-list .item .name {
    text-align: center;
    color: #f60;
    font-size: 140%;
    display: block;
    margin: 10px 0;
    line-height: 1.2
}

main .staff-list .item .description {
    text-align: center;
    font-size: 100%;
    display: block;
    line-height: 1.2;
    margin: 10px 0 0
}

main .staff-list .item .description-full {
    font-size: 100%;
    display: block;
    line-height: 1.2;
    margin: 0;
    position: absolute;
    left: 0;
    width: 100%;
    top: 0;
    background: #fff;
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    box-sizing: border-box;
    padding: 25px;
    text-align: left;
    overflow: hidden;
    height: 102%;
    z-index: 2;
    opacity: 0;
    visibility: hidden;
    overflow-y: auto;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

main .staff-list .item:hover .description-full {
    opacity: 1;
    visibility: visible
}

main .news-list {
    margin: 0 0 0
}

main .news-list .item {
    box-sizing: border-box;
    padding: 0;
    margin: 10px 0;
    display: block;
    position: relative;
    text-decoration: none;
    color: #000;
    clear: both;
    padding: 20px 0
}

main .news-list .item::after {
    content: "";
    display: block;
    width: 100%;
    height: 9px;
    background: url(../images/line-hg.svg) top left no-repeat;
    background-size: 100% 100%;
    position: absolute;
    bottom: -10px;
    opacity: .3
}

main .news-list .item:first-child {
    padding-top: 0;
    margin-top: 0
}

main .news-list .item:last-child::after {
    display: none
}

main .news-list .item .image {
    display: block;
    float: left;
    width: 200px;
    margin: 0 20px 0 0
}

main .news-list .item .image img {
    width: 100%
}

main .news-list .item .name {
    line-height: 1.2;
    color: #f60;
    font-weight: 400;
    font-family: Caption;
    font-size: 138%;
    display: block;
    position: relative;
    margin: 0 0 10px 0
}

main .news-list .item .date {
    font-size: 100%;
    display: block;
    line-height: 1.2;
    margin: 5px 0;
    float: right
}

main .news-list .item .answer, main .news-list .item .description {
    font-size: 100%;
    display: block;
    line-height: 1.2;
    margin: 10px 0 0
}

main .news-list .item .answer {
    padding: 15px 20px;
    background: #ffe9c7;
    border-radius: 5px;
    color: #212121
}

main .news-list .item .answer .title {
    line-height: 1;
    color: #333;
    font-weight: 400;
    font-family: Caption;
    font-size: 120%;
    position: relative;
    margin: 0 0 11px;
    display: inline-block
}

main .gallery .news-list .item {
    padding: 1px 0
}

main .gallery .news-list .item::after {
    bottom: 0
}

main .gallery .news-list .item .name {
    display: inline-block
}

main .gallery .news-list .item .total {
    display: inline-block;
    line-height: 1.2;
    color: #333;
    font-weight: 400;
    font-family: Bold;
    font-size: 100%;
    margin: 0 0 0 10px
}

main .gallery .news-list .item ul.images-list {
    margin: 0 0 20px
}

main .youtube {
    margin: 0 0 20px
}

main .youtube iframe {
    width: 100%;
    height: 300px
}

main .images-list a.media {
    display: block;
    position: relative;
    height: 150px;
    overflow: hidden
}

main .images-list a.media img {
    height: 190px;
    width: auto;
    margin: -18px 0 0 -12px
}

main .images-list a.media::after {
    content: "";
    display: block;
    width: 54px;
    height: 55px;
    background: url(../images/icons.png) -535px -86px no-repeat;
    position: absolute;
    left: 50%;
    top: 50%;
    background-size: 589px;
    margin: -27px 0 0 -26px;
    z-index: 3
}

main .news-list.psy .item .description {
    overflow: hidden;
    margin: 0 0 15px 0;
    max-height: 500px;
    transition: .6s;
    -webkit-transition: .6s;
    -moz-transition: .6s;
    -o-transition: .6s
}

main .news-list.psy .item.closed .description {
    max-height: 73px
}

main .news-list.psy .item .toggle {
    text-decoration: none;
    border-bottom: 1px dashed;
    color: #004234
}

main .news-list.psy .item .toggle:hover {
    border-bottom: 1px dashed transparent
}

main .news-detail img {
    margin: 15px 10px 15px 0;
    float: left
}

main .programms-full-list {
    margin: 0 -15px 0
}

main .programms-full-list .item {
    box-sizing: border-box;
    padding: 0;
    margin: 10px 0;
    display: block;
    position: relative;
    text-decoration: none;
    color: #000;
    clear: both;
    padding: 20px 0
}

main .programms-full-list .item::after {
    content: "";
    display: block;
    width: 100%;
    height: 9px;
    background: url(../images/line-hg.svg) top left no-repeat;
    background-size: 100% 100%;
    position: absolute;
    bottom: -10px;
    opacity: .3
}

main .programms-full-list .item:first-child {
    padding-top: 0;
    margin-top: 0
}

main .programms-full-list .item:last-child::after {
    display: none
}

main .programms-full-list .item a {
    text-decoration: none;
    display: block;
    position: relative;
    overflow: hidden
}

main .programms-full-list .item a::before {
    content: "";
    display: block;
    width: 104%;
    height: 104%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 2;
    background: url(../images/mask.svg) left top no-repeat;
    background-size: 100% 100%
}

main .programms-full-list .item a .image {
    width: 100%;
    height: 345px;
    overflow: hidden;
    display: block;
    background-size: cover;
    background-position: center;
    transition: .5s;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    -o-transition: .5s;
    transform-origin: center;
    -webkit-transform-origin: center;
    -moz-transform-origin: center;
    -o-transform-origin: center
}

main .programms-full-list .item a:hover .image {
    transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2)
}

main .programms-full-list .item a .image img {
    width: 100%
}

main .programms-full-list .item a .name, .banners .item a .name {
    box-sizing: border-box;
    line-height: 1.2;
    color: #004234;
    font-weight: 400;
    font-family: Caption;
    font-size: 28px;
    text-align: center;
    display: block;
    width: max-content;
    max-width: 100%;
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    padding: 10px 20px;
    text-decoration: underline;
    transition: .5s;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    -o-transition: .5s
}

main .programms-full-list .item a:hover .name {
    text-decoration: none;
    color: #f60
}

main .review-button {
    font-family: Caption;
    font-size: 130%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    text-align: center;
    line-height: .9;
    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 30px;
    letter-spacing: .03em;
    position: relative;
    display: block;
    width: 30%;
    margin: 0 auto 20px;
    box-sizing: border-box
}

main .contacts .center {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around
}

main .contacts .title {
    font-size: 230%;
    color: #004234;
    font-family: Caption;
    margin: 0;
    line-height: 1
}

main .item.mail .title, main .item.phone .title {
    margin: 0
}

main .item.map .title, main .item.soc .title {
    text-align: center
}

main .item.map .soc {
    text-align: center
}

main .contacts .desc {
    font-size: 138%;
    line-height: 1.4;
    color: #033;
    margin: 20px 0 0
}

main .contacts a {
    font-size: 30px;
    color: #fff;
    font-family: Caption;
    text-decoration: none
}

main .item {
    clear: both
}

main .item.mail {
    display: inline-block;
    vertical-align: middle;
    width: 300px;
    text-align: left;
    margin-bottom: 20px
}

main .item.mail i {
    display: block;
    width: 96px;
    height: 75px;
    background: url(../images/icons.png) -23px -235px no-repeat;
    float: left;
    margin: -13px 20px 0 0;
    background-size: 588px
}

main .item.phone {
    display: inline-block;
    vertical-align: middle;
    width: 300px;
    margin-left: 0px;
    text-align: left
}

main .item.phone i {
    display: block;
    width: 68px;
    height: 62px;
    background: url(../images/icons.png) -137px -236px no-repeat;
    float: left;
    margin: 10px 20px 0 0;
    background-size: 588px
}

main .item.soc ul {
    margin: 20px 0
}

main .item.map img {
    margin: 0 auto;
    display: block
}

main .item.yandex .yandex-map {
    width: 90%;
    height: 500px;
    margin: 20px 5%;
    padding: 5px;
    position: relative
}

main .item.yandex .yandex-map::before {
    content: "";
    display: block;
    width: 104%;
    height: 104%;
    position: absolute;
    left: -2%;
    top: -2%;
    z-index: 0;
    background: url(../images/mask.svg) left top no-repeat;
    background-size: 100% 100%
}

main .home .programms-list {
    margin: 0 0
}

.my-programms-list {
    display: flex;
    flex-wrap: wrap
}

main .home .programms-list .programms-item {
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    box-sizing: border-box;
    padding: 15px;
    position: relative;
    width: 50%;
    min-height: 450px;
    float: left
}

main .home .programms-list .programms-item.double {
    width: 66%
}

main .home .programms-list .programms-item a {
    text-decoration: none;
    display: block;
}

main .home .programms-list .programms-item .name {
    font-family: Caption;
    font-weight: 400;
    color: #333;
    font-size: 185%;
    text-align: center;
    margin: 0 0 10px 0;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

main .home .programms-list .programms-item a:hover .name {
    color: #f60
}

main .home .programms-list .programms-item .image {
    position: relative;
    margin: 0 0 10px 0
}

main .home .programms-list .programms-item .image::before {
    content: "";
    position: absolute;
    display: block;
    width: 104%;
    height: 102%;
    left: -2%;
    top: -2%;
    z-index: 0;
    background: url(../images/mask.svg) left top no-repeat;
    background-size: 100% 100%
}

main .home .programms-list .programms-item .image img {
    width: 100%
}

main .home .programms-list .programms-item .description {
    font-size: 100%;
    line-height: 1.2;
    color: #000;
    margin-left: 10px;
    display: flex;
    flex-direction: column;
    position: relative;
}
main .home .programms-list .programms-item .description::before{
  display: block;
  position: absolute;
  content: '';
  padding: 50%;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 0;
  background: url('../images/15years.png')no-repeat center/contain;
  opacity: 0.2;
  transform: translateY(60px);
}
main .home .programms-list .programms-item .description ul {
    font-size: 120%;
    line-height: 1.2;
    color: #000;
    margin-left: 10px
}

main .home .index-collectiv, main .home .index-text {
    margin: 0 10px 20px;
    width: 1080px
}

main .request {
    text-align: center
}

main .success {
    text-align: center;
    font-size: 120%;
    line-height: 1.4;
    color: #004234;
    padding: 10px 0 0
}

main .request .message {
    text-align: left
}

main .request form .child {
    padding: 20px;
    background: url(../images/content-yellow.svg) left top no-repeat;
    background-size: 100% 100%;
    display: inline-block;
    width: 50%;
    min-width: 300px;
    box-sizing: border-box;
    vertical-align: top;
    margin: 1% 2% 1% 0;
    position: relative
}

main .request form .white-bg {
    margin: 0 auto;
    font-size: 16px
}

main .request form .white-bg .i1 {
    width: 48%;
    display: inline-block;
    vertical-align: top;
    margin-right: 2%
}

.req-opend {
    width: 48%;
    margin-left: 100px
}

main .request form .white-bg .i2 {
    width: 49%;
    display: inline-block;
    vertical-align: top
}

main .request form .child .remove {
    color: #fff;
    text-decoration: none;
    position: absolute;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s;
    font-size: 43px;
    right: -10px;
    top: -25px
}

main .request form .child .remove:hover {
    color: #000
}

main .request form .form-group {
    margin: 10px 0
}

main .request form .form-group label {
    font-size: 100%;
    display: block;
    text-align: left;
    color: #004234;
    margin: 10px 0 5px
}

main .request form .form-group input[type=password], main .request form .form-group input[type=text], main .request form .form-group select, main .request form .form-group textarea {
    display: block;
    width: 100%;
    padding: 8px 10px;
    box-sizing: border-box;
    font-size: 100%;
    background: #f3f3f3;
    border-radius: 2px;
    color: #004234;
    text-align: left;
    border: 0;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .3)
}

main .request form .form-group select {
    display: inline-block;
    vertical-align: top
}

main .request .close-b, main .request form .form-group button, main .request form .form-group input[type=button], main .request form .form-group input[type=submit] {
    font-family: Caption;
    font-size: 165%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    text-align: center;
    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 0;
    letter-spacing: .03em;
    position: relative;
    border: 0;
    display: block;
    margin: 20px auto;
    width: 40%;
    min-width: 200px
}

main .request form .form-group input[type=button] {
    margin: 0 0 10px;
    font-size: 130%;
    display: inline-block;
    width: auto;
    padding: 10px 30px
}

main .request form .form-group.check-input label {
    display: none
}

main .request form .form-group.check-input input[type=checkbox] {
    margin: 0 20px
}

main .request form .child .form-group label {
    color: #92621b
}

main .request form .child .form-group input[type=password], main .request form .child .form-group input[type=text], main .request form .child .form-group select, main .request form .child .form-group textarea {
    border: 0;
    background: #fff;
    box-shadow: 0 1px 1px rgba(0, 0, 0, .3)
}

main .paging {
    margin: 10px 0
}

main .paging ul {
    text-align: center
}

main .paging ul li {
    display: inline-block;
    vertical-align: top
}

main .paging ul li::before {
    display: none
}

main .paging ul li a {
    font-family: Caption;
    text-decoration: none;
    font-size: 120%;
    display: block;
    padding: 20px 0px;
    color: #000
}

main .paging ul li a:hover, main .paging ul li.active a {
    color: #f60
}

main .staff-list .slick-next, main .staff-list .slick-prev {
    top: 36%
}

main .staff-list .slick-next:before, main .staff-list .slick-prev:before {
    font-size: 40px;
    font-weight: 700;
    color: #333
}

main .staff-list .slick-next {
    right: -5px
}

aside {
    width: 250px;
    display: inline-block;
    vertical-align: top;
    margin: 0 0 30px 0px;
    position: relative;
    z-index: 2
}

aside nav {
    margin: 0 0 40px
}

aside nav ul li {
    list-style: none;
    position: relative
}

aside nav ul li a, aside nav ul li span {
    font-family: Caption;
    font-size: 200%;
    text-decoration: none;
    color: #fff;
    display: block;
    position: relative;
    padding: 0 0 0 30px;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

aside nav ul li span {
    cursor: default
}

aside nav ul li a:hover, aside nav ul li.active a, aside nav ul li.active span, aside nav ul li:hover a {
    color: #fc3
}

aside nav > ul li a::before, aside nav > ul li span::before {
    content: ">";
    display: inline-block;
    margin: 0 10px 0 0;
    position: absolute;
    left: 0;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s;
    transform: rotate(0);
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -o-transform: rotate(0);
    transform-origin: center;
    -webkit-transform-origin: center;
    -moz-transform-origin: center;
    -o-transform-origin: center
}

aside nav > ul li:hover a::before {
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -o-transform: rotate(180deg)
}

aside nav ul.sub {
    position: absolute;
    right: 100%;
    background: url(../images/content-bg.svg) left top no-repeat;
    background-size: 100% 100%;
    top: 0;
    box-sizing: border-box;
    padding: 10px 20px;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s;
    transform: translate3d(-30px, 0, 0);
    -webkit-transform: translate3d(-30px, 0, 0);
    -moz-transform: translate3d(-30px, 0, 0);
    -o-transform: translate3d(-30px, 0, 0)
}

aside nav li:hover ul.sub {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0)
}

aside nav ul.sub li a, aside nav ul.sub li span {
    font-family: Caption;
    font-size: 140%;
    text-decoration: none;
    color: #5c8d89;
    display: block;
    position: relative;
    padding: 0 0 0 30px;
    white-space: nowrap
}

aside nav ul.sub li a:hover, aside nav ul.sub li.active a, aside nav ul.sub li.active span {
    color: #fc3
}

aside .submenu ul li {
    list-style: none;
    margin: 10px 0 10px
}

aside .submenu ul li a, aside .submenu ul li span {
    font-family: Caption;
    font-size: 200%;
    text-decoration: none;
    color: #fff;
    display: block;
    position: relative;
    padding: 0;
    line-height: 1;
    clear: both;
    text-align: left;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

aside .submenu ul li a:hover, aside .submenu ul li.active a, aside .submenu ul li.active span {
    color: #fc3
}

aside .submenu ul li a.testing::before {
    content: "";
    display: block;
    width: 50px;
    height: 48px;
    background: url(../images/icons.png) -634px -123px no-repeat;
    margin: 0 auto 10px
}

aside .submenu ul li a.staff::before {
    content: "";
    display: block;
    width: 94px;
    height: 95px;
    background: url(../images/icons.png) -347px -122px no-repeat;
    margin: 0 auto 10px
}

aside .submenu ul li a.question::before {
    content: "";
    display: block;
    width: 75px;
    height: 75px;
    background: url(../images/icons.png) -542px -122px no-repeat;
    margin: 0 auto 10px
}

aside .submenu ul li a.video::before {
    content: "";
    display: block;
    width: 75px;
    height: 75px;
    background: url(../images/icons.png) -765px -122px no-repeat;
    margin: 0 auto 10px
}

aside .submenu ul li a.fb, aside .submenu ul li a.vk {
    line-height: 50px
}

aside .submenu ul li a.fb::before, aside .submenu ul li a.vk::before {
    content: "";
    display: block;
    width: 51px;
    height: 50px;
    margin: 0 20px 10px 0;
    float: right
}

aside .submenu ul li a.vk::before {
    background: url(../images/icons.png) -33px -23px no-repeat
}

aside .submenu ul li a.fb::before {
    background: url(../images/icons.png) -85px -23px no-repeat
}

aside .submenu ul li a.order-button,  .mobile-only a.order-button{
    font-family: Caption;
    font-size: 200%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    display: block;
    text-align: center;
    line-height: .9;
    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 20px;
    letter-spacing: .03em;
    position: relative;
    margin: 50px 0 0 0
}

aside .submenu ul li a.order-button::before {
    content: "";
    display: block;
    position: absolute;
    width: 48px;
    height: 105px;
    top: -120px;
    left: 50%;
    margin: 0 0 0 -24px
}

aside .submenu ul li a.eng-f-eng {
    font-size: 0;
    text-decoration: none;
    display: inline-block;
    background: url(../images/icons.png) -20px -123px no-repeat;
    position: relative;
    width: 116px;
    height: 133px;
    padding-right: 7px
}

aside .submenu ul li a.stock {
    font-size: 0;
    text-decoration: none;
    display: block;
    background: url(../images/icons.png) -162px -123px no-repeat;
    position: relative;
    width: 168px;
    height: 168px;
    margin: 30px auto;
    padding-right: 10px
}

aside .news-list .name {
    font-weight: 700;
    font-size: 16px
}

aside .all-news-link, aside .news-list .date {
    display: block;
    text-align: right;
    margin: 5px 0
}

footer {
    position: relative;
    margin-top: 70px;
    background: url(../images/chalk.webp) 78% 20% no-repeat
}

footer::before {
    content: "";
    display: block;
    width: 100%;
    height: 25px;
    left: 0;
    background: url(../images/line-h.svg) top left no-repeat;
    position: absolute;
    background-size: 100% 100%;
    top: -45px
}

footer ul {
    display: inline-block;
    vertical-align: top;
    margin: 0 40px 0 0
}

footer ul li {
    list-style: none
}

footer ul li a, footer ul li span {
    font-family: Regular;
    font-size: 140%;
    color: #fff;
    text-decoration: none;
    line-height: 1.2;
    transition: .2s;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s
}

footer ul li span {
    cursor: default
}

footer ul.contacts li:last-child a {
    font-family: Caption;
    color: #fc3;
    font-size: 150%;
    letter-spacing: .03em
}

footer ul li a:hover, footer ul li.active a, footer ul li.active span {
    color: #fc3
}

ul.social {
    margin: 0;
    text-align: center;
    font-size: 0;
    display: block;
    margin: 0px 0px 55px 0px;
}

ul.social li {
    list-style: none;
    display: inline-block;
    vertical-align: top;
    margin: 0 4px
}

ul.social li::before {
    display: none
}

ul.social li a {
    display: block;
    width: 51px;
    height: 50px;
    background-repeat: no-repeat;
    background-image: url(../images/icons.webp)
}

ul.social li a.telega {
    background-image: url(../images/telegram.png)
}

ul.social li a.whatsapp {
    background-image: url(../images/whatsapp.png)
}

ul.social li a.vi {
    background-position: -293px -23px
}

ul.social li a.tw {
    background-position: -241px -23px
}

ul.social li a.vk {
    background-position: -33px -23px
}

ul.social li a.fb {
    background-position: -85px -23px
}

ul.social li a.yo {
    background-position: -189px -23px
}

ul.social li a.in {
    background-position: -137px -23px
}

footer ul.contacts {
    float: right;
    margin: 0px 0 0 0;
    background: url(/local/templates/main/css/../images/line-v.png) top left no-repeat;
    background-size: auto 100%;
    padding: 0px 0 0px 25px;
}

footer .address {
    font-family: Regular;
    font-size: 140%;
    color: #fff;
    text-decoration: none;
    line-height: 1.2;
    display: inline-block;
    vertical-align: bottom
}

footer .address span {
    display: block
}

footer .copy {
    color: #042e27;
    font-size: 130%;
    text-align: center;
    padding: 90px 0 10px
}

.text_12 {
    padding: 2em;
    text-align: left
}

.politika_link {
    color: #fff
}

.like_h2 {
    color: #f60;
    font-weight: 400;
    font-family: Caption;
    font-size: 170%;
    display: block;
    position: relative;
    margin: 0 0 10px 0
}

.like_h3 {
    color: #f60;
    font-weight: 400;
    font-family: Caption;
    font-size: 138%;
    display: block;
    position: relative;
    margin: 20px 0 10px 0
}

main .online-lessons {
    display: block
}

main .online-lessons li {
    float: left;
    margin: 10px;
    background: 0 0
}

main .online-lessons li a {
    height: 160px !important
}

#staff .item:hover {
    cursor: default
}

.right_link {
    text-align: center;
    padding-top: 20px
}

.right_link a {
    color: #fff
}

.price-list {
    border: 2px solid #41716e;
    padding: 5px;
    box-shadow: 1px 1px 20px 4px #497a76;
    margin-top: 20px
}

.price-list p.titl {
    font-size: 20px;
    font-family: Caption;
    border-bottom: 1px solid #41716e;
    margin-bottom: 5px;
    padding-bottom: 10px
}

.price-list p:nth-child(odd) {
    float: left;
    width: 59%;
    border-right: 1px solid green;
    border-bottom: 1px solid #41716e;
    margin: 0;
    padding: 10px 0;
    text-align: center
}

.price-list p:nth-child(even) {
    float: left;
    width: 38%;
    padding-left: 2%;
    margin: 0;
    padding: 10px 0 10px 20px;
    border-bottom: 1px solid #41716e;
    text-align: center
}

.bold {
    font-weight: 700
}

.center {
    text-align: center
}

.block {
    display: block
}

.pay_form {
    text-align: center
}

.pay_form .labels {
    display: inline-block;
    padding: 20px;
    background: url(/local/templates/main/images/content-yellow.svg) left top no-repeat;
    background-size: 100% 100%;
    display: inline-block;
    width: 50%;
    min-width: 300px;
    box-sizing: border-box;
    vertical-align: top;
    margin: 1% 2% 1% 0;
    position: relative
}

.pay_form label {
    display: block;
    margin-bottom: 5px
}

.pay_form input[type=email], .pay_form input[type=number], .pay_form input[type=text] {
    display: block;
    width: 100%;
    padding: 8px 10px;
    margin-bottom: 10px;
    box-sizing: border-box;
    font-size: 100%;
    background: #f3f3f3;
    border-radius: 2px;
    color: #004234;
    text-align: left;
    border: 0;
    background: #fff;
    box-shadow: 0 1px 1px rgba(0, 0, 0, .3)
}

.pay_form input[type=submit] {
    display: inline-block;
    font-family: Caption;
    font-size: 200%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    text-align: center;
    line-height: .9;
    background: url(/local/templates/main/images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 70px;
    letter-spacing: .03em;
    position: relative;
    margin-top: 20px;
    outline: 0;
    border: none
}

.pay_form input[type=submit]:active, .pay_form input[type=submit]:focus, .pay_form input[type=submit]:hover {
    outline: 0;
    border: none
}

.news-main-page {
    margin-top: 20px
}

.news-main-page .news-list {
    display: flex;
    justify-content: space-between
}

main .news-main-page .item {
    width: 31%;
    margin: 0;
    padding: 0
}

main .news-main-page .item:last-child:after {
    content: "";
    display: block;
    width: 100%;
    height: 9px;
    background: url(/local/templates/main/css/../images/line-hg.svg) top left no-repeat;
    background-size: 100% 100%;
    position: absolute;
    bottom: -10px;
    opacity: .3
}

main .news-main-page .all-news-link {
    margin-left: auto
}

main .news-main-page .all-news-container {
    text-align: right;
    font-size: 21px;
    margin-right: 30px;
    margin-top: 20px
}

.submenu__items {
    display: flex
}

.submenu__items li {
    margin-top: 20px;
    width: 100%
}

.submenu pics li {
    margin-top: 20px
}

aside .submenu ul.submenu__items li a.order-button {
    margin-top: 130px
}

aside .submenu ul.submenu__items li a.stock {
    margin: 0;
    width: 100%;
    height: auto;
    padding: 0;
    background: url(/images/stock.png) no-repeat;
    background-size: contain
}

aside.main-page {
    margin-top: -30px;
    width: 250px
}

.submenu.pics {
    margin-top: -27px
}

main .home-big .programms-list .programms-item {
    width: 31%;
    margin-right: 5px;
    display: flex;
    flex-direction: column;
}

@media (max-width: 768px) {
    main .home-big .programms-list .programms-item {
        width: 80%;
        margin-right: 0
    }
}

.index-text-main-page {
    margin-top: 20px
}

.aside .submenu ul.submenu__items li a.eng-f-eng {
    width: 110px
}

aside .submenu.order ul li a.order-button::before {
    content: none
}

aside .submenu.order ul li a.order-button {
    margin-top: 0
}

aside .submenu ul li.zayavka {
    margin-bottom: 5px
}

.flex_parent__left {
    float: left
}

.flex_parent__left img {
    max-height: 300px;
    margin-right: 1em
}

@media screen and (min-width: 1024px) {
    .container_home {
        justify-content: center;
        height: 426px;
        display: flex;
        align-items: center
    }
}

.header_container {
    min-width: 470px;
    max-width: 100%;
    display: flex;
    position: relative
}

.change-programm-slider__header, .nav__title a {
    text-decoration: none;
    font-family: Caption;
    color: #fff;
    font-size: 34px
}

.change-programm-slider__header {
    margin-bottom: 10px
}

.header_nav {
    display: flex;
    justify-content: center;
    position: relative
}

.header__age {
    text-align: center;
    margin-bottom: 10px
}

.nav__icon-next, .nav__icon-prev {
    top: -5px;
    min-width: 52px;
    min-height: 52px;
    cursor: pointer;
    position: absolute
}

.nav__icon-prev {
    background: url(/images/icon-arrow-prev.png) no-repeat;
    left: 0
}

.nav__icon-next {
    background: url(/images/icon-arrow-next.png) no-repeat;
    right: 0
}

.nav__title {
    display: flex;
    align-items: center;
    text-align: center;
    margin-left: auto;
    margin-right: auto
}

.slides__slide {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap
}

.slide__ceil {
    background: url(/images/fon-slides-block.png) no-repeat;
    height: 352px;
    width: 242px;
    padding: 15px 15px 30px 15px;
    background-size: cover;
    margin-bottom: 10px
}

.ceil__image {
    width: 100%;
    margin-bottom: 5px
}

.ceil__image img {
    max-width: 100%
}

.ceil__season {
    color: #ef9143;
    font-size: 20px;
    font-weight: 700;
    width: 47%
}

.ceil__season a {
    text-decoration: none
}

.ceil__age, .ceil__name-programm, .ceil_location {
    font-size: 16px
}

.ceil_container {
    padding-left: 25px
}

.ceil__price {
    font-family: Caption;
    font-size: 29px;
    margin-bottom: 10px;
    color: #ef9143
}

.btn-detail-container__btn-detail {
    background: url(/images/btn-detail.png) no-repeat;
    font-size: 18px;
    color: #fff;
    font-family: Caption;
    text-decoration: none;
    width: 163px;
    height: 38px;
    display: flex;
    justify-content: center;
    align-items: center
}

.ceil__season-main {
    display: flex;
    margin-bottom: 10px;
    min-height: 48px
}

.season_title {
    width: min-content;
    font-size: 20px;
    margin-right: 26px;
    display: flex;
    align-items: center;
    font-family: Caption
}

.seasons {
    display: flex;
    flex-wrap: wrap;
    align-items: center
}

.ceil__season.summer a {
    color: #ef9143
}

.ceil__season.aut a {
    color: #e05b4b
}

.ceil__season.winter a {
    color: #3ebcbd
}

.ceil__season.spring a {
    color: #abb143
}

.ceil__description {
    min-height: 76px;
    margin-bottom: 10px
}

@media screen and (max-width: 470px) {
    .header_container {
        width: 320px;
        min-width: auto
    }

    .nav__title {
        max-width: calc(100% - 104px)
    }
}

.new_slide__ceil {
    background-image: url(/images/stub_bg.webp)
}

.new_slide_title {
    font-family: Caption;
    color: #bf7609;
    font-size: 34px;
    display: flex;
    align-items: center;
    padding-top: 26px;
    margin-bottom: -5px
}

.new_slide_title_span {
    font-family: Caption;
    color: #bf7609;
    display: flex;
    align-items: center;
    font-size: 20px;
    margin-bottom: -5px
}

.new_slider_image {
    padding-top: 40px
}

.new_slide_input {
    padding-bottom: 3px;
    padding-top: 18px
}

.new_slide_input input {
    width: 158px;
    height: 33px;
    font-size: 16px;
    padding-left: 10px;
    border: 1px solid #eaecde;
    font-family: Regular
}

.new_slide_input input::placeholder {
    color: #000;
    font-family: Regular;
    font-size: 16px
}

select#x1 {
    width: 28%
}

select#x2 {
    width: 40%
}

select#x3 {
    width: 30%
}



@media (max-width: 700px) {
    select#x1 {
        width: 18%
    }
    select#x2 {
        width: 30%
    }

    select#x3 {
        width: 27%
    }
}

.new_btn_a_new {
    font-family: 'Caption';
    font-size: 130%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    display: block;
    text-align: center;
    line-height: 0.9;
    background: url(/local/templates/main/css/../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    width: 300px;
    padding: 14px 0px;
    letter-spacing: 0.03em;
    position: relative;
    margin: auto;
}

.new_btn_a {
    font-family: Caption;
    font-size: 130%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    display: block;
    text-align: center;
    line-height: .9;
    background: url(/local/templates/main/css/../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    width: 100%;
    padding: 14px 0;
    letter-spacing: .03em;
    position: relative;
    margin-top: auto;
    margin-bottom: 10px;
}

.new_title_green {
    color: #004234
}

@media (min-width: 568px) and (max-width: 667px) and (orientation: landscape) {
    .modal .modal-body form .form-group button {
        margin: 0;
        padding: 10px
    }

    .modal .recall {
        padding-top: 0;
        padding-bottom: 0;
        top: 20% !important
    }

    .recall .close-b {
        margin: 8px 0 7px 0 !important
    }

    .like_h3 {
        margin: 10px 0 5px 0
    }
}

@media (min-width: 568px) and (max-width: 767px) and (orientation: landscape) {
    .modal .review {
        padding-top: 0;
        padding-bottom: 0;
        top: 20%
    }

    .review #new_input3 {
        height: 2em
    }

    .review #new_btn {
        margin: 0
    }

    .review .new_i1 label, .review .new_i2 label, .review .new_i3 label {
        margin: 0
    }

    .g-recaptcha {
        display: flex;
        justify-content: center;
        transform: scale(.77);
        -webkit-transform: scale(.77)
    }

    .g-recaptcha > div {
        height: 56px !important
    }

    .new_fgr label {
        margin: 0
    }

    .new_fgr #new_btn {
        padding: 0;
        padding-top: 1px;
        padding-bottom: 1px
    }

    .review .form-group {
        padding: 0 !important
    }

    .review {
        transform: scale(.77);
        -webkit-transform: scale(.77);
        transform-origin: 0 0;
        -webkit-transform-origin: 0 0;
        margin-left: -120px !important
    }
}

@media (min-width: 769px) and (max-width: 799px) and (orientation: landscape) {
    .modal .review {
        padding-top: 0;
        padding-bottom: 0;
        top: 20%
    }

    .review #new_input3 {
        height: 2em
    }

    .review #new_btn {
        margin: 0
    }

    .review .new_i1 label, .review .new_i2 label, .review .new_i3 label {
        margin: 0
    }

    .g-recaptcha {
        display: flex;
        justify-content: center;
        transform: scale(.77);
        -webkit-transform: scale(.77)
    }

    .g-recaptcha > div {
        height: 56px !important
    }

    .new_fgr label {
        margin: 0
    }

    .new_fgr #new_btn {
        padding: 0;
        padding-top: 1px;
        padding-bottom: 1px
    }

    .review .form-group {
        padding: 0 !important
    }

    .review {
        transform: scale(.77);
        -webkit-transform: scale(.77);
        transform-origin: 0 0;
        -webkit-transform-origin: 0 0;
        margin-left: -120px !important
    }
}

@media (min-width: 801px) and (max-width: 823px) and (orientation: landscape) {
    .modal .review {
        padding-top: 0;
        padding-bottom: 0;
        top: 20%
    }

    .review #new_input3 {
        height: 2em
    }

    .review #new_btn {
        margin: 0
    }

    .review .new_i1 label, .review .new_i2 label, .review .new_i3 label {
        margin: 0
    }

    .g-recaptcha {
        display: flex;
        justify-content: center;
        transform: scale(.77);
        -webkit-transform: scale(.77)
    }

    .g-recaptcha > div {
        height: 56px !important
    }

    .new_fgr label {
        margin: 0
    }

    .new_fgr #new_btn {
        padding: 0;
        padding-top: 1px;
        padding-bottom: 1px
    }

    .review .form-group {
        padding: 0 !important
    }

    .review {
        transform: scale(.77);
        -webkit-transform: scale(.77);
        transform-origin: 0 0;
        -webkit-transform-origin: 0 0;
        margin-left: -120px !important
    }
}

@media (min-width: 568px) and (max-width: 568px) and (orientation: landscape) {
    .review {
        transform: scale(.6);
        -webkit-transform: scale(.6);
        transform-origin: 0 0;
        -webkit-transform-origin: 0 0;
        margin-left: -120px !important
    }
}

@media (min-width: 320px) and (max-width: 360px) {
    .review #new_input3 {
        height: 4em !important
    }

    #new_btn {
        margin: 0 !important
    }
}

@media (min-width: 320px) and (max-width: 375px) {
    .g-recaptcha {
        display: flex;
        justify-content: center;
        transform: scale(.85);
        -webkit-transform: scale(.85)
    }
}

@media (max-width: 766px) {
    main .staff-list#main-staff .item {
        height: 366px
    }

    main .staff-list .item .name {
        min-height: 10% !important
    }

    .submenu.not-mobile {
        display: none
    }

    .footmain .spechial-mobile {
        display: block
    }
}

@media (min-width: 731px) and (max-width: 731px) and (orientation: landscape) {
    main .staff-list#main-staff .item {
        height: 336px
    }

    main .staff-list .item .name {
        min-height: 14% !important
    }
}

@media (min-width: 823px) and (max-width: 823px) and (orientation: landscape) {
    main .staff-list#main-staff .item {
        height: 363px
    }

    main .staff-list .item .name {
        min-height: 21% !important
    }
}

@media (min-width: 736px) and (max-width: 736px) and (orientation: landscape) {
    main .staff-list#main-staff .item {
        height: 332px
    }

    main .staff-list .item .name {
        min-height: 13% !important
    }
}

@media (min-width: 768px) and (max-width: 768px) {
    main .staff-list#main-staff .item {
        height: 340px
    }

    main .staff-list .item .name {
        min-height: 15% !important
    }

    .vis-mobile {
        display: block !important;
    }
}

@media screen and (max-width: 425px),(orientation: landscape) and (max-width: 768px) {
    main .programms-full-list .item a {
        height: 265px
    }

    .vis-mobile {
        display: block !important;
        text-align: center;
        margin-bottom: 20px;
    }

    .new_header {
        margin-top: 130px !important;
    }

    .ip {
        display: none !important;
    }

    ul.contacts > li:nth-child(1) {
    }
}

.informatsiya-icons {
    float: left;
    margin: 0 15px 5px 0;
    max-height: 50px
}

.form-group-label {
    color: #f90 !important
}

.form-group-input {
    float: right;
    position: relative
}

.Montserrat_style {
    font-family: Montserrat-Regular;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    letter-spacing: .03em;
    color: #fff;
    mix-blend-mode: normal
}

#Burg {
    display: block;
    background: #fff !important;
    left: 10%;
    margin-top: auto;
    margin-bottom: auto;
    width: auto;
    position: relative
}

#Rectangle {
    width: 33%;
    left: 19%;
    position: relative;
    margin: auto
}

#header_phone {
    display: block;
    margin: auto;
    padding-left: 50;
    width: 33%;
    background: #fff !important;
    left: 22%;
    position: relative
}

#nav_menu {
    position: fixed;
    z-index: 9999;
    display: none;
    background: url(/local/templates/main/css/../images/background2.jpg) center top repeat-y;
    top: 51px;
    left: 0
}

.without-before li::before {
    content: none
}

.without-before .zayavka-button {
    max-width: 300px;
    margin: 0 auto
}

.new-item-master {
    display: flex;
    align-items: flex-start
}

@media (max-width: 768px) {
    .without-before .zayavka-button {
        width: 100%;
        max-width: none
    }

    main .submenu ul li a.order-button {
        font-size: 100%
    }

    .cashback {
        padding-left: 15px;
    }
}

@media (max-width: 1000px) {
    main .images-list li {
        width: calc(50% - 7px)
    }

    aside.main-page {
        margin-top: 0px !important;
    }
}

.submenu .reviews {
    font-size: 34px;
    color: #fff;
    font-family: Caption;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0
}

.width-100 {
    width: 100%;
!important;
}

@media (max-width: 1000px) {
    aside.main-page {
        margin-top: 0px !important;
    }
}

table.docs {
    width: 100%;
    margin-bottom: 20px;
    border: 1px solid #dddddd;
    border-collapse: collapse;
}

table.docs th {
    font-weight: bold;
    padding: 5px;
    background: #efefef;
    border: 1px solid #dddddd;
    text-align: center;
}

table.docs td {
    border: 1px solid #dddddd;
    padding: 5px;
    color: #fff;
}

table.docs td p {
    color: #fff !important;
}

.contact-block .ip {
    font-weight: Bold;
    font-size: 14px;
    color: #fff;
    text-decoration: none;
    line-height: 1.1;
    text-shadow: 0 2px 1px #000;
}

.vis-mobile {
    display: none;
}

.submenu-reviews .reviews {
    font-family: Regular;
    font-size: 150%;
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    line-height: 1.2;
    text-align: Center;
}

div.button-cash a.order-button {
    font-family: Caption;
    font-size: 270%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    display: block;
    text-align: center;
    line-height: .9;
    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;
    padding: 14px 0;
    letter-spacing: .03em;
    position: relative;
    margin: 50px 0 0 0;
}

a.order-button-txt {
    font-family: Caption;
    font-size: 170%;
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;

    text-align: center;

    background: url(../images/order-bg.png) left top no-repeat;
    background-size: 100% 100%;

    letter-spacing: .03em;
    width: 200px;
}

table.school {
    width: 100%;
    margin-bottom: 20px;
    border: 1px solid #dddddd;
    border-collapse: collapse;
}

table.school th {
    font-weight: bold;
    padding: 5px;
    background: #efefef;
    border: 1px solid #dddddd;
    text-align: center;
}

table.school td {
    border: 1px solid #dddddd;
    padding: 5px;
    color: #000;
}

table.school td p {
    color: #000 !important;
}

table.online td:nth-child(3n + 1) {
    width: 3%;
}

table.online td:nth-child(3n) {
    width: 97% !important;
}

.run-line {
    display: block;
    width: 100%;
}

.run-line img {
    width: 100%;
}

.run-line-mobile {
    display: none;
    width: 100%;
}

.mobile-banner {
    display: none;
}

@media only screen and (max-width: 450px) {
    main .request form .form-group label {
        width: 95%;
    }

    .form-group-input {

        right: -10px;
    }
}

@media only screen and (max-width: 768px) {
    .table-school {
        overflow: scroll;
    }

    table.school td:first-child {
        position: -webkit-sticky; /* for Safari */
        position: sticky;
        overflow-x: scroll;
        background: #fff;
        border-left: 1px solid #dddddd;
        left: 0;
        z-index: 1;
    }

    .submenu-reviews {
        padding-top: 30px;
    }

    table.school th {
        min-width: 25vw;
    }

    table.school {
        width: 100%;
        background: #fff;

    }

    table.school td {
        display: table-cell !important;
        width: 100%;
        overflow-x: hidden;
        z-index: 0;
    }

    .sticky-col {
        position: -webkit-sticky;
        position: sticky;
        left: 0
    }

    .run-line {
        display: none;
        width: 100%;
    }

    .run-line-mobile {
        display: block;
        width: 100%;
        margin-top: 60px;
        z-index: 500;
        position: relative;
    }

    .run-line-mobile img {
        width: 100%;
    }

    .mobile-banner {
        display: block;
        margin-top: 20px;
    }
}

.all-program {
    width: 100%;
    margin-top: 20px;
    max-width: 365px;
}

.all-program .new_btn_a {
    /*width: 30% !important;*/
}

.tourism {
    width: 100%;
    text-align: center;
}

.tourism img {
    width: 30%;
}

@media (max-width: 767px) {
    .all-program .new_btn_a {
        width: 100% !important;
    }
}
