:root {
    /*-------------SUBMENU FONT SIZES------------*/
    --majestic_submenu_main_font_size: 1.5vw;
    --majestic_submenu_small_font_size: 0.9vw;
    --majestic_submenu_extra_small_font_size: 0.7vw;
    --majestic_submenu_phone_font_size: 1.8vw;
    --majestic_submenu_mail_font_size: 1.4vw;
    --majestic_submenu_button_font_size: 1.2vw;
    /*-------------SUBMENU FONT SIZES------------*/
}

.majestic_submenu_container {
    width: 100%;
    height: 100%;
    position: fixed;
    top: -100%;
    left: 0;
    z-index: 99999999999;
    background-color: #fff;
    opacity: 0;
    transition: 0.5s all ease-in-out;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: flex-start;
    align-items: stretch;
}

.majestic_submenu_container.active {
    top: 0;
    opacity: 1;
    transition: 0.5s all ease-in-out;
}

.majestic_submenu_master_container {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    align-items: stretch;
}

.majestic_submenu_close_button {
    width: 40px;
    height: 40px;
    cursor: pointer;
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 9;
}

.majestic_submenu_close_button_line {
    width: 100%;
    background-color: #9c7f0b;
    height: 2px;
    position: absolute;
    left: 0;
    bottom: 50%;
    transition: all 1s ease-in-out;
}

#majestic_submenu_close_line_1 {
    transform: rotate(-45deg);
}

#majestic_submenu_close_line_2 {
    transform: rotate(45deg);
}

.majestic_submenu_links_master_container {
    flex: 0 1 50%;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    max-height: 100%;
    background-color: rgba(250, 250, 251, 0.8);
    /* background-position: center; */
    /* background-color: #3877b2; */
    /* background-color: #9c7f0b; */
}

.majestic_submenu_links_master_container::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/menu_bg.jpg");
    background-repeat: repeat;
    background-size: cover;
    z-index: -1;
}

.majestic_submenu_links_logo {
    display: block;
    position: relative;
    width: 30%;
    margin: 2vh 0 0 0vw;
}

.majestic_submenu_links_logo a {
    height: 100%;
    margin: 0 auto;
    display: block;
    width: 90%;
}

.majestic_submenu_links_logo img {
    width: 60%;
    position: relative;
    display: block;
    margin: 0 auto;
}

.majestic_submenu_links_container {
    flex: 0 1 60%;
    margin: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: center;
}

.majestic_submenu_images_container {
    flex: 0 1 50%;
    position: relative;
    height: 100%;
}

.majestic_submenu_images.shown {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 1;
    transition: 0.8s all ease-in-out;
}

.majestic_submenu_images.not_shown {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: 0.8s all ease-in-out;
}

.majestic_submenu_links {
    display: block;
    width: 100%;
    text-decoration: none;
    font: 300 var(--majestic_submenu_main_font_size) 'Alegreya Sans', sans-serif;
    padding: 0 0 0.5vh 0;
    margin: 0 auto;
    color: #9c7f0b;
    position: relative;
    transition: 0.2s all ease-in-out;
}

.majestic_submenu_links.highlighted {
    font: 400 var(--majestic_submenu_main_font_size) 'Alegreya Sans', sans-serif;
    color: #ffffff;
}

.majestic_submenu_links.small {
    font: 500 var(--majestic_submenu_small_font_size) 'Alegreya Sans', sans-serif;
    color: #fff;
}

.majestic_submenu_links_rooms_container {
    width: 80%;
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
    padding: 0 0 0 2.5%;
}

.majestic_submenu_links_tourist_info {
    width: 80%;
    position: relative;
    padding: 0 0 0 2.5%;
}

.majestic_submenu_links.extra_small {
    font: 300 var(--majestic_submenu_extra_small_font_size) 'Alegreya Sans', sans-serif;
    color: #9c7f0b;
    display: block;
    margin: 0;
    /* white-space: nowrap; */
    flex: 0 1 48%;
}

.majestic_submenu_links:hover {
    color: rgb(0 229 255);
    transition: 0.2s all ease-in-out;
}

.majestic_submenu_contact_details {
    width: 100%;
    position: relative;
    margin-top: 5vh;
}

.majestic_submenu_contact_links {
    display: block;
    width: 100%;
    text-decoration: none;
    font: 400 var(--majestic_submenu_mail_font_size) 'Alegreya Sans', sans-serif;
    padding: 0 0 0.5vh 0;
    margin: 0 auto;
    color: #9c7f0b;
}

.majestic_submenu_contact_links.phone {
    font: 400 var(--majestic_submenu_phone_font_size) 'Alegreya Sans', sans-serif;
    padding: 0 0 0.5vh 0;
    margin: 0 auto;
    color: #9c7f0b;
}

.majestic_submenu_button_container {
    width: 100%;
    position: relative;
    margin-top: 3vh;
}

.majestic_submenu_button {
    font: 300 var(--majestic_submenu_button_font_size) 'Effra';
    background-color: #ffffff;
    min-width: 12vw;
    position: relative;
    cursor: pointer;
    padding: 10px 0 5px 0;
    outline: none;
    color: #1e687f;
    margin: 0 10px 0 0;
    border: 1px solid #ffffff;
    transition: 0.2s all ease-in-out;
}

.majestic_submenu_button:hover {
    background-color: transparent;
    color: #fff;
    transition: 0.2s all ease-in-out;
}

.majestic_submenu_top_menu_booking_img {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    height: 1.1vw;
}

.majestic_submenu_top_menu_booking_img path {
    fill: #1e687f;
    transition: 0.2s all ease-in-out;
}

.majestic_submenu_button:hover .majestic_submenu_top_menu_booking_img path {
    fill: #fff;
    transition: 0.2s all ease-in-out;
}

@media screen and (max-width: 1280px) {
    .majestic_submenu_images_container {
        display: none;
    }
    .majestic_submenu_links_master_container {
        flex: 0 1 100%;
        flex-direction: column;
        justify-content: flex-start;
        align-items: center;
    }
    .majestic_submenu_links_logo {
        height: unset;
        position: relative;
        display: block;
        width: 100%;
        margin: 0;
        flex: 0 1 20%;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-content: center;
        justify-content: center;
        align-items: center;
    }
    .majestic_submenu_links_logo img {
        height: 100%;
        position: relative;
        width: 100%;
        object-fit: contain;
    }
    #floating_menu {
        max-height: unset;
        margin: 0 0 15px 0;
        justify-content: flex-start;
        margin: 0 auto;
        flex: 0 1 78%;
    }
    .majestic_submenu_links_container {
        width: 90%;
    }
    .majestic_submenu_button {
        padding: 10px calc(var(--majestic_submenu_button_font_size) * 2.2) 5px calc(var(--majestic_submenu_button_font_size) * 2.2);
    }
    .majestic_submenu_close_button {
        position: absolute;
        top: 15px;
        left: unset;
        right: 15px;
        width: 5.5vw;
        height: 5.5vw;
    }
    .majestic_submenu_links_rooms_container {
        width: 100%;
    }
    .majestic_submenu_links_rooms_container.left_right {
        display: block;
    }
    .majestic_submenu_links_rooms_container.left_right .extra_small {
        width: 50%;
        flex: unset;
        float: left;
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_top_menu_booking_img {
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        height: calc(var(--majestic_submenu_button_font_size) * 1.1);
    }
}

@media screen and (orientation: portrait) and (max-width: 500px) {
     :root {
        /*-------------SUBMENU FONT SIZES------------*/
        --majestic_submenu_main_font_size: 5.7vw;
        --majestic_submenu_small_font_size: 4.2vw;
        --majestic_submenu_extra_small_font_size: 3.7vw;
        --majestic_submenu_phone_font_size: 5.8vw;
        --majestic_submenu_mail_font_size: 5.4vw;
        --majestic_submenu_button_font_size: 5.2vw;
        /*-------------SUBMENU FONT SIZES------------*/
    }
    .majestic_submenu_images_container {
        display: none;
    }
    .majestic_submenu_links_master_container {
        flex: 0 1 100%;
        flex-direction: column;
        justify-content: flex-start;
    }
    .majestic_submenu_links_logo {
        height: 20%;
        position: relative;
        display: block;
        width: 100%;
        margin: 0;
        flex: 0 1 10%;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-content: center;
        justify-content: center;
        align-items: center;
    }
    .majestic_submenu_links_logo a {
        height: 80%;
    }
    .majestic_submenu_links_logo img {
        height: 100%;
        position: relative;
        width: 100%;
        object-fit: contain;
    }
    #floating_menu {
        max-height: unset;
        margin: 0 0 15px 0;
        justify-content: flex-start;
        margin: 0 auto;
        flex: 0 1 78%;
    }
    .majestic_submenu_links_container {
        width: 90%;
    }
    .majestic_submenu_button {
        padding: 10px calc(var(--majestic_submenu_button_font_size) * 2.2) 5px calc(var(--majestic_submenu_button_font_size) * 2.2);
    }
    .majestic_submenu_close_button {
        position: absolute;
        top: 15px;
        left: unset;
        right: 15px;
        width: 5.5vw;
        height: 5.5vw;
    }
    .majestic_submenu_links_rooms_container {
        width: 100%;
    }
    .majestic_submenu_links_rooms_container.left_right {
        display: block;
    }
    .majestic_submenu_links_rooms_container.left_right .extra_small {
        width: 50%;
        flex: unset;
        float: left;
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_top_menu_booking_img {
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        height: calc(var(--majestic_submenu_button_font_size) * 1.1);
    }
}

@media screen and (orientation: landscape) and (max-width: 900px) {
     :root {
        /*-------------SUBMENU FONT SIZES------------*/
        --majestic_submenu_main_font_size: 2.7vw;
        --majestic_submenu_small_font_size: 2.0vw;
        --majestic_submenu_extra_small_font_size: 1.7vw;
        --majestic_submenu_phone_font_size: 2.8vw;
        --majestic_submenu_mail_font_size: 2.4vw;
        --majestic_submenu_button_font_size: 2.2vw;
        /*-------------SUBMENU FONT SIZES------------*/
    }
    .majestic_submenu_images_container {
        display: none;
    }
    .majestic_submenu_links_master_container {
        flex: 0 1 100%;
    }
    .majestic_submenu_links_logo {
        height: 20%;
        position: relative;
        display: block;
        margin: 3vh 0 0 0vw;
    }
    .majestic_submenu_links_logo a {
        height: 100%;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-content: center;
        justify-content: center;
        align-items: center;
    }
    .majestic_submenu_links_logo img {
        height: 100%;
        position: relative;
    }
    #floating_menu {
        max-height: 100%;
        margin: 0 auto 15px auto;
        justify-content: flex-start;
    }
    .majestic_submenu_links_container {
        width: 90%;
    }
    .majestic_submenu_button {
        padding: 10px calc(var(--majestic_submenu_button_font_size) * 2.2) 5px calc(var(--majestic_submenu_button_font_size) * 2.2);
    }
    .majestic_submenu_close_button {
        position: absolute;
        top: 15px;
        left: unset;
        right: 15px;
        width: 2.5vw;
        height: 2.5vw;
    }
    .majestic_submenu_links_rooms_container.left_right {
        display: block;
    }
    .majestic_submenu_links_rooms_container.left_right .extra_small {
        width: 50%;
        flex: unset;
        float: left;
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_top_menu_booking_img {
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        height: calc(var(--majestic_submenu_button_font_size) * 1.1);
    }
}

@media screen and (orientation: portrait) and (min-width: 500px) and (max-width: 1050px) {
     :root {
        /*-------------SUBMENU FONT SIZES------------*/
        --majestic_submenu_main_font_size: 3.9vw;
        --majestic_submenu_small_font_size: 2.5vw;
        --majestic_submenu_extra_small_font_size: 2.0vw;
        --majestic_submenu_phone_font_size: 3.8vw;
        --majestic_submenu_mail_font_size: 3.4vw;
        --majestic_submenu_button_font_size: 3.2vw;
        /*-------------SUBMENU FONT SIZES------------*/
    }
    .majestic_submenu_images_container {
        display: none;
    }
    .majestic_submenu_links_master_container {
        flex: 0 1 100%;
        flex-direction: column;
    }
    .majestic_submenu_links_logo {
        height: 10%;
        position: relative;
        display: block;
        width: 100%;
        margin: 3vh 0 0 0vw;
        flex: 0 1 15%;
    }
    .majestic_submenu_links_logo img {
        height: 100%;
        position: relative;
    }
    #floating_menu {
        max-height: 85%;
        margin: 0 0 15px 0;
        justify-content: flex-start;
        margin: 0 auto;
    }
    .majestic_submenu_links_container {
        width: 90%;
        flex: 0 1 85%!important;
    }
    .majestic_submenu_button {
        padding: 10px calc(var(--majestic_submenu_button_font_size) * 2.2) 5px calc(var(--majestic_submenu_button_font_size) * 2.2);
    }
    .majestic_submenu_close_button {
        position: absolute;
        top: 15px;
        left: unset;
        right: 15px;
        width: 5.5vw;
        height: 5.5vw;
    }
    .majestic_submenu_links_rooms_container {
        width: 100%;
    }
    .majestic_submenu_links_rooms_container.left_right {
        display: block;
    }
    .majestic_submenu_links_rooms_container.left_right .extra_small {
        width: 50%;
        flex: unset;
        float: left;
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_top_menu_booking_img {
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        height: calc(var(--majestic_submenu_button_font_size) * 1.1);
    }
}

@media screen and (orientation: landscape) and (min-width: 900px) and (max-width: 1200px) {
     :root {
        /*-------------SUBMENU FONT SIZES------------*/
        --majestic_submenu_main_font_size: 2.5vw;
        --majestic_submenu_small_font_size: 1.8vw;
        --majestic_submenu_extra_small_font_size: 1.4vw;
        --majestic_submenu_phone_font_size: 2.8vw;
        --majestic_submenu_mail_font_size: 2.4vw;
        --majestic_submenu_button_font_size: 2.2vw;
        /*-------------SUBMENU FONT SIZES------------*/
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_images_container {
        display: none;
    }
    .majestic_submenu_links_master_container {
        flex: 0 1 100%;
    }
    .majestic_submenu_links_logo {
        height: 20%;
        position: relative;
        display: block;
        margin: 3vh 0 0 0vw;
    }
    .majestic_submenu_links_logo a {
        height: 100%;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-content: center;
        justify-content: center;
        align-items: center;
    }
    .majestic_submenu_links_logo img {
        height: 100%;
        position: relative;
    }
    #floating_menu {
        max-height: 100%;
        margin: 0 0 15px 0;
        justify-content: flex-start;
    }
    .majestic_submenu_links_container {
        width: 90%;
    }
    .majestic_submenu_button {
        padding: 10px calc(var(--majestic_submenu_button_font_size) * 2.2) 5px calc(var(--majestic_submenu_button_font_size) * 2.2);
    }
    .majestic_submenu_close_button {
        position: absolute;
        top: 15px;
        left: unset;
        right: 15px;
        width: 2.5vw;
        height: 2.5vw;
    }
    .majestic_submenu_links {
        padding: 0 0 1vmax 0;
    }
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    /*------------------------FLOATING MENU-----------------*/
    .majestic_submenu_links_rooms_container.left_right {
        display: block;
    }
    .majestic_submenu_links_rooms_container.left_right .extra_small {
        width: 50%;
        flex: unset;
        float: left;
    }
    .majestic_submenu_top_menu_booking_img {
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        height: calc(var(--majestic_submenu_button_font_size) * 1.1);
    }
}