/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.18.2
*/

/*************** ADD CUSTOM CSS HERE.   ***************/

@font-face {
    font-family: 'Greatvibes';
    font-weight: 400;
    font-style: normal;
    src: url(assets/fonts/greatvibes/greatvibes.woff2) format('woff2');
}

:root {
    --color-black: #000000;
    --color-white: #ffffff;
    --color-grey: #cccccc;
    --FontAwesome: 'Font Awesome 7 Pro';
    --font-html-size: 62.5%;
}

html {
    font-size: var(--font-html-size);
}

body {
    font-size: calc(16px + ((3 * (100vw - 720px)) / 719)) !important;
}

body [class*='word'] {
    white-space: nowrap;
}

body [class*='char'] {
    min-width: 0.25em;
    font-size: inherit;
    display: inline-block;
}

.flickity-prev-next-button {
    color: var(--color-white);
}

/* .alt-font-2 {
    font-family: 'Cormorant', sans-serif !important; 
} */

.phone-list__item,
.lang-list,
.menu__section_categories ul.inner li a span,
.h1,
.h2,
h1,
h2 {
    letter-spacing: 0.15em;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.3em;
}

h1,
.h1 {
    letter-spacing: 0.15em;
    font-size: calc(48px + ((22 * (100vw - 720px)) / 719));
}

.h2,
h2 {
    font-size: calc(24px + ((12 * (100vw - 720px)) / 719));
    letter-spacing: 0.15em;
}

h3,
.h3 {
    font-size: calc(32px + ((14 * (100vw - 720px)) / 719));
    font-weight: 400;
}

.h4,
h4 {
    line-height: 1.3em;
    font-size: calc(20px + ((6 * (100vw - 720px)) / 719));
    font-weight: 400;
}

.h5,
.h6,
h5,
h6 {
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2em;
}

p {
    margin-bottom: 1.5rem;
}

.dark,
.dark p,
.dark td {
    color: var(--color-white);
}

.col-child-left>.col-inner {
    margin-right: auto !important;
    margin-left: 0 !important;
}

.col-child-center>.col-inner {
    margin-right: auto !important;
    margin-left: auto !important;
}

.col-child-right>.col-inner {
    margin-right: 0 !important;
    margin-left: auto !important;
}

.off-canvas-left .mfp-content,
.off-canvas-right .mfp-content {
    background-color: hsla(0, 0%, 100%, 1);
}

.off-canvas:not(.off-canvas-center) .nav-vertical li>a {
    font-size: 1em;
    text-transform: capitalize;
    font-weight: 500;
    color: var(--color-black);
}

.ux-loader--style-spotlight .ux-loader__inner {
    height: 6rem;
    width: 6rem;
}

.loading-spin {
    border-radius: 50%;
    height: 42px;
    width: 42px;
    border-width: 2px;
}

.loading-spin.centered,
.processing:before {
    left: 50%;
    margin-left: -21px;
    margin-top: -21px;
    position: absolute;
    top: 50%;
    z-index: 99;
}

.button.is-xsmall {
    font-size: 13px;
}

.button.is-outline,
input[type='button'].is-outline,
input[type='reset'].is-outline,
input[type='submit'].is-outline {
    background-color: transparent;
    border: 1px solid;
}

.button.is-outline {
    line-height: 2.2em;
}

.rank-math-breadcrumb {
    font-size: 1.2rem;
    font-weight: bold;
}

.rank-math-breadcrumb a {
    color: #161616;
}

.rank-math-breadcrumb .separator {
    opacity: 0.5;
    margin: 0 16px;
    transform: rotate(180deg);
    display: inline-block;
}

.dark .rank-math-breadcrumb a {
    color: var(--color-white);
    opacity: 0.7;
}

.dark .rank-math-breadcrumb a:hover {
    opacity: 1;
}

.rank-math-breadcrumb p {
    margin-bottom: 0;
}

.page-template-page-blank-title-center #main {
    background-color: #f8f9fa;
}

.page-template-page-blank-title-center h1.entry-title {
    text-transform: uppercase;
}

.page-template-page-blank-title-center h1.entry-title+.is-divider {
    display: none;
}

.entry-content {
    padding-bottom: 0;
    padding-top: 0;
}

.button-split-text .char,
.split-text .char {
    display: inline-block;
    transform: rotateX(90deg);
    transform-origin: bottom;
    opacity: 0;
    transition: transform 1.6s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 1.6s ease;
}

.button-split-text .char.active,
.split-text .char.active {
    transform: rotateX(0deg);
    opacity: 1;
}

.button-split-text .space,
.split-text .space {
    display: inline-block;
    width: 0.3em;
}

.button-split-text .char {
    display: inline-block;
    transition: transform 0.35s ease;
}

.button-split-text:hover .char {
    transform: translateX(calc(var(--i) * 2px));
}

.button-split-text i {
    margin-right: 32px !important;
    transition: all 0.35s;
}

.button-split-text:hover i {
    transform: translateX(10px);
}

.button.is-link:hover,
.button.is-underline:hover {
    color: var(--fs-experimental-link-color-hover);
}

/*************** MENU OVERLAY ***************/
.hamburger-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
}

.hamburger_type-dots {
    position: relative;
    width: 21px;
    height: 21px;
    cursor: pointer;
    margin-right: 16px;
}

.hamburger_type-dots span {
    position: absolute;
    width: 3px;
    height: 3px;
    -webkit-transition-property: opacity, border-radius, -webkit-transform;
    transition-property: opacity, border-radius, -webkit-transform;
    transition-property: transform, opacity, border-radius;
    transition-property: transform, opacity, border-radius, -webkit-transform;
    -webkit-transition-duration: 1s;
    transition-duration: 1s;
    -webkit-transition-timing-function: cubic-bezier(0.75, 0, 0.25, 1);
    transition-timing-function: cubic-bezier(0.75, 0, 0.25, 1);
    border-radius: 50%;
    background-color: currentColor;
}

.hamburger_type-dots span:nth-child(odd) {
    left: 0;
}

.hamburger_type-dots span:nth-child(2n) {
    left: calc(50% - 1.5px);
}

.hamburger_type-dots span:nth-child(3),
.hamburger_type-dots span:nth-child(6),
.hamburger_type-dots span:nth-child(9) {
    left: calc(100% - 3px);
}

.hamburger_type-dots span:nth-child(7),
.hamburger_type-dots span:nth-child(8),
.hamburger_type-dots span:nth-child(9) {
    top: calc(100% - 3px);
}

.hamburger_type-dots span:nth-child(4),
.hamburger_type-dots span:nth-child(5),
.hamburger_type-dots span:nth-child(6) {
    top: calc(50% - 1.5px);
}

.hamburger_type-dots span:first-child,
.hamburger_type-dots span:nth-child(2),
.hamburger_type-dots span:nth-child(3) {
    top: 0;
}

.hamburger_type-dots span:first-child,
.hamburger_type-dots span:nth-child(7) {
    -webkit-transform-origin: left center;
    transform-origin: left center;
}

.hamburger_type-dots span:first-child,
.hamburger_type-dots span:nth-child(2),
.hamburger_type-dots span:nth-child(3) {
    top: 0;
}

.hamburger_type-dots span:first-child,
.hamburger_type-dots span:nth-child(7) {
    -webkit-transform-origin: left center;
    transform-origin: left center;
}

.hamburger-text {
    font-size: 11px;
    letter-spacing: 0.6em;
    font-weight: 700;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    text-transform: uppercase;
    overflow: hidden;
}

.hamburger-text__item [class*='char'] {
    -webkit-transition: -webkit-transform 1s cubic-bezier(0.75, 0, 0.25, 1);
    transition: -webkit-transform 1s cubic-bezier(0.75, 0, 0.25, 1);
    transition: transform 1s cubic-bezier(0.75, 0, 0.25, 1);
    transition: transform 1s cubic-bezier(0.75, 0, 0.25, 1), -webkit-transform 1s cubic-bezier(0.75, 0, 0.25, 1);
}

.hamburger-wrapper:hover .hamburger_type-dots.hamburger span:nth-child(2) {
    -webkit-transform: translateY(9px);
    transform: translateY(9px);
}

.hamburger-wrapper:hover .hamburger_type-dots.hamburger span:nth-child(5) {
    -webkit-transform: translateX(9px);
    transform: translateX(9px);
}

.hamburger-wrapper:hover .hamburger_type-dots.hamburger span:nth-child(6) {
    -webkit-transform: translateX(-9px);
    transform: translateX(-9px);
}

.hamburger-wrapper:hover .hamburger_type-dots.hamburger span:nth-child(8) {
    -webkit-transform: translateY(-9px);
    transform: translateY(-9px);
}

.menu-opened .hamburger-text[data-trigger='menu'] .hamburger-text__item [class*='char'] {
    -webkit-transform: translateY(-104%);
    transform: translateY(-104%);
}

.hamburger-text__item [class*='char']:first-child {
    -webkit-transition-delay: 0.05s;
    transition-delay: 0.05s;
}

.hamburger-text__item [class*='char']:nth-child(2) {
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
}

.hamburger-text__item [class*='char']:nth-child(3) {
    -webkit-transition-delay: 0.15s;
    transition-delay: 0.15s;
}

.hamburger-text__item [class*='char']:nth-child(4) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
}

.hamburger-text__item [class*='char']:nth-child(5) {
    -webkit-transition-delay: 0.25s;
    transition-delay: 0.25s;
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:first-child {
    -webkit-transform: translate(2px, 1px) rotate(45deg) scaleX(4) scaleY(0.2);
    transform: translate(2px, 1px) rotate(45deg) scaleX(4) scaleY(0.2);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(2) {
    -webkit-transform: translateY(9px);
    transform: translateY(9px);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(3) {
    -webkit-transform: translate(-5.5px, 5px) rotate(-45deg) scaleX(4) scaleY(0.2);
    transform: translate(-5.5px, 5px) rotate(-45deg) scaleX(4) scaleY(0.2);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(5) {
    -webkit-transform: translateX(9px);
    transform: translateX(9px);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(6) {
    -webkit-transform: translateX(-9px);
    transform: translateX(-9px);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(7) {
    -webkit-transform: translate(2px, -1px) rotate(-45deg) scaleX(4) scaleY(0.2);
    transform: translate(2px, -1px) rotate(-45deg) scaleX(4) scaleY(0.2);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(8) {
    -webkit-transform: translateY(-9px);
    transform: translateY(-9px);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(9) {
    -webkit-transform: translate(-6px, -5.5px) rotate(45deg) scaleX(4) scaleY(0.2);
    transform: translate(-6px, -5.5px) rotate(45deg) scaleX(4) scaleY(0.2);
}

.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(2),
.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(4),
.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(5),
.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(6),
.menu-opened .hamburger_type-dots.hamburger[data-trigger='menu'] span:nth-child(8) {
    opacity: 0;
}

#fixed-menu .mfp-hide {
    display: block !important;
}

#fixed-menu {
    background-color: var(--color-black);
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    height: 0;
    transition: height 1s ease;
    overflow: hidden;
}

#fixed-menu .split-text-container {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    z-index: -1;
    color: #fff;
    width: 100%;
    opacity: 0.2;
}

#fixed-menu .split-text-container h2 {
    color: currentColor;
    font-size: 200px;
    white-space: nowrap;
    letter-spacing: 0;
    text-align: center;
    margin: 0;
}

#fixed-menu .split-text .char {
    transition: transform 1s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 1s ease;
}

#fixed-menu .mobile-sidebar {
    padding-top: 22rem;
    overflow: scroll;
    height: calc(100% - 3rem);
}

.logged-in #fixed-menu .mobile-sidebar {
    padding-top: 25rem;
}

#fixed-menu.active {
    height: 100%;
}

#fixed-menu.active~#header .header-bg-color {
    background-color: transparent;
}

#fixed-menu.active~#main {
    overflow: hidden;
}

.top-divider {
    border-color: rgb(248, 249, 250);
}

#fixed-menu .nav-vertical li+li {
    border: none;
    text-align: center;
}

#fixed-menu .nav-vertical li>a {
    font-size: 46px;
    font-weight: 400;
    position: relative;
    padding: 12px 0;
    white-space: nowrap;
    letter-spacing: 0;
    color: #8d8d8d;
    text-transform: initial;
    display: block;
    text-align: center;
    transition: all 0.75s;
    font-family: 'Didot', serif;
}

#fixed-menu .nav-vertical li:hover>a {
    letter-spacing: 5px;
    color: var(--color-white);
}

/*************** END MENU OVERLAY ***************/

/*************** HEADER ***************/
.header-logo-dark,
.header-logo-sticky,
.dark .header-logo,
.sticky .dark .header-logo-dark,
.sticky .has-sticky-logo .header-logo {
    display: none !important;
}

.dark .header-logo-dark,
.stuck .header-logo-sticky {
    display: block !important;
}

.nav-column>li>a,
.nav-dropdown>li>a,
.nav-vertical-fly-out>li>a,
.nav>li>a {
    color: #161616;
    transition: all 0.2s;
}

#header .nav>li>a {}

.nav-size-xsmall>li>a {
    font-size: 0.65em;
}

.header__lang-list {
    list-style: none;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
    text-transform: uppercase;
}

.header__lang-list .lang-list__item {
    margin: 0;
}

.header__lang-list .lang-list__item a {
    display: inline-block;
    padding: 10px;
    color: #161616;
    font-family: 'Muli';
    font-size: 11px;
    font-weight: 600;
    height: 54px;
    width: 54px;
    place-content: center;
    text-align: center;
}

.transparent .header__lang-list .lang-list__item a {
    color: var(--color-white);
}

.lang-list__pointer {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 48px;
    height: 48px;
    pointer-events: none;
    opacity: 0.2;
    -webkit-transition: transform 0.75s ease, width 0.75s ease, height 0.75s ease,
        opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.75s ease, width 0.75s ease, height 0.75s ease, opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);

    border: 1px solid currentColor;
    border-radius: 50%;
}

.lang-list__item.is-active {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    pointer-events: none;
}

.roll-hover-btn__container {
    overflow: hidden;
}

.roll-hover-btn__label {
    display: block;
    position: relative;
    white-space: nowrap;
    -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
}

.roll-hover-btn__label>p {
    margin-bottom: 0;
}

.roll-hover-btn:hover .roll-hover-btn__label {
    -webkit-transform: translateY(-105%);
    transform: translateY(-105%);
}

#header .phone-list__item a {
    color: #161616;
    font-size: 11px;
    font-weight: 700;
}

#header.transparent .phone-list__item a {
    color: var(--color-white);
}

.button.primary.is-outline:hover {
    background-color: transparent !important;
}

.button.primary.is-outline span {
    z-index: 2;
    position: relative;
}

.button.is-outline.is-xlarge {
    font-size: 1rem;
    line-height: 1.5;
    padding: 28px 40px;
    letter-spacing: 4px;
}

#header .button.primary.is-outline,
#header .button.primary.is-outline span {
    line-height: 1;
    font-size: 13px;
    font-weight: 700;
}

.button.primary.is-outline:before {
    position: absolute;
    inset: 0;
    z-index: 1;
    background-color: var(--fs-color-primary);
    content: '';
    -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
}

.button.primary.is-outline:hover:before {
    -webkit-transform-origin: top center;
    transform-origin: top center;
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
}

#header .header-action-btn {
    padding: 16px 32px;
    text-transform: initial;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
}

#header .flex-right .html_nav_position_text {
    width: calc(40% - 1.875rem);
    justify-content: center;
    display: flex;
}

/*************** END HEADER ***************/

/*************** FOOTER ***************/
.contacts-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.contacts-item__content p,
.contacts-item__title p {
    margin-bottom: 0;
}

#footer .contacts-item__title {
    margin-right: 5px;
}

#footer .ux-menu-link {
    margin-bottom: 35px !important;
}

#footer .ux-menu-link__link {
    transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    display: block;
    font-weight: 700;
    opacity: 0.7;
    font-size: 1.2rem;

    text-transform: uppercase;
    border: none;
    letter-spacing: 3px;
    padding: 0;
}

#footer .ux-menu-link .roll-hover-btn__container {
    height: 20px;
    line-height: 20px;
}

.img.fit-content {
    display: inline-block;
    width: fit-content !important;
    margin-bottom: 0 !important;
}

.footer-section .img.fit-content img {
    height: 65px;
    width: auto;
    border-radius: 16px;
}

.footer-section .img.fit-content {
    margin-right: 10px;
}

.footer-section .footer-main-row .info-col>.col-inner {
    margin-left: calc(16.66666% + 0.9375rem);
}

.absolute-footer {
    font-size: 1.3rem;

    position: relative;
}

.absolute-footer:before {
    position: absolute;
    top: 0;
    left: 50%;
    width: 142rem;
    max-width: calc(100% - 2 * 15px);
    height: 1px;
    content: '';
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    opacity: 0.1;
    background-color: #fff;
}

.absolute-footer .footer-primary {
    width: 50%;
    padding: 1rem;
}

.absolute-footer .copyright-footer {
    display: flex;
    gap: 3px;
    color: var(--color-white);
}

.absolute-footer .footer-secondary {
    width: 50%;
    padding: 1rem;
}

.absolute-footer .footer-secondary ul {
    list-style: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    font-size: 1.3rem;

    margin: 0;
    padding: 0;
    border: none;
}

.absolute-footer .footer-secondary ul li {
    margin-bottom: 0;
}

.absolute-footer .footer-secondary ul li:not(:last-child) {
    margin-right: 24px;
}

/*************** END FOOTER ***************/

/*************** HOME PAGE ***************/
.button_call {
    position: relative;
    display: inline-block;
    width: auto;
    padding: 8rem;
}

.button_call .roll-hover-btn__label {
    font-size: 10px;
    text-transform: uppercase;
    font-weight: bold;
    letter-spacing: 4px;
}

a.button_call .pulse:before,
a.button_call:before {
    position: absolute;
    top: calc(50% - 40px);
    right: auto;
    bottom: auto;
    left: calc(50% - 40px);
    width: 80px;
    height: 80px;
    content: '';
    -webkit-transform: none;
    transform: none;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation: pulse 4s linear infinite;
    animation: pulse 4s linear infinite;
    pointer-events: none;
    opacity: 0;
    border: 1px solid #fff;
    border-radius: 50%;
    background-color: transparent;
}

a.button_call .pulse:after,
a.button_call:after {
    position: absolute;
    top: calc(50% - 40px);
    right: auto;
    bottom: auto;
    left: calc(50% - 40px);
    width: 80px;
    height: 80px;
    content: '';
    -webkit-transform: none;
    transform: none;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation: pulse 4s linear infinite;
    animation: pulse 4s linear infinite;
    pointer-events: none;
    opacity: 0;
    border: 1px solid #fff;
    border-radius: 50%;
    background-color: transparent;
}

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

a.button_call .pulse:before {
    -webkit-animation-delay: 2s;
    animation-delay: 2s;
}

a.button_call .pulse:after {
    -webkit-animation-delay: 3s;
    animation-delay: 3s;
}

@keyframes pulse {
    0% {
        -webkit-transform: scale(0);
        transform: scale(0);
        opacity: 0;
    }

    50% {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 0.2;
    }

    100% {
        -webkit-transform: scale(2);
        transform: scale(2);
        opacity: 0;
    }
}

.info {
    font-family: 'Didot', serif;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 32px;
    color: #161616;
}

.info-item__top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
}

.info-item__main {
    font-size: 36px;
    font-weight: 700;
}

.info-item__sub {
    font-size: 18px;
    font-weight: 700;
    margin-left: 8px;
    text-transform: uppercase;
}

.info-item__bot {
    font-family: Muli, sans-serif;
    font-size: 14px;
    text-transform: capitalize;
}

.info-item__bot p {
    margin-bottom: 0;
}

.info__divider {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    height: 1px;
    margin: 0 40px;
    opacity: 0.5;
    background-color: currentColor;
}

.rooms-section {
    background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat left 10rem / 38% auto;
}

.rooms-slider .col.room-item.is-selected+.col>.col-inner,
.rooms-slider .col.room-item.is-selected>.col-inner {
    transform: translateY(-5rem);
    opacity: 1;
}

.rooms-slider .col.room-item>.col-inner {
    padding-top: 5rem;
    transition: all 0.75s;
    opacity: 0.5;
}

.icon-box p {
    margin-bottom: 0;
}

.row-counter {
    counter-reset: rowCounter;
}

.row-counter>.col>.col-inner {
    padding-left: 6rem;
    padding-bottom: 1.2rem;
}

.row-counter>.col>.col-inner::before {
    counter-increment: rowCounter;
    content: counter(rowCounter);
    position: absolute;
    top: 0;
    left: 0;
    font-size: 14px;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 3px solid #021621;
    background-color: #215b7b;
    color: #fff;
}

.row-counter>.col>.col-inner p {
    margin-bottom: 8px;
}

.layers {
    display: -ms-grid;
    display: grid;
    grid-template-areas: 'layers';
    -ms-grid-columns: 100%;
    -ms-grid-rows: 100%;
    grid-template-columns: 100%;
    -ms-flex-align: center;
}

.layers>* {
    grid-area: layers;
}

.service-hover-row>.service-item {
    visibility: hidden;
    -webkit-transition: visibility 0s 0.75s;
    transition: visibility 0s 0.75s;
}

.service-hover-row>.service-item.is-hovered {
    visibility: visible;
}

.service-hover-row>.service-item.is-active {
    visibility: visible;
    position: relative;
    z-index: 1000;
}

.service-hover-row>.service-item.is-active~.services__list-container {
    opacity: 0;
}

.service-hover-row>.service-item.is-active~.close-service-popup {
    opacity: 1;
}

.service-hover-row>.service-item .box .box-image .image-cover {
    transition: all 0.75s;
    width: 0;
    opacity: 0.5;
}

.dark .primary.is-link,
.dark .primary.is-outline,
.dark .primary.is-underline {
    color: var(--color-white);
}

.service-hover-row>.service-item.is-hovered .box .box-image .image-cover {
    width: 50%;
}

.service-hover-row>.service-item.is-active .box .box-image .image-cover {
    width: 100%;
    opacity: 1;
}

.service-hover-row>.service-item .box .box-text {
    opacity: 0;
    transition: all 0.75s;
    transform: translateY(100px);
}

.service-hover-row>.service-item .box .box-text .box-text-inner {
    padding: 3rem 2rem !important;
}

.service-hover-row>.service-item.is-active .box .box-text {
    opacity: 1;
    transform: translateY(0);
}

.service-hover-row .services__list-container>.col-inner {
    height: 100%;
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    margin: 0 0 0 auto;
    place-content: center;
}

.services__list-container {
    position: relative;
    z-index: 999;
}

.services__list-container .services__list {
    list-style: none;
    margin-bottom: 0;
}

.services__list-container .services__list li {
    margin: 0;
}

.services__list-container .services__list h3 {
    margin-bottom: 0;
}

.services__list-container .services__list .list__link {
    font-family: Didot, serif;
    font-weight: 700;
    line-height: 1.3em;
    font-weight: 400;
    position: relative;
    display: block;
    padding: 20px 72px 20px 0;
    cursor: pointer;
    -webkit-transition: all 0.75s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 0.75s cubic-bezier(0.165, 0.84, 0.44, 1);
    opacity: 0.5;
}

.services__list-container .services__list .list__link.is-hovered,
.services__list-container .services__list .list__link.is-active {
    opacity: 1;
    padding-left: 50px;
}

.list__link .dots {
    position: absolute;
    top: 50%;
    left: 0;
    opacity: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1),
        -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1),
        -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    pointer-events: none;
    opacity: 0.5;
}

.list__link .dots .dot {
    position: relative;
    width: 1px;
    height: 1px;
    -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    background-color: #fff;
}

.list__link .dots .dot:not(:last-child) {
    margin-right: 8px;
}

.list__link.is-hovered .dots .dot:first-child,
.list__link.is-active .dots .dot:first-child {
    -webkit-transform: translateX(-16px);
    transform: translateX(-16px);
}

.list__link.is-hovered .dots,
.list__link.is-active .dots {
    -webkit-transform: translateX(16px);
    transform: translateX(16px);
    opacity: 1;
}

.list__link .dots .dot:after,
.list__link .dots .dot:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    content: '';
    -webkit-transform-origin: left center;
    transform-origin: left center;
    background-color: #fff;
}

.list__link.is-hovered .dots .dot:first-child:before,
.list__link.is-active .dots .dot:first-child:before {
    -webkit-animation: bubble-1 1.5s cubic-bezier(0.3, 0.1, 0.3, 1) infinite;
    animation: bubble-1 1.5s cubic-bezier(0.3, 0.1, 0.3, 1) infinite;
}

.list__link.is-hovered .dots .dot:first-child:after,
.list__link.is-active .dots .dot:first-child:after {
    -webkit-animation: fly-1 1.5s cubic-bezier(0.75, 0, 0.25, 1) infinite;
    animation: fly-1 1.5s cubic-bezier(0.75, 0, 0.25, 1) infinite;
}

.list__link.is-hovered .dots .dot:nth-child(2),
.list__link.is-active .dots .dot:nth-child(2) {
    -webkit-transform: translateX(-8px);
    transform: translateX(-8px);
}

@keyframes bubble-1 {
    0% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }

    20% {
        -webkit-transform: scaleX(2);
        transform: scaleX(2);
    }

    40% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }

    100% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }
}

@keyframes fly-1 {
    0% {
        -webkit-transform: translateX(0) scaleX(1);
        transform: translateX(0) scaleX(1);
    }

    50% {
        -webkit-transform: translateX(34px) scaleX(4);
        transform: translateX(34px) scaleX(4);
    }

    70% {
        -webkit-transform: translateX(34px) scaleX(1);
        transform: translateX(34px) scaleX(1);
    }

    100% {
        -webkit-transform: translateX(34px) scaleX(1);
        transform: translateX(34px) scaleX(1);
    }
}

.close-service-popup {
    position: absolute;
    top: 0;
    right: 0;
    margin: 0;
    z-index: 1001;
    opacity: 0;
    transition: all 0.75s;
}

.packages-section {
    background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat right 10rem / 38% auto;
}

.packages-section .parallax-text {
    font-size: 152px;
    line-height: 1;
    letter-spacing: 0.2em;
    font-family: 'Didot', serif;
    text-transform: uppercase;
    white-space: nowrap;
    color: #161616;
    opacity: 0.05;
    text-align: center;
    max-width: 120rem;
    margin: 0 auto -12rem;
    transition: all 1.2s;
}

.packages-section .slider .flickity-slider>.row:nth-child(odd) {
    padding-top: 5rem;
    transition: padding 0.75s;
}

.contact-section {
    background: url(/wp-content/uploads/2025/12/overlay_dark-img.png) no-repeat right 3rem / 38% auto;
}

/*************** END HOME PAGE ***************/

/*************** CONTACT PAGE ***************/
.contact-row form .wpcf7-form-control-wrap {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 1.5rem;
}

form input[type='text'],
form input[type='email'],
form input[type='tel'],
form textarea {
    font-size: 1.2rem;
}

.contact-row form input[type='text'],
.contact-row form input[type='email'],
.contact-row form input[type='tel'],
.contact-row form textarea {
    box-shadow: none !important;
    border: none;
    resize: none;
    position: relative;
    border-bottom: 1px solid #e3e3e3;
    background-color: transparent;
    height: 5rem;
    margin-bottom: 0;
    padding: 2rem 0 0.5rem;
}

.contact-row form .floating .wpcf7-form-control-wrap:after {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    bottom: -1px;
    content: '';
    -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: left center;
    transform-origin: left center;
    pointer-events: none;
    border-bottom: 1px solid #161616;
}

.contact-row form .floating .wpcf7-form-control-wrap:has(input:focus):after,
.contact-row form .floating .wpcf7-form-control-wrap:has(textarea:focus):after {
    transform: none;
}

.wpcf7 label {
    letter-spacing: 0.4em;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.25;
    display: block;
}

.contact-row form .floating label {
    text-transform: uppercase;
    padding-right: 16px;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    -webkit-transform: translateY(0.8em);
    transform: translateY(0.8em);
}

.contact-row form .floating textarea:focus+label,
.contact-row form .floating input:focus+label {
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

form input[type='checkbox'] {
    display: none;
}

form .wpcf7-list-item-label {
    padding-left: 2.8rem;
    position: relative;
    padding-left: 2.8rem;
    font-size: 1.4rem;
    letter-spacing: 0;
    font-weight: 400;
    min-height: 2rem;
    line-height: 1.5;
    display: block;
}

form .wpcf7-list-item-label::before {
    content: '';
    border: 1px solid #161616;
    background-color: transparent;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    content: '';
    width: 2rem;
    height: 2rem;
}

form input:checked+.wpcf7-list-item-label::before {
    opacity: 1;
}

form .wpcf7-list-item-label::after {
    position: absolute;
    left: 6px;
    top: 2px;
    right: 0;
    bottom: 0;
    content: '\f00c';
    width: 1rem;
    height: 1rem;
    font-family: var(--FontAwesome);
    font-weight: 400;
    font-size: 1rem;
    opacity: 0;
    transition: opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
}

form input:checked+.wpcf7-list-item-label::after {
    opacity: 1;
}

form button[role='submit'] {
    font-size: 1.3rem;

    padding: 6px 32px;
    letter-spacing: 4px;
}

.contact-row .contacts-item .contacts-item__content {
    font-weight: 600;
    padding-left: 4px;
}

.contact-row .contacts-item .contacts-item__content a {
    color: inherit;
}

/*************** END CONTACT PAGE  ***************/

/*************** GALLERY PAGE ***************/
.nav>li>a {}

.filter-nav {
    position: relative;
    width: fit-content;
    margin: 0 auto;
}

.filter-nav>li {
    margin: 0 !important;
    border-bottom: 2px solid #f8f9fa !important;
    position: relative;
}

.filter-nav>li>a {
    display: inline-block;
    padding: 24px 16px;
    -webkit-transition: color 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: color 0.35s cubic-bezier(0.3, 0.1, 0.3, 1), opacity 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    opacity: 0.6;
    color: currentColor !important;
    font-family: 'Muli', sans-serif !important;
    font-weight: 400 !important;
    text-transform: initial;
    font-size: 1.4rem;
    opacity: 1;
}

.tab-list__line {
    position: absolute;
    left: 0;
    top: 0;
    height: 2px;
    background-color: #082d41;
    transition: transform 0.3s ease, width 0.3s ease;
}

#fixed-gallery {
    background-color: var(--color-black);
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    height: 0;
    transition: height 1s ease;
    overflow: hidden;
}

#fixed-gallery.active {
    height: 100%;
}

#fixed-gallery.active~#header .header-bg-color {
    background-color: transparent;
}

#fixed-gallery {
    display: flex;
    align-items: center;
    justify-content: center;
}

#fixed-gallery .container-fluid {
    width: 100%;
    padding-top: 12rem;
}

.logged-in #fixed-gallery .container-fluid {
    width: 100%;
    padding-top: 15rem;
}

#fixed-gallery .loader {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.loader {
    width: 60px;
    height: 60px;
    display: inline-block;
    position: relative;
}

.loader::after,
.loader::before {
    content: '';
    box-sizing: border-box;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: 2px solid #fff;
    position: absolute;
    left: 0;
    top: 0;
    animation: animloader 2s linear infinite;
}

.loader::after {
    animation-delay: 1s;
}

@keyframes animloader {
    0% {
        transform: scale(0);
        opacity: 1;
    }

    100% {
        transform: scale(1);
        opacity: 0;
    }
}

.flickity-prev-next-button {
    width: 8rem;
    height: 8rem;
}

.flickity-nav-count {
    font-size: 1.6rem;
}

.flickity-nav-count .line {
    margin: 0 0.5rem;
    opacity: 0.2;
}

.flickity-nav-count .total-slides {
    opacity: 0.2;
}

.dark .flickity-nav-count {
    color: var(--color-white);
}

#fixed-gallery .slider {
    padding-bottom: 2rem;
}

#fixed-gallery .slider .nav-count-container {
    width: 60%;
    margin: 3rem auto 0;
    display: flex;
    align-items: center;
    justify-content: end;
}

.flickity-prev-next-button.active-follow {
    position: fixed !important;
}

body.hide-cursor .active-follow {
    cursor: none !important;
}

.close-popup {
    position: absolute;
    top: 10rem;
    right: 3rem;
    z-index: 100;
    margin: 0;
    color: #fff;
    font-size: 2.8rem;
    padding: 0px;
    width: 4rem;
    height: 4rem;
    line-height: 4rem;
    border: none;
    min-height: 4rem;
}

.logged-in .close-popup {
    top: 13rem;
}

.gallery-section .section-bg img {
    width: 38%;
    right: 0;
    top: 4rem;
    left: auto;
    height: auto;
}

.gallery-section .gallery-element-wrapper .container {
    margin-bottom: 12rem;
}

.box-default:before {
    position: absolute;
    z-index: -1;
    top: 32px;
    bottom: 0;
    left: -32px;
    width: 100%;
    content: '';
    -webkit-transition: opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1),
        -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1), opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1), opacity 0.75s cubic-bezier(0.3, 0.1, 0.3, 1),
        -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    -webkit-transform: translate(32px, -100px) scaleY(0);
    transform: translate(32px, -100px) scaleY(0);
    -webkit-transform-origin: bottom center;
    transform-origin: bottom center;
    opacity: 0;
    background-color: #f8f9fa;
}

.dark .box-default:before {
    background-color: #072738;
}

.box-default:hover:before {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
}

.box .box-image img:nth-child(2):not(:hover) {
    opacity: 0;
}

.box-default .box-text h4 {
    text-transform: initial;
    padding-left: 3rem;
    transition: all 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
}

.box-default .box-text h4:before {
    position: absolute;
    top: 3.2rem;
    left: 0;
    width: 20px;
    height: 1px;
    content: '';
    background-color: currentColor;
    -webkit-transition: -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.75s cubic-bezier(0.3, 0.1, 0.3, 1);
}

.box-default:hover .box-text h4 {
    padding-left: 6rem;
}

.box-default:hover .box-text h4:before {
    -webkit-transform: translateX(20px) scaleX(2);
    transform: translateX(20px) scaleX(2);
}

/*************** END GALLERY PAGE ***************/

/*************** SERVICE PAGE ***************/

.flickity-prev-next-button {
    z-index: 9999 !important;
}

.banner-section .banner-row {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 100;
    max-width: 96rem;
    overflow: hidden;
    transform: translate(-50%, -50%);
}

.banner-section .banner-row>.col>.col-inner {
    text-align: center;
}

.banner-section .banner-row h1 {
    text-transform: uppercase;
}

.banner-section .banner-row>.col>.col-inner * {
    color: var(--color-white);
}

.flickity-page-dots .dot {
    height: 6px;
    width: 6px;
}

.flickity-page-dots {
    left: 0;
    right: 0;
    text-align: left;
    padding: 0 5rem;
}

.service-archive .slider .banner h2 {
    font-size: 56px;
    text-transform: uppercase;
}

.explore-text {
    font-size: calc(24px + ((12 * (100vw - 720px)) / 719));
    margin: 0;
    font-family: 'Greatvibes', sans-serif;
}

.alt-font-2 {
    font-family: 'Greatvibes', sans-serif;
}

.explore-text p {
    margin: 0;
}

.archive .service-item {
    margin-bottom: 12rem;
}

.service-item .box-normal {
    display: flex;
    align-items: center;
}

.service-item .box-normal .box-image {
    flex-basis: 52%;
    max-width: 52%;
}

.service-item .box-normal .box-image img:nth-child(2):not(:hover) {
    opacity: 0;
}

.service-item .box-normal .box-text {
    flex-basis: 48%;
    max-width: 48%;
    order: -1;
    background-color: #fff;
    margin-left: calc(8.33333% + 0.9375rem);
    margin-right: calc(-8.33333% + 0.9375rem);
    z-index: 1;
    padding: 0;
}

.service-item .box.box-side .box-image {
    flex-basis: 50%;
    max-width: 50%;
}

.service-item .box.box-side.right .box-text {
    flex-basis: 50%;
    max-width: 50%;
    background-color: transparent;
    margin-left: 0;
    margin-right: 0;
}

.service-item .box-normal.right .box-text {
    order: 2;
    margin-right: calc(8.33333% + 0.9375rem);
    margin-left: calc(-8.33333% + 0.9375rem);
}

.service-item .box-normal .box-text .box-text-inner {
    max-width: 50rem;
    padding: 12rem 2rem;
    margin: 0 auto;
}

.eyebrow {
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2em;

    margin-bottom: 24px;
    text-transform: uppercase;
    display: -webkit-box;
    display: -ms-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.eyebrow__line {
    width: 40px;
    height: 1px;
    background-color: currentColor;
    -webkit-transform-origin: left center;
    transform-origin: left center;
}

.eyebrow__item:not(:last-child) {
    margin-right: 16px;
}

.eyebrow__item:not(:last-child) {
    margin-right: 16px;
}

.eyebrow__item h5 {
    font-family: 'Mulish', sans-serif !important;
    font-weight: bold;
    letter-spacing: 3px;
    margin-bottom: 0;
}

.service-item .post-title {
    text-transform: uppercase;
}

.box-text {
    font-size: 1em;
}

.service-item .excerpt {
    text-align: justify;
    margin-bottom: 6.4rem;
    font-family: 'Cormorant', sans-serif;
}

.schedule {
    margin-bottom: 64px;
    margin: 0;
    font-size: 1.4rem;
}

.schedule-item {
    padding: 0 24px 24px 16px;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-left: 0 !important;
}

.schedule-item:after {
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background-color: currentColor;
    opacity: 0.1;
}

.schedule-item:not(:last-child) {
    margin-bottom: 32px;
}

.schedule-item__description {
    max-width: 60%;
    text-align: justify;
}

.service-item .buttons .button {
    text-transform: initial;
    background-color: transparent;
    border: none;
    box-shadow: none !important;

    font-size: 1.4rem;
    min-height: unset;
    line-height: 1.5;
}

.service-item .buttons .button i {
    font-size: 1.2rem;
    position: relative;
    top: -1px;
    transition: all 0.75s;
}

.service-archive {
    background-color: #f8f9fa;
}

.service-archive #post-list {
    padding: 4rem 0;
}

/* .button [class*='char'],
a.button [class*='char'] {
    -webkit-transition: -webkit-transform 0.15s cubic-bezier(0.3, 0.1, 0.3, 1) !important;
    transition: -webkit-transform 0.15s cubic-bezier(0.3, 0.1, 0.3, 1) !important;
    transition: transform 0.15s cubic-bezier(0.3, 0.1, 0.3, 1) !important;
    transition: transform 0.15s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.35s cubic-bezier(0.3, 0.1, 0.3, 1) !important;
} */

.button.button_simple:hover {
    color: var(--fs-experimental-link-color-hover) !important;
}

.button_with-icon-left>span,
a.button_with-icon-left>span {
    margin-left: 32px;
}

.button_with-icon-left:hover i {
    transform: translateX(8px);
}

.button.button_with-icon-left span {
    transition: transform 0.5s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.5s cubic-bezier(0.3, 0.1, 0.3, 1) !important;
}

.button_with-icon-left:hover span {
    transform: translateX(2px);
}

.service-single {
    background-color: #f8f9fa;
}

.service-single .entry-content {
    margin-bottom: 6.4rem;
}

.single-gallery-section .slider .flickity-slider .img {
    padding-top: 50px;
    transition: all 0.75s;
}

.single-gallery-section .slider .flickity-slider .img.is-selected {
    padding-top: 0;
}

.slider .flickity-prev-next-button:hover .arrow,
.slider .flickity-prev-next-button:hover svg {
    fill: var(--color-white);
}

.related-section {
    padding-top: 6rem;
}

.related-section .slider .flickity-slider .col.service-item {
    padding-top: 50px;
    transition: padding 0.75s;
}

.related-section .slider .flickity-slider>.col.is-selected,
.related-section .slider .flickity-slider>.col.is-selected+.col {
    padding-top: 0;
    opacity: 1;
}

.related-section .box-default:before {
    background-color: #fff;
}

/*************** END SERVICE PAGE ***************/

/*************** ROOM PAGE ***************/
.room-archive {
    background-color: #f8f9fa;
}

.room-item>.col-inner {
    background-color: var(--color-white);
}

.room-item .box.box-normal .box-text {
    padding: 80px 120px;
}

.room-item .box.box-normal .post-title {
    position: relative;
    margin-bottom: 4rem;
}

.room-item .box.box-normal .post-title:before {
    position: absolute;
    width: 20px;
    height: 1px;
    top: -40px;
    left: calc(50% - 10px);
    content: '';
    background-color: currentColor;
}

.facilities-items {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: rem;
}

.facilities-items .facilities-item {
    width: 25%;
    text-align: center;
    font-size: 1.4rem;
}

.facilities-items .facilities-item [class^='icon-'] {
    margin-bottom: 8px;
    font-size: 2rem;
}

.facilities-items .facilities-item span {
    display: block;
}

.room-item .button {
    padding: 24px 40px;
    font-size: 1rem;
    margin-top: 4rem;
    margin-bottom: 0;
    letter-spacing: 4px;
}

.page-filters {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    right: 15px;
    width: calc(50% - 30px);
    z-index: 100;
}

.page-filters__form-item {
    border: 1px solid #e3e3e3;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

label,
legend {
    display: block;
    font-size: 1em;
    font-weight: 400;
    margin-bottom: 0;
    color: #161616;
}

.page-filters__form-item:not(:first-child) {
    margin-left: -1px;
}

.dropdown,
.dropdown__title {
    position: relative;
}

.dropdown__title {
    position: relative;
    -webkit-transition: background-color 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: background-color 0.35s cubic-bezier(0.3, 0.1, 0.3, 1);
    font-weight: 600;
    font-size: 12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 16px 16px 16px 32px;
    cursor: pointer;
}

.dropdown__title.active {
    background-color: var(--color-white);
}

.dropdown__title .decorator {
    overflow: hidden;
    height: 20px;
}

.dropdown__title .decorator [class^='icon-'] {
    margin-left: 16px;
    display: block;
    font-size: 20px;
    -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: -webkit-transform 0.6s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.6s cubic-bezier(0.3, 0.1, 0.3, 1);
    transition: transform 0.6s cubic-bezier(0.3, 0.1, 0.3, 1), -webkit-transform 0.6s cubic-bezier(0.3, 0.1, 0.3, 1);
}

.dropdown__inner {
    overflow: hidden;
    position: absolute;
    top: 100%;
    left: -1px;
    min-width: calc(100% + 2px);
    z-index: 1;
    background-color: var(--color-white);
    font-size: 1.4rem;
    display: none;
}

.page-filters__form-item:first-child .dropdown__inner {
    min-width: 250px;
}

.dropdown-list {
    border: 1px solid #e3e3e3;
}

.custom-checkbox {
    position: relative;
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 14px 16px;
}

.custom-checkbox .decorator {
    opacity: 0;
    margin-right: 8px;
    transition: all 0.3s;
}

.custom-checkbox.active .decorator {
    opacity: 1;
}

.visually-hidden {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
}

.dropdown-list__item label .decorator {
    margin-right: 16px;
    color: #161616;
    font-size: 12px;
    position: relative;
    top: 2px;
}

.custom-checkbox__label .decorator:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    content: '';
    background-color: #fff;
    opacity: 1;
}

.dropdown-list__item label .text {
    white-space: nowrap;
}

#archive-container {
    padding-top: 4rem;
}

#archive-container #post-list .col.room-item {
    margin-top: 3rem;
}

#archive-container #post-list .col.room-item:nth-child(1) {
    margin-top: 0;
}

#archive-container #post-list .col.room-item:nth-child(2) {
    margin-top: 8rem;
}

#archive-container .content-none {
    margin-top: 12rem;
}

.content-none h1 {
    font-size: 3.2rem;
}

.banner-section .slider .img .img-inner {
    min-height: 100vh;
}

.banner-section .banner-row>.col>.col-inner {
    max-width: 96rem;
    margin: 0 auto;
}

.room-single {
    background-color: #f8f9fa;
}

.room-single .facilities-items {
    max-width: 40rem;
    margin: 8rem auto 0;
}

.text-justify {
    text-align: justify;
}

.col.large-offset-2>.col-inner {
    padding-left: calc(33.332% + 0.9375rem);
}

.facilities__title {
    font-size: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 64px;
    font-family: 'Mulish', sans-serif;
}

.facilities__title .line {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 40px;
    height: 1px;
    margin-top: 0.5em;
    margin-right: 16px;
    background-color: currentColor;
}

.facilities__title h5 {
    font-family: inherit;
    line-height: 1.2em;
    text-transform: uppercase;
    letter-spacing: 0.4em;
}

.facilities-col .facilities__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    font-size: 1.4rem;
}

.facilities-col .facilities__content .facilities__item {
    width: calc(50% - 30px);
    margin: 1.5rem;
}

.facilities-col .facilities__content i {
    font-size: 2rem;
    margin-right: 12px;
}

.facilities-col>.col-inner {
    background-color: var(--color-white);
    padding: 3rem;
}

.facilities-col .facilities {
    max-width: 45rem;
    margin: 0 auto;
    padding: 3.4rem 0;
}

.facilities-col .facilities .button {
    margin-top: 3rem;
}

.room-single .room-content-col h2 {
    margin-bottom: 4rem;
}

.room-single .room-content {
    margin-bottom: 64px;
}

.room-single .banner-section {
    margin-bottom: 5rem;
}

.row.align-justify {
    justify-content: space-between;
}

.room-single .additonal-info-section {
    background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat top right / 38% auto;
    margin-top: -8rem;
    padding-top: 11rem;
}

.section-title {
    margin-bottom: 4rem;
    display: block;
}

.section-title :is(h1, h2, h3, h4, h5, h6) {
    margin-bottom: 0;
}

:is(h1, h2, h3, h4, h5, h6) .alt-font-2 {
    text-transform: initial;
}

.slider-nav-push:not(.slider-nav-reveal) .flickity-prev-next-button {
    margin-top: 0;
}

/*************** END ROOM PAGE ***************/

/*************** TEAM PAGE ***************/
.sub-title {
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2em;
    text-transform: uppercase;
    letter-spacing: 0.4em;
    position: relative;
    padding-left: 5.6rem;
}

.sub-title:after {
    content: '';
    width: 40px;
    height: 1px;
    margin-right: 16px;
    display: inline-block;
    background-color: currentColor;
    position: absolute;
    top: 5px;
    left: 0;
}

.family-section {
    background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat center right / 38% auto;
}

/*************** END TEAM PAGE ***************/

/*************** ABOUT PAGE ***************/
.history-steps-section {
    position: fixed;
    inset: 0;
}

.history-steps-section .history-step.active {
    display: block;
    text-align: center;
}

.history-steps-section .history-step {
    display: none;
}

.history-steps-section .history-step h2 {
    perspective: 1000px;
    white-space: nowrap;
    pointer-events: none;
    color: #072738;
    font-family: 'Didot', serif;
    line-height: 0.9em;
    position: absolute;
    z-index: -1;
    top: calc(50% - 0.5em);
    left: 0;
    font-size: calc(100px + ((150 * (100vw - 720px)) / 719));
    width: 100%;
    -webkit-transition: -webkit-transform 2s cubic-bezier(0.75, 0, 0.25, 1);
    transition: -webkit-transform 2s cubic-bezier(0.75, 0, 0.25, 1);
    transition: transform 2s cubic-bezier(0.75, 0, 0.25, 1);
    transition: transform 2s cubic-bezier(0.75, 0, 0.25, 1), -webkit-transform 2s cubic-bezier(0.75, 0, 0.25, 1);
    text-align: center;
}

.history-slider .slider,
.deny-last.slider,
.deny-last .slider,
.slider-container .slider {
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.slider-container .flickity-viewport,
.history-slider .flickity-viewport,
.deny-last.slider .flickity-viewport,
.deny-last .slider .flickity-viewport {
    overflow: visible !important;
}

.show-all-items .slider .flickity-slider>* {
    opacity: 1 !important;
}

.gap-3 .slider .flickity-slider>* {
    padding: 0 1.5rem;
}

.deny-last .slider .flickity-slider>.is-selected+div {
    opacity: 1 !important;
}

.has-hover .image-zoom-fade img {
    opacity: 1;
    transform: scale(1.1);
}

.has-hover:hover .image-zoom-fade img {
    transform: scale(1);
    opacity: 1 !important;
}

.flickity-button.next.disabled {
    display: none !important;
}

.particles-canvas {
    opacity: 0
}

#particles-canvas-threejs {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0
}

#particles-canvas-threejs canvas {
    width: 100%;
    height: 100%;
}

footer#footer {
    position: relative;
    z-index: 9999;
}

.wrap-three-slider {
    position: relative;
    overflow: hidden;
}

.wrap-three-slider .text-box .text-box-content {
    padding: 80px 15px;
}

.wrap-three-slider .text-box {
    position: absolute;
    bottom: 0;
    max-width: 1440px;
    width: 100% !important;
    z-index: 2;

}

.cover-slider__scene,
.cover-slider {
    min-height: 650px;
}

.wrap-three-slider .slider-nav {
    position: absolute;
    z-index: 1;
    bottom: 40px;
    left: 40px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-transform: none;
    transform: none;
    list-style: none;
    margin: 0;
}

.wrap-three-slider .slider-nav li {
    list-style: none;
    margin: 0;
}

.wrap-three-slider .slider-nav li span {
    display: block;
    padding: 16px;
    cursor: pointer;
}

.wrap-three-slider .slider-nav li span:before {
    display: block;
    width: 5px;
    height: 5px;
    content: "";
    -webkit-transition: opacity .35s cubic-bezier(.3, .1, .3, 1);
    transition: opacity .35s cubic-bezier(.3, .1, .3, 1);
    opacity: .66;
    border-radius: 50%;
    background-color: #fff;
}

.wrap-three-slider .slider-nav li span.active::before,
.wrap-three-slider .slider-nav li span:hover::before {
    opacity: 1;
}

.cover-slider__nav {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 50%;
}

.cover-slider__nav_next {
    left: auto;
    right: 0;
}

.cover-slider__nav {
    cursor: url(./assets/icons/cursor-prev.svg) 15 28, pointer;
}

.cover-slider__nav_next {
    cursor: url(./assets/icons/cursor-next.svg) 22 28, pointer;
}

.button.primary.btn-pulse {
    margin: 0;
    background: transparent !important;
    border: 0;
    padding: 32px;
    font-size: 12px;
    line-height: 1;
    box-shadow: unset !important;
}

.button.primary.btn-pulse span:before,
.button.primary.btn-pulse:before {
    position: absolute;
    top: calc(50% - 40px);
    right: auto;
    bottom: auto;
    left: calc(50% - 40px);
    width: 80px;
    height: 80px;
    content: '';
    -webkit-transform: none;
    transform: none;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation: pulse 4s linear infinite;
    animation: pulse 4s linear infinite;
    pointer-events: none;
    opacity: 0;
    border: 1px solid #fff;
    border-radius: 50%;
    background-color: transparent;
}

.button.primary.btn-pulse span:after,
.button.primary.btn-pulse:after {
    position: absolute;
    top: calc(50% - 40px);
    right: auto;
    bottom: auto;
    left: calc(50% - 40px);
    width: 80px;
    height: 80px;
    content: '';
    -webkit-transform: none;
    transform: none;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation: pulse 4s linear infinite;
    animation: pulse 4s linear infinite;
    pointer-events: none;
    opacity: 0;
    border: 1px solid #fff;
    border-radius: 50%;
    background-color: transparent;
}

.button.primary.btn-pulse:before {
    -webkit-animation-delay: 2s;
    animation-delay: 2s;
}

.button.primary.btn-pulse:after {
    -webkit-animation-delay: 3s;
    animation-delay: 3s;
}

.banner-text-ex {
    max-width: 900px;
    margin: 0 auto;
}

.parallax-image__item {
    position: relative;
    width: 100%;
}

.parallax-image__item>* {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    aspect-ratio: unset !important;

}

/*************** END ABOUT PAGE ***************/

@media only screen and (min-width: 1024px) {
    .header-full-width .container {
        padding: 0 5rem;
    }
}

@media (min-width: 1440px) {

    .h1,
    h1 {
        font-size: 70px;
    }

    .h1 span,
    .h2,
    h1 span,
    h2 {
        font-size: 36px;
    }

    .h3,
    h3 {
        font-size: 32px;
    }

    .h4,
    h4 {
        font-size: 26px;
    }

    .page-wrapper {
        padding-top: 60px;
    }

    body {
        font-size: 1.9rem !important;
    }
}

@media only screen and (max-width: 1023px) {

    /*************** ADD TABLET CSS HERE  ***************/
    #fixed-menu .mobile-sidebar {
        padding-top: 14rem;
    }

    .logged-in #fixed-menu .mobile-sidebar {
        padding-top: 16rem;
    }

    #fixed-menu .nav-vertical li>a {
        font-size: 36px;
        padding: 8px 0;
    }

    #fixed-menu .split-text-container h2 {
        font-size: 150px;
    }

    .responsive-img.img .image-cover {
        padding-top: 56.25% !important;
    }

    .history-slider .slider,
    .deny-last.slider,
    .deny-last .slider,
    .slider-container .slider {
        max-width: 80% !important;
    }

    .info {
        margin-bottom: 0;
        color: var(--color-white);
    }

    .select-resize-ghost,
    .select2-container .select2-choice,
    .select2-container .select2-selection,
    input[type='date'],
    input[type='email'],
    input[type='number'],
    input[type='password'],
    input[type='search'],
    input[type='tel'],
    input[type='text'],
    input[type='url'],
    select,
    textarea {
        font-size: 1.6rem;
    }

    .col.large-offset-2>.col-inner {
        padding-left: 0;
    }

    .service-hover-row .services__list-container>.col-inner {
        flex-basis: 100%;
        max-width: 100%;
    }

    .family-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat center right / 70rem auto;
    }

    .contact-section {
        background: url(/wp-content/uploads/2025/12/overlay_dark-img.png) no-repeat right 3rem / 70rem auto;
    }

    .packages-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat right 4rem / 70rem auto;
    }

    .room-single .additonal-info-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat top right / 70rem auto;
    }

    .packages-section .slider .flickity-slider>.row,
    .packages-section .slider .flickity-slider>.row:nth-child(odd) {
        padding-top: 3rem;
    }

    .packages-section .slider .flickity-slider>.row.is-selected,
    .packages-section .slider .flickity-slider>.row.is-selected+.row {
        padding-top: 0;
    }

    .packages-section .parallax-text {
        display: none;
    }

    .footer-section .footer-main-row .info-col>.col-inner {
        margin-left: 0;
    }

    .medium-text-center {
        text-align: center !important;
    }

    #footer .contacts-item {
        justify-content: center;
    }

    .absolute-footer .footer-secondary,
    .absolute-footer .footer-primary {
        width: 100%;
        text-align: center;
    }

    .absolute-footer .copyright-footer {
        justify-content: center;
    }

    .footer-section .img.fit-content img {
        height: 48px;
        border-radius: 12px;
    }

    .page-filters {
        position: relative;
        right: 0;
        width: 100%;
        margin-bottom: 3rem;
    }

    .facilities-col .facilities {
        max-width: 100%;
        padding: 3rem 0;
    }

    .facilities-col .facilities__content .facilities__item {
        width: calc(33.33% - 30px);
    }

    .related-section {
        padding-top: 3rem;
    }

    .service-item .box-normal {
        flex-wrap: wrap;
    }

    .box-normal.box-service .box-image,
    .box-normal.box-service .box-text {
        flex-basis: 100%;
        max-width: 100%;
    }

    .box-normal.box-service .box-image .image-cover {
        padding-top: 56.25% !important;
    }

    .service-item .box-normal.box-service .box-text {
        order: 2;
        margin-left: 0;
        margin-right: 0;
    }

    .service-item .box-normal .box-text .box-text-inner {
        max-width: 100%;
        padding: 1.5rem 0;
    }

    .archive .box-normal.box-service .box-text {
        background-color: transparent;
    }

    .archive .service-item {
        margin-bottom: 3rem;
    }

    .gallery-box .box-image .image-cover {
        padding-top: 56.25% !important;
    }

    .gallery-section .gallery-element-wrapper .container {
        margin-bottom: 5rem;
    }
}

@media only screen and (max-width: 623px) {

    /*************** ADD MOBILE ONLY CSS HERE  ***************/
    #fixed-menu .mobile-sidebar {
        padding-top: 12rem;
    }

    .logged-in #fixed-menu .mobile-sidebar {
        padding-top: 14rem;
    }

    #fixed-menu .nav-vertical li>a {
        font-size: 28px;
        padding: 5px 0;
    }

    #fixed-menu .split-text-container h2 {
        font-size: 120px;
    }

    .room-item .box.box-normal .box-text {
        padding: 20px 30px;
    }

    .room-item .button {
        padding: 12px 24px;
        margin-top: 2rem;
    }

    .row-slider .flickity-prev-next-button {
        opacity: 1;
        width: 50px !important;
    }

    .page-filters {
        flex-direction: column;
        gap: 2rem;
    }

    .page-filters__form-item:first-child .dropdown__inner {
        left: -1px;
        right: -1px;
    }

    .weather-info-col {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 100;
    }

    .info {
        margin-bottom: 0;
        color: var(--color-white);
        -webkit-box-align: end;
        align-items: flex-end;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        flex-direction: column;
    }

    .info__item {
        margin-bottom: 0px;
        text-align: right;
    }

    .info-item__main {
        font-size: 24px;
    }

    .info-item__sub {
        font-size: 14px;
    }

    .info-item__bot {
        font-size: 12px;
    }

    .slider-wrapper .flickity-prev-next-button {
        display: block;
        width: 5rem;
        height: 5rem;
    }

    #header .header-action-btn {
        padding: 12px 24px;
    }

    .rooms-slider .col.room-item.is-selected+.col>.col-inner {
        transform: translateY(0rem);
    }

    .rooms-slider .col.room-item>.col-inner {
        padding-top: 3rem;
    }

    .rooms-slider .col.room-item.is-selected>.col-inner {
        transform: translateY(-3rem);
    }

    .rooms-slider .col.room-item .image-cover {
        padding-top: 56.25% !important;
    }

    .eyebrow {
        margin-bottom: 12px;
    }

    .rooms-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat center 10rem / 100% auto;
    }

    .family-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat center right / 100% auto;
    }

    .contact-section {
        background: url(/wp-content/uploads/2025/12/overlay_dark-img.png) no-repeat right 3rem / 100% auto;
    }

    .packages-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat right 4rem / 100% auto;
    }

    .room-single .additonal-info-section {
        background: url(/wp-content/uploads/2025/12/overlay-img.png) no-repeat top right / 100% auto;
    }

    .service-item .box.box-side .box-image {
        display: none;
    }

    .service-item .box.box-side.right .box-text {
        flex-basis: 100%;
        max-width: 100%;
    }

    .service-item .box-normal .box-text .box-text-inner {
        max-width: 100%;
    }

    .schedule,
    .facilities__title .room-single .room-content,
    .service-item .excerpt,
    .service-single .entry-content {
        margin-bottom: 3.2rem;
    }

    .packages-section .slider .flickity-slider>.row.is-selected+.row {
        padding-top: 3rem;
    }

    #footer .ux-menu-link {
        margin-bottom: 24px !important;
    }

    .room-single .facilities-items {
        max-width: 100%;
        margin: 4rem auto 0;
    }

    .facilities-items .facilities-item {
        width: 50%;
        margin-bottom: 2rem;
    }

    .button.is-outline.is-xlarge {
        padding: 15px 24px;
    }

    .facilities-col .facilities__content .facilities__item {
        width: calc(50% - 30px);
    }
}

@media (max-width: 399px) {
    .facilities-col .facilities__content .facilities__item {
        width: 100%;
    }
}