:root {
    
    --body-color: #000;
    --body-back-color: #fff;
    --body-font-size: calc(var(--vw) * 0.8);
    --body-bigger-size: calc(var(--vw) * 1);

    --action-color: #000;
    --action-border-color: #666;
    --action-text-color: #fff;

    --scrollbar-width: 6px;
    --scrollbar-color: #333;
    
    --block-radius: calc(var(--vw) * 2.5);
    --btn-height: var(--block-radius);
    
    --header-height: var(--block-radius);
    --header-h-padding: var(--block-radius);
    
    --simple-padding: 15px;
    
    --page-h-padding: calc(var(--header-height) + var(--simple-padding));
    --page-v-padding: 70px;

    --grey-opacity: .5;

    --loader-size: 50px;

    --modal-window-back-color: #fff;
    --modal-cross-width: 25px;
    --modal-cross-margin: 15px;

    --h1-font-size: calc(var(--vw) * 1.8);
    --h2-font-size: calc(var(--vw) * 1.8);
    --h3-font-size: calc(var(--vw) * 1.1);

    --footer-aniv-image-width: 58px;

    --blue-color:  #D4DDF0;
    --red-color:   #C79587;
    --green-color: #B6C2AE;
    --yellow-color: #FCF69F;

    --red-active-color: #E31E25;

    --grey-social-color: rgb(158,158,158);

    --grey-color: #666;

    --grey-vlight-color: #f2f2f2;

    --logo-slogan-width: 128px;

    --modal-form-padding: var(--page-h-padding);
    --modal-container-margin: 60px;

    --mobile-menu-width: 450px;

    --section-block-width: calc( (100 * var(--vw) - 2 * var(--page-h-padding) - 2 * var(--simple-padding)) / 4);
    
    --footer-height: calc(var(--section-block-width) / 2);

    --fp-logo-width: calc(.54 * (100% + 2 * var(--block-radius)));/*calc(12 * var(--vw));*/


    --colored-round-height: calc(var(--body-font-size) * 1);

    --burger-menu-width: var(--block-radius);

    --mobile-menu-margin-top: calc(var(--section-block-width) / 3);
}

*::-webkit-scrollbar {
  width: var(--scrollbar-width);
}

*::-webkit-scrollbar-thumb {
  background-color: var(--scrollbar-color);
  border-radius: 5px;
}

*::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}

*::-webkit-scrollbar:horizontal {
    height: var(--scrollbar-width);
}

body {
    color: var(--body-color);
    background-color: var(--body-back-color);
    font-family: 'Comfortaa', sans-serif;
    font-optical-sizing: auto;
    font-size: var(--body-font-size);
}

img {
    pointer-events: none;
}

a, a:visited, a:active, a:hover { color: inherit; text-decoration: none; }

input:focus, select:focus, textarea:focus { outline: none; }
input { font: inherit; }

small, .small { font-size: .75em; }

.geometria {
    font-family: Geometria;
}

.one-line {
    white-space: nowrap;
    height: 1.1em;
    line-height: 1.1em;
    overflow: hidden;
    text-overflow: ellipsis;
}

.two-lines {
    height: 2.2em;
    line-height: 1.1em;
}

.abig { font-size: var(--body-bigger-size); }

header, footer, main {
    padding-left: var(--page-h-padding);
    padding-right: var(--page-h-padding);
}

header {
    height: var(--header-height);
    margin: var(--simple-padding) 0px;
    z-index: 50;
    position: relative;
}

header.index .logo-wrapper {
    display: none;
}

header.common .logo-placeholder {
    display:  none;
}

header.common .logo-wrapper {
    color: #fff;
    position: absolute;
    /*left: var(--page-h-padding);*/
    left: var(--simple-padding);
    top: calc(-1* var(--simple-padding));
    background-color: var(--red-color);
    width: var(--section-block-width);
    border-radius: 0 0 var(--block-radius) var(--block-radius);
    height: calc(2* var(--block-radius));
    display: flex;
    align-items: center;
}

header.common .logo-wrapper img {
    /*height: var(--header-height);*/
    width: 100%;
}

.as-header-logo {
    display: inline-block;
    width: 37%;
}

header:not(.index) {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    background-color: #fff;

    padding-top: var(--simple-padding);
    padding-bottom: Var(--simple-padding);
    margin: 0px;
    height: calc(var(--header-height) + 2* var(--simple-padding));

}

header:not(.index):after {
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0px;
    /*height: calc(2 * var(--simple-padding));*/
    height: calc(0.7* var(--block-radius));
    background-color: #fff;
 /*   background-image: linear-gradient(0deg, transparent, #fff 40%);*/
    width: 100%;
    transform: translateY(100%);
    z-index: -1;
}

.header-place-holder {
    height: calc(var(--header-height) + 2*var(--simple-padding));
}

footer {
    height: var(--footer-height);
    margin: var(--simple-padding) var(--page-h-padding);
    margin-bottom: var(--simple-padding);
    border-radius: var(--block-radius);
    border: 1px solid #ccc;
    padding: 0;
}

.footer_logo {
    /*height: calc(.9 * var(--header-height));*/
    width: calc(11* var(--vw));
}

footer .selected-block {
    padding: 0 var(--page-h-padding);
    width: calc(50% - 1.5* var(--simple-padding));
    z-index: 5;
    top: -1px;
    height: calc(100% + 2px);
}

footer .selected-block .maskingBack { opacity: .25; }

footer > .row {
    padding-right: calc(var(--simple-padding) / 2);
}

footer > .row > .flex:not(.selected-block) {
    width: calc(25% + .75 * var(--simple-padding));
}


h1, .h1 { font-size: var(--h1-font-size); }
h2, .h2 { font-size: var(--h2-font-size); }
h3, .h3 { font-size: var(--h3-font-size); font-weight: 200; }
h4, .h4 { font-size: var(--body-bigger-size) } 

.h3.text-left { text-align: left; }

.greyscale {filter: grayscale(1);}

.material-symbols-outlined {
    font-variation-settings:
        'FILL' 0,
        'wght' 400,
        'GRAD' 0,
        'opsz' 48
}

.zIndex5 { z-index: 5; }
.zIndex50 { z-index: 50; }

.red { color: rgb(228, 36, 29) }

.grey-back { background-color: var(--grey-vlight-color); }

.blue-back { background-color: var(--blue-color); }
.green-back { background-color: var(--green-color); }
.red-back { background-color: var(--red-color); }
.grey-back { background-color: var(--grey-vlight-color); }
.dark-grey-back { background-color: var(--grey-color); }
.yellow-back { background-color: var(--yellow-color); }

.noOverflow { overflow: hidden; }

.row.halfmargin {
    margin-left: calc(-1 * var(--simple-padding) / 2);
    margin-right: calc(-1 * var(--simple-padding) / 2);
    width: calc(4* var(--section-block-width) + 3* var(--simple-padding));
}

.colored-rounds {
    width: var(--colored-round-height);
    height: var(--colored-round-height);
    border-radius: 50%;
    position: absolute;
    top: -1px;
}

.colored-rounds + .colored-rounds { margin-left: 5px; }

.as-logo-text {
    /*margin-left: 15px;
    text-transform: uppercase;
    
    font-size: .8em;*/
    font-weight: 600;
    font-size: 1.2em;
    font-family: Geometria;
    text-rendering: geometricPrecision;
    line-height: .6em;
    color: #B3B3B3;
}

.logo-placeholder {
    width: var(--section-block-width);
}

.colored-rounds:nth-of-type(1) { left: calc(-1 * var(--colored-round-height) * 4.25 - var(--simple-padding) / 2); }
.colored-rounds:nth-of-type(2) { left: calc(-1 * var(--colored-round-height) * 3 - var(--simple-padding) / 2); }
.colored-rounds:nth-of-type(3) { left: calc(-1 * var(--colored-round-height) * 2); }

.asBlock { display: block; }

.flex.text-center {justify-content: center; text-align: center;}

.flex.vert-col {
    flex-direction: column;
    justify-content: space-between;
}

.flex.text-justify {
    justify-content: space-between;
}

.marginLeft10 { margin-left: 10px; }

.fixed-form {
    right: var(--page-h-padding);
    top: calc(var(--section-block-width) / 2 + var(--header-height) + var(--block-radius) / 2);
    height: auto;
}

.fixed-form .section-block {
    height: auto;
    margin: 0;
}

.hide-fixed-form {
    top: -30px;
    right: 0px;
}

.hide-fixed-form svg {
    width: 30px;
    height: 30px;
}

.geometria { font-family: Geometria; }

.round-btn {
    border-radius: calc(var(--btn-height) / 2);
    padding: 0 calc(var(--btn-height) / 2);
    height: var(--btn-height);
    line-height: var(--btn-height);
    text-align: center;
    cursor: pointer;
    display: inline-block;
    overflow: hidden;
    font-weight: 600;
}

.round-btn.transparent {
    border: 1px solid;
    transition: .3s ease-out;
}

.round-btn.transparent.white { color: #fff; }
.round-btn.transparent.onhover:hover { background-color: #fff; color: #333; border-color: #fff; }

.round-btn.mail-btn {
    width: var(--btn-height);
    padding: 0;
    font-size: calc( var(--btn-height) * .5 );
    /*margin-right: calc(var(--btn-height) / 2 + var(--simple-padding) / 2);*/
    margin-right: 0px;
    color: #808080;
}

header .round-btn.mail-btn {
    position: absolute;
    top: 50%;
    right: calc(var(--section-block-width) + var(--block-radius) / 2);
    transform: translate(-50%, -50%);
}

footer .round-btn.mail-btn { 
    margin-right: calc(var(--btn-height) - var(--simple-padding) / 2); 
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    left: calc(50% - 0* var(--simple-padding) / 2);
}

.blue-back.reversed {
    background-color: #fff;
}

.blue-back.reversed.mail-btn { color: #808080; }

.rounded {
    border-radius: var(--block-radius);
}

.marginTop { margin-top: var(--simple-padding); }
.marginLeft { margin-left: var(--simple-padding); }
.marginRight { margin-right: var(--simple-padding); }
.marginBottom { margin-bottom: var(--simple-padding); }

.radius-margin-right { margin-right: var(--block-radius); }

.radius-margin-left { margin-left: var(--block-radius); }

header .text-right.header-col { padding-right: 15px; }

header .text-right.header-col .row {
    margin: 0;
}

header .header-col { height: var(--block-radius); }

.section-block {
    width: var(--section-block-width);
    height: var(--section-block-width);
    padding: var(--block-radius);
    margin-left: calc(var(--simple-padding) / 2);
    margin-right: calc(var(--simple-padding) / 2);
    transition: .5s ease-out;
    overflow: hidden;
}

.section-block.double-section {
    width: calc(2 * var(--section-block-width));
}

.section-block.tripple-section {
    width: calc(3 * var(--section-block-width) + (var(--simple-padding) / 2) + var(--simple-padding) / 2);
}

.section-block.quatro-section {
    width: calc(100 * var(--vw) - 2 * var(--page-h-padding));
}

.section-block.double-row {
    height: calc(2 * var(--section-block-width));   
}

.section-block.news-preview__height { height: calc(var(--section-block-width) / 2); }

.section-block.news-preview__height_more { height: calc(var(--section-block-width) / 3 * 2); }

.section-block.swiper-container {
    padding: 0;
}

.section-block.slipped {
    width: 0;
}

.section-block .inner-section{
    transition: opacity .3s ease-out;
}

.section-block .inner-section.slipped {
    opacity: 0;
}



.section-block .section-inner-part {
    overflow: hidden;
    /*max-height: calc(var(--section-block-width) - 3* var(--block-radius) - var(--simple-padding) - 7.2em);*/
    height: calc(7* var(--vw));
    margin-top: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.section-block .section-inner-part p {
    line-height: calc(7/6* var(--vw));
    -webkit-line-clamp: 6;
    display: -webkit-box;
    -webkit-box-orient: vertical;
}

.section-block .section-inner-part .h4 { margin: 0; }

.round-padding-position {
    top: var(--block-radius);
    left: var(--block-radius);
}

.section-block .video-inline {
    width: 100%;
}

.section-inner-width {
    width: calc(var(--section-block-width) - 2 * var(--block-radius));
}

.section-inner-width-ovf {
    width: calc(var(--section-block-width) - 2 * var(--block-radius) + 3 * var(--vw));
    margin-left: calc(-1.5 * var(--vw));
    margin-right: calc(-1.5 * var(--vw));
}

.news-wrapper-width {
    width: calc(100% - var(--section-block-width) + 2 * var(--block-radius));
    padding-left: var(--block-radius);
}

.maskingBack {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center;
    background-size: var(--section-block-width);
    z-index: 0;
    background-image: url(/images/mask.png);
    opacity: .15;
}

.grey-back .maskingBack { opacity: .4; }

.row.accordeon-wrapper { margin-left: 0px; margin-right: 0px; }

.accordeon-slide {
    width: 50%;
    padding: 0 var(--simple-padding);
    padding-right: calc( var(--simple-padding) / 2 );
    height: calc(var(--section-block-width) - 1.5 * var(--simple-padding));
    transition: .3s ease-out;
}

.accordeon-slide:nth-of-type(even) {
    padding-left: calc( var(--simple-padding) / 2 );
    padding-right: var(--simple-padding);
}

.accordeon-slide .section-block {
    height: 100%;
    width: 100%;
    margin: 0;
}

.accordeon-wrapper:hover .accordeon-slide:not(:hover) {
    width: 33.335%;
    
}

.accordeon-wrapper:hover .accordeon-slide:hover {
    width: 66.665%;
}
.fp-logo {
    width: var(--fp-logo-width);
}

.round-btn .hettich-logo {
    margin-top: calc(-1* var(--block-radius) / 5);
    z-index: 5;
}

#hettich-slider,
#hettich-slider .swiper-slide {
    /*width: calc(var(--section-block-width) - 2 * var(--block-radius) + 2 * var(--simple-padding));*/
}

#hettich-slider .swiper-slide:not(.swiper-slide-active) {
    opacity: 0 !important;
}

#hettich-slider img {
    width: 100%;
}

.second-line-sub-header {
    margin: 0;
    margin-top: 2em;
}

.news-and-form-wrapper:before, .news-and-form-wrapper:after {
    content: "";
    clear: both;
    display: block;
}

.news-and-form-wrapper {
    height: calc(var(--section-block-width) / 2 + var(--simple-padding));
    transition: height .4s ease-out;
}

.news-and-form-wrapper.double {
    height: calc(var(--section-block-width) / 6 * 7 + var(--simple-padding) * 2);
}

.news-and-form-wrapper > .section-block {
    position: absolute;
}

#news_list_preview {
    top: 0;
    right: 0;
}

.double #news_list_preview { top: calc(var(--section-block-width) / 3 * 2 + var(--simple-padding)); }

.double #news_list_preview.force-top { top: 0; }

#newsSlider .swiper-slide {
    display: flex;
    align-items: center;
}

#newsSlider .swiper-pagination {
    right: 0px;
    top: 50%;
    position: absolute;
}

#newsSlider .swiper-pagination-bullet {
    background-color: #888;
}

.inner-section {
    width: 25%;
    padding: 0 calc(var(--block-radius) + var(--simple-padding));
}

.inline-form.section-block {
    padding-left: 0;
    padding-right: 0;
}

.inline-form .form-wrap {
    width: calc(100* var(--vw) - 2* var(--page-h-padding));;
}

.section-block .round-input {
    border: none;
}

textarea.round-input {
    line-height: 1.2em;
    height: calc(3.6em + var(--btn-height));
    padding: calc(var(--btn-height) / 2);
    resize: none;
}

.hide-inline-form {
    cursor: pointer;
    position: absolute;
    right: var(--block-radius);
    top: var(--block-radius);
    z-index: 500;
}

.hide-inline-form svg {
    width: 20px;
    height: 20px;
}

.round-input {
    width: 100%;
    border: 1px solid #ccc;
    height: var(--btn-height);
    border-radius: calc(var(--btn-height) /2);
    padding: 0 calc(var(--btn-height) /2);
    background-color: #fff;
}

.input-container label {
    position: absolute;
    left: calc(var(--btn-height) / 2);
    top: -1.7em;
}

.input-container + .input-container {
    margin-top: calc(3 * var(--simple-padding));
}

.footer-logo-part { width: calc(var(--section-block-width) - 2 * var(--block-radius) - 2 * var(--simple-padding)); }

.material-symbols-outlined { font-size: inherit; }
.material-symbols-outlined.thin { font-variation-settings: 'wght' 200 }

.swiper-container {
    overflow: hidden;
}

.mobile-menu-caller { 
    font-size: 35px; 
    font-variation-settings: 'FILL' 0, 'wght' 200, 'GRAD' 0, 'opsz' 48;
}

.flex.space-between { justify-content: space-between; }

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

.flex.flex-center { justify-content: center; }

.flex.flex-end { justify-content: flex-end;  }

.flex.toBottom { align-items: flex-end; }

.grey {
    opacity: var(--grey-opacity);
}

.noOuterPadding {
    margin-left: calc(-1 * var(--page-h-padding));
    margin-right: calc(-1 * var(--page-h-padding));
    width: calc(100% + 2 * var(--page-h-padding));
}

.squarePadding {
    padding: var(--page-h-padding);        
}

.underline { text-decoration: underline; }

.red-active, .red { color: var(--red-active-color); }

.very-body-text { font-size: var(--body-font-size); }

header .menuItem + .menuItem {
    margin-left: 40px;
}

header:not(.filled) .red-active { color: #fff; }

header .menuItem { z-index: 50; position: relative; }

header .menuItem .submenu {
    height: 0px;
    overflow:  hidden;
    position: absolute;
    /*background-color: rgba(0,0,0,.3);*/
    z-index: 5;
    padding: 0px 15px;
    margin-left: -15px;
    margin-right: -15px;
    left: 0;
    top: var(--header-height);
    transition: .3s ease-out;
}

header .menuItem a:not(.subMenuItem):after {
    text-decoration: none !important;
    content: "";
    transition: .3s ease-out;
    width: 0px;
    height: 0px;
    position: absolute;
    bottom: -18px;
    left: 50%;
    background-color: var(--green-color);
    border-radius: 50%;
    transform: translateX(-50%);
}

header .menuItem a.nounderline:after { display: none; }

header .menuItem a:hover:after,
header .menuItem a.active:after {
    bottom: -5px;
    width: 7px;
    height: 7px;
    background-color: var(--red-color);
}

.menuItem a,
.menuItem a:hover,
.menuItem a.active,
.menuItem a:active {
    text-decoration: none !important;
}

header .menuItem a { font-size: .9em; }

header .hasSubs {
    height: var(--header-height);
}

header .hasSubs > a { line-height: var(--header-height); }

header .menuItem.hasSubs a:after {
    bottom: calc(.5 * var(--header-height) - 0.65em);
}

header .menuItem:hover .submenu {
    height: auto;
    padding: 0px 15px 5px;
}

header.filled .submenu {
    background-color: #fff;
}

header .menuItem .submenu .subMenuItem {
    padding: 5px 0px;   
    opacity: .7;
    transition: .3s ease-out;
}

header .menuItem .submenu .subMenuItem:hover { opacity: 1; }

header .svg-social {
    fill: #fff;
    width: auto;
    height: 16px;
    margin-top: -3.5px;
}

header .menuItem span.icons { line-height: var(--header-height); }

header .svg-social.svg-mail { height: 13px; top: -3px; position: relative; }

header.filled .svg-social { fill: #000; }

footer .footer-logo{
    display: block;
    background-color: #aaa;
}

.svg-diller-1 {
    fill: #B3B3B3;
}

.svg-diller-2 {
    fill: #AEB0B2;
}

.svg-diller-3 {
    fill: #B3B3B3;
}

footer :not(.selected-block) .footer_logo {
    width: calc(12.65* var(--vw)* 0.85);
}

.footer_logo {
    width: calc(12.65* var(--vw));
}

footer .selected-block .footer_logo {
    width: calc(9.5 * var(--vw) * .85);
}

svg.optimized {
    shape-rendering:geometricPrecision; 
    text-rendering:geometricPrecision; 
    image-rendering:optimizeQuality; 
    fill-rule:evenodd; 
    clip-rule:evenodd;
}

.arrow.reversed svg {
    transform: rotate(180deg);
}

.font-normal { font-size: var(--body-font-size);  }

.subMenuItem.asBlock { display: block; }

header .menuItem .submenu.wide {
    width: 190px;
    left: auto;
    right: -2px;
    text-align: right;
}

.take-me.error {
    border-color: #e20;
}

#heightLog {
    position: fixed;
    background-color: #fff;
    padding: 10px;
    top: 0px;
    right: 0px;
    z-index: 5000;
}

/************  frick-hover-animation  ****************/

.frick-hover-animation {
    opacity: 0;
    transition: .3s ease-out;
}

.round-btn:hover .frick-hover-animation {
    opacity: 1;
}

.frick-hover-animation .shadow {
    background-color: #fff;
    opacity: 0.25;
}

/******************* MODAL ********************/
body.modal-shown {
    overflow: hidden;
    margin-right: var(--scrollbar-width);
}

.modal-window .swiper-container .absolute {
    pointer-events: initial;
}

#loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 501;
}

#loader svg {
    display: block;
    margin: auto;
    height: var(--loader-size);
}

.modal-window {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 500;
    padding: var(--page-v-padding) var(--page-h-padding);
    background-color: var(--modal-window-back-color);
}

.modal-window-inner {
    width: 100%;
    max-height: 100%;
}

.modal-window .hide-modal.cross-image {
    position: absolute;
    top: var(--page-v-padding);
    right: calc(var(--page-h-padding) - var(--modal-cross-margin) - var(--modal-cross-width));
    z-index: 500;
}

.modal-window .hide-modal.cross-image svg { width: var(--modal-cross-width); }

/**************** MODAL FORMS *****************/

.modal-form-container {
    position: fixed;
    padding: var(--page-h-padding) var(--modal-container-margin);
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 100;
}

.modal-form-container .shadow {
    background-color: var(--grey-social-color);
    opacity: .8;
}

.modal-form-container .wrapper {
    padding: var(--modal-form-padding);
    background-color: #fff;
}

.hide-modal-form { padding: 20px; fill: var(--grey-light-color); }

.hide-modal-form svg { height: 20px; width: 20px; }

.btInput:focus { outline: none; }

.btInput {
    height: 35px;
    line-height: 35px;
    padding: 0 10px;
    border:  1px solid var(--grey-light-color);
}

textarea.btInput {
    height: 105px;
    resize: vertical;
}

.btCheckbox + label {
    height: 35px;
    width: 35px;
    border: 1px solid var(--grey-light-color);
    margin: 0px 10px 0px 0px;
    position: relative;
}

.btCheckbox + label:before,
.btCheckbox + label:after {
    content: '';
    position: absolute;
    height: 1px;
    width: 30px;
    visibility: hidden;
    display: inline-block;
    background-color: var(--grey-social-color);
    top: 16px;
    left: 2px;
    z-index: 4;
    transform-origin: center;
}

.btCheckbox + label:before {
    transform: rotate(45deg);
}

.btCheckbox + label:after {
    transform: rotate(-45deg);
}

.btCheckbox:checked + label:before,
.btCheckbox:checked + label:after { visibility: visible; }

.contacts-input.error {
    border-color: var(--red-active-color);
}

.send-form-btn {
    height: 35px;
    line-height: 35px;
    background-color: var(--grey-vlight-color);    
    cursor: pointer;
    display: inline-block;
    padding: 0 45px;
}

img.nav-arrow {
    width: 100px;
}

img.nav-arrow.reversed {
    transform: rotate(180deg);
}

/******************* /MODAL *******************/

#mobileMenu {
    z-index: 500;
    /*
    background-color: rgba(0, 0, 0, .75);
    color: #fff;
    */
    background-color: #fff;
    color: #000;
    height: 100%;
    padding: var(--mobile-menu-margin-top) calc(var(--page-h-padding) + var(--block-radius)) 30px;
    width: 100%;
    left: 0;
    top: 0;
    transition: .3s ease-out;
}

#mobileMenu footer {
    position: absolute;
    bottom: calc(var(--block-radius) - var(--simple-padding));
    left: 0;
    width: calc(100% - 2 * var(--page-h-padding));
    border: none;
}

#mobileMenu.shown {
    left: 0px;
}

#mobileMenu .mobile-menu-hider:not(.round-btn) {
    padding: calc(var(--block-radius) / 2) calc(var(--page-h-padding) + var(--block-radius));
    z-index: 100;
}

#mobileMenu .mobile-menu-hider svg {
    width: 20px;
    height: 20px;
    /*
    fill: #fff;
    */
    fill: #000;
}

#mobileMenu .menuItem { margin-bottom: 7px; }

#mobileMenu .submenu .subMenuItem {
    display: block;
    margin: 7px 0px 0px;
    font-size: 13px;
    text-transform: uppercase;
}

.menuItem.abig, .menuItem .abig {
    font-size: 15px;
}

header .menuItem .submenu .subMenuItem.abig {
    font-size: var(--body-bigger-size);
}

#mobileMenu .menuItem.abig, 
#mobileMenu .menuItem .abig {
    /*font-size: 18px;*/
    font-size: var(--h2-font-size);
    margin-bottom: 0.6em;
}

#mobileMenu #footer-logo-slider { display: none;  }

#mobileMenu .icons svg {
    fill: #fff;
    width: 22px;
    height: 22px;
    top: 3px;
    position: relative;
}

#mob-menu__form-caller {
    /*height: var(--footer-height);*/
    height: calc(var(--section-block-width) / 4);
    bottom: calc(var(--section-block-width) / 4 + 30px)/*30px*/;
    left: 2px;/* var(--page-h-padding);*/
    position: absolute;
}

#mobileMenu footer .selected-block {
    width: calc(68% - 2.5* var(--simple-padding));
    margin-left: var(--simple-padding);
}

header.filled + #mobileMenu * {
    fill: var(--body-color);
    color: var(--body-color);
}

header.filled + #mobileMenu { background-color: #fff; }

/*********************************************/


.burger-menu {
    display: flex;
    width: var(--burger-menu-width);
    flex-direction: column;
    justify-content: space-between;
    height: 15px;
    margin-top: 3px;
}

.burger-menu .line {
    width: 100%;
    height: 1px;
    background-color: #333;
}

footer .swiper-slide.flex {
    display: flex;
}


footer .round-btn.mail-btn { 
    left: calc(50% - 1* var(--simple-padding) / 2);
}

#loaderContainer .maskingBack {
    opacity: 1;
    background-image: url('/img/staf.png');
}

#loaderContainer {
    z-index: 5000;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: #fff;
}

#loaderContainer .wrapper {
    width: 200px;
    height: 200px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1.2);
    /*border: 1px solid #ccc;*/
}

#loaderContainer .text {
    font-weight: 700;
    font-family: 'Geometria';
    transform: translate(-50%, -50%);
    font-size: 60px;
    /*mix-blend-mode: difference;*/
    z-index: 30;
    top: 50%;
    left: 50%;
    color: #fff;
    opacity: .8;
}

#loaderContainer .load-bubble {
    /*
    width: 99px;
    height: 99px;
    */
    aspect-ratio: 1 / 1;
    border-radius: 15px;
    top: 50%;
    left: 50%;
    transition: .9s ease-in;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

#loaderContainer .load-bubble.first {
    transform: translate(-102%, -102%);
    width: 70px;
    /*background-color: red;*/
}

#loaderContainer .load-bubble.first.done { width: 90px; }
#loaderContainer .load-bubble.first.animate { animation: bubble_1 3.5s ease-out 0s; }

#loaderContainer .load-bubble.second {
    transform: translate(2%, -102%);
    width: 60px;
    /*background-color: green;*/
}

#loaderContainer .load-bubble.second.animate { animation: bubble_2 3.5s ease-out 0s; }
#loaderContainer .load-bubble.second.done { width: 85px; }

#loaderContainer .load-bubble.third {
    transform: translate(2%, 2%);
    width: 75px;
    /*background-color: blue;*/
}
#loaderContainer .load-bubble.third.done { width: 80px; }
#loaderContainer .load-bubble.third.animate { animation: bubble_3 3.5s ease-out 0s; }

#loaderContainer .load-bubble.fourth {
    transform: translate(-102%, 2%);
    width: 55px;
    /*background-color: pink;*/
}
#loaderContainer .load-bubble.fourth.done { width: 85px; }
#loaderContainer .load-bubble.fourth.animate { animation: bubble_4 3.5s ease-out 0s; }

/***************** ANIMATION ****************/

@keyframes bubble_1 {
  0%   {
        width: 70px;
        background-image: url('/loader/01.jpg');
  }
  33%   {
        width: 90px;
        background-image: url('/loader/02.jpg');
  }
  66%   {
        width: 80px;
        background-image: url('/loader/03.jpg');
  }
  100%   {
        width: 70px;
        background-image: url('/loader/01.jpg');
  }
}

@keyframes bubble_2 {
  0%   {
        width: 85px;
        background-image: url('/loader/04.jpg');
  }
  33%   {
        width: 75px;
        background-image: url('/loader/05.jpg');
  }
  66%   {
        width: 80px;
        background-image: url('/loader/06.jpg');
  }
  100%   {
        width: 85px;
        background-image: url('/loader/04.jpg');
  }
  
}

@keyframes bubble_3 {
  0%   {
        width: 65px;
        background-image: url('/loader/07.jpg');
  }
  33%   {
        width: 75px;
        background-image: url('/loader/08.jpg');
  }
  66%   {
        width: 60px;
        background-image: url('/loader/09.jpg');
  }
  100%   {
        width: 65px;
        background-image: url('/loader/07.jpg');
  }
}
@keyframes bubble_4 {
  0%   {
        width: 80px;
        background-image: url('/loader/10.jpg');
  }
  33%   {
        width: 70px;
        background-image: url('/loader/11.jpg');
  }
  66%   {
        width: 60px;
        background-image: url('/loader/12.jpg');
  }
  100%   {
        width: 80px;
        background-image: url('/loader/10.jpg');
  }
}

/********************************************/

@media (min-width: 1181px) {
    .header-place-holder {
        height: calc(var(--header-height) + 4*var(--simple-padding));
    }
}

@media (min-width: 601px) {
    :root {
        --footer-height: calc(0.7 * var(--section-block-width) / 2);
    }
}

@media (max-width: 1180px) and (min-width: 769px) {
    :root {
        --page-h-padding: 45px;
        --simple-padding: 10px;
        --block-radius: 40px;
        --body-font-size: 11px;
        --h3-font-size: 16px;
        --h1-font-size: 24px;
        --h2-font-size: 24px;
        --body-bigger-size: 13px;
    }

    img.nav-arrow {
        width: 75px;
    }

    .md-smaller {
        font-size: .75em;
    }

    footer .selected-block {
        width: calc(68% - 1.5* var(--simple-padding));
        padding: 0 var(--block-radius);
    }

    .round-btn.mail-btn {
        /*margin-right: calc(var(--block-radius) - 15px);*/
        margin-right: 0px;
    }

    header .round-btn.mail-btn {
        margin-right: 0px;
        right: calc(var(--section-block-width) + var(--block-radius) / 2 - 8px);
    }
}

@media (max-width: 768px) and (min-width: 601px) {
    :root {
        --page-h-padding: 35px;
        --simple-padding: 10px;
        --block-radius: 30px;
        --body-font-size: 10px;
        --h3-font-size: 14px;
        --h1-font-size: 18px;
        --h2-font-size: 18px;
        --body-bigger-size: 12px;
    }

    .sm-smaller {
        font-size: .75em;
    }

    footer .selected-block {
        width: calc(68% - 1.5* var(--simple-padding));
    }

    .round-btn.mail-btn {
        /*/margin-right: calc(var(--block-radius) / 2 + 1em);*/
        /*margin-right: calc(var(--block-radius) - var(--simple-padding));*/
        margin-right: -3px;
    }

    footer .round-btn.mail-btn { 
        left: calc(50% + 1* var(--simple-padding) / 3);
    }
    
    #loaderContainer .wrapper { transform: translate(-50%, -50%); }
        
}

@media (max-width: 1180px) and (min-width: 601px) {

    .menuItem a.active {
        font-weight: 600;
        position: relative;
    }

    .menuItem a.active:before {
        content: "";
        position: absolute;
        top: 50%;
        left: -15px;
        background-color: var(--red-color);
        width: 8px;
        height: 8px;
        border-radius: 50%;
        transform: translateY(-50%);
    }

    #footer-logo-slider .swiper-slide { display: flex; }

    .hide-inline-form svg {
        width: 15px;
        height: 15px;
    }

    .md-nopadding,
    .md-nopadding.inner-section { /*padding: 0 0 0 0 !important;*/ }

    footer .selected-block {
        padding: 0 var(--block-radius);
    }

    .footer-logo-part {
        width: calc(var(--section-block-width) + 2* var(--simple-padding) - 2* var(--block-radius));
    }

    /*.footer_logo {  width: 135px; }*/

    
}

@media (max-width: 600px)  {
    :root {
        --page-h-padding: 10px;
        --body-font-size: 10px;
        --h1-font-size: 15px;
        --h2-font-size: 13px;
        --h3-font-size: 12px;
        --body-bigger-size: 10px;
        --section-block-width: calc(100 * var(--vw) - 2 * var(--page-h-padding));
        --block-radius: 20px;
        --btn-height: 30px;
    }

    #loaderContainer .wrapper { transform: translate(-50%, -50%); }

    body { overflow-x: hidden; }

    .burger-menu {
        height: 9px;
    }

    main {
        width: calc(100 * var(--vw));
    }

    main *, header *, footer * {
        max-width: calc(100 * var(--vw));
    }

    .white-back {
        background-color: #fff;
        color: #000;
    }

    .xs-nopadding { padding: 0; }

    .xs-upper { text-transform: uppercase; }
    .no-margin-xs { margin: 0; } 
    .text-center-xs { 
        text-align: center; 
        align-items: center;
        justify-content: center;
    }
    .xs-margin-top {
        margin-top: calc(var(--simple-padding) / 2);
    }
    .marginTop {
        margin-top: calc(var(--simple-padding) / 2);
    }
    .no-flow-xs { float: none; }

    .flex.xs-column { flex-direction: column;  }

    .asThree {
        height: calc(var(--section-block-width) / 4);
    }

    .xs-button-width {
        width: calc(var(--section-block-width) / 2 - 2 * var(--block-radius));
    }

    .xs-button-width2 {
        width: calc(1.15 * (var(--section-block-width) / 2 - 2 * var(--block-radius)));
    }

    #mobileMenu footer {
        width: calc(100vw - 2 * var(--page-h-padding));
    }
    
    #mobileMenu footer .selected-block {
        width: calc(100% - 1.5 * var(--simple-padding));
    }

    footer { 
        margin-top: calc(var(--simple-padding) / 2); 
        height: calc(var(--section-block-width) / 4);
        border: none;
    }

    footer .selected-block {
        width: calc(100* var(--vw) - 2* var(--page-h-padding));
        padding: 0 var(--block-radius) 0 calc(2* var(--block-radius));
        margin-left: 15px;
        opacity: .7;
    }

    footer .selected-block .footer_logo,
    footer .selected-block .call__form {
        /*width: calc(( (100* var(--vw) - 2* var(--page-h-padding)) - 2 * var(--simple-padding) - var(--block-radius))/2 - 2px - var(--simple-padding));*/
        width: calc(var(--section-block-width) / 2 - 2 * var(--block-radius));
    }

    footer .selected-block .mail-btn {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    footer .selected-block .round-btn:not(.mail-btn) {
        width: calc(var(--section-block-width) / 2 - 2* var(--block-radius) - var(--simple-padding) / 2);
        padding: 0px;
    }

    footer .footer-logo-part img {
        width: 96px !important;
    }

    .footer-logo-part { width: auto; }

    .maskingBack { background-size: calc(var(--section-block-width) / 2); }

    .hide-inline-form svg { width: 15px; height: 15px; }

    .slipped { z-index: -5; }

    #mobileMenu .menuItem.abig {
        font-size: calc(3 *var(--vh));
        text-align: center;
    }

    #mobileMenu .mobile-menu-hider:not(.round-btn) {
        padding: calc(var(--block-radius) / 2) 0;
        left: 50%;
        transform: translateX(-50%);
    }

}

@media (max-width: 1100px){
    .cursor {
        display: none !important;
    }
}