/*===============================================================================
	FONTS
===============================================================================*/

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-Light.eot');
    src: local('Bison Light'), local('Bison-Light'),
        url('../fonts/Bison-Light.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-Light.woff2') format('woff2'),
        url('../fonts/Bison-Light.woff') format('woff'),
        url('../fonts/Bison-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-DemiBold.eot');
    src: local('Bison Demi Bold'), local('Bison-DemiBold'),
        url('../fonts/Bison-DemiBold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-DemiBold.woff2') format('woff2'),
        url('../fonts/Bison-DemiBold.woff') format('woff'),
        url('../fonts/Bison-DemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-DemiBoldItallic.eot');
    src: local('Bison Demi Bold Itallic'), local('Bison-DemiBoldItallic'),
        url('../fonts/Bison-DemiBoldItallic.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-DemiBoldItallic.woff2') format('woff2'),
        url('../fonts/Bison-DemiBoldItallic.woff') format('woff'),
        url('../fonts/Bison-DemiBoldItallic.ttf') format('truetype');
    font-weight: 600;
    font-style: italic;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-Bold.eot');
    src: local('Bison Bold'), local('Bison-Bold'),
        url('../fonts/Bison-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-Bold.woff2') format('woff2'),
        url('../fonts/Bison-Bold.woff') format('woff'),
        url('../fonts/Bison-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-BoldItallic.eot');
    src: local('Bison Bold Itallic'), local('Bison-BoldItallic'),
        url('../fonts/Bison-BoldItallic.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-BoldItallic.woff2') format('woff2'),
        url('../fonts/Bison-BoldItallic.woff') format('woff'),
        url('../fonts/Bison-BoldItallic.ttf') format('truetype');
    font-weight: bold;
    font-style: italic;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-RegularItalic.eot');
    src: local('Bison Italic'), local('Bison-RegularItalic'),
        url('../fonts/Bison-RegularItalic.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-RegularItalic.woff2') format('woff2'),
        url('../fonts/Bison-RegularItalic.woff') format('woff'),
        url('../fonts/Bison-RegularItalic.ttf') format('truetype');
    font-weight: normal;
    font-style: italic;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-LightItalic.eot');
    src: local('Bison Light Italic'), local('Bison-LightItalic'),
        url('../fonts/Bison-LightItalic.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-LightItalic.woff2') format('woff2'),
        url('../fonts/Bison-LightItalic.woff') format('woff'),
        url('../fonts/Bison-LightItalic.ttf') format('truetype');
    font-weight: 300;
    font-style: italic;
}

@font-face {
    font-family: 'Bison';
    src: url('../fonts/Bison-Regular.eot');
    src: local('Bison'), local('Bison-Regular'),
        url('../fonts/Bison-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Bison-Regular.woff2') format('woff2'),
        url('../fonts/Bison-Regular.woff') format('woff'),
        url('../fonts/Bison-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}



/*===============================================================================
	PRELOADER
===============================================================================*/

#page-preloader {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: #000000;
    background-size: cover;
    z-index: 999999;
    overflow: hidden;
    width: 100vw;
    height: 100vh;
}

.contpre {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background-size: contain;
}

.spinner {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    -webkit-animation: spin 1s linear infinite;
    -moz-animation: spin 1s linear infinite;
    animation: spin 1s linear infinite;
}

@-moz-keyframes spin {
    100% {
        -moz-transform: rotate(360deg);
    }
}

@-webkit-keyframes spin {
    100% {
        -webkit-transform: rotate(360deg);
    }
}

@keyframes spin {
    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}



/*===============================================================================
	BODY
===============================================================================*/

:root {
    --global-color: #75AFE8;
    --global-color1: #000000;
    --global-color2: #FFFFFF;
    --global-heading-color: #000000;
    --global-text-color: #000000;
    --main-menu-color: #191919;
    --header-bg: #F5F5F5;
    --border-color: #BCBCBC;
    --placeholder-color: #787878;
    --body-background-color: #F5F5F5;
    --swiper-navigation-size: 25px;
    --clip1: polygon(0 0, 0 0, 0 100%, 0 100%);
    --clip2: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    --clip3: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
    --clip4: polygon(100% 0, 0 0, 0 100%, 100% 100%);
}

body {
    line-height: 28px;
    font-family: 'Arial', sans-serif;
    font-size: 16px;
    font-weight: normal;
    color: var(--global-text-color);
    background: var(--body-background-color);
    overflow-X: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

h1 {
    font-family: 'Bison', sans-serif;
    font-size: 48px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-color);
}

h2 {
    font-family: 'Bison', sans-serif;
    font-size: 48px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-heading-color);
}

h3 {
    font-family: 'Bison', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 36px;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-heading-color);
}

h4 {
    font-family: 'Bison', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 24px;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-heading-color);
}

h5 {
    font-family: 'Bison', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 20px;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-heading-color);
}

h6 {
    font-family: 'Bison', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 18px;
    line-height: normal;
    margin-bottom: 20px;
    color: var(--global-heading-color);
}

[class^="hvr-"] {
    margin: .4em;
    padding: 1em;
    cursor: pointer;
    background: #e1e1e1;
    text-decoration: none;
    color: #666;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.hvr-underline-from-left {
    display: inline-block;
    vertical-align: middle;
    -webkit-transform: perspective(1px) translateZ(0);
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    position: relative;
    overflow: hidden;
}

.hvr-underline-from-left:before {
    content: "";
    position: absolute;
    z-index: -1;
    left: 0;
    right: 100%;
    bottom: 0;
    background: var(--global-color);
    height: 2px;
    -webkit-transition-property: right;
    transition-property: right;
    -webkit-transition-duration: 0.4s;
    transition-duration: 0.4s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
}

.hvr-underline-from-left:hover:before,
.hvr-underline-from-left:focus:before,
.hvr-underline-from-left:active:before {
    right: 0;
}

/* Ripple Out */
@-webkit-keyframes hvr-ripple-out {
    100% {
        top: -12px;
        right: -12px;
        bottom: -12px;
        left: -12px;
        opacity: 0;
    }
}

@keyframes hvr-ripple-out {
    100% {
        top: -12px;
        right: -12px;
        bottom: -12px;
        left: -12px;
        opacity: 0;
    }
}

.hvr-ripple-out {
    display: inline-block;
    vertical-align: middle;
    -webkit-transform: perspective(1px) translateZ(0);
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    position: relative;
}

.hvr-ripple-out:before {
    content: '';
    position: absolute;
    border: var(--global-color) solid 1px;
    border-radius: 0;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
}

.hvr-ripple-out:hover:before,
.hvr-ripple-out:focus:before,
.hvr-ripple-out:active:before {
    -webkit-animation-name: hvr-ripple-out;
    animation-name: hvr-ripple-out;
}

a {
    color: var(--global-color);
}

a:hover {
    color: var(--global-color);
}



/*===============================================================================
	CHECKBOX
===============================================================================*/

.checkbox {
    margin-bottom: 0;
}

.checkbox input {
    position: absolute;
    z-index: -1;
    opacity: 0;
    margin: 6px 0 0 3px;
}

.checkbox_text {
    display: inline-block;
    position: relative;
    padding: 0 0 0 30px;
    cursor: pointer;
    color: #C8C8C8;
    font-family: 'Arial', sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    line-height: 24px;
}

.checkbox_text:before {
    content: '';
    position: absolute;
    top: calc(50% - 14px/2);
    left: 0;
    width: 14px;
    height: 14px;
    border-radius: 3px;
    background: transparent;
    transition: .2s;
    border: 1px solid var(--border-color);
}

.checkbox_text:after {
    content: '\2713';
    position: absolute;
    top: calc(50% - 11px);
    left: 2px;
    width: auto;
    height: auto;
    border-radius: 0;
    font-size: 14px;
    background: transparent;
    color: #fff;
    transition: .2s;
    opacity: 0;
}

.checkbox input:checked+.checkbox_text:before {
    background: var(--global-color);
    border-color: var(--global-color);
}

.checkbox input:checked+.checkbox_text:after {
    opacity: 1;
}

/* i-os */

.checkbox-ios {
    display: inline-block;
    height: 40px;
    line-height: 40px;
    margin-right: 10px;
    position: relative;
    vertical-align: middle;
    font-size: 14px;
    user-select: none;
}

.checkbox-ios .checkbox-ios-switch {
    position: relative;
    display: inline-block;
    box-sizing: border-box;
    width: 77px;
    height: 40px;
    border: 1px solid rgba(0, 0, 0, .1);
    border-radius: 25%/50%;
    vertical-align: top;
    background: #fff;
    transition: .2s;
}

.checkbox-ios .checkbox-ios-switch:before {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    display: inline-block;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #BBCADA;
    transition: .15s;
}

.checkbox-ios input[type=checkbox] {
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    z-index: -1;
    opacity: 0;
}

.checkbox-ios input[type=checkbox]:checked+.checkbox-ios-switch {
    background: var(--global-color);
}

.checkbox-ios input[type=checkbox]:checked+.checkbox-ios-switch:before {
    transform: translateX(37px);
    background: #fff;
}

/* Hover */
.checkbox-ios input[type="checkbox"]:not(:disabled)+.checkbox-ios-switch {
    cursor: pointer;
    border-color: rgba(0, 0, 0, .3);
}

/* Disabled */
.checkbox-ios input[type=checkbox]:disabled+.checkbox-ios-switch {
    filter: grayscale(70%);
    border-color: rgba(0, 0, 0, .1);
}

.checkbox-ios input[type=checkbox]:disabled+.checkbox-ios-switch:before {
    background: #eee;
}

/* Focus */
.checkbox-ios.focused .checkbox-ios-switch:before {
    box-shadow: inset 0px 0px 4px #ff5623;
}



/*===============================================================================
	RADIO
===============================================================================*/

.radio {
    position: absolute;
    z-index: -1;
    opacity: 0;
    margin: 10px 0 0 7px;
}

.radio+label {
    position: relative;
    padding: 0 0 0 35px;
    cursor: pointer;
    font-weight: bold;
    font-size: 15px;
    display: inline;
}

.radio+label:before {
    content: '';
    position: absolute;
    top: -1px;
    left: 0px;
    width: 22px;
    height: 22px;
    border: 2px solid var(--border-color);
    border-radius: 50%;
    background: #FFF;
}

.radio+label:after {
    content: '';
    position: absolute;
    top: 4px;
    left: 5px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--global-color);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, .5);
    opacity: 0;
    transition: .2s;
}

.radio:checked+label:after {
    opacity: 1;
}

.radio:checked+label:before {
    border-color: var(--global-color);
}



/*===============================================================================
	Form
===============================================================================*/

.form_group {
    position: relative;
    margin-bottom: 20px;
}

.form-label {
    color: var(--global-color);
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
    margin-bottom: 0;
}

.label_gray {
    color: #787878;
}

.form-control {
    display: block;
    width: 100%;
    font-family: 'Arial';
    font-style: normal;
    font-weight: 400;
    font-size: 16px !important;
    line-height: 22.4px;
    color: #C7C7C9;
    height: 30px;
    padding: 0;
    background-color: transparent;
    border: 0;
    border-bottom: 1px solid var(--global-color);
    border-radius: 0;
}

.form-control:focus {
    color: #C7C7C9;
    background-color: transparent;
    border-color: var(--global-color);
    outline: 0;
    box-shadow: none;
    caret-color: var(--global-color);
}

.form-control:disabled,
.form-control[readonly] {
    background-color: gray;
    color: #fff;
}

.effect::-webkit-input-placeholder {
    color: var(--placeholder-color);
    opacity: 1;
    transition: opacity 0.3s ease;
}

.effect::-moz-placeholder {
    color: var(--placeholder-color);
    opacity: 1;
    transition: opacity 0.3s ease;
}

.effect:-moz-placeholder {
    color: var(--placeholder-color);
    opacity: 1;
    transition: opacity 0.3s ease;
}

.effect:-ms-input-placeholder {
    color: var(--placeholder-color);
    opacity: 1;
    transition: opacity 0.3s ease;
}

.effect:focus::-webkit-input-placeholder {
    color: var(--placeholder-color);
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

.effect:focus::-moz-placeholder {
    color: var(--placeholder-color);
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

.effect:focus:-moz-placeholder {
    color: var(--placeholder-color);
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

.effect:focus:-ms-input-placeholder {
    color: var(--placeholder-color);
    opacity: 0.3;
    transition: opacity 0.3s ease;
}

textarea {
    resize: none;
}

.trainer_contactform textarea {
    height: 45px;
    padding: 0;
}

.popover {
    z-index: 999999;
}

.popover-body {
    font-family: 'Arial';
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    line-height: 16px;
    padding: 5px 10px;
}

/*----Validate input-----*/

.form-control.is-invalid~.invalid-feedback,
.form-control.is-valid~.valid-feedback {
    position: absolute;
    display: flex;
    align-items: center;
    margin-top: 0;
}

.invalid-feedback .message_text,
.valid-feedback .message_text {
    font-weight: normal;
    font-size: 10px;
    line-height: 14px;
    margin-bottom: 0;
    margin-left: 5px;
}

.form-control.is-invalid:focus,
.was-validated .form-control:invalid:focus,
.form-control.is-valid:focus,
.was-validated .form-control:valid:focus {
    box-shadow: none;
}



/*===============================================================================
	Select2
===============================================================================*/

.select2-container .select2-selection--single {
    font-family: 'Arial';
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    height: 45px;
    border: 0;
    border-bottom: 1px solid var(--global-color);
    border-radius: 0;
    outline: none;
    background: transparent;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    padding-left: 0;
    padding-right: 40px;
    line-height: 43px;
    color: #C7C7C9;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 43px;
    top: 0;
    right: 0;
    width: 0;
}

.select2-dropdown,
.select2-container--default .select2-search--dropdown .select2-search__field {
    border: 1px solid var(--border-color);
    border-radius: 0;
    z-index: 999999;
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background-color: var(--global-color);
    color: #fff;
}

.select2-container--default .select2-results__option--selected {
    background-color: lightgray;
    color: #fff;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    width: 10px;
    height: 10px;
    background-color: transparent;
    border-top: 2px solid #737375;
    border-right: 2px solid #737375;
    right: 0;
    margin-left: -15px;
    margin-top: -5px;
    transform: rotate(135deg);
    border-width: 1px;
    top: calc(50% - 2px);
}

.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
    transform: rotate(315deg);
    border-width: 1px;
    border-color: #737375 #737375 transparent transparent;
    top: calc(50% - -4px);
}

.select2-search__field {
    outline: none !important;
}

.select2-container--default .select2-results>.select2-results__options {
    max-height: 200px;
}

/* scrollbar chrome edge*/
.select2-container--default .select2-results>.select2-results__options::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

/* scrollbar firefox */
html .select2-container--default .select2-results>.select2-results__options {
    scrollbar-width: thin;
}

.select2-results__option {
    font-size: 16px;
    padding: 6px 15px;
    line-height: 24px;
}



/*===============================================================================
	Scrollbar browsers
===============================================================================*/

/* scrollbar firefox */
html {
    scrollbar-color: gray lightgrey;
    scrollbar-width: thin;
}

/*scrollbar chrome edge*/
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background-color: lightgrey;
    box-shadow: none;
}

::-webkit-scrollbar-thumb {
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .2);
    background-color: grey;
}

/* hidden scrollbar chrome edge*/
::-webkit-scrollbar {
    width: 0;
    height: 0;
}

/* hidden scrollbar firefox */
html {
    scrollbar-width: none;
}



/*===============================================================================
	Header
===============================================================================*/

header {
    background-color: var(--header-bg);
}

.navbar-brand {
    margin: 0;
}

.navbar-nav {
    display: flex;
    align-items: center;
    gap: 30px;
}

.navbar-nav .nav-item .nav-link {
    color: var(--main-menu-color);
    text-align: center;
    font-family: Bison;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.8px;
    padding-left: 0 !important;
    padding-right: 0 !important;
    transition: all .4s ease;
}

.navbar-nav .nav-item:hover .nav-link {
    color: var(--global-color);
}

.nav-item.active .nav-link {
    color: var(--global-color);
}

.mute_button {
    position: absolute;
    bottom: 30px;
    right: 50px;
    cursor: pointer;
}

.mute_button.mute_on svg path {
    stroke: var(--global-color);
}

header .btn-outline-primary {
    padding: 8px 24px;
    font-size: 16px;
}



/*===============================================================================
	Footer
===============================================================================*/

footer {
    margin-top: auto;
    padding-top: 80px;
    padding-bottom: 80px;
    background: #F5F5F5;
    overflow-x: hidden;
}

footer .block_menu {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

footer .block_menu+.block_menu {
    margin-top: 64px;
}

footer .block_menu__head {
    display: flex;
    align-items: center;
    gap: 15px;
}

footer .block_menu__head_text {
    color: #C8C8C8;
    font-family: Arial;
    font-size: 10px;
    font-style: normal;
    font-weight: 400;
    line-height: 100%;
    /* 10px */
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

footer .block_menu__head .circle {
    display: inline-flex;
    width: 10px;
    height: 10px;
    border: 1px solid #C8C8C8;
    border-radius: 50%;
    background: #C8C8C8;
    opacity: 0.2;
}

footer .block_menu__head .circle.active {
    background: var(--global-color);
    border-color: var(--global-color);
    opacity: 1;
}

footer .block_menu__list li {
    margin-bottom: 4px;
    overflow: hidden;
    position: relative;
}

footer .block_menu__list li a {
    color: #000;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 120%;
    /* 33.6px */
    letter-spacing: -0.56px;
    text-decoration: none;
    transition: all .4s ease;
}

footer .block_menu__list li a:hover {
    color: var(--global-color);
}

footer .block_menu__list.about_list li a,
footer .rules a {
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 145%;
    /* 21.75px */
}

footer .f_block {
    position: relative;
}

footer .f_logo {
    display: flex;
    justify-content: end;
}

footer.without-menu .f_logo {
    justify-content: start;
}

footer .f_top_line {
    height: 10px;
    background-color: var(--global-color);
    margin-bottom: 50px;
}

footer .contact_list li a,
footer .location_list li a {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    /* 19.6px */
    opacity: 0.75;
}

footer .location_list li {
    margin-bottom: 10px;
}

footer .location_list .loc_time {
    color: #191919;
    font-variant-numeric: lining-nums proportional-nums;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
    /* 20px */
}

footer .location_list .loc_day {
    color: #C8C8C8;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    /* 15.6px */
}

footer .f_social ul {
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 25px;
    flex-wrap: wrap;
}

footer .f_social li a {
    display: block;
}

footer .f_social li a svg,
footer .f_social li a svg path {
    transition: all .4s ease;
}

footer .f_social li a:hover svg {
    transform: scale(1.2);
}

footer .f_social li a.fill:hover svg path {
    fill: var(--global-color);
}

footer .f_social li a.stroke:hover svg path {
    stroke: var(--global-color);
}

footer .footer_bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 150px;
}

footer .footer_bottom ul {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 0;
}

footer .footer_bottom ul li a {
    text-decoration: none;
}

footer .footer_bottom .copyright,
footer .footer_bottom .info_pages_list a,
footer .footer_bottom .lang a,
footer .footer_bottom .by a {
    color: #C8C8C8;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    /* 15.6px */
    transition: all .4s ease;
    text-decoration: none;
}

footer .footer_bottom .info_pages_list a:hover,
footer .footer_bottom .lang a.current,
footer .footer_bottom .by a:hover {
    color: var(--global-color);
}



/*===============================================================================
	MAIN
===============================================================================*/

.btn-outline-primary {
    display: flex;
    padding: 14px 48px;
    align-items: flex-start;
    gap: 10px;
    border: 0;
    border-radius: 0;
    color: var(--global-color);
    text-align: center;
    font-family: Bison;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.btn-outline-primary:hover,
.btn-check:checked+.btn,
.btn.active,
.btn.show,
.btn:first-child:active,
:not(.btn-check)+.btn:active {
    background-color: var(--global-color);
    border-color: var(--global-color);
}

.btn-primary {
    display: flex;
    padding: 14px 48px;
    align-items: flex-start;
    gap: 10px;
    border: 0;
    border-radius: 0;
    color: var(--global-color2);
    background-color: var(--global-color);
    text-align: center;
    font-family: Bison;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.btn-primary:hover {
    background-color: var(--global-color);
}

.show-screen {
    background: url(../images/main_screen.svg) no-repeat center;
    background-size: cover;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9999;
}

.video-inline__container {
    height: 100vh;
}

.inspire-home__video #show-video {
    width: 100%;
    height: 100%;
    z-index: -1;
    object-fit: cover;
    -webkit-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.inspire-home__socials {
    position: absolute;
    top: 57%;
    right: 50px;
    transform: translateY(-50%);
}

.vertical_block {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 24px;
}

.vertical_block .v_text {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    color: #FFF;
    font-family: Arial;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-transform: uppercase;
}

.v_image {
    height: 60px;
    width: 3px;
    background-color: var(--global-color);
}

.v_list ul {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 25px;
}

.v_list li a {
    display: block;
}

.v_list li a svg path {
    transition: all .4s ease;
}

.v_list li a.fill:hover svg path {
    fill: var(--global-color);
}

.v_list li a.stroke:hover svg path {
    stroke: var(--global-color);
}

.core_text_top {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    /* 171.429% */
    padding: 64px 0;
}

.core_text_top p {
    margin-bottom: 0;
}

.core_values_wrapper {
    margin-top: -50px;
}

.core_block {
    display: flex;
    align-items: center;
}

.core_block_left {
    text-align: right;
    gap: 30px;
}

.core_underline::after {
    content: "";
    height: 3px;
    width: 105px;
    display: block;
    background: #75AFE8;
    margin-top: 60px;
    margin-left: auto;
}

.core_values_list li {
    position: relative;
    padding-left: 40px;
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    /* 128.571% */
    background: url(../images/check.svg) no-repeat left top;
    list-style: none;
}

.core_values_list li:not(:last-child) {
    margin-bottom: 24px;
}

.leaf_container {
    margin-top: -80px;
    position: relative;
    overflow-x: hidden;
}

.lift_block_top {
    position: absolute;
    top: 0;
    left: 100px;
    background: #191919;
    width: 500px;
    height: 420px;
}

.lift_block_top h2 {
    color: var(--global-color2);
    position: absolute;
    top: 47%;
    left: 50%;
    transform: translate(-50%, -53%);
    text-align: center;
    margin: 0;
}

.lift_block_top h2.dwn::before {
    content: "";
    position: absolute;
    bottom: -23px;
    height: 3px;
    width: 50px;
    display: block;
    background: #fff;
}

.lift_block_top h2.dwn::after {
    content: "Take A Breath";
    font-size: 16px;
    position: absolute;
    bottom: -29px;
    left: 60px;
    text-transform: uppercase;
}

.left_image {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    pointer-events: none;
}

.bottom_line {
    display: flex;
    position: absolute;
    bottom: 0;
    right: 0;
}

.lift_block_bottom {
    position: absolute;
    bottom: 120px;
    right: 0;
    width: 590px;
    height: 420px;
    z-index: -1;
    background: #75AFE8 url(../images/leaf_logo.webp) no-repeat right;
}

.lift_block_bottom__text {
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    /* 171.429% */
    position: absolute;
    left: 70px;
    bottom: 50px;
    width: 330px;
}

#moreGYM {
    background: gray url(../images/group_exercise.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding-top: 90px;
    padding-bottom: 170px;
    transition: all .4s ease;
    overflow: hidden;
}

#moreGYM.gym_elem_one {
    background: gray url(../images/clinic.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#moreGYM.gym_elem_two {
    background: gray url(../images/personal_training.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#moreGYM.gym_elem_three {
    background: gray url(../images/group_exercise.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#moreGYM.gym_elem_four {
    background: gray url(../images/tennis.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.gym_head h2 {
    color: #FFF;
    font-size: 48px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 2.4px;
}

.gym_head h2.ups::before {
    content: "";
    height: 3px;
    width: 50px;
    display: block;
    background: #fff;
    margin-bottom: 10px;
}

.gym_head h2.ups::after {
    content: "our services";
    font-size: 16px;
    position: absolute;
    top: -9px;
    left: 60px;
    text-transform: uppercase;
}

.gym_wrapper {
    padding-top: 275px;
}

.gym_elem {
    display: flex;
    padding: 48px 86px;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    flex: 1 0 0;
    border: 1px solid transparent;
    position: relative;
    transition: all .4s ease;
    height: 100%;
}

.gym_block {
    cursor: pointer;
}

.gym_elem.active {
    border-color: var(--global-color2);
}

.gym_elem.active::before {
    opacity: 1;
    max-width: 180px;
    width: 100%;
}

.gym_elem .gym_name {
    color: #FFF;
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.6px;
}

.gym_elem .gym_text {
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    /* 128.571% */
}

.gym_elem::before {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    height: 20px;
    width: 0%;
    background: var(--global-color);
    opacity: 0;
    transition: width 1s ease;
}

.gym_elem .gym_more {
    font-weight: bold;
    position: absolute;
    bottom: 1px;
    right: 5px;
    opacity: 0;
    transition: opacity .4s ease;
}

.gym_elem.active .gym_more {
    opacity: 1;
}

#Team,
#News {
    padding-top: 48px;
    padding-bottom: 48px;
}

#Gallery {
    padding-top: 90px;
    padding-bottom: 48px;
}

.gallery_container {
    padding-top: 28px;
    position: relative;
}

.swp-gallery .slides_block {
    height: 100%;
    overflow: hidden;
}

.swp-gallery .slides_block img {
    transition: transform .4s ease;
    transform: scale(1);
}

.swp-gallery .slides_block:hover img {
    transform: scale(1.1);
}

.gallery-button-prev.swp_btn_prev.swiper-button-disabled,
.gallery-button-next.swp_btn_next.swiper-button-disabled {
    opacity: 0;
    cursor: default;
}
.gallery-button-prev.swp_btn_prev.swiper-button-disabled.swiper-button-lock,
.gallery-button-next.swp_btn_next.swiper-button-disabled.swiper-button-lock {
    display: none !important;
}

.team_head h2.under::after {
    content: "";
    height: 3px;
    width: 105px;
    display: block;
    background: var(--global-color1);
    margin-top: 36px;
}

.team_pagi {
    display: flex;
    align-items: center;
}

.coaches_container {
    padding-top: 48px;
    padding-bottom: 48px;
}

.coaches_wrapper {
    position: relative;
    overflow: hidden;
    height: 85%;
}

.coaches_hover_block {
    position: absolute;
    bottom: -220px;
    right: 0;
    width: 95%;
    background: var(--global-color);
    z-index: 1;
    display: flex;
    flex-direction: column;
    text-align: center;
    opacity: 1;
    transition: all .4s ease;
    height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.coaches_block {
    position: relative;
    margin-top: -10px;
    height: 20px;
    width: 95%;
    background: #000102;
}

.coaches_name {
    color: #000;
    text-align: center;
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.6px;
    margin-bottom: 14px;
}

.coaches_text {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    /* 128.571% */
    margin-bottom: 24px;
}

.coaches_links ul {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
}

.coaches_wrapper:hover .coaches_hover_block {
    bottom: 0%;
    opacity: .8;
}

.names_container {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.names_container .names_block {
    color: #000;
    text-align: center;
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.6px;
    margin-bottom: 14px;
}

.names_container .names_block1 {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    /* 128.571% */
}

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

.latest_container {
    padding-top: 28px;
    padding-bottom: 48px;
}

.swp-coaches .coaches_image {
    max-width: 382px;
    max-height: 640px;
    height: 100%;
    margin: auto;
}

.coaches_image {
    text-align: center;
}

.el {
    width: 60px;
    height: 2px;
    position: relative;
    background: #191919;
}

.swiper-pagination-fraction {
    display: inline-flex;
    align-items: center;
    justify-content: end;
    gap: 24px;
    position: relative;
}

.swiper-pagination-current,
.swiper-pagination-total {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.news_wrapper {
    height: 100%;
}

.news_image {
    position: relative;
    /* max-width: 382px; */
    max-width: 807px;
    max-height: 552px;
    height: 100%;
    margin: auto;
    overflow: hidden;
}

.news_image img {
    transition: all .4s ease;
    height: 100%;
    object-fit: cover;
}

.news_cat,
.news_name,
.news_icon {
    position: absolute;
}

.news_cat {
    top: 0;
    right: 0;
    display: inline-flex;
    padding: 8px 14px;
    align-items: flex-start;
    gap: 10px;
    color: var(--global-color);
    font-family: Arial;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 16px;
    background: rgba(29, 29, 29, 0.80);
}

.news_name {
    left: 15px;
    bottom: 15px;
    width: 80%;
    color: #FFF;
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 40px;
}

.news_icon {
    bottom: 15px;
    right: 15px;
}

.swp-news .swiper-slide-active .news_cat {
    background: var(--global-color);
    color: #FFF;
}

.news_wrapper:hover .news_image img {
    transform: scale(1.05);
}

#Map {
    background: url(../images/map.webp) no-repeat center;
    background-size: cover;
    padding-top: 200px;
    padding-bottom: 250px;
    position: relative;
    overflow-x: hidden;
}

.maps_head h2 {
    color: var(--global-color2);
}

.maps_head h2.ups::before {
    content: "";
    position: relative;
    height: 3px;
    width: 50px;
    display: block;
    background: var(--global-color2);
    margin-bottom: 10px;
}

.maps_head h2.ups::after {
    content: "Clubs";
    font-size: 16px;
    position: absolute;
    top: -9px;
    left: 60px;
}

.map_text,
.map_text p {
    padding-top: 48px;
    padding-bottom: 48px;
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    max-width: 360px;
}

.button-contacts {
    position: absolute;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    top: 0;
    left: 50%;
    width: 150px;
    border-left: 1px solid rgba(255, 255, 255, 0.25);
    border-right: 1px solid rgba(255, 255, 255, 0.25);
    display: flex;
    align-items: center;
    height: 100%;
}

.button-contacts a {
    color: #FFF;
    text-align: center;
    font-family: Bison;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.2px;
    margin-top: 200px;
    text-decoration: none;
    transition: all .4s ease;
}

.button-contacts a:hover {
    color: var(--global-color);
}

#locations {
    background: url(../images/location_bg.webp) no-repeat center;
    background-size: cover;
    padding-top: 200px;
    padding-bottom: 100px;
}

.loc_head h2 {
    color: var(--global-color2);
}

.loc_head h2.up::before {
    content: "";
    height: 3px;
    width: 105px;
    display: block;
    background: var(--global-color2);
    margin-bottom: 36px;
}

.loc_text,
.loc_text p {
    padding-top: 48px;
    padding-bottom: 48px;
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    max-width: 650px;
}

.btn_wrapper_left {
    display: inline-flex;
}

.swp-loc .loc_text_top {
    padding: 0 5px;
    transform: translateY(150%);
    transition: all .4s ease .4s;
}

.swp-loc .loc_text_top .loc_addr_name {
    color: #FFF;
    font-family: Arial;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    letter-spacing: 0.56px;
    text-transform: uppercase;
}

.swp-loc .loc_text_top .loc_addr_text {
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
}

.swp-loc .loc_image {
    position: relative;
    max-height: 361px;
    height: 100%;
    top: 0;
    transition: all .4s ease;
}

.swp-loc .loc_text_bottom {
    position: relative;
    color: rgba(255, 255, 255, 0.87);
    text-shadow: 2px 2px 2px rgba(40, 141, 157, 0.39);
    font-family: Arial;
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-align: center;
    transform: translateY(-150%);
    transition: all .4s ease .4s;
    z-index: -1;
}

.swp-loc .swiper-slide-active .loc_text_top {
    transform: translateY(0);
}

.swp-loc .swiper-slide-active .loc_text_bottom {
    transform: translateY(30px);
}

.swp-loc .swiper-slide-active .loc_image {
    top: 20px;
}

.swp-loc .swiper-wrapper {
    padding: 0 10px 40px;
}

.swp-loc .loc_wrapper {
    position: relative;
    transition: all .4s ease;
}

.swp-loc .swiper-slide-active .borders {
    position: absolute;
    top: -10px;
    right: -10px;
    bottom: -10px;
    left: -10px;
    border-left: 1px solid #fff;
    border-right: 1px solid #fff;
}



/*===============================================================================
	SWIPER
===============================================================================*/

.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.swp-gallery img {
    max-height: 400px;
}

.swp_btn_next,
.swp_btn_prev {
    position: absolute;
    top: 50%;
    width: 27px;
    height: 27px;
    margin-top: -14px;
    z-index: 10;
    cursor: pointer;
    -moz-background-size: 27px 27px;
    -webkit-background-size: 27px 27px;
    background-size: 27px 27px;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
}

.swiper-button-prev,
.swiper-button-next,
.swp_btn_prev,
.swp_btn_next {
    color: #000;
    transition: all .3s ease;
    z-index: 2;
    background-image: none;
}

.swiper-button-prev:hover,
.swiper-button-next:hover,
.swp_btn_prev:hover,
.swp_btn_next:hover {
    color: var(--global-color);
}

.swiper-button-prev,
.swp_btn_prev {
    opacity: 1;
    left: 10px;
}

.swiper-button-next,
.swp_btn_next {
    opacity: 1;
    right: 10px;
}

/* Desktop */
@media (min-width: 1200px) {

    .swiper-button-prev,
    .swp_btn_prev {
        opacity: 0;
        left: 0;
    }

    .swiper-button-next,
    .swp_btn_next {
        opacity: 0;
        right: 0;
    }

    .swiper-wrapper:hover~.swiper-button-prev,
    .swiper-wrapper:hover~.swp_btn_prev,
    .swiper-button-prev:hover,
    .swp_btn_prev:hover {
        opacity: 1;
        left: 0;
    }

    .swiper-wrapper:hover~.swiper-button-next,
    .swiper-wrapper:hover~.swp_btn_next,
    .swiper-button-next:hover,
    .swp_btn_next:hover {
        opacity: 1;
        right: 0;
    }
}

.swp_btn_next:before,
.swp_btn_prev:before {
    display: flex;
    justify-content: center;
}

.swiper-button-prev:before,
.swp_btn_prev:before {
    content: "\f177";
    font-family: "Font Awesome 6 Pro";
    font-size: 25px;
    width: 27px;
    height: 27px;
    color: #000;
    transition: all .4s ease;
}

.swiper-button-next:before,
.swp_btn_next:before {
    content: "\f178";
    font-family: "Font Awesome 6 Pro";
    font-size: 25px;
    width: 27px;
    height: 27px;
    color: #000;
    transition: all .4s ease;
}

.swp_btn_next:hover::before,
.swp_btn_prev:hover::before {
    color: #75AFE8;
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled,
.swp_btn_next.swiper-button-disabled,
.swp_btn_prev.swiper-button-disabled {
    opacity: 0;
    cursor: pointer;
    pointer-events: none;
}



/*===============================================================================
	Accordion
===============================================================================*/

.accordion-button:focus {
    box-shadow: none;
}

.accordion-item .accordion-header .accordion-button {
    color: #000;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
}

.accordion-button,
.accordion-button:not(.collapsed),
.accordion-body {
    background-color: #F5F5F5;
    box-shadow: none;
}

.accordion-body {
    padding-top: 0;
    color: #171717;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.accordion-body li {
    color: var(--global-color);
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.accordion-body li+li {
    margin-top: 10px;
}



/*===============================================================================
	Button to top
===============================================================================*/

#button_top {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 63px;
    height: 63px;
    text-align: center;
    border-radius: 50%;
    position: fixed;
    bottom: 30px;
    right: 30px;
    opacity: 0;
    visibility: hidden;
    z-index: 99992;
    background: rgba(255, 255, 255, 0.30);
    box-shadow: 0px 4px 21px 0px rgba(0, 0, 0, 0.07);
    backdrop-filter: blur(10px);
}

#button_top:hover {
    cursor: pointer;
}

#button_top svg {
    transition: all .4s ease;
}

#button_top:hover svg {
    margin-bottom: 30px;
}

#button_top.showBtn {
    opacity: 1;
    visibility: visible;
}



/*===============================================================================
	Mobile Menu
===============================================================================*/

.drawer-list {
    position: fixed;
    right: 0;
    top: 0;
    height: 100vh;
    width: 100vw;
    transform: translate(100vw, 0);
    /* ie workaround */
    -ms-transform: translatex(-100vw);
    box-sizing: border-box;
    pointer-events: none;
    /*padding-top: 125px;*/
    transition: width 475ms ease-out, transform 450ms ease, border-radius .8s .1s ease;
    border-bottom-left-radius: 100vw;
    /* background-color: #008752; */
    background: #F5F5F5;
    -webkit-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.drawer-list .container {
    align-self: center;
}

.drawer-list ul {
    height: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
    overflow: auto;
    overflow-x: hidden;
    pointer-events: auto;
    columns: 1;
    -webkit-columns: 1;
    -moz-columns: 1;
    text-align: center;
    justify-content: center;
}

.drawer-list li {
    list-style: none;
    text-transform: uppercase;
    pointer-events: auto;
    white-space: nowrap;
    box-sizing: border-box;
    transform: translatey(-100vw);
    /* ie workaround */
    -ms-transform: translatey(100vw);
    overflow: hidden;
    display: block;
    margin: 0;
    line-height: 1.42;
    padding: 25px 0;
}

.drawer-list li a {
    font-family: 'Bison', sans-serif;
    font-size: 40px;
    font-weight: 700;
    line-height: 50px;
    text-decoration: none;
    text-transform: uppercase;
    color: var(--global-text-color);
    text-align: center;
    display: -webkit-inline-flex;
    display: -moz-inline-flex;
    display: -ms-inline-flex;
    display: -o-inline-flex;
    display: inline-flex;
    margin: 0;
    padding: 0;
    transition: all .4s ease 0s;
    overflow: hidden;
    background: transparent;
}

.drawer-list li a:hover {
    color: var(--global-color);
    cursor: pointer;
}

.drawer-list li a:last-child {
    margin-bottom: 0px;
}

.drawer-list ul ul {
    margin-top: 10px;
    margin-left: 20px;
}

.drawer-list ul ul li a {
    font-weight: normal;
    font-size: 26px;
    transition: all .4s ease 0s;
}

.drawer-list ul ul li a:hover {
    color: var(--global-color1);
}

input.hamburger {
    display: none;
}

input.hamburger:checked~.drawer-list {
    transform: translatex(0);
    border-bottom-left-radius: 0;
}

input.hamburger~.drawer-list li {
    opacity: 0;
}

input.hamburger:checked~.drawer-list li {
    transform: translatex(0);
    transition: transform 1.3s ease;
    transition: all 1s ease-in-out .3s;
    opacity: 1;
}

label.hamburger {
    z-index: 9999;
    position: relative;
    display: block;
    margin-bottom: 0;
}

label.hamburger:hover {
    cursor: pointer;
}

label.hamburger {
    left: 0;
}

.ham {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: transform 400ms;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.hamRotate.active {
    transform: rotate(45deg);
}

.hamRotate180.active {
    transform: rotate(180deg);
}

.ham .line {
    fill: none;
    transition: stroke-dasharray 400ms, stroke-dashoffset 400ms;
    stroke: #000;
    stroke-width: 3;
    stroke-linecap: round;
    -webkit-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.ham7 .top {
    stroke-dasharray: 40 82;
}

.ham7 .middle {
    stroke-dasharray: 25 111;
}

.ham7 .bottom {
    stroke-dasharray: 40 161;
}

.ham7.active .top {
    stroke-dasharray: 17 82;
    stroke-dashoffset: -62px;
}

.ham7.active .middle {
    stroke-dashoffset: 23px;
}

.ham7.active .bottom {
    stroke-dashoffset: -83px;
}

.hamburger:hover .top,
.ham7.active .top {
    stroke-dasharray: 40 82;
}

.hamburger:hover .middle,
.ham7.active .middle {
    stroke-dasharray: 40 111;
}

.hamburger:hover .bottom,
.ham7.active .bottom {
    stroke-dasharray: 40 161;
}

body.hidden {
    overflow: hidden !important;
}



/*===============================================================================
	Pages first block
===============================================================================*/

section.first_block {
    overflow-x: hidden;
}

.first_wrapper {
    position: relative;
}

.page_block {
    position: absolute;
    top: 55%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.page_block__name h1 {
    color: var(--global-color1);
}

.page_block__breadcrumbs ul {
    display: flex;
    align-items: center;
    justify-content: center;
}

.page_block__breadcrumbs ul li,
.page_block__breadcrumbs ul li a {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
    text-decoration: none;
    transition: all .4s ease;
}

.page_block__breadcrumbs ul li a:hover {
    color: var(--global-color);
}

.page_block__breadcrumbs ul li+li:before {
    content: '-';
    margin: 0 6px;
}



/*===============================================================================
	Personal trainers
===============================================================================*/

.personal_text_block {
    max-width: 830px;
    margin: auto;
    padding: 70px 0;
}

.personal_text__top {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
    margin-bottom: 36px;
}

.personal_text__bottom {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

#goals {
    background: url(../images/pages/personal/goals_bg.webp) no-repeat center;
    background-size: cover;
    padding-top: 48px;
    padding-bottom: 48px;
}

.pages_head .uphead {
    color: var(--global-color2);
    text-align: right;
    font-family: Bison;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.pages_head .uphead .line {
    display: block;
    height: 2px;
    width: 50px;
    background-color: var(--global-color);
}

#goals .pages_head h2 {
    color: var(--global-color2);
}

.card_wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 45px;
    margin-top: 25px;
}

.card_block {
    display: flex;
    max-width: 370px;
    width: 100%;
    padding: 24px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    border: 1px solid rgba(200, 200, 200, 0.50);
    background: rgba(0, 0, 0, 0.20);
    backdrop-filter: blur(5px);
}

.card_block .card_image {
    padding: 30px 20px;
}

.card_content {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.card_content .card_name {
    color: var(--global-color2);
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1.6px;
}

.card_content .card_name .paid {
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 19.6px;
    padding: 4px 14px;
    background: var(--global-color);
    position: absolute;
    margin: 6px 0 0 15px;
    text-transform: capitalize;
}

.card_content .card_text {
    color: var(--global-color2);
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.btn_details {
    display: flex;
    justify-content: center;
    margin: 45px 0 20px;
}

section.trainers {
    padding-top: 68px;
    padding-bottom: 68px;
}

.trainers_text_wrapper {
    max-width: 830px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: center;
    margin: 0 auto;
}

.trainers_head {
    position: relative;
}

.trainers_head h2.ups::before {
    content: "";
    position: relative;
    height: 3px;
    width: 50px;
    display: block;
    background: var(--global-color1);
    margin-bottom: 10px;
}

.trainers_head h2.ups::after {
    content: "trainers";
    font-size: 16px;
    position: absolute;
    top: -9px;
    left: 60px;
}

.trainers_text__top,
.trainers_text__bottom strong {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
}

.trainers_text__bottom strong {
    max-width: 550px;
    display: inline-block;
}

.trainers_text__bottom {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.trainer_block {
    margin-top: 48px;
}

.instructor_wrapper {
    position: relative;
    border: 1px solid #C8C8C8;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 24px;
    height: 85%;
    min-height: 300px;
    text-align: center;
    overflow: hidden;
}

.instructor_info {
    color: var(--global-color1);
    text-align: center;
    font-family: Bison;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 40px;
}

.book_wrapper {
    background: #191919 url(../images/pages/personal/logo_bg.webp) no-repeat center 15%;
}

.btn_wrapper {
    padding: 55px 0;
}



/*===============================================================================
	Personal trainers single
===============================================================================*/

.trainer_information {
    position: relative;
    padding-bottom: 100px;
}

.trainer_container {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    background: #191919;
    position: relative;
}

.trainer_info {
    display: flex;
    flex-direction: column;
    gap: 84px;
    max-width: 465px;
    padding: 60px 30px;
}

.trainer_info h2 {
    color: var(--global-color2);
}

.trainer_image {
    text-align: center;
    max-height: 662px;
}

.trainer_content,
.trainer_content p {
    color: var(--global-color2);
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.trainer_container .bottom_line {
    height: 30px;
    max-width: 430px;
    width: 100%;
    background: var(--global-color);
}

.inquiry_wrapper {
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 85px 0 85px 70px;
    max-width: 675px;
    background: var(--global-color) url(../images/pages/personal/logo_white.webp) no-repeat top right;
    background-size: contain;
}

.inquiry_btn {
    display: flex;
}

.inquiry_btn .btn {
    border: 1px solid var(--global-color2);
    color: var(--global-color2);
}

.inquiry_btn .hvr-ripple-out:before {
    border-color: var(--global-color2);
}

.trainer_videos {
    padding-bottom: 100px;
}

.video_text_info {
    display: flex;
    justify-content: center;
    padding: 50px 0 84px;
}

.video_content {
    max-width: 830px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 18px;
}

.video_text_top {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
}

.video_text_bottom p {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.trainer_video {
    display: flex;
    margin-top: 24px;
}

.trainer_details {
    position: relative;
    background: #191919;
    padding-top: 80px;
    padding-bottom: 80px;
    overflow-x: hidden;
}

.bg_image1 {
    background: url(../images/pages/personal/logo_big.webp) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 10%;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.bg_image2 {
    position: absolute;
    top: 0;
    right: 0;
    pointer-events: none;
}

.row_center {
    justify-content: center;
}

.trainer_details h2 {
    color: white;
    max-width: 425px;
}

.trainer_contactform .form-control {
    padding: 0 25px;
}

.trainer_contactform textarea.form-control {
    padding: 0;
}

.block_info {
    position: absolute;
    top: 25px;
    right: 0;
}

.trainer_contactform label.checkbox {
    margin-bottom: 20px;
}



/*===============================================================================
	Community
===============================================================================*/

.news_top {
    padding-top: 48px;
    padding-bottom: 48px;
    max-width: 810px;
    margin: auto;
}

.news_text {
    color: var(--global-color1);
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.filter_container {
    border-bottom: 1px solid #000;
    padding-top: 20px;
    padding-bottom: 20px;
}

.filter_container .button-group {
    display: flex;
    justify-content: center;
    gap: 50px;
}

.filter_container .button-group .btn_filter {
    color: var(--global-color1);
    text-align: center;
    font-family: Bison;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 26px;
    padding-bottom: 4px;
    border: 0;
    background: transparent;
}

.grid {
    padding-top: 20px;
}

.grid-sizer,
.grid-item {
    margin: 28px 14px 0;
    display: inline-block;
}

.grid-item .news_image {
    max-width: 751px;
}

/* .grid-item .news_image {
    max-width: 362px;
} */
.inst_container {
    position: relative;
}

.inst_wrapper {
    height: 100%;
}

.inst_image {
    max-height: 340px;
    overflow: hidden;
    height: 100%;
}

.inst_image::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, .3);
}

.inst_info {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 620px;
    width: 100%;
    text-align: center;
    z-index: 1;
    color: var(--global-color2);
}

.inst_info h2 {
    color: var(--global-color2);
}

section.instagramm_slider {
    padding-top: 48px;
}



/*===============================================================================
	Community single
===============================================================================*/

#postContent {
    background-color: white;
}

.post_header {
    margin-top: 50px;
    margin-bottom: 40px;
}

.post_info {
    display: flex;
    align-items: center;
    gap: 40px;
}

.post_info_by {
    color: #000;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.post_info_time {
    color: #000;
    font-family: Arial;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.32px;
    position: relative;
}

.post_info_time::before {
    content: '';
    height: 1px;
    width: 20px;
    background: #000;
    display: block;
    position: absolute;
    top: 50%;
    left: -27px;
    transform: translateY(-50%);
}

.post_image,
.post_content img {
    /*margin-bottom: 80px;*/
    max-width: 100%;
}

.post_content {
    padding-bottom: 100px;
}

.post_content p {
    color: #121416;
    font-family: Arial;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 26px;
}

.post_content .blockquote,
.post_content blockquote {
    display: flex;
    align-items: baseline;
    gap: 36px;
    margin: 80px 0 40px;
}

.post_content blockquote {
    color: var(--global-color1);
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
}

.post_content .blockquote,
.post_content .blockquote_head,
.post_content .blockquote p {
    color: var(--global-color1);
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
}

.post_content .blockquote_head {
    margin-top: 45px;
}

.post_content ul {
    margin: 30px 0 30px 60px;
}

.post_content ul li {
    color: #121416;
    font-family: Arial;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 26px;
}

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

section.all_news {
    padding-top: 48px;
}

.aside_wrapper {
    margin-left: 45px;
}

.aside_block+.aside_block {
    margin-top: 80px;
}

.follow_head {
    color: #121416;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.follow_content {
    padding-top: 40px;
    padding-bottom: 40px;
    display: flex;
    align-items: center;
    gap: 40px;
}

.follow_text {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.follow_text_top,
.follow_text_bottom {
    color: #000;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.follow_text_bottom {
    line-height: 18px;
}

.follow_text_bottom span {
    color: #373636;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 19.6px
}

.grid_container {
    display: grid;
    grid-gap: 10px;
    grid-template-columns: 1fr 1fr 1fr;
}

.post_block {
    padding: 20px;
}

.post_block+.post_block {
    padding-top: 20px;
}

.post_block.post_last h5,
.post_block.post_last .post_info_date,
.post_block.post_last .post_info_time {
    color: #fff;
}

.post_block.post_last .post_info_time::before {
    background: #fff;
}

.post_block.post_last .post_info_time svg path {
    stroke: #fff;
}



/*===============================================================================
	Clinik page
===============================================================================*/

section.therapy {
    background: #191919;
    margin-bottom: 100px;
    position: relative;
}

.clinic_image_bg {
    position: absolute;
    left: 0;
    bottom: 0;
    pointer-events: none;
}

.therapy h2 {
    color: white;
}

.clinic_text p {
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.therapy .pages_head {
    padding-top: 140px;
    margin-left: 140px;
}

.clinic_text {
    padding-top: 145px;
    padding-bottom: 250px;
    max-width: 605px;
    margin-left: auto;
}

section.therapy .inquiry_wrapper {
    bottom: -100px;
}

.clinic_trainer_image_block {
    position: relative;
}

.clinic_trainer_image {
    position: absolute;
    bottom: 100px;
    right: -100px;
    max-width: 683px;
    clip-path: var(--clip1);
    transition: all .8s;
    clip-path: var(--clip2);
}

.clinic_trainer_image img {
    width: 100%;
    object-fit: cover;
}

.clinic_trainer_info_container {
    padding-top: 50px;
    max-width: 605px;
    margin-left: auto;
}

.clinic_trainer_info_container .uphead {
    color: #000;
}

.clinic_trainer_info_wrapper {
    margin-top: 84px;
}

.clinic_trainer_info_wrapper p {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.clinic_services {
    padding-top: 100px;
}

.serv_block {
    width: 100%;
    height: 700px;
    position: relative;
}

.serv_block ul {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    display: flex;
    background: url(../images/pages/clinic/correction.webp);
    background-size: cover;
    background-position: center;
}

.serv_block ul li {
    position: relative;
    width: 33.333%;
    height: 100%;
    border-right: 1px solid #000;
    box-sizing: border-box;
    transition: all .4s ease;
}

.serv_block ul:hover li {
    width: 10%;
}

.serv_block ul li:hover {
    width: 80%;
}

.serv_block ul li:nth-child(1) {
    background: url(../images/pages/clinic/correction.webp);
    background-size: cover;
    background-position: left;
}

.serv_block ul li:nth-child(2) {
    background: url(../images/pages/clinic/massage.webp);
    background-size: cover;
    background-position: left;
}

.serv_block ul li:nth-child(3) {
    background: url(../images/pages/clinic/rehabilitation.webp);
    background-size: cover;
    background-position: left;
}

.serv_block_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.text_logo {
    color: #FFF;
    font-family: Arial;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    text-transform: capitalize;
    opacity: 0;
    transform: translateY(-50%);
    transition: all .4s ease .1s;
    min-height: 74px;
}

.serv_block ul li:hover .text_logo {
    opacity: 1;
    transform: translateY(25%);
}

.serv_block_content img {
    transform: translateY(50%);
    transition: all .4s ease .1s;
}

.serv_block ul li:hover .serv_block_content img {
    transform: translateY(0%);
}

.serv_wrapper {
    display: flex;
}

.serv_block_text {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    color: #191919;
    font-family: Bison;
    font-size: 64px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    padding: 0 50px;
    transform: rotate(180deg);
    text-align: center;
    border: 1px solid #C8C8C8;
    border-left: 0;
}

.serv_line {
    height: 10px;
    width: 0;
    background: var(--global-color);
    transition: all .4s ease .1s;
}

.serv_block ul li:hover .serv_line {
    width: 50px;
}



/*===============================================================================
	Cereers page
===============================================================================*/

.careers_headblock {
    max-width: 811px;
    margin: 0 auto;
    padding-top: 48px;
    padding-bottom: 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 18px;
    text-align: center;
}

.careers_headblock h2 {
    max-width: 550px;
    margin: 24px auto;
}

.headblock_text {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

section.careers_vacancies {
    padding-top: 50px;
    padding-bottom: 50px;
}

.careers_vacancies_head {
    text-align: center;
    border-bottom: 1px solid #000;
}

.careers_vacancies_accordion {
    margin-top: 10px;
}

.careers_form_image {
    position: relative;
    height: 100%;
}

.careers_form_image img {
    height: 100%;
    object-fit: cover;
}

.mini_logo {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.mini_logo .logo_line {
    height: 16px;
    width: 78px;
    background-color: var(--global-color);
    margin-top: -10px;
    position: relative;
    z-index: -1;
}

.vac_list h5 {
    color: var(--global-color);
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
    margin-bottom: 10px;
}

.careers_form_bg {
    background-color: #191919;
    overflow-x: hidden;
}

.careers_form,
.careers_form .form_container {
    height: 100%;
}

.careers_form .form_container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-top: 70px;
    padding-bottom: 70px;
    max-width: 530px;
    margin: 0 auto;
}

.form_container h2 {
    color: #fff;
}

.careers_form form {
    margin-top: 54px;
}

.custom-file-button input[type=file] {
    margin-top: 10px;
}

.custom-file-button input[type=file]::-webkit-file-upload-button {
    display: none;
}

.custom-file-button input[type=file]::file-selector-button {
    display: none;
}

.custom-file-button .form-text {
    color: var(--global-color);
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.careers_form .form_container button {
    margin-top: 20px;
    display: inline-block;
}



/*===============================================================================
	Memberships page
===============================================================================*/

.membership_information {
    position: relative;
    padding-bottom: 100px;
}

.membership_container {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #191919;
}

.membership_info {
    display: flex;
    flex-direction: column;
    gap: 84px;
    max-width: 465px;
    padding: 60px 30px;
}

.membership_info h2 {
    color: white;
}

.membership_container .bottom_line {
    height: 30px;
    max-width: 430px;
    width: 100%;
    background: var(--global-color);
}

.membership_content p {
    color: white;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.membership_image {
    position: relative;
    height: 100%;
}

.membership_image img {
    height: 100%;
    object-fit: cover;
}

section.block_faq {
    padding-top: 50px;
    padding-bottom: 50px;
}

.block_faq_head {
    text-align: center;
    border-bottom: 1px solid #000;
}

.block_accordion {
    margin-top: 10px;
}

.benefits_image {
    position: relative;
    height: 100%;
    background-color: #000;
}

.benefits_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.benefits_blk {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.benefits_blk h2 {
    color: #fff;
}

.benefits_blk h2::after {
    content: '';
    display: block;
    height: 3px;
    width: 105px;
    background: #fff;
    margin: 36px auto 0;
}

.benefits_blk_content {
    position: relative;
}

.benefits_blk_content__top {
    display: flex;
    justify-content: right;
    align-items: center;
}

.benefits_blk_content__bottom {
    display: flex;
    justify-content: left;
    align-items: center;
}

.benefits_blk_content__top .block_text,
.benefits_blk_content__bottom .block_text {
    position: relative;
    width: 100%;
}

.benefits_blk_content__top .block_text {
    max-width: 360px;
}

.benefits_blk_content__bottom .block_text {
    max-width: 300px;
}

.benefits_blk_content__top .block_text h3::before,
.benefits_blk_content__bottom .block_text h3::before {
    content: "";
    display: block;
    position: absolute;
    top: 20px;
    left: -20px;
    width: 10px;
    height: 10px;
    background-color: var(--global-color);
    border: 0;
    border-radius: 50%;
}

.benefits_blk_content__top .block_text {
    margin-right: 70px;
}

.benefits_blk_content__bottom .block_text {
    margin-left: 100px;
}

.benefits_blk_content__top .block_text p,
.benefits_blk_content__bottom .block_text p {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.benefits_content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.benefits_wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 570px;
    text-align: center;
    margin: 0 auto;
}

.benefits_wrapper h2 {
    color: #fff;
}

.pages_head_text {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
    margin-top: 18px;
}

.benefits_content_text {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin-top: 68px;
}



/*===============================================================================
	Group page
===============================================================================*/

.group_top_wrapper {
    padding-top: 65px;
    padding-bottom: 65px;
}

.group_top_wrapper p {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin: 0 auto;
    max-width: 830px;
}

.group_image {
    position: relative;
}

.group_image>img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.group_content {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 100%;
}

.group_wrapper {
    display: flex;
    flex-direction: column;
    gap: 84px;
    max-width: 635px;
    width: 100%;
}

.group_content_text p {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.group_wrapper .uphead {
    color: #000;
}

.group_wrapper h2 {
    position: relative;
}

.group_wrapper .paid {
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 19.6px;
    padding: 4px 14px;
    background: var(--global-color);
    color: #fff;
    position: absolute;
    bottom: 8px;
    margin: 0 0 0 20px;
    text-transform: capitalize;
}



/*===============================================================================
	Padel & Tennis page
===============================================================================*/

section.tennis_top {
    background: #191919;
    position: relative;
}

.tennis_top .inquiry_wrapper {
    max-width: 500px;
    padding: 70px 0 70px 70px;
}

.tennis_top .pages_head {
    padding-top: 140px;
    margin-left: 200px;
}

.tennis_top h2 {
    color: white;
    max-width: 300px;
}

.tennis_text {
    padding-top: 145px;
    padding-bottom: 350px;
    max-width: 605px;
    margin-left: auto;
}

.tennis_text p {
    color: #FFF;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.padel_image {
    position: absolute;
    bottom: 0;
    max-width: 1120px;
    width: 100%;
}

.padel_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tennis_image {
    position: relative;
    max-width: 1120px;
    width: 100%;
}

.tennis_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tennis_container {
    position: relative;
    margin-bottom: 100px;
}

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

.tennis_content {
    display: flex;
    flex-direction: column;
    gap: 84px;
    padding: 50px 0;
    max-width: 605px;
}

.tennis_content_text p {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

section.details {
    position: relative;
    background: #191919;
    padding-top: 80px;
    padding-bottom: 80px;
    overflow-x: hidden;
}

section.details h2 {
    color: white;
    max-width: 425px;
}

.tennis_contactform .form-control {
    padding: 0 25px;
}

.tennis_contactform button {
    margin-top: 20px;
    display: inline-block;
}
body.tennis .first_wrapper .page_block {
    background-color: rgb(255 255 255 / 30%);
    padding: 50px 100px 40px;
}



/*===============================================================================
	Contacts page
===============================================================================*/

section.contacts {
    padding-top: 55px;
    padding-bottom: 48px;
}

.contacts_header {
    text-align: center;
    border-bottom: 1px solid #000;
}

#Sahara>.container>.row+.row,
#Nbk>.container>.row+.row,
#nbk>.container>.row+.row {
    margin-top: -30px;
}

#Nbk, #nbk {
    padding-top: 100px;
}

.contact_info_wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    position: relative;
    left: -80px;
}

.contact_info_container {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.contacts_image {
    width: 100%;
    height: 100%;
    max-height: 477px;
}

.contacts_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.blue_wrapper {
    position: relative;
}

.blue_content {
    position: absolute;
    top: 50%;
    left: 100px;
    transform: translateY(-50%);
    max-width: 400px;
    width: 100%;
    display: flex;
    flex-direction: column;
}

.blue_content .btn {
    display: inline-flex;
    margin-left: auto;
}

.address_container {
    display: flex;
    gap: 14px;
}

.address_wrapper {
    padding: 100px 0 0 100px;
}

.addr_list li+li {
    margin-top: 24px;
}

.addr_head {
    color: #000;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.addr_text {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
}

.addr_time {
    color: #000;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
}

.addr_time1 {
    color: #C8C8C8;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    margin-top: 5px;
}

.addr_phone a,
.addr_mail a {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
    display: block;
    text-decoration: none;
    transition: all .4s ease;
}

.addr_phone a:hover,
.addr_mail a:hover {
    color: var(--global-color);
}



/*===============================================================================
	Rules page
===============================================================================*/

section#Rules {
    background: #fff;
    padding-top: 60px;
    padding-bottom: 60px;
}

.rules_head {
    margin-bottom: 68px;
}

.rules_content h2 {
    color: #121416;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.rules_content p {
    color: #121416;
    font-family: Arial;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 26px;
}



/*===============================================================================
	404
===============================================================================*/

.error_wrapper {
    width: 100%;
    height: 100Vh;
    overflow: hidden;
}

.error_wrapper .container-fluid,
.error_wrapper .container-fluid .row {
    height: 100%;
}

.error_left {
    display: flex;
    margin-top: auto;
}

.error_right {
    display: flex;
    margin-top: auto;
    justify-content: center;
}

.error_block {
    padding-left: 100px;
    margin-bottom: 80px;
}

.error_content {
    max-width: 652px;
    width: 100%;
    margin-bottom: 150px;
}

.error_btn_wrapp {
    display: flex;
    justify-content: end;
    padding: 60px 100px 60px 0;
    background: var(--global-color) url(../images/404_logo.webp) no-repeat top left;
    background-size: contain;
}

.error_block_btn a {
    border: 1px solid var(--global-color2);
    color: var(--global-color2);
    display: inline-block;
}

.error_block_btn a:hover,
.error_block_btn .hvr-ripple-out:before {
    border-color: var(--global-color2);
}



/*===============================================================================
	About page
===============================================================================*/

#Founded .group_wrapper {
    padding: 48px;
}

#coreValues .group_wrapper {
    max-width: 650px;
    padding: 48px;
}

.group_content_lists ul {
    list-style: none;
    margin-bottom: 0;
}

.group_content_lists ul li {
    position: relative;
}

.group_content_lists ul li+li {
    margin-top: 24px;
}

.group_content_lists ul li::before {
    content: '';
    background-color: var(--global-color);
    width: 10px;
    height: 10px;
    border: 0;
    border-radius: 50%;
    position: absolute;
    top: 9px;
    left: -20px;
    display: block;
}

.lists_head {
    color: #000;
    font-family: Arial;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 25.2px;
}

.lists_text {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.values_button {
    display: flex;
}

#clubBenefits .benefits_image {
    background-color: transparent;
}

#clubBenefits .benefits_blk h2 {
    color: #000;
}

#clubBenefits .benefits_blk h2::after {
    content: '';
    background: #000;
}

#Sahara,
#Nbk,
#nbk {
    overflow-x: hidden;
}

#ourServices {
    padding-top: 48px;
    padding-bottom: 48px;
}

#ourServices>.container>.row+.row {
    margin-top: 48px;
}

.service_text_wrapper {
    max-width: 600px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0 auto;
}

.service_text_wrapper .uphead {
    color: #000;
}

.service_text_wrapper .service_text {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px;
    max-width: 400px;
    width: 100%;
}

.service_text_bottom {
    color: #000;
    text-align: center;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22.4px;
    max-width: 650px;
    width: 100%;
    margin: 0 auto;
}

.service_card_wrapper {
    display: flex;
    padding: 24px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    border: 1px solid #C8C8C8;
    height: 100%;
}

.service_card_image {
    min-height: 400px;
    max-height: 400px;
    width: 100%;
    overflow: hidden;
}

.service_card_bg {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: left;
    display: block;
    width: 100%;
    min-height: 400px;
    max-height: 400px;
    height: 100%;
    transition: all 0.4s ease-in-out;
}

.service_card_hover_bg {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    display: block;
    width: 100%;
    min-height: 400px;
    max-height: 400px;
    height: 100%;
    transition: all 0.4s ease-in-out;
}

.card_training .service_card_bg {
    background-image: url(../images/pages/about/personal.webp);
}

.card_training .service_card_hover_bg {
    background-image: url(../images/pages/about/personal_h.webp);
}

.service_card_wrapper:hover .card_training .service_card_bg,
.service_card_wrapper:hover .card_training .service_card_hover_bg {
    transform: translateY(-100%);
}

.card_group {
    display: flex;
    flex-wrap: wrap-reverse;
    flex-direction: column-reverse;
}

.card_group .service_card_bg {
    background-image: url(../images/pages/about/group.webp);
}

.card_group .service_card_hover_bg {
    background-image: url(../images/pages/about/group_h.webp);
}

.service_card_wrapper:hover .card_group .service_card_bg,
.service_card_wrapper:hover .card_group .service_card_hover_bg {
    transform: translateX(100%);
}

.card_clinic .service_card_bg {
    background-image: url(../images/pages/about/clinic.webp);
}

.card_clinic .service_card_hover_bg {
    background-image: url(../images/pages/about/clinic_h.webp);
}

.service_card_wrapper:hover .card_clinic .service_card_bg,
.service_card_wrapper:hover .card_clinic .service_card_hover_bg {
    transform: translateY(-100%);
}

.card_nutrition {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
}

.card_nutrition .service_card_bg {
    background-image: url(../images/pages/about/nutrition.webp);
}

.card_nutrition .service_card_hover_bg {
    background-image: url(../images/pages/about/nutrition_h.webp);
}

.service_card_wrapper:hover .card_nutrition .service_card_bg,
.service_card_wrapper:hover .card_nutrition .service_card_hover_bg {
    transform: translateX(-100%);
}

.service_card_info p {
    color: #000;
    font-family: Arial;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.service_card_button {
    margin-top: auto;
    position: relative;
}

.service_card_button::after {
    content: '';
    width: 100%;
    height: 20px;
    display: block;
    background-color: #000;
    position: absolute;
    left: -10px;
    bottom: -10px;
    z-index: -1;
    transition: all 0.4s ease-in-out;
}

.serv_btn_wrapp {
    position: relative;
    overflow: hidden;
    display: block;
}

.serv_btn_wrapp .btn {
    /* transform: translateY(36px); */
    position: relative;
    top: 36px;
    transition: all 0.4s ease-in-out;
    color: var(--global-color);
}

.service_card_wrapper:hover .serv_btn_wrapp .btn {
    /* transform: translateY(0); */
    top: 0;
    color: white;
}

.service_card_wrapper:hover .service_card_button::after {
    left: 0;
    bottom: 0;
    opacity: 0;
}

.swp_img_wrapp {
    width: 100%;
    height: 100%;
    display: block;
}

.swp_img_wrapp a {
    cursor: pointer;
}

.swp_container .swiper-slide {
    display: flex;
    height: auto;
}



/*===============================================================================
	Auth
===============================================================================*/

.auth_wrapper {
    position: relative;
    width: 100%;
    height: auto;
    background-color: #191919;
}

.auth_wrapper>.container-fluid,
.auth_wrapper>.container-fluid>.row {
    height: 100%;
}

.auth_right {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.auth_image {
    width: 100%;
    height: 100%;
}

.auth_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.auth_container {
    max-width: 680px;
    width: 100%;
    padding-top: 125px;
    padding-bottom: 50px;
}

.auth_container h2 {
    color: white;
}

.auth_contactform {
    max-width: 485px;
}

.auth_bg_image {
    position: absolute;
    top: 0;
    right: 0;
    pointer-events: none;
}

.show_pass {
    cursor: pointer;
}

.show_pass.active svg path {
    stroke: var(--global-color);
}

.auth_contactform .form-text,
.mailform .form-text {
    color: white;
}

.auth_btn_wrapper {
    display: flex;
    align-items: center;
    gap: 46px;
    color: white;
    margin-top: 15px;
}

.link_auth {
    display: flex;
    align-items: center;
    gap: 10px;
}

.formWrapper {
    scrollbar-color: gray lightgrey;
    scrollbar-width: thin;
    max-height: 555px;
    overflow: hidden;
    overflow-y: auto;
    padding-right: 10px;
}

.formWrapper::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.formWrapper::-webkit-scrollbar-track {
    background-color: lightgrey;
    box-shadow: none;
}

.formWrapper::-webkit-scrollbar-thumb {
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .2);
    background-color: grey;
}



/*===============================================================================
	Modal
===============================================================================*/

#dialog-content {
    background: #191919;
}

#dialog-content .select2-container {
    width: 100% !important;
}

#dialog-content h2 {
    color: white;
}

#dialog-content .bg_image1 {
    top: auto;
    left: 0;
    height: 70%;
    width: 70%;
}

#dialog-content .fancybox-close-small {
    color: white;
}

#dialog-content .block_info {
    top: 0;
}

.dialog_send h3 {
    color: white;
}



/*===============================================================================
	Calendar
===============================================================================*/

#Schedule {
    position: relative;
    padding-top: 48px;
    padding-bottom: 48px;
}
.schedule_bg {
    background: url(../images/pages/group/schedule_bg.webp) no-repeat center;
    background-size: cover;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    filter: brightness(0.3);
}
.schedule_head h2 {
    color: white;
}
.schedule_date {
    margin: 36px 0 18px;
    color: white;
    text-align: center;
    font-family: Arial;
    font-size: 28px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px; /* 128.571% */
}
.schedule_table {
    border: 1px rgba(200, 200, 200, 0.50);
    backdrop-filter: blur(5px);
    width: 100%;
}
.schedule_table th {
    color: #FFF;
    font-family: Bison;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.8px;
}
.schedule_table th,
.schedule_table td {
    background-color: transparent;
    color: white;
    padding: 10px;
    width: 14.285%;
}
.schedule_table td {
    max-width: 130px;
}
.schedule_table th,
.schedule_table td {
    background: rgba(0, 0, 0, 0.80);
}
.training_group {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 4px;
    padding: 0 15px;
}
.group_name {
    color: var(--global-color);
    text-align: center;
    font-family: Bison;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 1px;
    margin-bottom: 4px;
}
.group_time {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}
.training_name {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}
.trainer_name {
    color: #FFF;
    text-align: center;
    font-family: Arial;
    font-size: 12px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}
.schedule-button-prev,
.schedule-button-next {
    position: absolute;
    top: 0;
    z-index: 1;
    height: 100%;
    display: flex;
    align-items: center;
    background: rgba(117, 175, 232, 0.08);
    width: 15px;
}
.schedule-button-prev {
    left: 0;
    justify-content: center;
}
.schedule-button-prev::after {
    content: "\f177";
    font-family: "Font Awesome 6 Pro";
    font-size: 12px;
}
.schedule-button-next {
    right: 0;
    justify-content: center;
}
.schedule-button-next::after {
    content: "\f178";
    font-family: "Font Awesome 6 Pro";
    font-size: 12px;
}
.schedule-button-prev.swiper-button-disabled,
.schedule-button-next.swiper-button-disabled {
    opacity: 0;
    cursor: default;
}
.schedule-button-prev.swiper-button-disabled.swiper-button-lock,
.schedule-button-next.swiper-button-disabled.swiper-button-lock {
    display: none !important;
}
#Schedule .btn_wrapper {
    padding-top: 20px;
}