@import url('https://fonts.googleapis.com/css2?family=Dosis:wght@300;400;500;600;700;800&family=Jost:wght@100;300;400;500;600;700&display=swap'); 

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

ol, ul {
    list-style: none
}

blockquote, q {
    quotes: none
}

blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none
}

:focus {
    outline: 0
}

ins {
    text-decoration: none
}

del {
    text-decoration: line-through
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

input, select, img, iframe {
    vertical-align: middle;
}

html {
    font-size: 125%;
}

body {
    font-family: 'Dosis', sans-serif;
    font-size: 16px;
    color: #5E5D56;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
}

body * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-touch-callout: none;
}

hr {
    border: none;
    border-bottom: 1px solid #999999;
    width: 30px;
    margin: 20px 0;
}

a {
    text-decoration: none;
    color: #333333;
}

.body_text a:hover {
    color: #C7B192;
}

/**************** FRAMEWORK ****************/
.full_height {
    height: 100%;
}

.full_width {
    width: 100%;
}

.absolute {
    position: absolute;
    top: 0;
    left: 0;
}

.relative {
    position: relative;
}

.toUppercase {
    text-transform: uppercase;
}

.break {
    margin-top: 60px;
}

.double_break {
    margin-top: 80px;
}

aside {
    margin-top: 150px;
    overflow: hidden;
}

.row {
    width: 100%;
    float: left;
}

h1, h2, h3, h4 {
    font-weight: 400;
}

.scroll_transition {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.native-scroll .scroll_transition {
    -webkit-transition: none;
    transition: none;
}

.has_transition_600_quint {
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 600ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 600ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 600ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_800_quint {
    -webkit-transition: -webkit-transform 800ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 800ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 800ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 800ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1000_quint {
    -webkit-transition: -webkit-transform 1000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 1000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1500_quint {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1800_quint {
    -webkit-transition: -webkit-transform 1800ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 1800ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 1500ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_3000_quint {
    -webkit-transition: -webkit-transform 3000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 3000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 3000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 3000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_4000_quint {
    -webkit-transition: -webkit-transform 4000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 4000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 4000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 4000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_5000_quint {
    -webkit-transition: -webkit-transform 5000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 5000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    transition: transform 5000ms cubic-bezier(0.230, 1.000, 0.320, 1.000), opacity 5000ms cubic-bezier(0.230, 1.000, 0.320, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_600 {
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_800 {
    -webkit-transition: -webkit-transform 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1000 {
    -webkit-transition: -webkit-transform 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1200 {
    -webkit-transition: -webkit-transform 1200ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1200ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1200ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1200ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1500 {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1600 {
    -webkit-transition: -webkit-transform 1600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1800 {
    -webkit-transition: -webkit-transform 1800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_2000 {
    -webkit-transition: -webkit-transform 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_2500 {
    -webkit-transition: -webkit-transform 2500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 2500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 2000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_3000 {
    -webkit-transition: -webkit-transform 3000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 3000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 3000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 3000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_3500 {
    -webkit-transition: -webkit-transform 3500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 4500ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    transition: transform 3500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 4500ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_5000 {
    -webkit-transition: -webkit-transform 5000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 5000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    transition: transform 5000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 5000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_6000 {
    -webkit-transition: -webkit-transform 6000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 6000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    transition: transform 6000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 6000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1000_inout_quint {
    -webkit-transition: -webkit-transform 1000ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1000ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    transition: transform 1000ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1000ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1500_inout_quint {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    transition: transform 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_2500_inout_quint {
    -webkit-transition: -webkit-transform 2500ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    transition: transform 2500ms cubic-bezier(0.645, 0.045, 0.355, 1.000), opacity 1500ms cubic-bezier(0.645, 0.045, 0.355, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_600_inout {
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 600ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    transition: transform 600ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 600ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1000_inout {
    -webkit-transition: -webkit-transform 1000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 1000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    transition: transform 1000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 1000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_1500_inout {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 1500ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    transition: transform 1500ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 1500ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_2000_inout {
    -webkit-transition: -webkit-transform 2000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    transition: transform 2000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_3000_inout {
    -webkit-transition: -webkit-transform 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    transition: transform 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005), opacity 3000ms cubic-bezier(0.575, 0.005, 0.285, 1.005);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_3500_inout {
    -webkit-transition: -webkit-transform 3500ms cubic-bezier(0.860, 0.000, 0.070, 1.000), opacity 3500ms cubic-bezier(0.860, 0.000, 0.070, 1.000);
    transition: transform 3500ms cubic-bezier(0.860, 0.000, 0.070, 1.000), opacity 3500ms cubic-bezier(0.860, 0.000, 0.070, 1.000);
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.has_transition_zoom {
    -webkit-transition: transform 20000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    -moz-transition: transform 20000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    -o-transition: transform 20000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
    transition: transform 20000ms cubic-bezier(0.250, 0.460, 0.450, 0.940);
}

.transform_only {
    -webkit-transition-property: transform, opacity !important;
    transition-property: transform, opacity !important;
}

.transform_all {
    -webkit-transition-property: all !important;
    transition-property: all !important;
}

.no_transform {
    -webkit-transform: none !important;
    -moz-transform: none !important;
    -o-transform: none !important;
    transform: none !important;
}

.no_opacity {
    opacity: 0 !important;
    pointer-events: none;
}

.no_visibility {
    visibility: hidden;
}

.no_width {
    transform: scale(0, 1);
}

.no_height {
    transform: scale(1, 0);
}

.disabled {
    pointer-events: none;
}

.top_single {
    opacity: 0 !important;
    -webkit-transform: translateY(15px);
    transform: translateY(15px);
    pointer-events: none;
}

.top_double {
    opacity: 0 !important;
    -webkit-transform: translateY(35px);
    transform: translateY(35px);
}

.top_hidden {
    -webkit-transform: translateY(101%);
    transform: translateY(101%);
}

.top_translated {
    -webkit-transform: translateY(300px);
    transform: translateY(300px);
}

.top_translated_less {
    -webkit-transform: translateY(150px);
    transform: translateY(150px);
}

.top_translated_full {
    -webkit-transform: translateY(100%);
    transform: translateY(100%);
}

.left_translated {
    -webkit-transform: translateX(-100px);
    transform: translateX(-100px);
    opacity: 0;
}

.bottom_hidden {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
}

.hidden_by_scaling_full {
    -webkit-transform: scale(0.00) !important;
    transform: scale(0.00) !important;
    pointer-events: none;
}

.hidden_by_scaling_low {
    -webkit-transform: scale(0.95) !important;
    transform: scale(0.95) !important;
    pointer-events: none;
    opacity: 0;
}

.hidden_by_scale_up {
    -webkit-transform: scale(1.05) !important;
    transform: scale(1.05) !important;
    pointer-events: none;
    opacity: 0;
}

.hidden_from_left {
    transform: translateX(-20px);
    opacity: 0;
}

.hidden_from_right {
    transform: translateX(20px);
    opacity: 0;
}

.no_overflow {
    overflow: hidden;
}

.no_transition {
    -webkit-transition: none !important;
    transition: none !important;
}

.mobile_only {
    display: none;
}

.covered {
    overflow: hidden;
    position: relative;
    will-change: transform;
}

.cover.grey {
    background: #EAEAEC;
}

.cover.white {
    background: #FFFFFF;
}

.covered .content.hidden {
    -webkit-transform: translateX(-30%);
    transform: translateX(-30%);
    visibility: hidden;
}

.covered div.content {
    width: 100%;
    height: 100%;
    visibility: visible;
    padding: 1px 0;
    box-sizing: border-box;
    height: 360px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.content.no_fix {
    top: 1px;
    position: relative;
}

.covered .content>.body {
    position: relative;
}

.cover {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    background: inherit;
    left: calc(-100% - 1px);
    top: 0;
}

.cover.hidden {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
}

.covered.vertical .cover {
    left: 0;
    top: 100%;
}

.covered.vertical .cover.hidden {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
}

.covered.vertical .content.hidden {
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
}

.covered.reverse .cover {
    left: 100%;
}

.covered.reverse .content.hidden {
    -webkit-transform: translateX(30%);
    transform: translateX(30%);
}

.covered.reverse .cover.hidden {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
}

.text_center {
    text-align: center;
}

.text_right {
    text-align: right;
}

.tablet_show {
    display: none;
}

/****************************************/
/******************* HOME  ***************/
#main {
    position: relative;
    height: 100vh;
    width: 100%;
    overflow: hidden;
}

#main.out {
    transform: translateX(100px);
}

#main_scroller {
    position: relative;
    -webkit-backface-visibility: hidden;
    -webkit-perspective: 1000;
}

#main_veil {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    transform-origin: right;
    background: #FFFFFF;
    z-index: 100;
}

body.browsing {
    opacity: 0;
    -webkit-transition: transform 1200ms cubic-bezier(0.770, 0.000, 0.175, 1.000), opacity 500ms cubic-bezier(0.165, 0.840, 0.440, 1.000) !important;
    transition: transform 1200ms cubic-bezier(0.770, 0.000, 0.175, 1.000), opacity 500ms cubic-bezier(0.165, 0.840, 0.440, 1.000) !important;
}

.iScrollIndicator {
    -webkit-transition: all 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000) !important;
    transition: all 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000) !important;
    background: #796f66 !important;
    border: none !important;
    border-radius: 0 !important;
}

.iScrollVerticalScrollbar {
    width: 10px !important;
}

.veil {
    opacity: 0.4;
    background: #000000;
    transform-origin: left;
}

#header {
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 1;
    pointer-events: none;
    will-change: transform;
}

.menu_controller {
    position: absolute;
    top: 18px;
    left: 22px;
    pointer-events: all;
    cursor: pointer;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 20px;
    transition: 0.2s;
}

.menu_controller .menu_button {
    padding: 6px 11px 5px 14px;
    cursor: pointer;
    border-radius: 30px;
    border: solid 1px white;
    transition: 0.2s;
}

.menu_controller .lang_switch {
    cursor: pointer;
    color: #FFF;
    letter-spacing: 1px;
    display: flex;
    gap: 15px;
    left: 13px;
    padding-right: 20px;
    position: relative;
    top: 0;
    padding-left: 20px;
    border-left: solid 1px #ffffff6e;
    align-items: center;
}

.menu_controller .lang_switch li {
    font-size: 17px;
    cursor: pointer;
    transition: 0.2s;
    font-weight: 500;
    padding: 3px 0px;
}

.menu_controller .lang_switch li:hover {
    opacity: 0.5;
}

.menu_controller .vertical {
    background: #36342C;
    width: 68px;
    height: 100%;
    transform-origin: top;
}

.white_button_separator {
    width: 60px;
    height: 4px;
    background: #FFFFFF;
    margin-top: 3px;
    margin-bottom: 2px;
}

.menu_controller.force_white .white_button_separator {
    background: #FFFFFF !important;
}

.menu_controller.force_white .button_text {
    color: #FFFFFF !important;
}

.white_button_separator.no_width {
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.button_text {
    color: #FFFFFF;
    letter-spacing: 2.5px;
    font-weight: 400;
    font-size: 16px;
    transition: 0.2s;
    text-align: center;
}

.book_now_bar .book_button:hover .button_text {
    color: #0c0c0c !important;
}

.book_now_bar .book_button:hover .white_button_separator {
    background: #171717 !important;
}

.menu_button:hover .button_text {
    color: #C7B192 !important;
}

.menu_button:hover .white_button_separator {
    background: #C7B192 !important;
}

.book_now_bar {
    position: absolute;
    pointer-events: all;
    top: 0;
    right: 50px;
    height: 80px;
}

.book_now_bar.covid {
    top: calc(50% - 40px);
    height: 90px;
}

.book_now_bar .vertical {
    background: #018edf;
    width: 80px;
    height: 100%;
    transform-origin: top;
    box-shadow: -2px 2px 1px 0px black;
    border-radius: 0 0 5px 5px;
}

.book_now_bar.covid .vertical {
    width: 100px;
}

.book_button {
    position: absolute;
    top: 2px;
    left: 7px;
    cursor: pointer;
    text-align: center;
}

.book_now_bar.covid .book_button {
    top: 40px;
}

.book_now_bar .horizontal {
    background: #36342C;
    width: calc(50vw - 190px);
    height: 60px;
    position: absolute;
    bottom: 0;
}

.book_button .button_text._1 {
    letter-spacing: 1.5px;
}

.book_button .button_text._2 {
    letter-spacing: 1px;
    color: #ffffff;
    font-weight: 600;
    transition: 0.2s;
}

.close_button {
    position: absolute;
    top: 10px;
    right: 10px;
    cursor: pointer;
    padding: 10px;
}

.close_button .line {
    background: #FFFFFF;
    width: 1px;
    height: 20px;
    top: 0;
    position: absolute;
}

.close_button .line._1 {
    transform: rotate(45deg);
}

.close_button .line._2 {
    transform: rotate(-45deg);
}

.call_now {
    display: none;
}

.overlay_panel {
    position: fixed;
    top: 0;
    left: 0;
    background: #FFFFFF;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
}

.overlay_panel.hidden {
    opacity: 0;
    pointer-events: none;
    -webkit-transition: -webkit-transform 100000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 100000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.menu_vm {
    position: absolute;
    position: absolute;
    top: 136px;
    left: 9px;
}

.menu_vm a {
    pointer-events: none
}

; .menu_vm .small_vm {
    display: block;
}

.panel_logo {
    position: absolute;
    left: 50%;
    margin-left: -85px;
    top: 29px;
}

.panel_content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.panel_close {
    position: absolute;
    top: 29px;
    left: 29px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 2;
}

.panel_close .button_text {
    color: #36342C;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 3.5px;
    width: 48px;
    margin-top: 10px;
}

.x_close {
    width: 25px;
    position: relative;
    height: 25px;
    transform: rotateZ(45deg);
}

.x_close .line_1 {
    width: 25px;
    height: 3px;
    background: #36342C;
    position: absolute;
    top: 11px;
}

.x_close .line_2 {
    height: 25px;
    width: 3px;
    background: #36342C;
    position: absolute;
    top: 0px;
    left: 11px;
}

.x_close .line_1.no_width {
    -webkit-transition: -webkit-transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.x_close .line_2.no_height {
    -webkit-transition: -webkit-transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

#menu_side {
    position: relative;
    right: 29px;
    width: 120px;
}

#menu_side li:first-child {
    margin-top: 0;
}

#menu_side li {
    text-align: right;
    letter-spacing: 4px;
    font-weight: 700;
    margin-top: 10px;
    cursor: pointer;
}

#menu_side li.double_break {
    margin-top: 60px;
}

#menu_book {
    position: relative;
    left: 29px;
    width: 120px;
}

#menu_book .book_button {
    position: initial;
    left: auto;
    top: auto;
    width: 44px;
}

#menu_book .button_text {
    color: #36342C;
    font-weight: 700
}

#menu_book .white_button_separator {
    background: #36342C;
}

#menu_container {
}

.menu_area {
    position: relative;
    margin-top: 146px;
}

.menu_section {
    position: relative;
    height: 71px;
}

.menu_section .macro {
    padding: 15px 0;
    width: 460px;
    cursor: pointer;
}

.menu_section .macro p, .menu_section .macro a {
    font-size: 34px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 1.4px;
    text-align: right;
    color: #5f5f5f;
    display: block;
    font-weight: 400;
}

.menu_section .detail {
    position: relative;
    margin-left: 570px;
    top: -54px;
    box-sizing: border-box;
    width: 460px;
}

.detail_border {
    height: calc(100% + 64px);
    width: 1px;
    position: absolute;
    background: #CEBEAB;
    left: -56px;
    top: -30px;
    transform: scale(1, 0);
    -webkit-transition: -webkit-transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.menu_trail {
    position: absolute;
    height: calc(100% + 32px);
    width: 1px;
    background: #EDE8E1;
    left: 514px;
    top: -13px;
}

.menu_section.active {
    opacity: 1;
    z-index: 1;
}

.menu_section.active .detail_border {
    transform: scale(1, 1);
    -webkit-transition: -webkit-transform 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1000ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.menu_section.greyed .macro {
    opacity: 0.5;
}

.menu_section.active .submenu_item {
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.submenu_item {
    -webkit-transition: -webkit-transform 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 800ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    opacity: 0;
    padding: 10px 0;
    transform: translateY(15px);
    pointer-events: none;
    cursor: pointer;
}

.menu_section.active .submenu_item.active, .menu_section.active .submenu_item:hover {
    opacity: 1 !important;
}

.menu_section.active .submenu_item.visible {
    opacity: 1;
    transform: translateY(0px);
    pointer-events: all;
}

.menu_section.active .submenu_item.visible.greyed {
    opacity: 0.5;
}

.menu_section .detail ul li a {
    color: #000;
    font-size: 18px;
    letter-spacing: 2px;
    font-weight: 400;
    font-family: 'Dosis', sans-serif;
}

#top {
    height: 100vh;
    position: relative;
    display: flex;
}

.top_container {
    height: calc(100vh + 140px);
    overflow: hidden;
}

#index #top {
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}

article {
    margin-top: 300px;
    min-height: 500px;
}

#content.no_margin_top, article.no_margin_top {
    margin-top: 0;
}

.top_img {
    height: calc(100% + 140px);
    position: absolute;
    pointer-events: none;
    overflow: hidden;
    width: 100%;
    left: 0;
}

.top_img_container {
    transform-origin: right;
    height: 100%;
}

.top_img_container.scaled_up {
    transform: scale(1.05);
}

.top_bars {
    width: calc(100% - 22px);
    height: 60px;
    top: calc(100% + 139px);
    position: absolute;
    left: 22px;
    display: flex;
}

.top_bars .left {
    width: calc(50vw - 190px);
    height: 100%;
    background: #36342C;
    transform-origin: left;
}

.top_bars .right {
    background: #36342C;
    width: calc(50vw + 168px);
    height: 100%;
}

.top_bars .brown {
    background: #36342C;
    width: 100%;
    height: 100%;
}

.top_veil {
    background: #000000;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(100% + 140px);
    opacity: 0.3;
    pointer-events: none;
    will-change: transform;
}

#home_logo {
    width: 290px;
    position: relative;
    top: 25px;
    height: 140px;
}

.logo_square {
    position: relative;
    width: 72px;
    height: 72px;
    margin: auto;
    border-radius: 30%;
    overflow: hidden;
}

.logo_square .border {
    background: #FFFFFF;
    position: absolute;
}

.panel_logo .logo_square .border {
    background: rgb(117 166 190 / 39%);
}

.logo_square .border.no_width, .logo_square .border.no_height {
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.logo_square .border.top {
    width: 100%;
    height: 2px;
    top: 0;
    left: 0;
    transform-origin: left;
}

.logo_square .border.bottom {
    width: 100%;
    height: 2px;
    bottom: 0;
    left: 0;
    transform-origin: right;
}

.logo_square .border.left {
    width: 2px;
    height: 100%;
    bottom: 0;
    left: 0;
    transform-origin: bottom;
}

.logo_square .border.right {
    width: 2px;
    height: 100%;
    top: 0;
    right: 0;
    transform-origin: top
}

.logo_pieces {
    width: 280px;
}

.logo_pieces img {
    will-change: initial !important;
    backface-visibility: initial !important;
    filter: brightness(0) invert(1);
}

.logo_p {
    width: 100%;
    position: absolute;
    top: 0;
}

.star_container {
    width: 67px;
    margin: auto;
    position: relative;
    top: 42px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.star {
    width: 10px;
}

.star.hidden_by_scaling_low {
    opacity: 0;
    transform: scale(0.5) rotateZ(15deg);
}

#pay {
    width: 1037px;
    overflow: hidden;
    position: relative;
    z-index: 1;
    margin-top: auto;
    margin-bottom: auto;
}

.pay_top {
    color: #FFFFFF;
    font-family: 'Dosis', sans-serif;
    font-size: 76px;
    letter-spacing: 7.5px;
    text-transform: uppercase;
    text-align: center;
}

.pay_sub {
    color: #FFFFFF;
    font-size: 34px;
    font-weight: 300;
    letter-spacing: 8px;
    text-align: center;
}

.pay_line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    opacity: 0.7;
}

#widget {
    position: absolute;
    right: 30px;
    bottom: 8px;
    will-change: transform;
    width: 112px;
    z-index: 1;
}

#widget_watch {
    border: 1px solid rgba(255, 255, 255, 0.3);
    width: 110px;
    height: 110px;
    position: relative;
}

#widget.alt_type #widget_watch {
    border: 1px solid rgba(54, 52, 44, 0.4);
}

#clock {
    position: absolute;
    width: 50px;
    height: 50px;
    top: 20px;
    left: 20px;
}

.hours {
    width: 3px;
    height: 20px;
    background: #FFFFFF;
    position: absolute;
    top: 5px;
    left: 24px;
    transform-origin: bottom;
    transform: translateY(0.5px) rotateZ(0deg);
}

.minutes {
    width: 1px;
    height: 25px;
    background: #FFFFFF;
    position: absolute;
    top: 0px;
    left: 25px;
    transform-origin: bottom;
    transform: translateY(0.5px) rotateZ(0deg);
}

.clock_center {
    width: 5px;
    height: 5px;
    background: #FFFFFF;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    position: absolute;
    margin-left: -2.5px;
    margin-top: -2.5px;
}

#widget.alt_type .hours, #widget.alt_type .minutes, #widget.alt_type .clock_center {
    background: #36342C;
}

.location_label {
    color: #ffffff;
    letter-spacing: 4px;
    font-size: 14px;
    position: absolute;
    bottom: 8px;
    right: 8px;
    text-shadow: 1px 1px 1px #000000;
}

#widget.alt_type .location_label, #widget.alt_type .date_label, #widget.alt_type .temp_label {
    color: #36342C;
    text-shadow: none;
}

#widget_date {
    margin-top: 20px;
}

.date_label {
    color: #FFFFFF;
    display: flex;
    justify-content: space-between;
    font-size: 20px;
    letter-spacing: 1px;
    text-shadow: 1px 1px 1px #000000;
}

.date_label .month {
    text-transform: uppercase;
}

#widget_meteo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
    padding-bottom: 15px;
}

.weather_img {
    max-width: 80px;
    position: relative;
    left: 0px;
}

#audio_player {
    margin-top: 25px;
    display: flex;
    justify-content: flex-end;
    opacity: 0.6;
    cursor: pointer;
}

.temp {
}

.temp_label {
    color: #FFFFFF;
    font-size: 20px;
    letter-spacing: 1px;
    text-shadow: 1px 1px 1px #000000;
}

#scroll_down {
    position: absolute;
    left: 50%;
    margin-left: -8px;
    bottom: 30px;
    width: 16px;
}

#index #scroll_down {
    position: relative;
    margin-left: 0;
    left: auto;
}

#scroll_down .vertical_elem {
    height: 107px;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.start_square {
    width: 6px;
    height: 6px;
    background: #BEA990;
}

#scroll_down .start_square {
    background: #FFFFFF;
}

#scroll_down .square {
    margin-top: 14px;
}

#scroll_down .square.top.shifted {
    margin-top: 18px;
}

.square {
    width: 16px;
    height: 16px;
    position: relative;
}

.square .border {
    width: 14px;
    height: 14px;
    border: 1px solid #BDA991;
}

.square .inline {
    width: 10px;
    height: 10px;
    position: absolute;
    top: 3px;
    left: 3px;
    background: #BDA991;
}

.line_set *.force_white {
    background: #FFFFFF !important;
}

.square.shifted .inline {
    background: #5E5D56;
}

.square.white .inline {
    background: #FFFFFF;
}

.square.white .border {
    border: 1px solid #FFFFFF;
}

.square.shifted.top .inline {
    top: -4px;
}

.square.shifted.bottom .inline {
    top: 10px;
}

.square.shifted.left .inline {
    left: -4px;
}

.square.shifted.right .inline {
    left: 10px;
}

.line_set._1 .line, .line_set._2 .line, .line_set.side_walk .line, .line_set.round {
    background: #AEAEAA;
}

.line {
    background: #D8CBBC;
}

.line.white {
    background: #FFFFFF;
}

.line.horizontal {
    height: 1px;
    width: calc(100% - 35px);
}

.line.horizontal.hidden {
    transform: scale(0, 1);
}

.line.vertical.hidden {
    transform: scale(1, 0);
}

.line.vertical {
    height: 100%;
    width: 1px;
}

.line.t_b {
    transform-origin: top;
}

.line.b_t {
    transform-origin: bottom;
}

.line.l_r {
    transform-origin: left;
}

.line.r_l {
    transform-origin: right;
}

.scroll_loop {
    -webkit-animation: scrollLoop 4000ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
    animation: scrollLoop 4000ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
}

@-webkit-keyframes scrollLoop {
    0% {
        -webit-transform: scale(1, 0);
        -webit-transform-origin: top;
    }

    40% {
        -webit-transform: scale(1, 1);
        -webit-transform-origin: top;
    }

    41% {
        -webit-transform-origin: bottom;
        -webit-transform: scale(1, 1);
    }

    81% {
        -webit-transform: scale(1, 0);
        -webit-transform-origin: bottom;
    }

    82% {
        -webit-transform-origin: top;
        -webit-transform: scale(1, 0);
    }
}

@keyframes scrollLoop {
    0% {
        transform: scale(1, 0);
        transform-origin: top;
    }

    40% {
        transform: scale(1, 1);
        transform-origin: top;
    }

    41% {
        transform-origin: bottom;
        transform: scale(1, 1);
    }

    81% {
        transform: scale(1, 0);
        transform-origin: bottom;
    }

    82% {
        transform-origin: top;
        transform: scale(1, 0);
    }
}

.paragraph_container {
}

.paragraph.right {
    float: right;
    width: calc(50% + 26px);
}

.paragraph.offset {
}

#index .paragraph.offset {
    height: 300px;
    position: relative;
    top: 1px;
}

.outer_letter {
    position: absolute;
    left: -117px;
    overflow: hidden;
    width: 117px;
    height: 140px;
}

.first_letter {
    font-family: 'Dosis', sans-serif;
    font-size: 170px;
    position: absolute;
    left: 0px;
    color: #FFFFFF;
    line-height: 118px;
    top: 23px;
}

.first_letter.hidden {
    transform: translateX(117px);
}

.text_first_letter {
    font-family: 'Dosis', sans-serif;
    font-size: 170px;
    position: relative;
    left: -117px;
    color: #5E5D56;
    line-height: 118px;
    top: 23px;
    display: block;
}

.text_first_letter.hidden {
    transform: translateX(-117px);
}

.paragraph {
    position: relative;
}

.paragraph_title_container {
    position: relative;
    margin-top: 60px;
}

.paragraph_title_container.first {
    margin-top: 0;
}

.paragraph_body {
    overflow: hidden;
    background: #FFFFFF;
    height: 100%;
}

.paragraph_body.hidden {
    transform: translateY(140px);
}

.paragraph_title_home {
    height: 140px;
}

.paragraph_title_home .welcome {
    color: #5E5D56;
    font-family: 'Dosis';
    font-size: 88px;
    letter-spacing: 10px;
    position: absolute;
    top: 50px;
    left: 10px;
    float: left;
}

.paragraph_title_home .welcome::first-letter {
    opacity: 0;
    margin-left: -60px;
}

.text_block {
    z-index: 1;
}

.body_text {
    /*font-size: 24px;*/
    font-size: 22px;
    color: #5E5D56;
    line-height: 35px;
    letter-spacing: 0.5px;
}

.body_text.smaller_width {
    width: 560px;
}

.p_title_text {
    position: absolute;
    top: 13px;
    left: calc(50% - 150px);
    max-width: 55%;
}

.paragraph_title_home+.body_text_container {
    margin-top: 20px;
}

.small_offset {
    background: #FFFFFF;
    width: calc(50vw - 190px);
    left: 22px;
    height: 61px;
    position: absolute;
    top: -60px;
}

.small_offset.hidden {
    transform: translateY(60px);
}

.paragraph_title.type_1 {
    font-size: 35px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 4px;
    color: #BDA991;
    max-width: calc(50vw - 300px);
    height: 49px;
}

.paragraph_title.type_2 {
    font-size: 40px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 10px;
    color: #BDA991;
}

.paragraph_subtitle {
    color: #5E5D56;
    font-size: 22px;
    font-weight: 400;
    letter-spacing: 5.25px;
}

.line {
    -webkit-transition: all 750ms cubic-bezier(0.250, 0.250, 0.750, 0.750);
    -moz-transition: all 750ms cubic-bezier(0.250, 0.250, 0.750, 0.750);
    -o-transition: all 750ms cubic-bezier(0.250, 0.250, 0.750, 0.750);
    transition: all 750ms cubic-bezier(0.250, 0.250, 0.750, 0.750);
}

.line.first {
    -webkit-transition: all 600ms cubic-bezier(0.550, 0.055, 0.675, 0.190);
    -moz-transition: all 600ms cubic-bezier(0.550, 0.055, 0.675, 0.190);
    -o-transition: all 600ms cubic-bezier(0.550, 0.055, 0.675, 0.190);
    transition: all 600ms cubic-bezier(0.550, 0.055, 0.675, 0.190);
}

.line.last {
    -webkit-transition: all 800ms cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -moz-transition: all 800ms cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -o-transition: all 800ms cubic-bezier(0.215, 0.610, 0.355, 1.000);
    transition: all 800ms cubic-bezier(0.215, 0.610, 0.355, 1.000);
}

.line.only {
    -webkit-transition: all 1500ms cubic-bezier(0.770, 0.000, 0.175, 1.000);
    -moz-transition: all 1500ms cubic-bezier(0.770, 0.000, 0.175, 1.000);
    -o-transition: all 1500ms cubic-bezier(0.770, 0.000, 0.175, 1.000);
    transition: all 1500ms cubic-bezier(0.770, 0.000, 0.175, 1.000);
}

.line_set._1 {
    position: absolute;
    left: calc(50% - 234px);
    top: 16px;
    width: 53%;
}

.line_set._1 .start_square {
    position: absolute;
    top: 5px;
    left: 30px;
}

.line_set._1 .square {
}

.line_set._1 .line._1 {
    top: 8px;
    position: absolute;
    left: 37px;
    width: calc(100% - 37px);
}

.line_set._1 .line._2 {
    right: 0;
    position: absolute;
    bottom: 8px;
    height: 20vh;
    background: linear-gradient(#FFFFFF, #AEAEAA);
}

.big_square {
    position: absolute;
    width: 137px;
    height: 137px;
}

.big_square .borders {
    border: 1px solid #FFFFFF;
    width: 135px;
    height: 135px;
}

.big_square .inline {
    width: 115px;
    height: 115px;
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.line_set .big_square {
    cursor: pointer;
}

.line_set .big_square:hover .inline_back {
    background: #C7B192;
}

.line_set .big_square:hover .square_label {
    color: #FFFFFF;
}

.big_square .inline .inline_back {
    background: #FFFFFF;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    transform-origin: left;
}

.big_square.shifted.right .inline {
    left: 80px;
    transform-origin: left;
}

.big_square.shifted.right .inline.hidden {
    transform: scale(0, 1);
    -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 600ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

.line_set._1 .big_square {
    bottom: calc(20vh + 20px);
    right: -60px;
}

.square_label {
    color: #36342C;
    font-size: 22px;
    z-index: 1;
    font-weight: 500;
    letter-spacing: 2px;
    text-align: center;
}

.line_set._2 {
    position: absolute;
    left: calc(50% - 228px);
    top: 29px;
}

.line_set._2 .start_square {
    position: absolute;
    top: 30px;
    left: 5px;
}

.line_set._2 .square {
}

.line_set._2 .line._1 {
    height: 120px;
    background: linear-gradient(#AEAEAA, #FFFFFF);
    left: 8px;
    position: absolute;
    top: 37px;
}

.line_set._2 .line._2 {
    width: 30vw;
    top: 156px;
    position: absolute;
    right: 7px;
    background: linear-gradient(90deg, #AEAEAA, #FFFFFF);
}

.line_set._2 .line._3 {
    height: 120px;
    background: linear-gradient(#AEAEAA, #FFFFFF);
    left: calc(-30vw + 8px);
    position: absolute;
    top: 156px;
}

.line_set._2 .big_square {
    position: absolute;
    width: 137px;
    height: 137px;
    left: calc(-30vw - 60px);
    top: 288px;
}

.big_square.bottom.shifted .inline {
    top: 80px;
}

.pic_container {
    position: relative;
}

#index .pic_container {
    overflow: hidden;
    min-height: 440px !important;
}

section.fullscreen {
    width: 100%;
    overflow: hidden;
}

.welcome_drink .paragraph.full {
    padding-top: 30px;
    padding-bottom: 75px;
}

.welcome_drink .pic_left {
    width: 30vw;
    position: absolute;
    top: 125px;
    z-index: 2;
}

.welcome_drink .pic_right {
    width: 73vw;
    position: relative;
    top: 31.5%;
    z-index: 1;
    /* float: right; */
    left: 27vw;
}

section {
    margin-top: 150px;
}

.less_margin {
    margin-top: 50px;
}

section.no_margin_top {
    margin-top: 0;
}

section:first-child {
    margin-top: 0;
}

section.fine_dining {
    margin-bottom: 100px;
    margin-top: 130px;
}

.fine_dining .more_container .more {
    width: 75%;
    margin-right: auto;
}

.line_set.side_walk {
    position: absolute;
    top: 46px;
    left: 104px;
    height: calc(100% - 20px);
    z-index: 1;
}

.line_set.side_walk .line._1 {
    width: 40px;
    position: absolute;
}

.line_set.side_walk .line._2 {
}

.line_set.side_walk .start_square._1 {
    position: absolute;
    left: 40px;
    top: -2px;
}

.line_set.side_walk .start_square._2 {
    left: -3px;
    position: absolute;
}

.line_set.side_walk .square.left.shifted {
    position: absolute;
    left: 61px;
    top: -6px;
}

.line_set.side_walk .square.top.shifted {
    bottom: -37px;
    position: absolute;
    left: -7px;
}

.paragraph.full {
    padding-left: 104px;
    padding-top: 75px;
    padding-bottom: 75px;
    z-index: 3;
}

.fine_dining .paragraph {
    padding-left: 230px;
    padding-top: 0;
    padding-bottom: 0;
    margin-bottom: 20px;
}

.start_square.lonely {
    position: absolute;
    top: 44px;
    left: 900px;
}

.fine_dining .square_middle {
}

.square .border.rotated {
    transform: rotateZ(45deg) translateX(10px);
    position: relative;
    z-index: 1;
}

.ziqu_logo {
    position: absolute;
    top: 72px;
    top: -72px;
    right: 3.5vw;
    padding-bottom: 22px;
    background: #FFFFFF;
    padding: 20px;
    border-radius: 10px;
}

.paragraph.full.ziqu {
    padding-top: 100px;
    padding-bottom: 100px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

section.fine_dining .more_container {
    left: 230px;
    right: auto;
    position: relative;
}

.ziqu .square.middle {
    position: absolute;
    left: 108px;
    top: calc(50% - 8px);
}

.border.rotated+.inline+.start_square {
    left: -7px;
    position: absolute;
    top: 4px;
}

.fine_dining .pic_left {
    width: 75vw;
}

.fine_dining .pic_right {
    position: absolute;
    right: 0;
    top: 58px;
    width: 45vw;
}

.pic_right .small_offset {
    top: 0;
    right: 0;
    left: auto;
    width: 83%;
    min-width: 402px;
    z-index: 1;
}

.more_container {
    position: absolute;
    right: 0;
    width: 25%;
    bottom: 0;
    height: 25%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.more_container:hover .more_text {
    color: #C7B192;
}

.more:hover .more_text {
    color: #C7B192 !important;
}

.more {
    width: 100%;
}

.more .more_text {
    color: #36342C;
    font-size: 20px;
    letter-spacing: 2px;
    display: flex;
}

.more.flexed .more_text {
    width: 100%;
}

.square+.more_text {
    margin-left: 25px;
    width: 100%;
}

.more_text span {
    width: 100%;
    height: 1px;
    display: block;
    position: relative;
    top: 14px;
    background: #5E5D56;
    float: right;
    margin-left: 15px;
}

.more_text span.more_loop {
    -webkit-animation: moreLoop 2500ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
    animation: moreLoop 2500ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
}

@-webkit-keyframes moreLoop {
    0% {
        -webit-transform: scale(0, 1);
        -webit-transform-origin: left;
    }

    47% {
        -webit-transform: scale(1, 1);
        -webit-transform-origin: left;
    }

    48% {
        -webit-transform-origin: right;
        -webit-transform: scale(1, 1);
    }

    95% {
        -webit-transform: scale(0, 1);
        -webit-transform-origin: right;
    }

    96% {
        -webit-transform-origin: left;
        -webit-transform: scale(0, 1);
    }
}

@keyframes moreLoop {
    0% {
        transform: scale(0, 1);
        transform-origin: left;
    }

    47% {
        transform: scale(1, 1);
        transform-origin: left;
    }

    48% {
        transform-origin: right;
        transform: scale(1, 1);
    }

    95% {
        transform: scale(0, 1);
        transform-origin: right;
    }

    96% {
        transform-origin: left;
        transform: scale(0, 1);
    }
}

.left_block_offset {
    width: 50vw;
    height: max-content;
    background: #FFFFFF;
    margin-top: -45px;
    position: relative;
    top: 15px;
}

.left_block_offset.hidden {
    transform: translateY(150px);
}

.pool.paragraph_pic {
    width: calc(100% - 650px);
    max-width: 920px;
}

.pool_title_container {
    position: relative;
    top: 120px;
}

.pool .paragraph_title.type_2 {
    text-align: center;
}

.paragraph_content {
    display: flex;
    z-index: 1;
}

.pool .paragraph_content {
    align-items: center;
    position: relative;
}

.pool .more_container {
    position: absolute;
    left: 274px;
    width: 240px;
    bottom: -30px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    height: auto;
    z-index: 1;
}

.left_text_column {
    width: 60%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 520px;
    height: max-content;
    position: relative;
    z-index: 1;
    will-change: transform;
}

.left_text_column p {
    width: 90%;
    max-width: 60%;
    margin: auto;
    font-size: 19px;
    line-height: 30px;
    font-family: 'Dosis', sans-serif;
    font-weight: 400;
    letter-spacing: 1px;
}

.line_set._round {
    position: absolute;
    left: calc(50% - 2px);
    top: 65px;
    height: calc(100% + 112px);
}

.paragraph_pic {
    width: calc(100% - 650px);
    max-width: 820px;
    position: relative;
    z-index: 0;
}

.line_set._round .line._1 {
    height: 120px;
    width: 1px;
    left: 3px;
    position: absolute;
    top: -120px;
}

.line_set._round .line._2 {
    width: 395px;
    top: -120px;
    height: 1px;
    position: absolute;
    left: 3px;
}

.line_set._round .line._3 {
    position: absolute;
    left: 397px;
    top: -120px;
    height: 100%;
    width: 1px;
}

.line_set._round .line._4 {
    width: 395px;
    top: calc(100% + -120px);
    height: 1px;
    position: absolute;
    left: 3px;
}

.line_set._round .line._5 {
    height: 120px;
    width: 1px;
    left: 3px;
    position: absolute;
    top: calc(100% - 240px);
}

.line_set._round .square {
    position: absolute;
    top: calc(100% - 260px);
    left: -4px;
}

.pay_line .line {
    width: calc(50% - 20px);
}

.fullscreen_pic {
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

.fullscreen_pic .top_forced {
    margin-top: 0 !Important;
}

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

.pic_big {
    position: absolute;
    height: 100%;
    overflow: hidden;
    width: 100%;
}

#gallery_container {
    position: relative;
}

#gallery_container .right_veil {
    width: 12.5vw;
    position: absolute;
    height: 100%;
    background: #36342C;
    opacity: 0.5;
    right: 0;
    top: 0;
    z-index: 1;
}

.arrow_container {
    bottom: 5%;
    top: auto;
    right: 0;
    width: 12.5vw;
    z-index: 2;
    flex-direction: column;
    position: absolute;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.l_arrow, .r_arrow {
    border: none;
    background: none;
    cursor: pointer;
    padding: 10px 0;
}

.arrow_right:hover .r_arrow {
    transform: translateX(15px);
}

.arrow_left:hover .l_arrow {
    transform: translateX(-15px);
}

.pic_strip {
    background: #36342C;
    width: calc(50vw - 272px);
    left: 104px;
    height: 60px;
    position: absolute;
    bottom: -35px;
    z-index: 1;
    will-change: transform;
}

.pic_strip.right {
    left: auto;
    right: 0;
}

.romantic .paragraph_title {
    text-align: center;
    color: #5E5D52;
}

.romantic .paragraph_subtitle {
    text-align: center;
    color: #BDA991;
}

.romantic .paragraph_content {
    margin-top: 18vw;
}

.particles {
    position: absolute;
    top: -3vw;
    display: flex;
    width: 100%;
    justify-content: space-between;
}

.romantic_pic {
    width: 70vw;
    max-width: 1400px;
    margin: auto;
    position: relative;
    transform-origin: botttom;
}

.romantic_pic.hidden {
    transform: translateY(250px) scale(0.95);
}

.romantic_pic+.more_container {
    right: 1.5%;
    width: 11.50%;
    height: 100%;
}

.romantic_pic+.more_container .more_text {
    color: #FFFFFF;
}

.romantic_pic+.more_container .more_text .line {
    background: #FFFFFF;
}

.pic_viewport {
    height: 400px;
    width: 100%;
    background: #36342C;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
}

section.lifestyle {
    margin-top: 10vw;
}

.lifestyle_container {
    width: 80vw;
    max-width: 1400px;
    margin: auto;
}

.line_title {
    overflow: hidden;
    margin-left: -21px;
}

.line_title h3 {
    font-size: 70px;
    letter-spacing: 24px;
    background: #FFFFFF;
    float: left;
    font-weight: 200;
    text-indent: 20px;
}

.line_title .line {
    width: 100vw;
    height: 1px;
    position: absolute;
    left: 0;
    background: #72716B;
    z-index: -1;
    margin-top: -20px;
    transform-origin: left;
}

.lifestyle_articles {
    display: flex;
    margin-top: 75px;
    width: 100%;
    justify-content: space-between;
}

.lifestyle_article {
    width: 32.8%;
}

.lifestyle_pic {
    width: 100%;
    height: 26vw;
}

.lifestyle_pic .covered {
    width: 100%;
    height: 100%;
}

.lifestyle_copy {
    width: 270px;
    height: 270px;
    border: 1px solid #36342C;
    margin: auto;
    position: relative;
    margin-top: -60px;
}

.lifestyle_text {
    color: #36342C;
    font-size: 20px;
    margin-top: 100px;
    letter-spacing: 2px;
    margin-left: 25px;
    line-height: 25px;
    width: calc(100% - 60px);
    text-transform: uppercase;
    position: relative;
    z-index: 1;
}

.lifestyle_article .more {
    position: absolute;
    width: 100%;
    bottom: 20px;
}

.lifestyle_article .more .more_text {
    color: #BEA990;
    font-size: 20px;
    letter-spacing: 2px;
    width: calc(100% - 60px);
    margin: auto;
    text-align: right;
}

.lifestyle_article .more .more_text span {
    width: 72%;
    height: 1px;
    display: block;
    position: relative;
    top: 15px;
    background: #E5DDD3;
}

.padding_container {
    padding-left: 50px;
}

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

.flexed.wrap {
    flex-wrap: wrap;
}

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

.flexed.between {
    justify-content: space-between;
    align-items: center;
}

.flexed.all_center {
    justify-content: center;
    align-items: center;
}

.flexed.start {
    justify-content: flex-start;
    align-items: center;
}

.flexed.end {
    justify-content: center;
    align-items: center;
}

.flexed.stretch {
    align-items: stretch;
}

.flexed.center_align {
    align-items: center;
}

.flexed.column.center_align {
    justify-content: center;
    align-items: flex-start;
}

.flexed.top_align {
    align-items: flex-start;
}

.flexed.bottom_align {
    align-items: flex-end;
}

.block_list {
    width: 100%;
}

/*******************************************/
/******************* FOOTER ***************/
#footer {
    height: 290px;
    margin-top: 10px;
}

#index #footer {
    margin-top: 4vw;
}

#footer_top {
    height: 50%;
    background: #88755e;
    position: relative;
}

#footer_bottom {
    height: 50%;
    position: relative;
}

#footer_logo {
    position: relative;
    border-radius: 10px;
    filter: brightness(0) invert(1);
    width: 200px;
    text-align: center;
    margin-right: 20px;
}

#footer_logo img {
    width: 230px;
}

#footer_socials {
    width: 150px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1;
}

#socials {
    display: flex;
    justify-content: space-between;
    width: 105px;
    align-items: center;
    top: 0px;
    position: relative;
}

#socials img {
    height: 28px;
}

#footer .single_line {
    width: calc(100% - 105px);
    display: none;
}

#footer .line_set.single_line .line._1 {
    background: #C2A988;
}

#footer_infos .line_set.single_line .line._1 {
    background: #C2A988;
    width: calc(100% + 70px);
}

#footer_brands {
    position: relative;
    width: calc(100% - 350px);
}

#brand_container {
    width: 95%;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 45px;
}

.brand {
    padding: 0px 32px;
    height: 100%;
    display: flex;
    align-items: center;
}

.legend img {
    position: relative;
}

#copy {
}

.copy_text {
    font-family: 'Dosis', sans-serif;
    font-size: 17px;
}

#footer_infos {
    position: absolute;
    height: 100%;
    top: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    left: 0;
}

#footer_infos .info_top, #footer_infos .info_bottom {
    display: flex;
    align-items: flex-start;
    padding-right: 40px;
    justify-content: flex-end;
    flex-direction: row;
    width: 70%;
    gap: 30px;
}

#footer_infos .line_set {
    top: 64px;
    position: absolute;
    display: none;
}

.body_text.footer_text {
    font-size: 18px;
    letter-spacing: 0.5px;
    font-weight: 500;
}

.footer_text.first {
    min-width: 230px;
}

.body_text .pink {
    color: #1756aa;
}

/****************************************************************/
/************* HOTEL **********************/
.line_set.single_line {
    position: relative;
}

.line_set.light .inline {
    background: #C2A988;
}

.line_set.light .border {
    border-color: #FFFFFF;
}

.line_set.dark .start_square, .line_set.dark .inline {
    background: #5E5D56;
}

.line_set.single_line.dark .borders {
}

.line_set.single_line.horizontal {
    height: 16px;
}

.line_set.single_line.horizontal.starting .square {
    float: left;
}

.line_set.single_line.horizontal.starting .square.shifted {
}

.line_set.single_line.horizontal.starting .start_square {
    position: absolute;
    top: 5px;
    left: 30px;
}

.line_set.single_line.horizontal.starting .line._1 {
    left: 35px;
    position: absolute;
    top: 8px;
}

.line_set.single_line.horizontal.starting .square+.square.shifted {
    left: 20px;
}

.line_set.single_line.horizontal.starting .square+.square.shifted+.start_square {
    left: 76px;
}

.line_set.single_line.horizontal.starting .square+.square.shifted+.start_square+.line {
    left: 82px;
    width: calc(100% - 82px);
}

.line_set.single_line.horizontal.ending .square {
    float: right;
}

.line_set.single_line.horizontal.ending .square.shifted {
}

.line_set.single_line.horizontal.ending .start_square {
    position: absolute;
    top: 5px;
    right: 30px;
}

.line_set.single_line.horizontal.ending .line._1 {
    right: 35px;
    position: absolute;
    top: 8px;
}

.line_set.single_line.horizontal.ending .square+.square.shifted {
    right: 20px;
}

.line_set.single_line.horizontal.ending .square+.square.shifted+.start_square {
    right: 76px;
}

.line_set.single_line.horizontal.ending .square+.square.shifted+.start_square+.line {
    right: 82px;
    width: calc(100% - 82px);
}

.line_set.single_line.vertical {
}

.line_set.single_line.vertical.starting .square {
}

.line_set.single_line.vertical.starting .square.shifted {
}

.line_set.single_line.vertical.starting .start_square {
    position: absolute;
    top: 30px;
    left: 5px;
}

.line_set.single_line.vertical.starting .line._1 {
    left: 7px;
    position: absolute;
    top: 36px;
    height: calc(100% - 36px);
    width: 1px;
}

.line_set.single_line.vertical.starting .square+.square.shifted {
    top: 20px;
}

.line_set.single_line.vertical.starting .square+.square.shifted+.start_square {
    top: 76px;
}

.line_set.single_line.vertical.starting .square+.square.shifted+.start_square+.line {
    top: 82px;
    height: calc(100% - 82px);
}

.line_set.single_line.vertical.has_comment .line {
    height: calc(100% - 242px) !important;
}

.line_set.single_line.vertical.starting .start_square {
    position: absolute;
    top: 30px;
    left: 5px;
}

.line_set.single_line.vertical.starting .line._1 {
    left: 7px;
    position: absolute;
    top: 36px;
    height: calc(100% - 36px);
    width: 1px;
}

.line_set.single_line.vertical.ending .square {
}

.line_set.single_line.vertical.ending .square.shifted {
}

.line_set.single_line.vertical.ending .start_square {
    position: absolute;
    top: 5px;
    left: 30px;
}

.line_set.single_line.vertical.ending .line._1 {
    left: 35px;
    position: absolute;
    top: 8px;
}

.section_viewport {
    width: 74%;
    margin: auto;
    max-width: 1140px;
}

.on_top {
    z-index: 1;
}

.light_pink {
    color: #C7B192;
}

#section_logo {
    position: absolute;
    left: 30px;
    top: 95px;
}

#vm_borders {
    width: 138px;
    height: 138px;
    position: relative;
    z-index: 1;
}

#vm_borders .top {
    width: calc(100% - 4px);
    height: 2px;
    background: #FFFFFF;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 2px;
    transform-origin: left;
}

#vm_borders .bottom {
    width: 68px;
    height: 2px;
    background: #FFFFFF;
    opacity: 0.5;
    position: absolute;
    bottom: 0;
    left: 2px;
    transform-origin: right;
}

#vm_borders .left {
    height: 100%;
    width: 2px;
    background: #FFFFFF;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0;
    transform-origin: bottom;
}

#vm_borders .right {
    height: 20px;
    width: 2px;
    background: #FFFFFF;
    opacity: 0.5;
    position: absolute;
    top: 0;
    right: 0;
    transform-origin: top;
}

#vm_borders .small_vm {
    position: absolute;
    bottom: 10px;
    left: 10px;
}

#section_title {
    position: absolute;
    width: 330px;
    height: 330px;
    background: #FFFFFF;
    top: 25px;
    left: 75px;
    padding: 40px;
    box-sizing: border-box;
    transform-origin: left;
}

#section_title h2 {
    text-transform: uppercase;
}

#section_title.hidden {
    transform: scale(0.95);
    opacity: 0;
}

.section_title_typo {
    color: #5E5D52;
    font-size: 40px;
    letter-spacing: 7px;
}

.section_title_typo.smaller {
    font-size: 42px;
    letter-spacing: 8px;
}

.pic_block {
}

.pic_block .line_set.single_line.vertical, .text_block .line_set.single_line.vertical {
    position: absolute;
    margin-left: -60px;
    height: 100%;
}

.section_big_pic {
}

.comment {
    position: absolute;
    bottom: -10px;
    right: calc(100% + 52px);
    width: 20%;
}

.comment_text {
    font-size: 18px;
    letter-spacing: 0.2px;
    text-align: right;
    font-weight: 500;
}

.body_text.antic {
    font-family: 'Dosis', sans-serif;
    letter-spacing: 0;
    font-size: 22px;
    letter-spacing: 1px;
    color: #000000;
    text-align: left;
}

.body_text.smaller {
    font-size: 18px;
    letter-spacing: 0.5px;
}

.block_title h3 {
    font-size: 40px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 4px;
    text-transform: uppercase;
}

.body_text antic {
    font-family: 'Dosis', sans-serif;
    font-size: 19px;
    margin-top: 50px;
    letter-spacing: 0.1px;
}

.text_with_picture {
    display: flex;
    position: relative;
    align-items: flex-start;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0px 50px;
    width: 90%;
}

.twp_picture {
    width: 45%;
    position: relative;
}

.twp_picture .borders.bottom {
    background: #C0A98C;
    position: absolute;
    width: calc(100% + 30px);
    height: 33%;
    bottom: -15px;
    z-index: -1;
    left: -15px;
}

.twp_text {
    width: 45%;
    box-sizing: border-box;
}

.twp_text .line_set {
    position: absolute;
    bottom: -22px;
    width: 45%;
}

.hash {
    position: absolute;
    transform-origin: left;
    transform: rotateZ(-90deg);
    bottom: -25px;
    left: -60px;
}

.reverse .hash {
    left: calc(100% + 60px);
}

.pic_container .hash {
    bottom: -12px;
}

.hash_text {
    font-size: 18px;
    letter-spacing: 3px;
    font-family: 'Dosis', sans-serif;
    color: #BEA990;
    font-weight: 600;
}

.hash_text span {
    color: #333333;
}

.pic_container {
}

.two_col_block {
}

.main_title {
}

.main_title.right {
    display: flex;
    justify-content: flex-end;
}

.main_title h1 {
    font-size: 45px;
    font-weight: 100;
    letter-spacing: 8px;
    line-height: 60px;
}

.main_title h1 .big_letter {
    color: #C0A98C;
    font-size: 2.5em;
    font-weight: 100;
}

.big_letter.tilt {
    position: absolute;
    left: -10px;
}

.two_col_text {
    column-count: 2;
    column-gap: 8vw;
}

.text_with_picture.reverse .twp_text {
    order: 0;
}

.text_with_picture.reverse .twp_picture {
    order: 1;
}

.out_box {
    width: calc(100vw - (100vw - 1140px)/2);
}

.out_box_container {
    position: relative;
}

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

.vertical_box {
    width: 32.5%;
}

.cta {
    position: relative;
    display: block;
}

.rect_pic {
    position: relative;
}

.rect_pic .veil {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.cta_label {
    top: 35%;
    position: absolute;
    right: 180px;
    width: 740px;
    height: 115px;
}

.cta_label .big_square {
    right: -57px;
    top: -10px
}

.label_container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    position: relative;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.5);
    transform-origin: top;
}

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

.labels .hover {
    position: absolute;
    top: -75px;
}

.labels p {
    font-size: 24px;
    color: #FFFFFF;
    letter-spacing: 8px;
    text-shadow: 1px 1px 1px #333333;
}

.line_set.download .vertical_elem {
    height: 107px;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.line_set.download .square {
    margin-top: 14px;
}

.line_set.download .square.top.shifted {
    margin-top: 18px;
}

.cta:hover .label_container {
    background: #FFFFFF;
}

.cta:hover .labels .out {
    color: #36342C;
}

/**************************************** DINING *************************/
#dining.index .top_bars .right {
    background: #36342C;
}

.section_viewport.large {
    max-width: none;
    width: 75%;
    margin-top: 40px !important;
}

.left_title_offset {
    height: 201px;
    background: #FFFFFF;
    width: calc(100% + 12.5vw - 22px);
    margin-left: calc(-12.5vw + 22px);
    margin-bottom: 149px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding-left: calc(12.5vw - 22px);
    padding-right: 0;
}

.left_title_offset.hidden {
    transform: translateY(100%);
}

.left_title_offset.pic_follow {
    margin-bottom: 199px;
}

.left_title_offset h2.less_spacing {
    letter-spacing: 5.5px;
}

.left_title_offset h2 {
    line-height: 60px;
    height: 113px;
    width: 90%;
}

.left_col {
    width: 60%;
    z-index: 1;
}

.right_col {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    width: 58.45%;
    justify-content: space-between;
}

.right_col.side_single_paragraph {
    padding-bottom: 120px;
    position: absolute;
    background: #FFFFFF;
    z-index: 1;
    right: 0;
    padding-right: 12.5vw;
    box-sizing: border-box;
    margin-top: 330px;
}

.left_col .left_pic {
    width: 120%;
    padding: 0 15px 45px 0;
    box-sizing: border-box;
    background: #FFFFFF;
    position: relative;
    float: left;
}

.simple_col {
}

.half {
    width: 50%;
}

.left_pic .hash {
    bottom: 35px;
}

.col_text {
    max-width: 390px;
    width: 60%;
}

.col_text.quote_container {
    flex: 1 1 100%;
}

.quote_container .body_text {
    width: 100%;
}

.ziqu_label {
    position: absolute;
    right: 0;
    max-width: 431px;
    top: -198px;
    width: 28vw;
}

.ziqu_label .bottom {
    position: relative;
    top: -20px;
}

.ziqu_label .top {
    height: 214px;
    display: flex;
    align-items: flex-end;
}

.ziqu_label h4 {
    font-family: 'Dosis', sans-serif;
    color: #36342C;
    font-size: 55px;
    letter-spacing: 6.6px;
    position: relative;
    float: left;
}

.ziqu_label h4 span {
    font-size: 150px;
    color: #36342C;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 12px;
}

.ziqu_label .top img {
    position: absolute;
    top: 87px;
    right: 14px;
}

.ziqu_label h5 {
    font-family: 'Dosis', sans-serif;
    color: #FFFFFF;
    font-size: 55px;
    letter-spacing: 6.6px;
    font-weight: 300;
    float: right;
    margin-right: 15px;
}

.ziqu_pic {
    position: relative;
}

.left_text {
    width: 90%;
    padding: 100px 0;
    float: left;
}

.download_button {
    width: 90%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
    height: 100%;
}

.download_label {
    font-size: 40px;
    font-family: 'Dosis', sans-serif;
    text-align: center;
    font-weight: 400;
    letter-spacing: 2.5px;
    width: 100%;
    cursor: pointer;
}

.download_label:hover {
    color: #C7B192;
}

.download_w_gallery {
    display: flex;
}

.overflow_cover {
    position: absolute;
    width: 12.5vw;
    left: -12.5vw;
    background: #FFFFFF;
    height: 100%;
}

.horizontal_gallery {
    position: relative;
}

.download_w_gallery .left {
    width: 25%;
    z-index: 1;
    background: #FFFFFF;
    position: relative;
}

.download_w_gallery .right {
    width: 75%;
}

.download_w_gallery .glide__wrapper {
    overflow: visible;
}

.download_w_gallery .left_veil {
    width: 12.5vw;
    position: absolute;
    height: 100%;
    background: #FFFFFF;
    opacity: 0.5;
    left: 0;
    top: 0;
    z-index: 1;
}

.download_w_gallery .right_veil {
    width: 12.5vw;
    position: absolute;
    height: 100%;
    background: #36342C;
    opacity: 0.5;
    right: -12.5vw;
    top: 0;
    z-index: 1;
}

.download_w_gallery .glide--horizontal .glide__arrows {
    bottom: 5%;
    top: auto;
    right: -12.5vw;
    width: 12.5vw;
    z-index: 2;
    flex-direction: column;
}

.diamond_side_content {
    width: 56.5%;
}

.diamond_side_content .body_text {
    width: 90%;
    max-width: 500px;
}

.diamond_container {
    width: 43.5%;
    margin-top: -15.2vw;
    padding-bottom: 6vw;
}

.diamond {
    border: 15px solid #FFFFFF;
    width: 100%;
    transform: rotateZ(45deg);
    overflow: hidden;
    position: relative;
    right: -5%;
    background: #FFFFFF;
    box-sizing: border-box;
    display: block;
}

.diamond.hidden {
    transform: translateY(35%) rotateZ(45deg);
}

.diamond img {
    transform: rotateZ(-45deg) scale(1.5);
}

.diamond img.hidden {
    transform: rotateZ(-45deg) scale(1.4);
}

.diamond .d_cover {
    position: absolute;
    width: 100%;
    height: 100%;
    background: #FFFFFF;
}

.diamond .d_cover.show {
    transform: none !important;
}

.diamond .d_cover._1 {
    left: -100%;
    transform: translateX(100%);
    top: 0;
}

.diamond .d_cover._2 {
    bottom: -100%;
    transform: translateY(-100%);
    left: 0;
}

.diamond .d_cover._3 {
    right: -100%;
    top: 0;
    transform: translateX(-100%);
}

.diamond .d_cover._4 {
    top: -100%;
    transform: translateY(100%);
    left: 0;
}

.quote {
    color: #C5AC91;
    font-size: 30px;
    font-family: 'Dosis', sans-serif;
}

.chef_space {
    margin-top: 16vw;
}

.chef_space .diamond {
    transform: rotateZ(45deg) translate3d(10%, -10%, 0);
}

.chef_space .diamond_container {
    margin-top: 0;
}

.chef_space .diamond_side_content {
    margin-top: -5vw;
}

.chef_space .diamond_side_content .body_text {
    width: 100%;
    margin-left: 88px;
    max-width: 405px;
}

.diamond_pic {
    margin-top: -15vw;
}

.wine h2 .big_letter {
    letter-spacing: -15px;
}

.main_title.compressed h2 {
    letter-spacing: 1px;
}

.wine h2 {
    margin-left: -10px;
}

.wine .title_shift {
    display: block;
    margin-left: 128px;
}

.letter_text {
    width: 40%;
    align-self: flex-end;
}

.letter_pic {
    width: 60%;
}

.letter_box .body_text {
    margin-left: 120px;
    max-width: 305px;
}

.form_title h2 {
    font-size: 78px;
    font-weight: 200;
    letter-spacing: 15px;
}

.form_title .line {
    width: 100vw;
    height: 1px;
    position: absolute;
    left: 0;
    background: #72716B;
    z-index: -1;
    margin-top: 74px;
}

.form_title h3 {
    font-family: 'Dosis', sans-serif;
    color: #BFA98D;
    font-size: 40px;
    letter-spacing: 10px;
    text-transform: uppercase;
    margin-top: 16px;
    background: #FFFFFF;
    padding: 0 15px 0 25px;
    margin-left: -25px;
    float: left;
}

.form_title h3 br {
    display: none;
}

form label {
    font-size: 20px;
    font-weight: 500;
    min-width: 130px;
    display: block;
    letter-spacing: 2px;
}

form input {
    width: 100%;
    border: none;
    border-bottom: 1px solid #D4D4D2;
    font-size: 24px;
    font-family: 'Dosis', sans-serif;
    font-weight: 500;
    margin-top: -5px;
    letter-spacing: 2px;
}

.form_container .simple_col {
    width: 45%;
}

.double_input .input_field:first-child {
    margin-top: 50px;
}

.double_input .input_field {
    width: 45%;
}

.input_field {
    display: flex;
    margin-top: 50px;
}

.input_field.arrival, .input_field.departure {
    width: 67%;
    min-width: 309px;
}

.input_field.unlimited {
    max-width: none;
}

.input_field:first-child {
    margin-top: 0;
}

.input_field.small {
    width: 45%;
}

p.radio_input {
    float: left;
    font-family: Lato;
    color: #333333;
    font-size: 12px;
    position: relative;
    height: 18px;
    text-indent: 0;
    top: 9px;
    margin-left: 132px;
}

p.radio_input>input {
    padding: 0;
    margin: 0;
    height: 18px;
    width: 17px;
    float: left;
    position: absolute;
    left: 0;
    opacity: 0;
}

input[type=radio], input[type=checkbox] {
    cursor: pointer;
}

p.radio_input:not(#foo)>input[type=radio]+label {
    background-position: 0 -7px;
}

p.radio_input:not(#foo)>input+label {
    background: url(images/radio_input.png) 0 -1px no-repeat;
    height: 17px;
    line-height: 17px;
}

p.radio_input>label {
    padding: 0px 0px 1px 28px;
    float: left;
}

p.radio_input:not(#foo)>input[type=radio]:hover+label, p.radio_input:not(#foo)>input[type=radio]:focus+label, p.radio_input:not(#foo)>input[type=radio]+label:hover {
    background-position: 0 -32px;
}

p.radio_input:not(#foo)>input[type=radio]+label {
    background-position: 0 -7px;
}

p.radio_input:not(#foo)>input[type=radio]:hover:checked+label, p.radio_input:not(#foo)>input[type=radio]:focus:checked+label, p.radio_input:not(#foo)>input[type=radio]:checked+label:hover, p.radio_input:not(#foo)>input[type=radio]:focus:checked+label {
    background-position: 0 -57px;
}

p.radio_input:not(#foo)>input[type=radio]:checked+label {
    background-position: 0 -57px;
}

textarea {
    width: 100%;
    border: 1px solid #D4D4D2;
    font-size: 20px;
    font-family: 'Dosis', sans-serif;
    font-weight: 500;
    margin-top: -5px;
    letter-spacing: 2px;
    resize: none;
    padding: 5px;
    box-sizing: border-box;
}

.mandatory {
    letter-spacing: 2px !important;
    font-weight: 500;
    font-size: 16px;
    font-family: 'Dosis', sans-serif;
}

.send {
    margin: auto;
    width: 45%;
    border: none;
    background: #36342C;
    padding: 10px 0;
    color: #FFFFFF;
    font-size: 20px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 2px;
    display: block;
    cursor: pointer;
}

.send_container {
    z-index: 2;
    position: relative;
}

/***************** ROOMS *********************/
#rooms.index #main_veil {
    transform: scale(0, 1);
}

.top_img .covered {
    height: 100%;
}

#top.alt_type {
    height: calc(100vh - 140px);
}

#top.alt_type #vm_borders>div {
    background: #C0A98C;
}

#top.alt_type .top_bars {
    top: calc(100% + 80px);
}

#top.alt_type .top_bars .left {
    margin-left: 83px;
    width: 36.11vw;
}

#section_logo .top_img {
    height: calc(100vh - 179px);
    top: 25px;
    left: 75px;
    width: calc(100vw - 325px);
}

.menu_controller.black .button_text {
    color: #36342C;
    font-weight: 600;
}

.menu_controller.black .white_button_separator {
    background: #36342C;
}

.right_viewport {
    box-sizing: border-box;
    max-width: 1410px;
    width: 100%;
}

.right_viewport .right_col {
    width: 65%;
    z-index: 1;
}

.alt_title h2 {
    text-align: right;
    flex: 1 1 100%;
    line-height: 51px;
    font-size: 50px;
    font-family: 'Dosis', sans-serif;
    color: #35332C;
    letter-spacing: 0.2vw;
    margin-bottom: 5px;
    text-transform: none !important;
}

.right_title_offset {
    height: 140px;
    background: #FFFFFF;
    display: flex;
    align-items: flex-end;
    width: max-content;
    padding-right: 20px;
    padding-left: 50px;
}

.right_title_offset span {
    display: inline-block;
}

.right_title_offset.hidden {
    transform: translateY(140px);
}

.right_viewport .right_col .text_container {
    width: 100%;
}

span.gold_title {
    font-size: 1.2em;
    color: #C3A985;
}

.right_viewport .twp_picture {
    width: 36%;
}

.right_viewport .twp_text, .right_viewport .twp_text .line_set {
    width: 50.5%;
}

.item_list {
    margin-left: 10.7%;
    width: 85%;
    max-width: 700px;
}

.item {
    display: block;
}

.item_pic {
    overflow: hidden;
    max-height: 800px;
    height: 90vh;
}

.item_veil {
    width: 100%;
    height: 100%;
    transform-origin: top;
    position: absolute;
    transform: scale(1, 0);
    top: 0;
    left: 0;
    background: #000000;
    opacity: 0.3;
}

.item:hover .item_veil {
    transform: scale(1, 1);
}

.item:hover .more_text {
    color: #C7B192;
}

.item_pic img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.item_title .line_set.single_line {
    max-width: 133px;
    margin-top: 25px;
    left: 4px;
}

.item_list .item_title h2 {
    line-height: initial;
}

.item_content {
    position: relative;
}

.item_mirror {
    position: absolute;
    top: 0;
    width: 31.522%;
    left: -15.761%;
    top: 80px;
    border: 15px solid #FFFFFF;
    box-sizing: border-box;
    transform-origin: left;
    background: #FFFFFF;
}

.item_text {
    position: absolute;
    bottom: 60px;
    width: 52.174%;
    max-height: 720px;
    background: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    left: calc(100% - 60px);
    flex-direction: column;
    z-index: 1;
    will-change: transform;
    padding: 30px 0;
}

.item_text .body_text {
    width: 90%;
    max-width: 280px;
}

.item_text .more {
    width: 70%;
}

.section_viewport.center {
    width: 50vw;
    margin: auto;
}

.text_container.smaller {
    width: 65%;
}

#room_services {
    display: flex;
    height: 56vw;
    justify-content: flex-end;
    transform: rotateZ(-90deg) translateY(3vw) translateX(3vw);
}

#service_title {
    position: absolute;
    margin-left: -180px;
    top: -20px;
    right: 184px;
}

#service_title h3 {
    font-size: 40px;
    color: #C0A98C;
    letter-spacing: 2px;
}

.service_labels {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.slot {
    display: flex;
    height: 8.5%;
    align-items: center;
}

.slot.hidden_from_left {
    transform: translateX(-50px);
}

#room_services.hidden_from_left {
    transform: translateX(-50px);
}

.slot p {
    font-size: 22px;
    letter-spacing: 2px;
}

.slot:first-child {
    height: 6.5%;
}

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

.icons {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.icons .slot {
    justify-content: center;
}

#room_services .line_set {
    margin: 0 50px;
}

.slot img {
    transform: rotateZ(90deg);
}

.inroom_section {
    height: 600px;
}

/*********** POSITION ******************/
.how_to .diamond_content {
    padding-bottom: 100%;
    width: 100%;
    background: #C0A98A;
    display: flex;
    justify-content: center;
}

.diamond_content .download_button {
    position: absolute;
    transform: rotateZ(-45deg);
    justify-content: center;
    width: 100%;
    left: 0;
}

.diamond_content .download_button .download_label {
    color: #FFFFFF;
    margin-top: 20px;
}

.line_set.white .square .inline {
    background: #FFFFFF;
}

.line_set.white .square .border {
    border: 1px solid #5E5D56;
}

.line_set.white .start_square {
    background: #FFFFFF;
}

.line_set.white .line {
    background: #5E5D56;
}

.main_title h1.how_to_title {
    font-size: 40px;
    font-weight: 300;
    letter-spacing: 2px;
    color: #BFA986;
}

.how_to_subtitle {
    color: #BFA986;
    text-decoration: underline;
    font-size: 1.1em;
}

/******************** FACILITIES ********************/
#facilities.index #main_veil {
    transform: scale(0, 1);
}

.right_viewport.max {
    width: calc(100% - 324px);
    max-width: 1525px;
}

.block {
    width: 49.7%;
    margin-top: 120px;
}

.block_container {
    display: flex;
    width: 100%;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 200px;
}

.block_pic {
    position: relative;
}

.block_copy {
    width: 270px;
    height: 270px;
    border: 1px solid #36342C;
    margin: auto;
    position: relative;
    margin-top: -60px;
    z-index: 1;
}

.block.reverse {
    position: relative;
}

.block.reverse .block_copy {
    width: 270px;
    height: 270px;
    border: 1px solid #36342C;
    margin: 0;
    position: relative;
    z-index: 1;
    position: absolute;
    left: 50%;
    margin-left: -135px;
    top: -210px;
}

.block_copy .copy_back, .lifestyle_copy .copy_back {
    position: absolute;
    top: 0;
    left: 0;
    background: #36342C;
    opacity: 0.3;
    transform: scale(0.8);
    width: 100%;
    height: 100%;
    opacity: 0;
}

.block_text {
    color: #36342C;
    font-size: 30px;
    margin-top: 110px;
    letter-spacing: 3px;
    line-height: 35px;
    text-align: center;
    text-transform: uppercase;
}

.block_veil {
    background: #000000;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.3;
    pointer-events: none;
    will-change: transform;
    transform-origin: top;
}

.block:hover .block_veil {
    transform: scale(1, 0);
}

.block:hover .block_copy, .lifestyle_article:hover .lifestyle_copy {
    transform: translateY(-30px);
}

.block:hover .copy_back, .lifestyle_article:hover .copy_back {
    opacity: 1;
    transform: scale(1);
}

.block:hover .block_text, .lifestyle_article:hover .lifestyle_text {
    color: #FFFFFF;
}

#section_title.with_borders {
    padding: 30px;
}

.title_borders {
    position: absolute;
    top: 30px;
    left: 30px;
    width: calc(100% - 60px);
    height: calc(100% - 60px);
}

.title_borders>div {
    background: #36342C;
    position: absolute;
}

.title_borders .top {
    width: 100%;
    height: 1px;
    top: 0;
    left: 0;
    transform-origin: left;
}

.title_borders .left {
    height: 100%;
    width: 1px;
    transform-origin: bottom;
    left: 0;
    bottom: 0;
}

.title_borders .right {
    height: 120px;
    width: 1px;
    transform-origin: top;
    right: 0;
    top: 0;
}

.title_borders .bottom {
    width: 30px;
    transform-origin: right;
    bottom: 0;
    left: 0;
    height: 1px;
}

.title_macro {
    padding-left: 30px;
}

.title_section {
    position: absolute;
    bottom: 30px;
    right: 30px;
    width: calc(100% - 100px);
}

.title_section h3 {
    text-align: right;
    color: #b5a088;
    text-transform: uppercase;
    font-family: 'Dosis', sans-serif;
    font-size: 30px;
    letter-spacing: 6px;
}

.title_macro h2 {
    color: #33332C;
    font-size: 27px;
    letter-spacing: 5px;
    font-weight: 500;
}

.small_title h2 {
    font-size: 40px;
    text-transform: uppercase;
    font-weight: 300;
}

.center_title_offset {
    min-height: 201px;
    background: #FFFFFF;
    transform-origin: bottom;
}

.center_title_offset h2 {
    margin-top: 75px;
}

.center_title_offset.hidden {
    transform: translateY(201px);
}

.padded {
    padding-left: 140px;
    padding-right: 40px;
}

.main_title .line_set {
    max-width: 133px;
    margin-top: 25px;
    left: 4px;
}

.background_container {
    background: #36342C;
}

.background_container .cover {
    background: #36342C;
}

.background_container .line_set.single_line.vertical {
    margin-left: 60px;
    height: 100%;
    z-index: 1;
    margin-top: -25px;
}

.detail .block_container:after {
    content: "";
    width: 32.8%;
}

.detail .block_container {
    margin-top: 260px;
    margin-bottom: 0;
}

.detail .block, #index .block {
    margin-top: 0.55vw;
}

#index .block_container {
    margin-top: 100px;
    margin-bottom: 100px;
}

.line_set.form {
    position: absolute;
    top: 40px;
    left: -75px;
    width: calc(100% + 150px);
    height: 100%;
}

.line_set.form .square.first {
}

.line_set.form .start_square.first {
    position: absolute;
    top: 30px;
    left: 5px;
}

.line_set.form .line {
    background: #AEAEAA;
}

.line_set.form .line.first {
    height: 58px;
    left: 8px;
    position: absolute;
    top: 37px;
}

.line_set.form .line._2 {
    width: 100%;
    top: 94px;
    position: absolute;
    left: 9px;
}

.line_set.form .line._3 {
    height: calc(100% - 155px);
    position: absolute;
    right: -9px;
    top: 94px;
}

.line_set.form .line._4 {
    width: 25%;
    bottom: 60px;
    right: -9px;
    position: absolute;
}

.line_set.form .start_square.last {
    bottom: 58px;
    right: calc(25% - 10px);
    position: absolute;
}

.line_set.form .square.last {
    bottom: 53px;
    right: calc(25% + 10px);
    position: absolute;
}

.contact_form {
    position: relative;
}

/*************** PHOTOGALLERY *******************/
#photogallery #main_veil {
    transform: scale(0, 1);
}

#photogallery.index .main_title h1 .big_letter {
    letter-spacing: -5px;
}

#photogallery.detail #footer {
    display: none;
}

#photogallery.detail .menu_controller .button_text {
    color: #36342C !important;
    font-weight: 600;
}

#photogallery.detail .menu_controller.black .white_button_separator {
    background: #36342C !important;
}

#photogallery.detail #vm_borders .small_vm {
    position: absolute;
    bottom: 10px;
    left: 0px;
}

#photogallery_container {
    height: 100%;
    left: 104px;
    width: calc(100% - 104px);
    position: absolute;
}

#photogallery.detail #top {
    height: 100vh;
}

#photogallery_controller {
    position: absolute;
    bottom: 0;
    height: 60px;
    width: calc(100% + 22px);
    left: -22px;
}

#photogallery_controller .bottom_bar {
    width: 100%;
    height: 100%;
    background: #36342C;
    padding-left: 22px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#photogallery.detail #gallery_container .arrow_container {
    display: none;
}

#photogallery.detail.isFullscreen #gallery_container .arrow_container {
    display: flex;
}

#photogallery_controller .arrow_container {
    position: relative;
    bottom: auto;
    top: auto;
    height: auto;
    margin-right: 15px;
}

#photogallery_controller .arrow_container .l_arrow, #photogallery_controller .arrow_container .r_arrow {
    padding: 2px;
}

.other_galleries {
    height: 100%;
}

.other_galleries ul {
    height: 100%;
    display: flex;
    align-items: center;
}

.other_galleries .separator {
    width: 5px;
    height: 5px;
    background: #BFA98E;
    margin: 0 10px;
}

.other_galleries .separator:last-child {
    display: none;
}

.other_galleries a {
    font-size: 20px;
    color: #BFA98E;
    font-family: 'Dosis', sans-serif;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.other_galleries a:hover {
    color: #FFFFFF;
}

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

.gallery_title h1 {
    font-size: 45px;
    color: #FFFFFF;
    font-weight: 100;
    letter-spacing: 5px;
}

#gallery_container .gallery_slider:hover+#gallery_arrow {
    opacity: 1;
}

#gallery_arrow {
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    opacity: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 200ms linear;
    display: none;
}

#gallery_arrow .drag_icon, #gallery_arrow .drag_icon_label {
    display: none;
}

.isFullscreen #gallery_arrow .drag_icon, .isFullscreen #gallery_arrow .drag_icon_label {
    display: block;
}

.isFullscreen #gallery_arrow .click_icon, .isFullscreen #gallery_arrow .click_label {
    display: none;
}

.click_label, .drag_icon_label {
    font-size: 21px;
    color: #FFFFFF;
    text-shadow: 2px 2px 1px #000000;
    width: 140px;
    margin-left: 12px;
    letter-spacing: 1px;
    transition: opacity 200ms linear;
}

/****** SPECIALS ***********/
#specials.index #main_veil {
    transform: scale(0, 1);
}

#specials .main_title h1, #lifestyle .main_title h1 {
    font-size: 40px;
    font-weight: 200;
    letter-spacing: 8px;
    line-height: initial;
    text-transform: uppercase;
}

#specials .main_title h3, #lifestyle .main_title h3 {
    font-size: 20px;
    font-family: 'Dosis', sans-serif;
    margin-top: 35px;
    letter-spacing: 1px;
    color: #000000;
    line-height: 32px;
}

.start_date {
    font-family: 'Dosis', sans-serif;
    text-transform: uppercase;
    font-size: 28px;
    text-align: right;
    line-height: 36px;
}

.end_date {
    font-family: 'Dosis', sans-serif;
    text-transform: uppercase;
    font-size: 28px;
    text-align: left;
    line-height: 36px;
    margin-top: 150px;
    margin-left: 25px;
}

.date_slash {
    background: #BFA98A;
    width: 2px;
    height: 100px;
    transform: rotateZ(25deg);
    margin-top: 75px;
    margin-left: 20px;
}

.pay_view {
    position: absolute;
    bottom: 21px;
    left: 12%;
    width: 88%;
}

.pay_view .more {
    position: absolute;
    bottom: 4px;
    right: 0;
    width: calc(100% - 120px);
    align-items: flex-end;
}

.pay_view .more_text span {
    margin-right: 15px;
    margin-top: 3px;
}

.pay_view h4 {
    color: #CBB99F;
    font-size: 100px;
    font-weight: 100;
    line-height: 110px;
}

.special_label {
    font-size: 40px;
    font-weight: 200;
    color: #5E5D52;
}

#specials .item_text {
}

.date_view {
    display: flex;
    margin-top: -170px;
}

#specials.detail .center_title_offset h2 {
    margin-top: 58px;
}

.background_container .main_title h1 {
    padding-top: 100px;
    color: #BFA98C;
}

.background_container .body_text {
    color: #FFFFFF;
    padding-bottom: 100px;
}

#specials.detail section:nth-child(2) .body_text a {
    width: 140px;
    border: none;
    background: #FFFFFF;
    padding: 10px 0;
    color: #36342C;
    font-size: 20px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 2px;
    display: block;
    cursor: pointer;
    margin-top: 50px;
    text-align: center;
}

/************* LIFESTYLE ******************/
#lifestyle #main_veil {
    transform: scale(0, 1);
}

#lifestyle .main_title h3 {
    text-transform: uppercase;
}

#lifestyle .item_list {
    max-width: 880px;
}

#lifestyle .item_list .item_pic img {
    margin-top: 0;
}

#lifestyle .item_list .item_pic {
    width: 50%;
    position: relative;
}

#lifestyle .item_list .item_text {
    width: 50%;
    position: initial;
    bottom: 0;
    height: 100%;
    flex-direction: column;
}

#lifestyle .item_content {
    display: flex;
    align-items: center;
}

#lifestyle .more {
    width: 70%;
    max-width: 280px;
}

.category_list a {
    width: 100%;
    text-align: right;
    font-weight: 400;
    color: #5E5D52 !important;
    display: block;
    text-transform: capitalize;
    letter-spacing: 2px !important;
}

#lifestyle.macro .category_list {
}

#top.alt_type.full_height {
    height: 100vh;
}

#top.alt_type.full_height #section_logo .top_img {
    height: calc(100vh - 120px);
}

#top.alt_type.full_height #section_title.with_borders {
    transform-origin: center;
    z-index: 1;
}

#lifestyle.detail #top {
    height: 100vh;
    z-index: 2;
    position: absolute;
}

.lifestyle_img {
}

.section_viewport.left {
    width: calc(100% - 260px);
    max-width: 1310px;
    margin-left: 230px;
}

.lifestyle_left {
    width: 50%;
}

.lifestyle_right {
    width: 50%;
}

.head_view .lifestyle_left {
    width: 68%;
}

.head_view .lifestyle_right {
    width: 32%;
    position: relative;
}

.lifestyle_article_title {
    background: #FFFFFF;
    padding: 50px;
    max-width: 620px;
    position: relative;
    top: 40%;
    left: -15vw;
    width: 44vw;
    transform-origin: top;
}

.lifestyle_intro {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding-left: 50px;
    box-sizing: border-box;
}

#lifestyle .article_p_title {
    color: #5E5D52;
    font-size: 70px !important;
    text-transform: none !important;
}

#lifestyle .body_text span {
    color: #C7B192;
}

.article_main_text {
    width: 90%;
}

.lifestyle_right .twp_picture, .lifestyle_right .twp_text {
    width: 75%;
}

.text_with_picture.vertical .twp_text .line_set {
    width: 100%;
    position: relative;
}

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

.lifestyle_button:hover button {
    background: #928c84;
}

.back_icon:hover>div {
    background: #928c84;
}

.lifestyle_button button {
    background: #BFA98E;
    border: none;
    padding: 20px 60px;
    cursor: pointer;
}

#lifestyle_prev p {
    color: #BFA98D !important;
    margin-left: 25px;
}

#lifestyle_next p {
    color: #BFA98D !important;
    margin-right: 25px;
}

.back_icon .line {
    height: 30px;
    width: 3px;
    background: #BFA98E;
    float: left;
    margin-left: 4px;
}

.back_icon .line._1 {
    margin-left: 0;
}

/*********************************************/
#book_panel .panel_content {
    justify-content: center;
    flex-direction: column;
    align-items: center;
    margin-top: 165px;
}

#book_panel .form_input label {
    width: 100%;
    font-family: 'Dosis', sans-serif;
    font-size: 20px;
    letter-spacing: 2px;
    line-height: 25px;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #000000;
    cursor: pointer;
}

#book_panel .form_input:first-child {
    margin-top: 0;
}

#book_panel .form_input {
    width: 320px;
    margin-top: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    cursor: pointer;
}

#book_panel .form_input input[type=text] {
    width: 100%;
    border: none;
    border-bottom: 1px solid #CCCCCC;
    margin-top: 20px;
    color: #000000;
    font-family: 'Dosis', sans-serif;
    text-align: center;
    font-size: 24px;
    letter-spacing: 3px;
    cursor: pointer;
}

#book_panel .form_input label img {
    margin-top: 15px;
}

#book_submit {
    margin-top: 70px;
    width: 320px;
}

#book_submit button {
    width: 100%;
    border: none;
    background: #FFFFFF;
    padding: 10px 0;
    color: #000000;
    font-size: 20px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 2px;
    display: block;
    font-weight: 400;
    text-transform: lowercase;
    border: 1px solid #CCCCCC;
    cursor: pointer;
}

/********************* STAI SPA *************************/
.spa_subtitle {
    color: #C7B192;
    text-decoration: underline;
}

.right_col.spa_col {
    width: 40%;
    margin-top: 342px;
    align-items: flex-start;
}

.spa_col .col_text {
    max-width: none;
    width: 80%;
    align-self: flex-end;
}

.vertical .twp_picture, .vertical .twp_text {
    width: 100%;
}

.spa_col._2 {
    margin-top: 0;
    padding-bottom: 15px;
    align-items: flex-end;
    padding-left: 50px;
    box-sizing: border-box;
}

.spa_col._2 .main_title h1 {
    line-height: 80px;
}

.spa_col._2 .body_text {
    padding: 0 25px;
}

/************* CONTACS ***********/
#contacts #main_veil {
    transform: scale(0, 1) !important;
}

/********** BOOK ADVICE ******************/
#bookAdvice {
    position: fixed;
    width: 100vw;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 0;
    left: 0;
}

#bookAdviceContent {
    max-width: 1480px;
    width: 90%;
    background: #FFFFFF;
    padding: 80px;
    box-sizing: border-box;
    position: relative;
}

#adviceClose {
    position: absolute;
    right: 40px;
    top: 40px;
    cursor: pointer;
}

#adviceTitle p {
    font-size: 25px;
    font-family: 'Dosis', sans-serif;
    letter-spacing: 2px;
}

#adviceText {
    margin-top: 25px;
}

/************** RESPONSIVE ***************/
@media all and (max-width: 1599px) {
    .tablet_show {
        display: block;
    }

    .tablet_hidden {
        display: none;
    }

    #pay {
        width: 854px;
    }

    .ziqu_logo {
        padding-bottom: 7px;
    }

    .pay_top {
        font-size: 60px;
    }

    .pay_sub {
        font-size: 25px;
        letter-spacing: 7.77px;
    }

    .pay_sub_container {
        margin-top: 5px;
    }

    .left_title_offset {
        margin-bottom: 75px;
    }

    .paragraph_title_home+.body_text_container {
        position: relative;
        top: 0;
        left: 0;
        margin-top: 20px;
        width: 85%;
    }

    .body_text {
        font-size: 17px;
        line-height: 28px;
        letter-spacing: 0.8px;
    }

    .mandatory {
        font-size: 16px;
    }

    .body_text.antic {
        font-size: 18px;
    }

    .body_text.footer_text {
        font-size: 18px;
        letter-spacing: 0.5px;
    }

    .paragraph_title.type_1 {
        font-size: 30px;
        font-family: 'Dosis', sans-serif;
        letter-spacing: 4px;
        color: #BDA991;
        max-width: calc(50vw - 150px);
        opacity: 1 !important;
        transform: none;
    }

    .small_offset {
        width: 50vw;
    }

    .paragraph.full {
        padding-left: 97px;
        padding-top: 10px;
        padding-bottom: 60px;
    }

    #section_title {
        padding: 20px;
        width: 250px;
        height: 250px;
    }

    .section_title_typo {
        font-size: 40px;
        letter-spacing: 9.3px;
    }

    .section_title_typo.smaller {
        font-size: 30px;
        letter-spacing: 9.3px;
    }

    .fine_dining .paragraph {
        padding-left: 230px;
        padding-top: 0px;
        padding-bottom: 0;
        margin-bottom: 20px;
    }

    .paragraph_title_container {
        margin-top: 40px;
    }

    .p_title_text {
        position: absolute;
        top: 13px;
        left: 50%;
    }

    .line_set._1 {
        position: absolute;
        left: calc(50% - 44px);
        top: 11px;
        width: 38%;
    }

    .line_set._2 {
        left: calc(50% - 44px);
        top: 11px;
    }

    .pic_block .line_set.single_line.vertical {
        position: absolute;
        margin-left: -48px;
        height: 100%;
    }

    .ziqu_label {
        max-width: 362px;
        top: -205px;
    }

    .ziqu_label .bottom {
        top: -10px;
    }

    .ziqu_label h5, .ziqu_label h4 {
        font-size: 45px;
    }

    .ziqu_label h4 span {
        font-size: 120px;
        letter-spacing: inherit;
    }

    .ziqu_label .top img {
        position: absolute;
        top: 64px;
        right: 11px;
    }

    .comment {
        position: relative;
        left: 0;
        right: auto;
        width: 100%;
    }

    .comment_text {
        text-align: left;
    }

    .pic_container+.line_set.single_line {
        margin-top: 30px;
    }

    .hash {
        left: -49px;
        /* equidistante a 1366 */
    }

    .left_pic .hash {
        left: -40px;
    }

    .main_title h1 {
        font-size: 50px;
        line-height: 65px;
        letter-spacing: 6px;
    }

    .alt_title h2 {
        letter-spacing: 5px;
        line-height: 40px;
    }

    .left_title_offset h2 {
        height: 90px;
    }

    .spa_col._2 .main_title h1 {
        line-height: 60px;
    }

    /* rimuovi se non va bene */
    .left_title_offset.pic_follow {
        margin-bottom: 120px;
        height: 150px;
        margin-top: 51px;
    }

    .right_col.side_single_paragraph {
        padding-bottom: 65px;
        margin-top: 265px;
    }

    /****************************/
    .left_title_offset h2.mobile_shift {
        margin-left: calc(-12.5vw + 126px);
    }

    .chef_space .diamond {
        transform: rotateZ(45deg) translate3d(-6%, 6%, 0);
    }

    .left_text {
        padding: 33px 0;
    }

    .wine .title_shift {
        margin-left: 82px;
    }

    .letter_box .body_text {
        margin-left: 0;
        max-width: 295px;
        width: 95%;
        margin-top: 30px;
    }

    .letter_box {
        align-items: center;
    }

    section, aside {
        margin-top: 60px;
    }

    .double_break {
        margin-top: 0px;
    }

    p.radio_input {
        top: 7px;
    }

    .form_title h2 {
        font-size: 60px;
        letter-spacing: 12px;
    }

    .form_title h3 {
        font-size: 30px;
        letter-spacing: 8px;
    }

    .item_text {
        width: 50%;
        left: 93%;
    }

    .item_text .body_text {
        width: 70%;
        max-width: 280px;
    }

    #specials .item_text {
        justify-content: flex-start;
        align-items: flex-start;
    }

    .end_date br {
        display: none;
    }

    .start_date br {
        display: none;
    }

    .date_view {
        margin-top: 30px;
        flex-direction: column;
        align-items: flex-start;
        margin-left: 30px;
    }

    .date_slash {
        position: absolute;
        transform: rotateZ(90deg);
        margin-left: 53px;
        margin-top: 0px;
    }

    .end_date {
        margin-left: 0;
        margin-top: 29px;
    }

    .pay_view h4 {
        font-size: 75px;
        line-height: 85px;
    }

    #section_logo .top_img, #top.alt_type.full_height #section_logo .top_img {
        height: calc(100vh + 1px);
        top: -96px;
        left: -30px;
        width: calc(100vw - 0px);
    }

    .right_viewport {
        margin-right: 0;
        padding-right: 45px;
        padding-left: 45px;
        box-sizing: border-box;
        z-index: 1;
        width: calc(100% - 85px);
    }

    .right_title_offset {
        margin-right: -40px;
        padding-right: 50px;
        height: 141px;
    }

    .hash {
        position: relative;
        left: 0 !important;
        bottom: 0 !important;
        right: auto;
        width: 100%;
        transform: none;
        top: 52px;
        margin-top: -22px;
    }

    .section_viewport.center {
        width: 75%;
        max-width: none;
    }

    .section_viewport {
        width: 75%;
    }

    #room_services {
        display: flex;
        height: 75vw;
        justify-content: flex-end;
        transform: rotateZ(-90deg) translateY(1vw) translateX(-4vw);
    }

    #widget.alt_type .hours, #widget.alt_type .minutes, #widget.alt_type .clock_center {
        background: #FFFFFF;
    }

    .location_label {
        color: #ffffff;
    }

    #widget.alt_type .location_label, #widget.alt_type .date_label, #widget.alt_type .temp_label {
        color: #FFFFFF;
        text-shadow: 1px 1px 1px #000000;
    }

    #widget.alt_type #widget_watch {
        border: 1px solid rgba(255, 255, 255, 1);
    }

    .menu_controller.black .button_text {
        color: #FFFFFF;
        font-weight: 600;
    }

    .menu_controller.black .white_button_separator {
        background: #FFFFFF;
    }

    #top.alt_type #vm_borders>div {
        background: #FFFFFF;
    }

    .padded {
        padding-left: 70px;
        padding-right: 70px;
    }

    .background_container .padded {
        padding-left: 35px;
        padding-right: 35px;
    }

    .background_container .line_set.single_line.vertical {
        margin-left: -30px;
        height: 100%;
        z-index: 1;
        margin-top: -25px;
    }

    #specials .main_title h1, #lifestyle .main_title h1 {
        font-size: 35px;
    }

    .menu_section .macro p, .menu_section .macro a {
        font-size: 25px;
    }

    .menu_section {
        height: 50px;
    }

    .menu_area {
        margin-top: 100px;
    }

    .menu_section .macro {
        padding: 10px 0;
        width: 360px;
    }

    .menu_section .detail {
        margin-left: 450px;
        top: -46px;
        width: 360px;
    }

    .detail_border {
        height: calc(100% + 8px);
        left: -45px;
        top: -4px;
    }

    .menu_trail {
        top: 0;
        height: 100%;
        left: 405px;
    }

    .download_label {
        font-size: 30px;
    }

    .lifestyle_article_title {
        left: -26vw;
    }

    .double_input .input_field {
        width: 100%;
    }

    .double_input {
        flex-direction: column;
    }

    .input_field.arrival, .input_field.departure {
        width: 45%;
    }

    .line_title h3 {
        font-size: 43px;
        letter-spacing: 16px;
    }
}

@media all and (max-width: 1540px) {
    .out_box {
        width: calc(100vw - (100vw - 74vw)/2);
    }

    .lifestyle_article_title {
        left: -26vw;
    }

    #footer_brands {
    }

    .brand {
        padding: 0px 25px;
        border: none !important;
    }

    #footer_socials .line_set {
        display: none;
    }
}

@media all and (max-width: 1366px) {
    .form_container {
        flex-direction: column;
    }

    .double_input .input_field:first-child {
        margin-top: 30px;
    }

    .form_container .simple_col {
        width: 100%;
        margin-top: 30px;
    }

    .input_field {
        flex-wrap: wrap;
        margin-top: 30px;
    }

    .input_field input {
        margin-top: 10px;
    }

    textarea {
        margin-top: 10px;
        font-size: 20px;
        font-weight: 400;
        height: 150px;
    }

    .double_input .input_field {
        width: 45%;
    }

    .double_input {
        flex-direction: row;
    }

    p.radio_input {
        width: 100%;
        margin-top: 0;
        margin-left: 0;
    }

    .small_pic {
        margin-left: 24%;
    }
}

@media all and (max-width: 1279px) {
    .main_title h1 {
        font-size: 42px;
    }

    .no_1024 {
        display: none;
    }

    .lifestyle_article_title {
        left: -26vw;
    }

    .title_section h3 {
        font-size: 22px;
        letter-spacing: 3px;
    }

    .title_macro h2 {
        font-size: 23px;
        letter-spacing: 3px;
    }

    .spa_col .col_text {
        margin-left: 0;
        max-width: none;
        width: 80%;
        align-self: center;
    }

    .ziqu .body_text {
        width: 50%;
    }

    .paragraph_pic {
        width: calc(100% - 550px);
    }

    .item_list {
        width: 70%;
    }

    .col_text {
        margin-left: 15%;
        width: 75%;
        max-width: none;
    }

    .right_col.side_single_paragraph {
        padding: 0 0 70px;
        align-items: flex-start;
    }

    .item_text {
        width: 45%;
        left: 90%;
        height: auto;
        padding: 25px 0 30px 0;
    }

    #rooms .item_text .more {
        margin-top: 30px;
    }

    .date_view {
        margin-top: 2vw;
    }

    .right_title_offset {
        height: 120px;
        margin-top: 25px;
        width: max-content;
        max-width: 50%;
    }

    .alt_title h2 {
    }

    #specials .alt_title h2, #lifestyle .alt_title h2 {
        font-size: 30px;
        letter-spacing: 5px;
    }

    .block_copy {
        width: 190px;
        height: 190px;
        margin-top: -50px;
    }

    .block.reverse .block_copy {
        width: 190px;
        height: 190px;
        margin-left: -95px;
        top: -140px;
    }

    .block_text {
        font-size: 25px;
        margin-top: 85px;
    }

    .block.reverse .block_text {
        margin-top: 75px;
    }

    .block {
        margin-top: 70px;
    }

    .form_title h2 {
        font-size: 48px;
        letter-spacing: 10px;
    }

    #index #footer {
        margin-top: 170px;
    }

    #footer {
        height: auto;
        margin-top: 160px;
    }

    #footer_top>div {
        flex-direction: column;
        align-items: center;
        padding-left: 0;
    }

    #footer_top {
        height: 90px;
    }

    .brand img {
        top: -20px !important;
    }

    #footer_socials {
        width: 100%;
        align-items: center;
        z-index: 1;
        justify-content: center;
        margin-left: 0;
        height: 100%;
    }

    #footer_logo {
        position: relative;
        margin-top: -140px;
        margin-right: 0px;
    }

    #footer_brands {
        right: 0vw;
        margin-bottom: 25px;
        width: 100%;
        display: none;
    }

    #brand_container {
        width: 100%;
        height: 100px;
    }

    .brand {
        display: flex;
        justify-content: center;
        width: 50%;
        padding: 0;
    }

    #footer_bottom {
        height: 250px;
    }

    #footer_bottom>div {
        padding-left: 0;
        flex-direction: column;
    }

    #footer_infos .info_top, #footer_infos .info_bottom {
        flex-direction: column;
        margin-top: 25px;
        padding: 0;
    }

    #footer_infos .line_set, #footer .single_line {
        display: none;
    }

    .body_text.footer_text {
        font-size: 18px;
        letter-spacing: 0.5px;
        width: 90%;
        min-width: 0;
        text-align: center;
        margin-left: 0%;
    }

    #footer_infos {
        margin-top: 0px;
        left: 0;
        width: 100%;
        justify-content: center;
    }

    #copy {
        position: absolute;
        top: 190px;
        width: 100%;
        text-align: center;
    }

    .copy_text {
        text-align: center;
    }

    .r_arrow {
        overflow: hidden;
        width: 80px;
    }

    .l_arrow {
        width: 80px;
        overflow: hidden;
    }

    .r_arrow img {
        float: right;
    }
}

@media all and (max-width: 1024px) and (min-width:1024px) {
    .pool .more_container {
        position: absolute;
        left: 138px;
        width: 240px;
        bottom: -3px;
    }

    .pay_view .more {
        right: 17px;
    }
}

@media all and (max-width: 959px) {
    #adviceTitle p {
        font-size: 20px;
        font-family: 'Dosis', sans-serif;
        letter-spacing: 2px;
        width: 88%;
    }

    section.right .paragraph_content {
        display: flex!important;
        flex-direction: column !important;
    }

    section.right .left_block_offset {
        position: relative!important;
    }

    #adviceText p.body_text {
        font-size: 15px;
        line-height: 3.5vh;
    }

    #bookAdviceContent {
        width: 90%;
        padding: 15px 30px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    #adviceClose {
        right: 20px;
        top: 20px;
    }

    #adviceClose img {
        width: 25px;
    }

    .mobile_hidden {
        display: none !important;
    }

    #widget {
        right: 5px;
        top: 85px;
        width: 50px;
    }

    #widget_watch {
        border: none !important;
        width: 50px;
        height: 50px;
        display: block;
    }

    #clock {
        top: 0px;
        left: 0px;
    }

    .menu_controller, .book_now_bar {
        left: 0;
        position: absolute;
        bottom: 0px;
        pointer-events: all;
    }

    .book_now_bar {
        right: 15px;
        left: auto;
        top: 0;
        height: 80px;
    }

    .call_now {
        background: #36342C;
        position: absolute;
        right: 61px;
        top: 0;
        width: 59px;
        height: 59px;
        display: none;
    }

    .call_now img {
        width: 60%;
        height: auto;
        margin: auto;
    }

    .menu_controller {
        left: 15px;
        gap: 5px;
        height: max-content;
        top: 22px;
    }

    .menu_controller .menu_button {
        top: 5px;
        left: 5px;
    }

    .menu_controller .lang_switch {
        display: none;
    }

    .menu_controller .lang_switch li:first-child {
        margin-bottom: 8px;
    }

    .book_button {
        position: absolute;
        top: 4px;
        left: 3px;
        cursor: pointer;
    }

    .book_now_bar .vertical {
        width: 72px;
    }

    .menu_vm {
        top: 50px;
        display: none;
    }

    #home_logo {
        top: 70px;
        height: 95px;
    }

    .logo_pieces img {
        height: 60px;
        width: auto;
        margin: auto !important;
        left: 0;
        right: 0;
        top: 15px;
    }

    #widget_date {
    }

    #widget_meteo {
    }

    #pay {
        max-width: 350px
    }

    .pay_top {
        font-size: 34px;
        letter-spacing: 2px;
        text-align: center;
    }

    .pay_line {
        margin-top: 5px;
    }

    .pay_sub {
        font-size: 20px;
        letter-spacing: 2px;
        white-space: initial;
        text-align: center;
    }

    #scroll_down .vertical_elem {
        height: 50px;
    }

    #scroll_down {
        display: flex;
        flex-direction: column;
        align-items: center;
        bottom: 8px;
    }

    .top_img {
        height: 120%;
    }

    #main header#top {
        height: 513px !important;
    }

    #main header#top .top_img_container {
        display: flex;
        justify-content: center;
        align-items: stretch;
    }

    #main header#top .top_img_container img {
        height: 100% !important;
        width: auto !important;
    }

    #top.alt_type {
        height: calc(100vh - 85px);
    }

    .paragraph.right {
        width: 100%;
        float: none;
    }

    .paragraph_title_home .welcome {
        left: -6px;
        position: relative;
        font-size: 50px;
        top: 52px;
    }

    .paragraph_title_home .welcome::first-letter {
        margin-left: -20px;
    }

    .text_first_letter {
        float: left;
        font-size: 100px;
        left: 0;
        top: 5px;
    }

    .paragraph_title_home {
        display: flex;
        justify-content: center;
        margin-top: 20px;
    }

    .text_first_letter.hidden {
        transform: none;
        opacity: 0;
    }

    #index .paragraph.offset {
        height: auto;
    }

    .welcome {
        left: -6px;
        float: left;
        top: 52px;
        font-size: 50px;
    }

    .paragraph_title_home+.body_text_container {
        position: relative;
        top: 0;
        left: 0;
        margin: auto;
        width: 72%;
        margin-bottom: 10px;
    }

    .welcome_drink .paragraph.full {
        padding: 50px 5%;
    }

    .paragraph_title.type_1 {
        max-width: none;
        height: auto;
    }

    .paragraph_title_container {
        margin-top: 0;
    }

    .p_title_text {
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        max-width: none;
        margin-top: 25px;
    }

    .welcome_drink .pic_left {
        position: relative;
        width: 100%;
        top: 0;
    }

    .welcome_drink .pic_right {
        width: 100%;
        left: 0;
        top: 0;
        margin-top: 25px;
    }

    section, aside {
        margin-top: 60px;
    }

    section.fine_dining {
        margin-top: 50px;
        margin-bottom: 0;
    }

    .fine_dining .paragraph {
        padding: 0 5%;
    }

    .paragraph_title.type_2 {
        font-size: 30px;
    }

    .paragraph_subtitle {
        margin-top: 25px;
    }

    .double_break {
        margin-top: 50px;
    }

    .rect_pic img {
        width: 150%;
        margin-left: 0;
    }

    .covered div.content {
        padding: 0;
        top: 0;
    }

    .ziqu_logo {
        position: relative;
        width: 70%;
        top: 20px;
        padding-bottom: 0;
    }

    .ziqu_logo img {
        width: 100%;
    }

    .paragraph.full.ziqu {
        flex-direction: column;
        padding: 50px 5%;
    }

    .body_text.smaller_width {
        width: 100%;
    }

    .more_container {
        position: relative;
        top: 0;
        width: 100%;
        height: 100px;
    }

    .fine_dining .pic_left {
        width: 100%;
    }

    .fine_dining .pic_right {
        width: 100%;
        position: relative;
        top: 0;
        margin-top: 25px;
    }

    .left_block_offset {
        width: 100%;
        margin-top: 0;
        height: auto;
    }

    .pool {
        display: flex;
        flex-direction: column;
    }

    .pool .left_block_offset {
        order: 1;
    }

    .pool .fullscreen_pic {
        order: 2;
        margin-top: 50px;
    }

    .pool_title_container {
        top: 0;
        padding: 0 5%;
    }

    .pool .paragraph_content {
        order: 3;
        display: flex;
        flex-direction: column;
    }

    .left_text_column {
        margin-top: 25px;
        width: 100%;
        min-height: max-content;
    }

    .left_text_column .text_body {
        width: 90%;
        max-width: none;
        font-size: 18px;
        line-height: 35px;
    }

    .more_container .more {
        width: 75%;
    }

    .paragraph_pic {
        width: 100%;
        margin-top: 25px;
    }

    .pool .more_container {
        position: relative;
        left: 0;
        height: 100px;
        align-items: center;
    }

    section.fine_dining .more_container {
        left: 0;
        margin: auto;
        height: 100px;
        align-items: center;
        width: 240px;
        bottom: -7px;
        display: flex;
    }

    .left_block_offset.hidden {
        transform: none;
    }

    .romantic_pic {
        width: 90%;
        margin-top: 5%
    }

    .pic_viewport {
        height: auto;
    }

    .romantic_pic+.more_container {
        right: 0;
        width: 100%;
        height: 100px;
    }

    section.lifestyle {
        margin-top: 75px;
    }

    .lifestyle_container {
        width: 90%;
    }

    .lifestyle_articles {
        flex-direction: column;
        margin-top: 25px;
    }

    .lifestyle_article {
        width: 100%;
        margin-top: 25px;
    }

    .line_title h3 {
        font-size: 26px;
        letter-spacing: 4px;
    }

    .lifestyle_pic {
        height: 450px;
        overflow: hidden;
        width: auto;
    }

    #section_title {
        padding: 20px;
        width: 200px;
        height: 200px;
        background: rgba(255, 255, 255, 0.8);
    }

    .top_veil {
        height: 100%;
    }

    article {
        margin-top: 5%;
    }

    .top_bars {
        display: none;
    }

    .section_viewport {
        flex-direction: column;
        width: 90%;
    }

    .block_title h3 {
        font-size: 30px;
        letter-spacing: 2.6px;
    }

    .text_with_picture {
        flex-direction: column;
        margin-bottom: 100px;
    }

    .twp_picture {
        width: 100% !important;
        order: 1 !important;
    }

    .twp_text {
        width: 100% !important;
        margin-top: 50px;
        order: 2 !important;
    }

    .about_imgs a {
        width: calc(50% - 20px)!important;
    }

    .row.animate-box {
        padding: 0 30px!important;
    }

    .line_set.single_line.horizontal {
        width: 100%;
        position: relative;
    }

    .two_col_text {
        column-count: 1;
    }

    html.touchevents #gallery_arrow {
        display: none;
    }

    .arrow_container {
        bottom: 15px;
        width: 60px;
        height: auto;
    }

    .r_arrow {
        width: 24px;
        overflow: hidden;
    }

    .l_arrow {
        width: 24px;
        overflow: hidden;
    }

    #gallery_container .right_veil {
        width: 60px;
    }

    .text_block {
        margin-top: 60px;
    }

    .break {
        margin-top: 30px;
    }

    .double_break {
        margin-top: 60px;
    }

    .less_margin {
        margin-top: 50px;
    }

    .main_title h1 {
        font-size: 35px;
        line-height: 45px;
    }

    .main_title.right {
        display: flex;
        justify-content: flex-start;
    }

    .hash {
        margin-top: -9px;
        order: 4;
    }

    .section_title_typo.smaller, .section_title_typo {
        font-size: 25px;
        letter-spacing: 9px;
    }

    .section_viewport.large {
        max-width: none;
        width: 90%;
    }

    .left_col {
        width: 100%;
    }

    .left_title_offset.pic_follow, .left_title_offset {
        margin-top: 2%;
        margin-bottom: 0;
        height: auto;
        padding-left: 0;
        width: 100%;
        margin-left: -3px;
    }

    .left_title_offset h2.mobile_shift {
        margin-left: 0;
        line-height: 45px;
        height: auto;
        padding-top: 25px;
    }

    .right_col.side_single_paragraph {
        width: 100%;
        margin-top: 30px;
        position: relative;
        padding: 0 0 60px;
    }

    .col_text {
        margin-left: 0;
        width: 100%;
    }

    .diamond {
        right: 0%;
        transform: rotateZ(45deg) !important;
    }

    .diamond_container {
        order: 1;
        width: 80%;
        max-width: 400px;
        margin-left: auto;
        margin-right: auto;
    }

    .diamond_side_content {
        order: 2;
        width: 100%;
    }

    .diamond_side_content .body_text {
        width: 100%;
        max-width: none;
    }

    .diamond_content .line_set.download .vertical_elem {
        height: 50px;
    }

    .diamond_content .line_set.download {
        margin-top: -40px;
    }

    .download_label {
        font-size: 22px;
    }

    .left_text {
        padding: 0;
        width: 100%;
    }

    .right_col {
        width: 100%;
    }

    .col_text.quote_container {
        flex: 1 1 100%;
        margin-top: 40px;
        margin-bottom: 30px
    }

    .chef_space .diamond_side_content .body_text {
        width: 100%;
        margin-left: 0px;
        max-width: none;
    }

    .chef_space .diamond_container {
        order: 2;
        margin-top: 60px;
    }

    .chef_space .diamond_side_content {
        order: 1;
    }

    .letter_text {
        width: 100%;
    }

    .letter_pic {
        width: 100%;
        margin-top: 30px;
    }

    .letter_box {
        flex-direction: column;
    }

    .form_title {
        overflow: hidden;
    }

    .form_title h2 {
        font-size: 35px;
    }

    form label {
        font-size: 15px;
    }

    .double_input .input_field:first-child {
        margin-top: 30px;
    }

    form input {
        margin-top: 5px;
        font-size: 16px;
    }

    .simple_col:first-child {
        margin-top: 0;
    }

    .send {
        width: 100%;
        margin-top: 75px;
    }

    #section_logo {
        position: absolute;
        left: 8px;
        top: 60px
    }

    #section_logo .top_img, #top.alt_type.full_height #section_logo .top_img {
        left: -8px;
        top: -62px;
        overflow: hidden;
    }

    .right_title_offset {
        height: 130px;
        margin: 0;
        margin-top: 0px;
        padding-right: 0;
        width: 100% !important;
        margin-right: 0;
        justify-content: flex-start;
        padding: 0 !important;
        max-width: 100% !important;
    }

    .alt_title h2 {
        font-size: 30px;
        letter-spacing: 5px;
        text-align: left;
        margin-left: 4.9vw;
        margin-bottom: 0;
    }

    .right_viewport {
        padding: 0 !important;
        width: 90%;
        padding-right: 0;
        margin: auto;
    }

    .right_viewport .right_col {
        width: 100%;
    }

    .alt_title h2 {
        font-size: 30px;
        letter-spacing: 5px;
    }

    .right_viewport .right_col .text_container {
        width: 100%;
    }

    .right_viewport .right_col .text_container.text_right {
        text-align: left;
        max-width: none;
        margin-top: 0 !important;
    }

    .item_list {
        width: 100%;
        margin-left: 0;
        max-width: none;
    }

    .item_text {
        width: 100%;
        position: initial;
        height: auto;
        left: 0;
        margin-top: 25px;
        align-items: flex-start;
    }

    .item_text .body_text {
        width: 100%;
        max-width: none;
    }

    .item_mirror {
        display: none;
    }

    .pay_view .more {
        width: 75%;
        position: relative;
        bottom: 0;
        top: 0;
        margin-top: 10px;
    }

    .pay_view .more_text span {
        margin-right: 15px;
        margin-top: 3px;
        margin-left: 0;
    }

    .more_text span.more_loop {
        -webkit-animation: moreLoop 5000ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
        animation: moreLoop 5000ms cubic-bezier(0.770, 0.000, 0.175, 1.000) infinite;
    }

    .section_viewport.center {
        width: 90%;
        max-width: none;
    }

    .text_container.smaller {
        width: 100%;
    }

    #service_title {
        position: absolute;
        margin-left: 13px;
        margin-top: -70px;
        left: auto;
        top: auto;
        right: auto;
    }

    #service_title h3 {
        font-size: 30px;
    }

    #rooms.detail .text_block {
        margin-top: 30px;
    }

    #room_services {
        transform: none;
        height: auto;
        justify-content: flex-start;
        margin-top: 120px;
    }

    #room_services .line_set {
        margin: 0px 28px;
        margin-top: -56px;
    }

    .slot p {
        font-size: 16px;
        text-align: right;
    }

    .slot {
        height: 50px;
    }

    .icons .slot {
        justify-content: center;
        width: 30px;
    }

    .slot img {
        transform: rotateZ(0deg);
        width: 100%;
    }

    .detail .block_container {
        margin-top: 50px;
        margin-bottom: 0;
    }

    .block {
        width: 100%;
        margin-top: 30px !important;
        display: flex;
        align-items: center;
    }

    .block_pic {
        position: relative;
        width: 50%;
    }

    .block_copy {
        position: relative !important;
        width: 50% !important;
        top: 0 !important;
        left: 0 !important;
        margin-left: 0 !important;
        margin-left: 0;
        height: calc(100% - 2px) !important;
        margin-top: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .block_text {
        font-size: 18px;
        margin-top: 0 !important;
    }

    .block:nth-child(even) .block_pic, .block:nth-child(odd) .block_copy {
        order: 1;
    }

    .block:nth-child(odd) .block_pic, .block:nth-child(even) .block_copy {
        order: 2;
    }

    .block:hover .block_copy {
        transform: none;
    }

    .center_title_offset h2 {
        margin-top: 50px;
    }

    .padded, .background_container .padded {
        padding-left: 0;
        padding-right: 0;
    }

    .panel_close {
        left: 8px;
        top: 9px;
    }

    .panel_logo {
        top: 10px;
    }

    #menu_book {
        position: absolute;
        top: 10px;
        right: 8px;
        left: auto;
        width: 44px;
    }

    #menu_container {
        width: 100%;
        height: 100%;
    }

    .menu_section {
        height: 48px;
    }

    .menu_section.auto_height {
        height: auto;
    }

    .menu_section .macro {
        width: 100%;
        padding: 7px 0px;
    }

    .menu_section .macro p, .menu_section .macro a {
        text-align: center;
        font-size: 20px;
    }

    .menu_section .submenu_item {
        text-align: center;
    }

    .submenu_item {
        padding: 6px 0;
    }

    .menu_section .detail {
        top: 0;
        width: 100%;
        margin-left: 0;
        margin-top: 0px;
        margin-bottom: 7px;
    }

    .menu_section .detail ul li a {
        font-weight: 400;
        font-size: 15px;
    }

    .panel_content {
        align-items: center;
        justify-content: flex-start;
        width: 100%;
        height: auto;
        margin-top: 0;
    }

    .menu_area {
        height: 100%;
        margin-top: -50px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    #menu_side {
        position: absolute;
        bottom: 100px;
        width: 100%;
        right: 0;
    }

    #menu_side li {
        font-weight: 500;
        margin-top: 0 !Important;
        font-size: 13px;
        text-align: center;
        padding: 15px;
    }

    #menu_side ul {
        width: calc(100% - 20px);
        display: flex;
        justify-content: space-between;
        padding: 0 10px;
        align-items: center;
    }

    .book_now_bar.covid {
        top: auto;
        bottom: 0;
        height: 90px;
    }

    .lang_button {
        margin: 0 10px;
    }

    #menu_book .book_button {
        position: initial;
        left: auto;
        top: auto;
        width: 44px;
    }

    .panel_logo {
        top: -1px;
    }

    .panel_logo .logo_p._4 {
        margin-top: -82px;
    }

    .x_close .line_1.no_width, .x_close .line_2.no_height {
        opacity: 0;
        transform: none;
    }

    .panel_close .button_text.top_single {
        transform: none;
    }

    .panel_logo .logo_p._5 {
        margin-top: -82px;
    }

    .panel_close .button_text {
        margin-top: 7px;
    }

    .star_container {
        top: 47px;
    }

    #rooms.index section {
        background: #FFFFFF;
    }

    .body_text.antic {
        font-size: 16px;
        line-height: 28px;
    }

    .spa_col .col_text {
        width: 91%;
    }

    .spa_col._2 {
        padding: 0;
        width: 100%;
    }

    .spa_col._2 .body_text {
        padding: 0;
    }

    .download_label {
        margin-top: 30px;
    }

    .download_w_gallery .left, .download_w_gallery .right {
        width: 100%;
    }

    .horizontal_gallery {
        margin-left: -5vw;
        width: 100vw;
        margin-top: 50px;
    }

    .download_w_gallery .left_veil {
        right: 0;
    }

    .download_w_gallery .glide--horizontal .glide__arrows, .download_w_gallery .right_veil {
        right: 0;
    }

    .menu_section .submenu_item {
        -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 0ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
        transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 0ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    }

    .menu_section.active .submenu_item {
        -webkit-transition: -webkit-transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
        transition: transform 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000), opacity 1500ms cubic-bezier(0.190, 1.000, 0.220, 1.000);
    }

    .comment_text {
        font-size: 16px;
    }

    .cta_label {
        top: 15%;
        width: 137px;
        height: 137px;
        left: 50%;
        margin-left: -68.5px;
    }

    .cta .label_container {
        display: none;
    }

    .cta img {
        width: 300%;
        margin-left: -100%;
    }

    .cta .content {
        overflow: hidden;
    }

    .cta_label .big_square {
        right: 0;
        top: 0;
    }

    .mandatory {
        font-size: 16px !important;
    }

    .date_view {
        margin-top: 0;
        margin-left: 0;
    }

    .pay_view {
        position: relative;
        left: 0;
        bottom: 0;
        margin-top: 15px;
        margin-bottom: 30px;
    }

    #specials .main_title h1, #lifestyle .main_title h1 {
        font-size: 26px;
    }

    #specials .main_title h3, #lifestyle .main_title h3 {
        font-size: 16px;
        line-height: 28px;
        letter-spacing: 0.5px;
    }

    #specials.index .big_letter._2, #specials.index .text._5 {
        display: none;
    }

    .pay_view h4 {
        font-size: 54px;
        line-height: 54px;
    }

    .start_date, .end_date {
        font-size: 22px;
    }

    .special_label {
        font-size: 30px;
        font-weight: 200
    }

    .title_borders {
        display: none;
    }

    #section_title.with_borders {
        padding: 0px;
    }

    .title_macro {
        padding-left: 15px;
        align-self: flex-start;
        padding-top: 15px;
    }

    .title_macro h2 {
        color: #33332C;
        font-size: 20px;
        letter-spacing: 5px;
        font-weight: 500;
        line-height: 28px;
    }

    .title_section {
        position: absolute;
        bottom: 15px;
        left: 15px;
        width: calc(100% - 100px);
    }

    #lifestyle .item_content {
        flex-direction: column;
    }

    #lifestyle .item_list .item_pic, #lifestyle .item_list .item_text {
        width: 100%;
    }

    .section_viewport.left {
        width: 90%;
        margin: auto;
    }

    .head_view .lifestyle_left, .head_view .lifestyle_right {
        width: 100%;
    }

    .lifestyle_img {
        margin-left: -5vw;
        width: 100vw;
    }

    .lifestyle_article_title {
        width: 100%;
        top: 0;
        left: 0;
        padding: 0;
        max-width: none;
        margin-top: 30px;
    }

    .lifestyle_intro {
        position: relative;
        padding-left: 0;
        margin-top: 30px;
    }

    .lifestyle_left .main_title {
        display: none;
    }

    .lifestyle_left, .lifestyle_right {
        width: 100%;
    }

    .article_main_text {
        width: 100%;
    }

    .lifestyle_right {
        margin-top: 30px;
    }

    .lifestyle_button button {
        width: 0px;
        padding: 10px 30px;
        display: flex;
        justify-content: flex-end;
        overflow: hidden;
    }

    #lifestyle_prev button {
        justify-content: flex-start;
    }

    textarea {
        font-size: 16px;
    }

    .input_field.arrival, .input_field.departure {
        width: 45%;
        min-width: 0;
    }

    .input_field.arrival, .input_field.departure {
        min-width: 324px;
    }

    #photogallery_container {
        width: 100%;
        left: 0;
    }

    #photogallery #vm_borders {
        display: none;
    }

    .other_galleries {
        display: none;
    }

    #photogallery_controller .arrow_container .l_arrow, #photogallery_controller .arrow_container .r_arrow {
        padding: 2px 0px;
    }

    #photogallery_controller .arrow_container {
        position: relative;
        width: 85px;
        height: 48px;
    }

    #photogallery.detail .menu_controller .button_text {
        color: #ffffff !important;
    }

    #photogallery.detail .menu_controller.black .white_button_separator {
        background: #ffffff !important;
    }

    .gallery_title h1 {
        font-size: 35px;
        letter-spacing: 4px;
        font-weight: 200;
        margin-left: 10px;
    }

    #index .block_container {
        margin-top: 0px;
        margin-bottom: 20px;
    }

    .line_title .line {
        margin-top: -16px;
    }
}

@media all and (max-width: 400px) {
    .input_field.arrival, .input_field.departure {
        width: 100%;
        max-width: none;
    }
}

@media (max-width: 359px) {
    .input_field.arrival, .input_field.departure {
        min-width: 288px;
    }
}

@media screen and (orientation: portrait) {
    .isFullscreen .fullscreen_pic {
        height: 100vh !important;
    }
}

@media screen and (orientation: landscape) {
    .fullscreen_pic {
        height: 100vh !important;
    }

    .isFullscreen .fullscreen_pic {
        height: 100vh !important;
    }
}

@media screen and (orientation: landscape) and (max-width:959px) {
    #photogallery_controller {
        transform: translateY(60px);
    }
}

@media (max-height: 840px) {
    #book_panel .form_input label {
        display: flex;
        justify-content: center;
        flex-direction: row;
    }

    #book_panel .form_input {
        margin-top: 45px;
    }

    #book_panel .form_input label img {
        margin-left: 20px;
        margin-top: 0;
    }

    #book_submit {
        margin-top: 100px;
        width: 320px;
    }

    #book_panel .form_input input[type=text] {
        font-size: 24px;
    }
}

@media (max-height: 730px) {
    #book_panel .panel_logo {
        opacity: 0;
    }

    #book_panel .panel_content {
        transform: translateY(-87px);
    }

    #book_submit {
        width: 280px;
    }

    #book_panel .form_input {
        width: 280px;
    }
}

@media (max-height: 840px) and (min-width:960px) {
    .menu_section .macro p, .menu_section .macro a {
        font-size: 25px;
    }

    .menu_section {
        height: 50px;
    }

    .menu_area {
        margin-top: 10px;
    }

    .menu_section .macro {
        padding: 10px 0;
        width: 360px;
        position: relative;
    }

    .menu_section .detail {
        margin-left: 450px;
        top: -46px;
        width: 460px;
    }

    .detail_border {
        height: calc(100% + 8px);
        left: -45px;
        top: -4px;
    }

    .menu_trail {
        top: 0;
        height: 100%;
        left: 405px;
    }
}

@media (max-height: 650px) and (min-width:960px) {
    .panel_logo .logo_p._4 {
        margin-top: -91px;
    }

    .panel_logo .logo_square {
        display: none;
    }

    .panel_logo .logo_p._5 {
        margin-top: -89px;
    }

    .panel_logo .logo_p._1, .panel_logo .logo_p._2, .panel_logo .logo_p._3 {
        display: none;
    }

    .menu_area {
        margin-top: 86px;
    }
}

@media all and (-ms-high-contrast: none) and (min-width: 960px), (-ms-high-contrast: active) {
    .pay_top {
        letter-spacing: 7px;
    }

    .left_text_column .text_body {
        margin-top: 0;
    }

    .ziqu.full.paragraph {
        justify-content: inherit;
    }

    .romantic_pic {
        top: -10vw;
    }

    .detail .block_container::after {
        content: none;
    }

    .block_list.flexed {
        justify-content: inherit;
    }

    .block_text {
        position: relative;
    }

    #lifestyle .item_list .item_text {
        left: 50%;
    }

    #photogallery_controller {
        z-index: 2;
    }
}

@supports (-ms-accelerator:true) {
    /* IE Edge 12+ CSS styles go here */
}

.logo_pieces.invert img {
    filter: invert(1) brightness(0);
}

.panel_logo .logo_square.invert .border {
    background: #dfdfdf;
}

.covered div.content img {
    width: 100%;
    height: auto;
}

.content.has_transition_3000 img {
    width: 100% !important;
    height: auto !important;
}

.ziqu_logo img {
    height: 240px !important;
}

.inpage header#top {
    height: 320px !important;
}

.alt_title h1.first-text::first-letter {
    font-size: 200%;
    color: #d3c1a7;
}

.right_viewport .right_col.full-width {
    width: 100%;
}

.double_break h3 {
    text-align: left;
    font-size: 30px;
    margin-bottom: 20px;
    font-weight: 600;
}

.inpage .right_viewport .right_col {
    width: 100%;
}

.inpage .right_viewport .right_col .text_container p, .double_break p {
    font-family: sans-serif;
    line-height: 28px;
    text-align: left;
    font-weight: 300;
    margin: 10px 0px 0px 0px;
}

.inpage .right_viewport .right_col .text_container * {
    text-align: left;
}

.inpage .right_viewport .right_col .text_container h3 {
    font-size: 20px !important;
    line-height: 30px;
    margin: 20px 0px 5px 0px;
}

.row.animate-box {
    padding: 0 70px;
    box-sizing: border-box;
}

.about_imgs {
    display: flex;
    flex-direction: row;
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 30px;
}

.about_imgs a {
    width: calc(25% - 25px);
    margin-bottom: 25px;
    display: flex;
    position: relative;
    transition: 0.2s;
    overflow: hidden;
    border-bottom: solid #c0a98c 30px;
    height: 20vh;
    align-items: center;
    justify-content: center;
}

.about_imgs a img {
    width: 100%;
    transition: 0.2s;
    height: auto;
    min-height: 100%;
}

.about_imgs a:hover {
    opacity: 0.75;
}

.brand {
    width: 33%;
    display: block;
    text-align: center;
}

.brand img {
    width: 100%;
    filter: brightness(0) invert(1);
    top: -40px;
    position: relative;
    max-width: 240px;
}

.padding-top .double_break {
    padding-top: 40px;
}

.content.full img.full_width {
    height: auto !important;
    width: auto !important;
    min-width: 100% !important;
    min-height: 100% !important;
}

.book_now_bar .white_button_separator {
    width: 65px;
}

.home-desc {
    position: relative;
    line-height: 38px;
}

.x_close:hover {
    opacity: 0.25;
}

.book_now_bar small {
    color: white;
}

.menu_controller .menu_button .button_text {
    font-size: 17px;
}

.book_now_bar .book_button:hover .button_text._2 {
    color: #131212 !important;
}

.whatsapp-button {
    position: fixed !important;
    left: 20px !important;
    z-index: 999;
    bottom: 18px;
}

.whatsapp-button>a>span {
    font-size: 11px !important;
    margin-bottom: 3px;
    display: block;
    text-align: center;
    display: none;
    background: white;
    border-radius: 3px;
}

.whatsapp-button>a>svg {
    width: 60px;
    fill: #00a800;
    border-radius: 50%;
    background: rgb(255 255 255 / 90%);
    height: 60px;
}

.whatsapp-button>a:hover {
    transform: scale(1.2);
}

.whatsapp-button>a {
    transition: 0.2s;
    display: inline-block;
}

.whatsapp-button>a:hover svg {
    fill: #02c802;
}

.whatsapp-button>a:hover>span {
    display: block;
}

.whatsapp-button.phone-call {
    left: inherit !important;
    right: 20px !important;
}

.whatsapp-button.phone-call>a>svg {
    outline-color: #248ace;
    fill: #248ace;
}

.whatsapp-button.phone-call>a:hover svg {
    fill: #02aee6;
}

@media all and (max-width: 991px) {
    #footer_infos {
        display: flex;
        flex-direction: column;
        height: max-content;
        position: relative;
        top: 0 !important;
    }

    .info_top {
        height: max-content !important;
    }

    #footer_socials {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        height: 55px;
        margin-bottom: -10px;
    }

    div#copy {
        position: relative;
        top: -120px;
    }

    #footer_infos>a {
        width: 100% !important;
        display: block;
        text-align: center;
        padding: 20px 0px;
    }

    .book_now_bar_new {
        right: 10px !important;
        gap: 5px !important;
    }

    ul.social_new {
        gap: 5px !important;
    }
}

.book_now_bar_new {
    position: fixed;
    right: 30px;
    left: auto;
    top: 22px;
    display: flex;
    align-items: center;
    gap: 15px;
    pointer-events: all;
    transition: 0.2s;
}
.book_now_bar_new.force_white {
    padding: 5px 6px 6px 6px;
    background: rgb(0 0 0 / 69%);
    border-radius: 30px;
    top: 15px;
}
ul.social_new {
    display: flex;
    gap: 10px;
}

ul.social_new a img {
    height: 14px;
    transition: 0.2s;
}

ul.social_new a {
    display: flex;
    width: 30px;
    height: 30px;
    align-items: center;
    justify-content: center;
    border: solid 1px white;
    border-radius: 50%;
    transition: 0.2s;
}

ul.social_new a:hover {
    background-color: #ffffff;
}

ul.social_new a:hover img {
    filter: invert(1);
}

a.book_button_new {
    border: solid 1px white;
    border-radius: 40px;
    overflow: hidden;
    display: flex;
    box-shadow: 0px 2px 4px -3px black;
    font-size: 15px;
}

a.book_button_new span {
    background: white;
    padding: 5px 4px 7px 11px;
    display: block;
    border-radius: 30px;
    transition: 0.2s;
}

a.book_button_new img {
    width: 15px;
    padding: 0px 7px;
    filter: invert(1);
    transition: 0.2s;
}

a.book_button_new:hover img {
    background: white;
    filter: invert(0);
}

a.main-home-page img {
    height: 20px;
    filter: invert(1);
}

a.main-home-page {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: solid 1px white;
    margin-right: 10px;
}

a.book_button_new:hover span {
    border-radius: 0;
}

.menu_controller .menu_button:hover {
    background: white;
}

a.main-home-page:hover {
    background: white !important;
}

a.main-home-page:hover img {
    filter: invert(0);
}

.menu_controller.force_white {
    padding: 4px 5px 5px 4px;
    background: rgb(0 0 0 / 69%);
    border-radius: 30px;
    top: 15px;
}

section.pool.fitness {
    margin-bottom: 80px;
}

.home-desc .p1 {
    line-height: 31px !important;
    width: 80%;
}

.body_text.home-desc.p_title_text p {
    max-width: 90%;
    line-height: 30px;
}

section.right .paragraph_content {
    display: flex;
    flex-direction: row-reverse;
}

section.right .left_block_offset {
    right: 0 !important;
    transform: none !important;
    position: absolute;
    right: 0 !important;
}

section.pool.fitness {
    position: relative;
}

/* Butonun stilini belirleme */
#scrollToTopBtn {
    position: fixed;
    bottom: 100px;
    right: 30px;
    color: white;
    border-radius: 50%;
    width: 40px;
    padding-bottom: 8px;
    background: rgb(123 105 83 / 82%);
    height: 32px;
    display: none;
    border: solid 1px rgb(123 105 83);
    cursor: pointer;
    font-size: 22px;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    align-items: center;
    justify-content: center;
    z-index: 999;
}

#scrollToTopBtn:hover {
    background-color: rgb(117 99 80);
}

.menu_section.active .macro::after {
    content: ">" !important;
    position: absolute !important;
    right: -17px !important;
    display: block !important;
    font-size: 20px !important;
    top: 14px;
}

.about-section .section-wrapper .about-content .about-bottom p b {
    color: black;
}

#policy {
    position: fixed;
    bottom: -100%;
    z-index: 999999999;
    transition: 1s;
}

.policy-area {
    padding: 10px 20px 15px 20px;
    background: rgb(255 255 255 / 75%);
    box-shadow: 0px -2px 8px rgb(0 0 0 / 15%);
    display: flex;
    justify-content: space-between;
    align-items: center;
    backdrop-filter: blur(10px);
}

.policy-area p {
    font-size: 13px;
    line-height: 18px;
    color: #4c4c4c;
    padding-right: 20px;
}

.policy-area h4 {
    font-size: 16px;
    margin-bottom: 4px;
}

.policy-area-buttons {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 10px;
    flex-direction: column;
}

.policy-area-buttons button {
    padding: 7px 10px;
    background: #f5f4f4;
    font-size: 14px;
    cursor: pointer;
    transition: 0.2s;
    outline: none !important;
}

.policy-area-text {
    width: calc(100% - 85px);
}

.policy-area-buttons button.btn-primary {
    border-color: #3e2f26 !important;
    background: #806758 !important;
    color: white;
}

.policy-area-buttons button:hover {
    opacity: 0.75;
}

.policy-area a {
    color: blue;
    text-decoration: underline;
}

#policy.active {
    bottom: 0;
}

.policy-area b {
    color: #565656;
}
img#slide-image {
    transition: opacity 0.7s ease !important;
    opacity: 1;
}

section.fine_dining.video {
    margin-bottom: -120px !important;
}

section.fine_dining.video .rect_pic.double_break > img {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    background-color: rgb(148 132 114 / 50%);
    border-radius: 30px;
    transition: 0.2s;
    width: 160px;
}
section.fine_dining.video .rect_pic.double_break > img:hover {
    transform: scale(1.25) rotate(-5deg);
    background-color: rgb(148 132 114 / 80%);
}

.video-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.85); /* Arkaplan karartma */
    z-index: 99999; /* En üstte durması için */
    display: none; /* Başlangıçta gizli */
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.video-modal-overlay.active {
    display: flex;
    opacity: 1;
}

.video-modal-content {
    position: relative;
    width: 90%;
    max-width: 900px; /* Video genişliği sınırı */
    background: #000;
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.video-modal-close {
    position: absolute;
    top: -40px;
    right: 0;
    color: #fff;
    font-size: 35px;
    font-weight: bold;
    cursor: pointer;
    transition: color 0.2s;
}

.video-modal-close:hover {
    color: #f1c40f; /* Varsa tema renginle değiştir */
}

/* Videonun kenarlarının yuvarlatılması için */
.video-modal-content video {
    border-radius: 8px;
    display: block; 
}
.container.row-content {
    margin: 240px 0px 10px 0px;
}

.row.animate-box.row-content {
    display: flex;
    gap: 30px;
    float: none !important;
}
h2.inpage {
    margin: 0px auto  40px auto !important;
    font-size: 50px;
    color: #b4937a;
    display: inline-flex !important;
    width: 100% !important;
    align-items: center;
    justify-content: center;
}

.text_block.text_container.double_break.odalar {
    font-size: 18px;
}

.text_block.text_container.double_break.odalar ul {
    line-height: 34px;
    list-style: circle;
    padding-left: 20px;
    margin: 20px 0px;
    display: flex;
    gap: 40px;
}

.text_block.text_container.double_break.odalar h4 {
    margin: 20px 0px;
    font-size: 30px;
    font-weight: 500;
}
#socials img {
    height: 28px;
}

.mobile-phone > a {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mobile-phone {
    position: fixed !important;
    left: 20px !important;
    bottom: 20px !important;
    background: #88755e;
    border-radius: 50%;
    color: white;
    transition: 0.2s;
    z-index: 999;
}

.mobile-phone img {
    height: 40px;
}
.mobile-phone i {
    font-size: 30px;
    color: white;
}
.mobile-phone:hover {
    transform: scale(1.1) rotate(15deg);
}
@media all and (max-width: 767px) {
    .policy-area {
        display: flex;
        flex-direction: column;
        padding-bottom: 31px;
    }

    .policy-area-text {
        width: 100%;
    }

    .policy-area-buttons {
        width: 100% !important;
        display: flex;
        flex-direction: row;
        justify-content: center;
    }

    .policy-area-buttons button {
        width: 50%;
    }

    .policy-area p {
        font-size: 12px;
    }
}