@media screen and (max-width: 1400px) {
    .page { width: 1100px; }



    .submit .button { margin-top: 20px; }
}
@media screen and (max-width: 1200px) {
    .page { width: 960px; }
    .service-bar ul li { line-height: 30px; }
    .service-bar ul li a { font-size: 14px; }
    ul.main-menu > li > a { font-size: 16px; }
    .carousel-cell { width: 25%; }


    .form_container .search-field { margin-top: 20px; }
    .form_container input.w-450px { width: 100%; margin-bottom: 20px; }
}
@media screen and (max-width: 1024px) {
    .page { width: 740px; }
    .bar-level-1 > a { padding: 5px; margin: 7px 2px; }
    a.name-site { width: 65%; }
    .name-site .logo { width: 100px; height: 100px; }
    .name-site .top-title { line-height: 26px; font-size: 20px; }
    .search-container { width: 35%; }
    .search-container .work-time { font-size: 16px; }
    .service-bar ul li { line-height:normal; padding: 5px 10px; text-align: center; }
    a.open-right-col { display: block; }
    .main-column { width: 100%; margin-right: 0; }
    .right-column { display: none; position: fixed; right: 2px; top: 15%; height: 70%; overflow: auto; background-color: var(--bg-light);
        padding-top: 20px; width: 340px; border: 1px solid var(--border-dark); z-index: 1100; }
    .right-column .col-bg-1 { background: transparent; }
    .right-column .col-bg-2 { background: transparent; }
    .right-column .col-bg-3 { background: transparent; }
    .rc-close { display: block; position: absolute; left: 10px; top: 10px; text-decoration: none; color: var(--text-main); font-size: 20px; }
    .sub-menu ul { margin: 0 0 2px 5px; }
    .sub-menu ul a { font-size: 13px; }
    .sub-menu > a { margin-bottom: 1px; padding: 0 0 1px; font-size: 14px; line-height: 28px; }
    h2.home { font-size: 32px!important; }
    h3.home { font-size: 24px; }
    .footer { font-size: 16px; }
    .footer .title { font-size: 18px; }
    .footer-menu ul li a {}
    .carousel-cell { width: 33.33%; }
    ul.schedule li { width: 50%; }
    ul.schedule li:nth-child(1), ul.schedule li:nth-child(4), ul.schedule li:nth-child(5) { background-color: var(--bg-dark); }
    ul.schedule li:nth-child(2), ul.schedule li:nth-child(3), ul.schedule li:nth-child(6) { background-color: var(--bg-page); }
    .footer-logo img { width: 130px; }



    .content h2 { font-size: 18px; }
    .content h3 { font-size: 16px; }
    ul.main-info > li ul li { margin: 0 0 7px; }
    .page-title h1, .columnHeader { font-size: 18px; }
    .main-panel { padding: 15px; }
    .dialog { padding: 0 20px; }
    .form-row input.w-300px { margin-top: 20px; }
    .form_container .search-field { width: 90%; }
    ul.partners li .img { display: block!important; margin: 0 auto 10px!important; }
    ul.partners li .info { width: 100%!important; }
    ul.masonry li { width: calc(50% - 37px); }
}
@media screen and (max-width: 768px) {
    .page { width: auto; }
    a.menu-button { display: block; }
    .name-panel { padding: 0 10px 30px; }
    .name-site .top-title { line-height: 22px; font-size: 18px; }
    .service-bar { display: none; }
    .mm-container { display: none; position: fixed; right: 2px; top: 2px; background-color: var(--bg-page); background-image: none;
        box-sizing: border-box; width: 340px; height: calc(100% - 6px); overflow: auto; padding: 10px; border: 1px solid var(--border-dark);
        z-index: 1100; }
    .mm-container.home { height: calc(100% - 6px); }
    .mm-close { display: block; position: absolute; left: 10px; top: 10px; text-decoration: none; color: var(--text-main); font-size: 20px; }
    .service-bar-640 { display: block; margin-top: 30px; }
    .service-bar-640 ul { list-style: none; margin: 0 0 20px 30px; }
    .service-bar-640 ul li { line-height: 28px; }
    .service-bar-640 ul li a { text-decoration: none; font-size: 16px; color: var(--accent-dark); }
    .service-bar-640 ul li a::before { content: "✓"; margin-right: 7px; }
    ul.main-menu { position: relative; left: auto; bottom: auto; background: none; text-align: left; }
    ul.main-menu>li { display: block; margin-bottom: 5px; }
    ul.main-menu>li>a { padding: 0 10px; font-size: 16px; line-height: 22px; }
    i.fa-angle-down { display: none; }
    ul.main-menu ul.level-2.dropd { display: block; position: relative; background: transparent; padding: 0; box-shadow: none; }
    ul.main-menu ul.level-2 { right: auto; top: auto; width: auto; margin-left: 20px; }
    ul.main-menu ul.level-2.dropd li { margin-bottom: 5px; }
    ul.main-menu ul.level-2.dropd li a { padding: 0; }
    ul.main-menu ul.level-2.dropd li a:hover { background: transparent; color: var(--accent-dark); }
    a.mm-current, ul.dropd li a.dd-current { background: transparent; color: var(--text-main); }
    .branchLine { margin: 0; padding: 10px 10px; }
    a.open-right-col { right: 3px; }
    ul.page_menu { margin-left: 10px; }
    .actual_info { padding: 20px 10px; }
    .actual_info .flex { display: block; }
    .actual_info p { margin-bottom: 10px; }
    .news-list-container > .news-list-column { width: 50%; }
    ul.news-list li { margin-bottom: 10px; }
    ul.news-list-1 { margin: 30px 10px; }
    ul.news-list-1 li.news-2 { width: calc(50% - 5px); }
    ul.news-list-1 li.news-3 { width: calc(33% - 5px); }
    ul.news-list-1 li.news-4 { width: calc(50% - 5px); }
    ul.news-list-2 { margin: 0 10px; }
    ul.news-list-2 li.news-4 { width: calc(50% - 5px); }
    img.news-left, img.news-right { margin: 10px auto; float: none; display: block; }
    .carousel-cell { width: 50%; }
    .footer { font-size: 14px; padding: 40px 10px 10px; }




/*
ul.main-menu ul.level-2 { right: 10px; top: 40px; width: 300px; text-align: left; }
ul.main-menu ul.level-2>li>a { font-size: 16px; }
ul.dropd { display: none; list-style: none; position: absolute; background: var(--bg-dark); padding: 10px 0;
    box-shadow: 2px 2px 10px 0 #666; opacity: .93; z-index: 10; }
ul.dropd li a { color: var(--text-main); display: block; padding: 3px 10px; text-decoration: none; font-weight: bold; }
ul.dropd li a:hover, ul.dropd li a.dd-current { background: var(--bg-top); color: var(--text-top); }
    .content ul { margin-right: 16px; }
*/

    .logo-top { margin-right: 10px; }
    ul.service-bar { top: -18px; }
    ul.service-bar li { margin: 0 3px -15px; border: 1px solid #fecc19; padding: 1px 4px; }
    ul.service-bar li a { margin-right: 5px; font-size: 10px; line-height: 17px; }
    ul.service-bar li a span { margin-right: 5px; }
    ul.main-info { display: block!important; padding: 10px 0!important; }
    ul.main-info > li { display: block!important; margin: 10px!important; }
    .home-panel { padding: 10px 20px!important; }
    .form-footer { display: block; }
    .form-footer .button { margin-top: 20px; }
    .dialog-container { width: 50%; }
    .comment { padding: 10px 50px; }
}
@media screen and (max-width: 640px) {
    html { font: 16px/20px 'Open Sans', sans-serif; }
    ul.social-ico li { margin: 4px 4px; }
    ul.social-ico li a { display: block; font-size: 12px; color: var(--bg-top); background-color: var(--text-top);
        padding: 2px 1px; width: 19px; line-height: 16px; }
    .bar-level-1 > a { font-size: 10px; color: var(--bg-top); background: var(--text-top); padding: 2px 5px; margin: 2px 0; border-radius: 3px;
        line-height: normal; }
    .bar-level-1 > a:hover { color: var(--text-top); background: var(--accent); }
    .bar ul { left: -45px; right: auto; top: 22px; padding: 5px 0; }
    .bar ul li a { font-size: 14px; padding: 2px 5px; }
    .bar ul.contact-bar li { width: 240px; }
    a.login { font-size: 11px; color: var(--text-top); background: var(--accent); padding: 2px 5px; margin: 2px 0; border-radius: 3px; }
    a.login:hover { color: var(--bg-top); background: var(--text-top); }
    a.menu-button { font-size: 24px; margin: 5px 10px 0 0; }
    .name-panel { margin-top: 35px; }
    .name-panel > .flex { display: block; }
    a.name-site { width: 100%; margin-top: 20px; }
    .name-site .logo { width: 80px; height: 80px; }
    .name-site .top-title { line-height: 20px; font-size: 16px; }
    .search-container { width: 100%; margin-top: 20px; }
    .search-container .search input { font-size: 18px; line-height: 28px; width: calc(100% - 38px); }
    .search-container .search button.fa-search { font-size: 18px; width: 28px; height: 28px; }
    .search-container .work-time { margin-top: 10px; text-align: right; font-size: 14px; }
    ul.page_menu { flex-wrap: wrap; margin: 20px 10px 15px; }
    ul.page_menu li { margin-bottom: 5px; }
    ul.news-list-1 li.news-3 { width: calc(50% - 5px); }
    ul.news-list-2 li.news-3 { width: calc(50% - 5px); }
    ul.schedule li { width: 100%; }
    ul.schedule li:nth-child(1), ul.schedule li:nth-child(3), ul.schedule li:nth-child(5) { background-color: var(--bg-dark); }
    ul.schedule li:nth-child(2), ul.schedule li:nth-child(4), ul.schedule li:nth-child(6) { background-color: var(--bg-page); }
    .footer { padding: 20px 10px 10px; }
    .footer-part { display: block; }
    .footer-menu ul { margin-bottom: 10px; }
    .footer-logo { margin-right: 0; text-align: center; }
    .footer-logo img { width: 110px; }
    .copyright { line-height: normal; }



    a.login { margin: 4px; padding: 2px 10px; }
    .logo-top { margin-right: 5px; background-size: contain; width: 48px; height: 44px; }
    .flickity-page-dots .dot { margin: 0 5px; }
    .hide-640 { display: none!important; }
    .content h2 { font-size: 16px; }
    .content h3 { font-size: 14px; }
    ul.service-bar { list-style: none; position: relative; top: 0; }
    ul.service-bar li { display: block; margin: 0 0 5px; width: 270px; box-shadow: none; }
    ul.service-bar li a { text-align: left; font-size: 12px; line-height: 20px; }
    ul.service-bar li a:hover { color: #2f7553; }
    .menu-container { margin-top: 20px; padding-top: 10px; border-top: 1px solid #fecc19; }
    .menu-container .title, .menu-container .columnHeader { color: #5BB0B1; font-size: 18px; margin: 0 0 10px 30px; padding: 0;
        font-weight: normal; text-transform: none; }
    /*
    .side-bar { display: none; }
    .side-bar .col-panel-content { box-shadow: none; margin-right: 0; padding: 0; border-radius: 0; }
    .side-bar .sub-menu a { color: #ffcd05; font-size: 14px; }
    .side-bar .sub-menu a:hover, .side-bar .sub-menu a.sm-current { color: #fff; background: transparent; font-weight: normal; }
    .side-bar .sub-menu ul { list-style: none; margin: 0 0 5px 10px; }
    .side-bar .sub-menu ul li a { font-size: .9em; }
    */
    .dialog label { display: block; }
    .dialog-container { width: 60%; text-align: center; }
    .dialog label { width: 100%; margin-right: 0; text-align: center; }
    .dialog input[type="text"], .dialog input[type="password"] { width: calc(80% - 2px); }
    .form-row input.w-300px { width: 250px; }
    ul.pagination li.page-item { margin: 10px 5px; }
    .comment { padding: 10px; }
    .comment .date-in { font-size: 12px; }
    .comment .title { width: 80px; }
    .comment .note { font-size: 14px; margin-left: 90px; }
    ul.masonry { margin-left: 10px; }
    ul.masonry li { width: calc(100% - 42px); }
}
@media screen and (max-width: 480px) {
    .news-list-container { display: block; }
    .news-list-container > .news-list-column { width: 100%; }
    ul.news-list-1 li.news-2 { width: 100%; }
    ul.news-list-1 li.news-3 { width: 100%; }
    ul.news-list-1 li.news-4 { width: 100%; }
    ul.news-list-2 li.news-1 { width: 100%; }
    ul.news-list-2 li.news-2 { width: 100%; }
    ul.news-list-2 li.news-3 { width: 100%; }
    ul.news-list-2 li.news-4 { width: 100%; }
    .carousel-cell { width: 100%; }
}
@media screen and (max-width: 360px) {
    .videodetector { width: 100%; }
    .footer .logo-container { float: none; width: 100%; text-align: center; }
    .footer-container { padding: 30px; margin-right: 0; }
    .footer-container a { font-size: 12px; }
    .dialog input[type="text"], .dialog input[type="password"] { width: calc(100% - 2px); }
    .dialog-container { width: 80%; }
    .form-row input.w-300px { width: 100%; }
    .comment .note { margin-left: 0; }
    .comment .title { margin: 0 10px 20px 0; }
}
