@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&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, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td { margin: 0px; padding: 0px; border: 0px none; outline: 0px none; font-weight: inherit; font-style: inherit; font-size: 100%; font-family: inherit;}
:focus { outline: 0px none; }
ol, ul { list-style: none outside none; }
strong{font-weight:500;}
a{color:#000;text-decoration:none;}
a:hover{color:#000;text-decoration:none;}
.clear{clear:both;}

html, body {
	position: relative;
	height: 100%;
}
body {
	background: #1A1A1A;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	line-height:20px;
	color:#fff;
	margin:0;
	padding:0;
	transition: all 0.5s ease-in 0s;  
	overflow-x:hidden;
}

html {
	scroll-behavior: smooth;
}

.no_scroll {
	overflow: hidden;
}

.padd{
	padding-top: 100px;
	padding-bottom: 100px;
	overflow:hidden;
	position:relative;
}

.no-padding {
	padding-left: 0px;
	padding-right: 0px;
}

.padd_small{
	padding-top: 40px;
	padding-bottom: 40px;	
}
.padd_top{
	padding-top: 100px;
	padding-bottom: 0px;	
}
.padd_big {
	padding-top: 100px;
	padding-bottom: 100px;
}

.padd_bottom{
	padding-top: 0px;
    padding-bottom: 100px;	
}
.container-fluid.no-padd{
	padding-top: 0px;
	padding-bottom: 0px;
}
.img-responsive{
	width: 100%;
}

hr {
	margin-top: 50px;
    margin-bottom: 40px;
    border-top: 1px solid #ECEAE4;
}
.no-gutter > [class*='col-'],  .no-gutter .row > [class*='col-'] {
    padding-right:0;
    padding-left:0;
}
.no-margin.row {
    margin-right:0;
    margin-left:0;
}

.overflow {
	overflow: hidden;
}

label[for=NewsletterSignupEmail] {
	display: none;
}

.visible {
	overflow: visible!important;
}

.no-margin.row  [class^="col-"],
.no-margin.row  [class*=" col-"] {
  padding-right: 0;
  padding-left: 0;
  position: relative;
}

.flex_center {
	display: flex;
	align-items: center;
}

.hide_text {
	display: none;
}

.drive_me{
	margin-top:20px;
	display: block;
}

.hotel_history{padding-bottom:30vh;}

.name_moto{
	background:#000000;
	padding:5%;
}
.name_moto hr{
	border:1px solid #674439;
}
.home_half_text .name_moto p{
	font-family: 'Alegreya', serif;
	font-style: italic;
	font-size:20px;
	letter-spacing: 0.1px;
	color: #fffbeb;
}

.home_half_text .name_moto p:before{
	display:inline;
	font-size: 6em;
	padding: 0;
	color:#fff;
	position: relative;
	top: .25em;
	quotes: "“" "“" "“" "“";
	content: open-quote;
}

#show_991 {
	display: none;
}

.more{
	font-size: 21px;
    line-height: normal;
    color: #fff;
    position: relative;
    text-decoration: none;
    padding: 22px 115px;
    margin-top: 220px;
    display: block;
    width: fit-content;
    font-weight: 400;
    transition: all 0.3s ease-in-out;
    border: 1px solid #fff;
    border-radius: 70px;
	z-index: 1;
}

.more.center {
	margin: 40px auto 0 auto;
}

.more.white {
	color: #fff;
    font-size: 19px;
	border: 1px solid #ccc;
}

.more::before {
	content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
	border-radius: 70px;
    transition: opacity 0.3s, border 0.3s;
}

.more:hover::before {
	opacity: 0;
}

.more:hover {
    color: #1a1a1a;
}

.more::after {
	content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
	border-radius: 70px;
    background-color: #fff;
    border-color: transparent;
    transform: translate(0px, 0px) scale(0.1);
    opacity: 0;
    z-index: -1;
    transition: transform 0.3s, opacity 0.3s, background-color 0.3s;
}

.more:hover::after {
	opacity: 1;
	transform-origin: 52px 50px;
	transform: scale(1) translate(0px, 0px);
}

.more.directions {
    margin-top: 30px;
    margin-left: auto;
    margin-right: auto;
    background: #1a1a1a;
    margin-bottom: 20px;
}


.styled_btn{
	position: fixed;
    left: 0px;
    bottom: 0px;
    /* width: 100px; */
    /* height: 100px; */
    z-index: 2;
    border-radius: 0px;
    background: #101010;
    color: white;
    border: none;
    border: 1px solid #454444;
    padding: 6px;
    font-weight: 200;
    padding: 5px 19px;
    border-top-right-radius: 5px;
}

/* ================= HEADER ==================== */

.header {
    width: 100%;
    height: auto;
    margin: 0;
	padding: 25px 85px;
    position: relative;
    z-index: 999;
    transition: all 0.3s;
    border-bottom: 1px solid #fff;
}

.header_wrapper {
    position: relative;
    width: 100%;
    color: #fff;
    background: #1a1a1a;
	z-index: 999;
	/* animation: slide-down 0.7s; */
}

ul.menu {
	display: flex;
	justify-content: space-between;
}

ul.menu.down {
	justify-content: space-around;
}

.logo.mob {
	display: none;
}

.menu li {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
	position: relative;
}

.menu li.first {
	align-items: flex-start;
}

.menu li.last {
	align-items: flex-end;
}

.menu li img {
    width: 37px;
    height: 37px;
    margin-bottom: 30px;
}

.menu li a {
    font-size: 22px;
    color: #fff;
    font-weight: 200;
    transition: all 0.3s ease-in-out;
    font-family: 'Inter', sans-serif;
    background: #00000001;
    transition: all 0.3s ease-in-out;
}

.menu li:hover a {
	opacity: 0.5;
}

.menu li.current a {
    opacity: 0.5;
}

#lang_info {
	display: block;
    z-index: 999;
    margin-left: 15px;
}
#lang_info a{ color:#fff; transition:all 1s;}
.caret {
	display: block;
    margin: 3px auto 0 auto;
}

#lang_mob { position:absolute; top: 50px; left: 215px; display: block;z-index:9999;  font-weight:400; font-size:15px; color:#fff; transition:all 1s; }
#lang_mob a{ color:#fff; transition:all 1s;}

#header.fixed #top_info, #header.fixed #top_info_right { top: 20px; transition:all 1s;}
#header.fixed #top_info a, #header.fixed #top_info_right a { color:#202020; }

#header.fixed #lang_info { top: 30px; transition:all 1s;}
#header.fixed #lang_info a{ color:#606060; transition:all 1s;}
#header.fixed .languages_menu.active { box-shadow: 0 2px 6px rgb(0 0 0 / 20%); background: rgb(227 223 218); }


/* ============================ MENU DROPDOWN ============================ */

.rooms-trigger-menu, .experience-trigger-menu{position: relative;display: inline-block;}
.dropdown_rooms_menu, .dropdown_experience_menu {
	display: none;
	position: absolute;
	background-color: #F7F6F5;
	min-width: 160px;
	box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
	z-index: 1;
	padding:10px 10px;
  }
  .dropdown_rooms_menu ul li, .dropdown_experience_menu ul li{padding:5px 15px;}
  .dropdown_rooms_menu ul li a, .dropdown_experience_menu ul li a{color:#94A069;}
  .rooms-trigger-menu:hover .dropdown_rooms_menu, .experience-trigger-menu:hover .dropdown_experience_menu {display: block;}


#menu {
	border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    padding: 12px 0;
    margin-top: 15px;
}


.sticky {
	position: fixed;
    top: 0;
    width: 100%;
    z-index: 9999999;
    animation: slide-down 0.4s;
    transition: all 0.3s ease-in-out;
}  

.header_wrapper.sticky .menu li img {
   display: none;
}

.sticky #menu {
	display: none;
}

.sticky .top_info {
	border-bottom: none;
    background: #3B3B3B;
    padding: 0px 7%;
}

.sticky #logo {
	width: 115px;
    height: 60px;
    margin: 5px auto 5px auto;
}

#language {
    position: fixed;
    right: 0;
    bottom: 15px;
    display: flex;
    width: 85px;
    z-index: 3;
    justify-content: center;
    margin-top: 10px;
    writing-mode: horizontal-tb;
}

#language.mob {
	display: none;
}

.languages {
	display: block;
	transition: all 0.5s ease-in-out;
}

.languages a {
    color: #fff;
    font-size: 14px;
    padding: 0px 3px;
    font-weight: 500;
    width: 33px;
    height: 33px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.languages.lang-active a{
	border: 1px solid #fff;
	border-radius: 50%;
    font-weight: 600;
}
.languages .languages_menu{  display: none; }
.phones .phones_menu{display: none;}
.languages .languages_menu.active{
	display: block;
    margin-top: 1px;
    padding: 5px 12px;
    background: #fff;
    text-align: center;
    z-index: 99999;
    position: absolute;
}
.phones .phones_menu.active{
		display: block;
    margin-top: 1px;
    padding: 12px 12px;
    background: #fff;
    text-align: center;
    z-index: 99999;
    position: absolute;

}
#lang_info .languages .languages_menu a,.phones .phones_menu.active a { 
	color: #488990;
    display: block;
    font-size: 18px;
    padding: 4px 4px !important;
    transition: all 0.3s ease 0s;
}
#lang_info .languages .languages_menu a:hover, .phones .phones_menu.active a:hover { color:#444; transition: all 0.3s ease 0s;   }

#logo {
	margin: 10px auto 0 auto;
    display: block;
    width: 150px;
    height: 80px;
    background: url(../img/layout/logo.svg) no-repeat scroll center center;
    background-size: 100%;
    z-index: 9999;
    transition: all 0.5s ease-in-out;
}
#logo_mob { position:absolute; display: block; width: 220px; height: 140px; background: url('../img/layout/logo.svg') no-repeat scroll center center; background-size:100%;z-index:999; transition:all 1s; margin-left: 30px; }
#logo a, #logo_mob a { display: block; width: 100%; height: 100%;text-indent: -999999px!important; background: #00000001; }

.open_menu {
	position: relative;
    display: none;
    font-weight: 400;
    z-index: 999;
    transition: all 1s;
}

.close_menu {
	display: none;
}

.open_menu.inactive {
	display: none;
}

.close_menu.active {
	display: block;
}

.top_info_right img {
	display: none;
}

img.dark_call, img.dark_email { display: none; }
#header.fixed img.white_call, #header.fixed img.white_email { display: none; }
#header.fixed img.dark_call, #header.fixed img.dark_email { display: inline-block; }

#header.fixed .open_menu { color:#202020; top: 10px; transition:all 1s; }
#header.fixed .open_menu img.dark_menu{display:inline-block;}
#header.fixed .open_menu img.white_menu{display:none;}

.responsive_menu ul li .dropdown_rooms,
.responsive_menu ul li .dropdown_sights {
    width: 100%;
    color: #fff;
    transition: all ease-in-out .3s;
    -webkit-transition: all ease-in-out .3s;
    -moz-transition: all ease-in-out .3s;
    display: none;
}
.responsive_menu ul li .dropdown_rooms.active, .responsive_menu ul li .dropdown_sights.active { display: block; }

.responsive_menu ul li .dropdown_rooms ul {
	display: inline-block;
    padding: 2px 0;
    margin: 10px auto 5px auto;
    border: none;
}

.responsive_menu ul li .dropdown_rooms ul li {
  position: relative;
  display: inline-block;
  transition: all ease-in-out .3s;
  margin-bottom: 0;
}

.responsive_menu ul li .dropdown_rooms ul li a {
	display: block;
    padding: 3px 0 0 0;
    line-height: 1.5;
    transition: all ease-in-out .3s;
    color: #889566;
    font-size: 18px;
    border: none;
    font-weight: 300;
    text-transform: uppercase;
}

.responsive_menu ul li .dropdown_rooms ul li.first a {
	width: fit-content;
    margin: 0 auto;
    padding: 2px 20px;
    color: #fff;
    background: #889566;
    margin-top: 5px;
}

.close_menu {
    background: url(../img/layout/close.svg) no-repeat center;
    background-size: 50px;
    width: 50px;
    height: 50px;
    background-position: center;
    text-indent: -999999px!important;
    z-index: 9999;
    margin: 0 auto;
}
.close_menu:hover { }

#book_now {
	position: absolute;
    top: 0px;
    right: 150px;
    display: block;
    font-weight: 400;
    font-size: 20px;
    z-index: 999;
    color: #fff;
    text-decoration: none;
    transition: all 1s;
    border-bottom: 2px solid #fff;
    padding: 5px 30px 7px 0;
}
#book_now:hover{
	padding-right: 38px;
}

.responsive_menu #book_now {
    top: 50px;
    color: #362211;
    border-bottom: 2px solid #362211;
}

#header.fixed #book_now {
	color: #606060;
    top: 20px;
    transition: all 1s;
    border-bottom: 2px solid #606060;
    background: none;
}

#header.fixed .responsive_menu #book_now {
	color: #362211;
    border-bottom: 2px solid #362211;
	top: 40px;
	display: block;
}

#header.fixed { height: 110px; padding: 0px 7%; background: #F4F3F2; box-shadow: 0 2px 6px rgb(0 0 0 / 20%); }
#header.fixed #menu {
	display: none;
}

#header.fixed .top_info {
    border-bottom: none;
}

@keyframes slide-down {
    0% {
        opacity: 0;
        transform: translateY(-100%);
    } 
    100% {
        opacity: 0.9;
        transform: translateY(0);
    } 
}
/*
#header.fixed  #top_info{ color:#3D3D3B;}
#header.fixed  #top_info a{ color:#3D3D3B; }
#header.fixed  .languages  a.selected_lang{ color:#3D3D3B; border-color:#3D3D3B; }
#header.fixed  .languages  .languages_menu a{ color:#3D3D3B; }
#header.fixed  .open_menu  { color:#3D3D3B; border-color:#3D3D3B; }
#header.fixed  #book_now  { color:#3D3D3B; border-color:#3D3D3B; }*/
#header.fixed  #logo {
	width: 130px;
    height: 90px;
    margin-top: 10px;
}

.responsive_menu{   
    position: fixed;
    right: 0;
	top: 154px;
    margin: 0 auto;
    height: calc(100vh - 154px);
    width: 100%;
    display: none;
    color: #fff;
    z-index: 999;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden;
    -webkit-overflow-scrolling: touch;
    -webkit-transform: translateX(-100%);
    -moz-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    -o-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition-property: -webkit-transform;
    -moz-transition-property: -moz-transform;
    transition-property: transform;
    -webkit-transition-duration: 0.4s;
    -moz-transition-duration: 0.4s;
    transition-duration: 0.4s;
}
.responsive_menu .responsive_menu_container {   
	width: 100%;
    height: 100%;
    margin: 0 auto;
    position: relative;
    display: flex;
    justify-content: center;
	flex-direction: column;
	align-items: center;
}
.responsive_menu.active {   
	-webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
    overflow-y: scroll;
    background: #1a1a1a;
    display: block;
}

.sticky .responsive_menu {
    top: 80px;
    height: calc(100vh - 80px);
}

.responsive_menu.active .hero_bg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    /* animation: unset; */
	/* animation: grow 40s linear 10ms infinite; */
    transition: all 0.2s ease-in-out;
}


.responsive_menu ul{ margin: 0 3%;  padding: 0px 0 0 0; width: 100%;  float: left;  list-style: none; }
.responsive_menu ul li{
    width: 100%;
    display: block;
    margin-bottom: 7px;
    color: #fff;
    font-size: 18px;
    text-transform: uppercase;
    font-weight: 200;
    text-align: center;
}

.responsive_menu ul.menu_half li a {
	font-weight: 300;
}

.responsive_menu ul li:last-child a {
	border-bottom: none;
}

.responsive_menu ul li a{
    display: block;
    position: relative;
    z-index: 9999;
    font-size: 25px;
    color: #fff;
    padding: 10px 0px;
    border-bottom: 1px solid #888;
    background: #00000001;
    font-weight: 200;
    text-align: center;
    transition: all 0.3s ease-in 0s;
}

.responsive_menu ul li.hide_item {
	display: none;
}

.contact_menu .footer_social {
    border-top: 2px solid #fff;
}

.responsive_menu .contact_menu ul li {
	margin-bottom: 9px;
    background: #00000001;
    color: #fff;
    font-weight: 200;
}

.responsive_menu .contact_menu ul li a {
    color: #fff;
    font-weight: 200;
	border-bottom: none;
}

.responsive_menu .contact_menu ul li.menu_social {
	margin-top: 15px;
    margin-bottom: 0;
}

.responsive_menu .contact_menu ul li.menu_social a {
    display: inline-block;
}

.responsive_menu .contact_menu ul li a {
	font-size: 17px;
    padding: 2px 0;
}

.responsive_menu ul li a span{  font-size: 16px; font-weight:300;  color:#333; padding:0px 10px 0px 0px; font-weight:300;transition: all 0.3s ease-in 0s;}
.responsive_menu ul li.book_now_menu_item{ display: none;}

.book_menu{position: absolute; top:20px;left:20px;}
.book_menu a{  display: block;   font-weight: 400;    font-size: 14px;    z-index: 999;    color: #fff;    text-decoration: none;    transition: all 1s;    border: 1px solid #fff;
    padding: 10px;    background: rgba(0,0,0,.2); }

.book_menu a:hover {color: #fff!important;		transition: all 0.3s ease 0s;}
.book_menu a:hover:before {    transform: scaleX(1);    transform-origin: left 50%;    width: 100%;    height: 100%;    display: block;}

.responsive_menu .extra_links {
    position: relative;
    top: 300px;
    display: block;
    width: fit-content;
    padding-left: 20px;
    margin-left: 10px;
    border-left: 1px solid #fff;
}

.responsive_menu .extra_links p {
	font-size: 16px;
    font-family: 'Manrope', sans-serif;
    font-weight: 300;
    color: #fff;
    margin-bottom: 10px;
	letter-spacing: 1px;
	text-transform: uppercase;
}

.responsive_menu .extra_links p a {
	color: #fff;
	transition: all 0.3s ease-in-out;
}

.responsive_menu .contact_menu{
    padding: 30px 50px;
    display: block;
    margin: 5% 5% 0 5%;
    border-top: 1px solid #fff;
}

.responsive_menu .contact_menu ul {
	width: 100%;
    margin: 0;
}

.menu_graphic {
	position: absolute;
    width: 120px;
    margin-top: -55px;
    margin-left: -60px;
}
.responsive_menu .contact_menu span{
	display: inline-block;
	font-size: 18px;
    margin: 10px 0px 10px 0px;
    color: #362211;
    text-align: center;
    font-family: 'Manrope', sans-serif;
    font-weight: 500;
}

.responsive_menu .contact_menu span a {
	color: #362211;
}

.responsive_menu .contact_menu img{ width: 22px;  display: inline-block; margin-right:5px; vertical-align:middle;  }

.menu_social {
	display: flex;
    align-items: center;
	margin-right: 0px;
}

.responsive_menu .menu_social img {
	width: 24px;
    margin: 0 10px;
	filter: invert(1);
}

.mobile_graphic {
    background-image: url(../img/layout/logo_footer.svg);
    position: absolute;
    width: 38%;
    height: 38%;
    left: -10px;
    filter: blur(4px);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.contact_menu_container{width:100%;margin:0 auto;}


/* Newsletter */

.newsletter {
	display: flex;
    position: relative;
    align-items: center;
    flex-direction: column;
    justify-content: center;
	padding: 170px 0 80px 0;
	margin-top: 80px;
}

.newsletter_title {
	font-size: 62px;
    line-height: 62px;
    margin-bottom: 20px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 600;
    color: #338484;
}

.newsletter_subtitle {
	font-size: 21px;
    font-weight: 200;
    color: #333;
    line-height: normal;
    letter-spacing: 1px;
    margin-bottom: 35px;
}

.newsletter-input {
	width: 23%;
    text-align: center;
}

.newsletter-input input {
	border: none;
    border-bottom: 1px solid #3b3b3b;
    width: 100%;
    font-size: 21px;
    font-weight: 300;
    color: #3b3b3b;
    padding-bottom: 18px;
	text-align: center;
    background: none;
}

.newsletter-input input::placeholder {
	color: #3b3b3b;
}

.newsletter-input .submit input {
    background: none;
    border: 1px solid #3b3b3b;
    color: #000;
    font-weight: bold;
    font-size: 21px;
    transition: all 0.3s ease-in-out;
    width: fit-content;
    padding: 20px 50px;
    margin-top: 25px;
    font-family: 'Source Serif Pro', sans-serif;
}

.newsletter-input .submit input:hover {
	background-color: #338484;
	color: #fff;
	border: 1px solid #338484;
}

.newsletter_bg {
	background-image: url(../img/layout/newsletter_graphic.svg);
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    width: 100%;
    height: 310px;
    top: 0px;
    z-index: -1;
}

/* Footer */
.padd_prefooter{
	background: #3B3B3B;
    overflow: hidden;
    position: relative;
}

.footer_mobile {
	display: none;
}

.logo_bg_footer {
    text-align: center;
    padding: 32px 0;
    border-bottom: 1px solid #fff;
}

.footer {
    margin: 30px 0px 0px 0px;
    position: relative;
    border-top: 1px solid #fff;
    padding-top: 20px;
	padding-bottom: 20px;
}

.footer_box .book {
	padding: 15px 35px;
    color: #fff;
    border: 1px solid #fff;
    display: block;
    width: fit-content;
    font-size: 21px;
    margin: 0 auto 55px auto;
    font-family: 'Source Serif Pro', sans-serif;
}

.footer_box h6{
	font-size: 24px;
    font-weight: 300;
    margin-bottom: 10px;
    line-height: normal;
    color: #fff;
	letter-spacing: 1px;
}

.footer_box img {
	width: 15px;
    margin-right: 10px;
}

.footer_box img.footer_first_img {
	width: 13px;
}
.footer_box_container ul { margin-top:18px; padding-top:25px; border-top:2px solid #674439; display: flex; list-style: none;  justify-content: space-between;}
.footer_box_container ul li{ overflow:hidden;height:20px; position:relative;}
.footer_box_container ul li a{ display:block; text-transform:uppercase; color: #333; font-size:16px;font-weight:400; margin-right:18px; transition: all 0.3s ease 0s;}
.footer_box_container ul li a:hover{  color: #674439;  transition: all 0.3s ease 0s;}

.content .footer_box p {
    line-height: 36px;
    font-size: 26px;
	font-weight: 200;
}

.footer_box {
	margin-bottom: 90px;
}

.footer_box p a {
	color: #fff;
	font-weight: 200;
    font-size: 26px;
    transition: all 0.3s ease-in-out;
}

.footer_box p a.phone_sec, .footer_box p a.mail_sec {
	margin-left: 25px;
}

.footer_box p.newsletter_subtitle {
	line-height: 28px;
	margin-bottom: 15px;
}

.footer_box .hide {
	display: none;
}

.footer_box p a:hover { opacity: 0.5; transition: all 0.3s ease-in-out; }

.footer_box.social_media { }
.footer_box.social_media img{ width: 32px;  display: inline-block; margin-right:7px; transition: all 0.3s ease 0s; }
.footer_box.social_media img:hover{ opacity: 0.5; }

.footer_social {
	padding: 25px 0px 30px 0px;
}

.footer_social.mob {
	display: none;
}

img.footer_logo{
    max-width: 55%;
    width: 100%;
    float: right;
    margin-right: 80px;
}
.footer_details_left{width:50%;float:left;}
.footer_details_right{width:50%;float:left;}

.footer_social img {
    width: 27px;
    display: inline-block;
    margin-right: 22px;
}

.footer_social img.instagram {
	width: 25px;
}


/* ============= ESPA ================= */
.espa {
    position: absolute;
    left: 7px;
    z-index: 1;
    bottom: 0;
    max-width: 100px;
}
.espa img { max-width: 100%; }


@media only screen and (max-width: 549px) {
	.espa {
		bottom: 65px;
		max-width: 80px;
	}
}

@media only screen and (max-width: 479px) {
	.espa {
		bottom: 0;
	}
}

@media only screen and (max-width: 420px){
	.espa {
		bottom: 20px;
	}
}

/* ============== END ESPA ============== */



/* Copyright */
.padd_footer{	padding-top: 10px;	padding-bottom: 10px;	background:#EBEAE6; }
.copyright{
    font-size: 18px;
    padding-bottom: 15px;
    padding-top: 15px;
    color: #fff;
    text-transform: uppercase;
    font-weight: 200;
    display: inline-block;
}
.copyright a{	color: #fff;}
#wapp{position:relative;}
#wapp a{
	display: block;
    width: 90px;
    height: 27px;
    background: #00000001 url(../img/layout/wapp.svg) no-repeat center;
    text-indent: -999999px!important;
    background-size: 100%;
}

.copyright_wrapper {
	padding: 15px 0px;
    position: relative;
    overflow: hidden;
}

.copyright_wrapper.mob {
	display: none;
}

.copyright_menu p {
	display: inline-block;
}


/* PAGE HEADINGS
================================================== */

.page_heading_image {
	position: relative;
    color: #fff;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    height: 100vh;
    min-height: 400px;
    margin: 85px;
    filter: grayscale(0.6);
    border-radius: 25px;
}

.page_heading_image.room_header {
	filter: none;
}

.page_heading_shadow{
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(180deg, rgba(0,0,0,0.3) 100%, rgba(0,0,0,0.3) 100%, rgba(0,0,0,0.3) 100%);
    z-index: 0;
}

.room_heading_shadow {
	height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(180deg, rgba(0,0,0,0.1) 100%, rgba(0,0,0,0.1) 100%, rgba(0,0,0,0.1) 100%);
    z-index: 0;
}

.content.about.dynamic {
    padding-bottom: 0;
    width: 68%;
}

.dynamic_img {
	margin-top: 150px;
    width: 90%;
    border-radius: 20px;
    margin-bottom: 90px
}

.content.about.page {
    width: 100%;
    padding-top: 0;
    padding-bottom: 0;
}

.about_img {
	display: none;
}

.about_img img {
    border-radius: 20px;
    filter: brightness(0.6);
}

.content.about.page p {
	font-size: 21px;
    line-height: 34px;
    margin: 10px 15px 10px 0;
    display: block;
	font-weight: 300;
}

.content.page h3 {
	font-size: 24px;
    font-weight: 500;
    margin-top: 30px;
    margin-bottom: 15px;
}

.content.page ul li {
	display: block;
    position: relative;
    font-size: 21px;
    font-weight: 400;
    line-height: 25px;
    padding: 5px 0;
    padding-left: 40px;
}

.content.page ul li a {
	color: #fff;
}

.content.page ul li:before {
    content: '';
    position: absolute;
    width: 15px;
    height: 15px;
    background: #fff;
    border-radius: 100%;
    left: 0;
    top: 11px;
}

.page_description {
	width: 50%;
    float: right;
    padding-top: 140px;
    padding-bottom: 190px;
}

.content .page_description p {
    font-size: 25px;
    font-weight: 300;
    line-height: 35px;
	margin-bottom: 15px;
}

.page_banner_content {
	z-index: 1;
    position: relative;
    margin-top: -45px;
}

.page_banner_content h1 {
    font-size: 80px;
    font-weight: bold;
    color: #fff;
}

.page_banner_content h1 span.first {
	padding-left: 150px;
}

.page_banner_content h1 span.sec {
	float: right;
}

.page_heading_image p { margin-bottom:10px;font-size:18px;font-weight:300;line-height:28px;text-shadow: 1px 0 50px rgba(0,0,0,0.2); display: block;  }

.header_content {
	padding: 30px 0;
	margin-bottom: 30px;
	border-bottom: 1px solid #fff;
}

.header_content h1 {
	font-size: 80px;
    font-weight: bold;
    color: #fff;
	text-transform: uppercase;
}

/* HOMEPAGE
================================================= */

.content {
	padding-left: 100px;
    padding-right: 100px;
}

.content.about h2 {
    margin-right: 110px;
    position: relative;
    display: inline-flex;
    top: -10px;
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}

.content h2 {
	font-size: 21px;
    font-weight: 300;
    position: relative;
	padding-left: 40px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #fff;
    padding-bottom: 25px;
	margin-bottom: 40px;
	text-transform: uppercase;
}

.content h2:before {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 100%;
    left: 0;
}

.content p {
	font-size: 41px;
    font-weight: 400;
    line-height: 52px;
}

.content.about p {
	display: inline;
}

.content.about {
    width: 66%;
    float: left;
    padding-top: 60px;
    display: block;
	padding-bottom: 260px;
    overflow: hidden;
}

.content.location {
    padding-bottom: 260px;
    padding-top: 270px;
}

.location1 {
	width: 300px;
    position: relative;
    display: inline-block;
    margin-left: 65px;
    margin-top: -75px;
    float: left;
    border-radius: 20px;
    z-index: -1;
} 

.location2 {
	width: 300px;
    position: relative;
    display: inline-block;
	border-radius: 20px;
	float: right;
	margin-right: 30px;
}

.location3 {
    display: block;
    width: 450px;
    border-radius: 20px;
    margin: 30px auto 0 auto;
}

.offer_box {
    border-right: 1px solid #fff;
    padding-right: 115px;
}

.offer_box.last {
    padding-left: 50px;
    padding-right: 80px;
    border-right: none;
}

.offer_box h3 {
	font-size: 52px;
    margin-bottom: 30px;
}

.offers_home .offer_box {
    margin: 20px 0;
}

.offers_home .offer_box.even:before {
	content: '';
	position: absolute;
	border-top: 1px solid #fff;
	width: 100vw;
	top: 0;
}

.content .offer_box p {
    font-size: 27px;
    font-weight: 300;
    line-height: 35px;
    min-height: 105px;
}

.offer_box ul {
    margin-top: 55px;
    min-height: 120px;
}

.offer_box ul li {
    display: inline-flex;
	position: relative;
    width: 49%;
    font-size: 21px;
    font-weight: 300;
    line-height: 25px;
    padding: 5px 0;
	padding-left: 40px;
	text-transform: uppercase;
}

.offer_box ul li:before {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 100%;
    left: 0;
    top: 9px;
}

.book_offer {
    display: flex;
    align-items: center;
    margin-top: 90px;
    justify-content: space-between;
}

.content .offer_box .book_offer p {
    font-size: 28px;
    font-weight: 400;
    min-height: auto;
}

.book_offer .more {
	font-size: 20px;
    padding: 22px 65px;
	margin-top: 0;
}

/* PAGE TEXT
================================================== */
.page_text { }
.page_text h1 {
	font-size: 42px;
    font-weight: 300;
    margin-bottom: 75px;
    color: #000;
    font-family: 'Source Serif Pro', sans-serif;
    position: relative;
    line-height: 50px;
    text-align: center;
}

.page_text h1 span {
	color: #488990;
    font-size: 85px;
    line-height: 110px;
    font-weight: 500;
	display: block;
}

.page_text h2 {
	font-size: 45px;
    line-height: 60px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 300;
    margin-bottom: 20px;
    color: #488990;
}

.page_text h3 {
	font-size: 27px;
    font-weight: 500;
    line-height: 30px;
    margin-bottom: 22px;
    color: #338484;
    font-family: 'Source Serif Pro', serif;
}

.page_text.centered h1 {
	padding-left: 0;
	margin-left: 0;
}

.page_text p.before_title{    font-size: 16px;
    line-height: normal;
    letter-spacing: 1.7px;
    color: #fffbeb;
    text-transform: uppercase;
    margin-top: 25px;
    margin-bottom: 10px;
    font-weight: 400;
    background: #000;
    display: inline-block;
    padding: 5px 15px;
}

.page_text p {
	margin-bottom: 10px;
    font-size: 19px;
    font-weight: 200;
    line-height: 32px;
    color: #000;
}
.page_text ul {margin: 15px 0 15px 0px; overflow:auto;}
.page_text ul li {
	margin: 5px 0 5px 0;
    padding: 0px 0 0 20px;
    font-size: 19px;
    font-weight: 300;
    line-height: 30px;
	color: #3a3a3a;
    background: transparent url(../img/layout/dot_dark.svg) no-repeat 0 12px;
    background-size: 10px;
    transition: all 0.3s ease 0s;
}

.page_text ul.half_list li {
	display: inline-block;
	width: 49%;
}
.page_text ul li:hover {transition: all 0.3s ease 0s;}

.page_text p.zoom{font-size:12px; z-index: 3;  position: relative;}
.centered {text-align:center;}
.left_image {float:left;max-width:400px; margin:10px 30px 10px 0;}
.left_image.offset_top { margin-top:-30px;}
.right_image {float:right;max-width:400px; margin:10px 0px 10px 30px;}
.right_image.offset_top { margin-top:-70px;}

.decorate_image_left {    position: absolute;    right: calc(100% - 125px);    top: 150px;    width: 100%;    max-width: 250px; }
.decorate_image_left img {   width: 100%;   }

.decorate_image_right {    position: absolute;    left: calc(100% - 125px);    top: 450px;    width: 100%;    max-width: 250px; }
.decorate_image_right.rooms {     top: 50px;     }
.decorate_image_right img {   width: 100%;   }

.page_text span.third_row {
	margin-left: 7%;
}

.page_text span.second_row {
	margin-left: 22%;
}

.mini_font a {
	text-decoration: underline;
}

.location_info {
	padding-left: 25px;
}

.page_text .location_info h1 {
	color: #fff;
    font-weight: 500;
    font-size: 55px;
    text-align: left;
    line-height: 65px;
	background: #00000001;
}

.spa_treats {
	margin: 70px 0 20px 0;
	background-color: #9f9e9e;
	padding: 30px 0;
}

.spa_treats h2 {
	text-align: center;
	color: #fff;
	margin-bottom: 30px!important;
	font-size: 30px!important;
}

.page_text.spa_treats ul {
	text-align: center;
	overflow: hidden;
}

.page_text.spa_treats .spa_list li {
	background-image: url(../img/layout/spa_white.svg);
	padding: 15px 25px 25px 25px;
    display: inline-block;
    margin: 3px 15px;
}

.page_text.spa_treats .spa_list li a {
	color: #fff;
	font-family: 'Manrope';
}

.page_text .spa_list li {
	background-image: url(../img/layout/spa.svg);
    background-repeat: no-repeat;
    background-size: 30px;
    background-position: left 19px;
	padding: 15px 15px 25px 25px;
}

.spa_list a {
	padding-left: 10px;
    color: #9a9f87;
    font-weight: 400;
	transition: all 0.3s ease-in-out;
}

.spa_list a:hover {
	text-decoration: underline;
}

@-webkit-keyframes shine_letters {
	from {
	  -webkit-mask-position: 150%;
	}
	
	to {
	  -webkit-mask-position: -50%;
	}
}

.book_now{
    transform-origin: 0 0;
    color: #fff;
    position: fixed;
    right: 0px;
	height: calc(100% - 70px);
    bottom: 0;
    display: flex;
    border-left: 1px solid #fff;
	align-items: center;
    justify-content: center;
    writing-mode: vertical-rl;
    z-index: 1;
    background: #1a1a1a;
	overflow: hidden;
}

.book_now a.book_link {
    color: #fff;
    font-size: 28px;
    font-weight: 700;
    display: flex;
	height: 100%;
    letter-spacing: 25px;
    padding: 0 32px;
    justify-content: center;
    align-items: center;
	z-index: 2;
}

.book_now a.book_link:after {
    content: "";
    position: absolute;
    width: 0;
    height: 100%;
    background: #fff;
    top: 0;
    left: 0;
    z-index: -1;
    transition: 0.4s all cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.book_now:hover a.book_link {
	color: #1a1a1a;
}

.book_now:hover a.book_link:after {
    width: 100%;
}

.book_now:hover #language li a {
    color: #1a1a1a;
}

.book_now:hover .languages.lang-active a {
    border: 1px solid #1a1a1a;
}


/* HOME PAGE
================================================== */

a.overlay_link {display:block;width:100%;height:100%;position:absolute;top:0px;left:0px;text-indent: -999999px; z-index:10; }

.covid_notice { margin:20px 20px 40px 20px; padding:20px; border:1px solid #3D3D3B; text-align:center;}

.home_header {
    height: calc(100vh - 150px)!important;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
}

.home_header h1 {
    font-size: 92px;
    font-weight: 500;
    display: flex;
    align-items: center;
    width: 85%;
    height: 100%;
}

.home_header.el h1 {
	font-size: 85px;
}

.home_header h1 span.left {
    width: 40%;
    text-align: right;
}

.home_header h1 span.banner_graphic {
    background-image: url(../img/layout/banner_graphic.svg);
    background-repeat: no-repeat;
    background-size: 85%;
    background-position: center;
    display: flex;
    width: 60%;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #1a1a1a;
    margin-top: 25px;
    font-weight: 700;
    font-size: 85px;
	position: relative;
	/* -webkit-animation: movescale_little 12s linear infinite;
    -moz-animation: movescale_little 12s linear infinite;
    animation: movescale_little 12s linear infinite; */
}

/* .scroller {
	position: relative;
    overflow: hidden;
    height: 90px;
	width: 100%;
	margin-left: -15%;
    text-align: center;
	display: flex;
    text-align: center;
    align-items: center;
	margin-top: -15px;
} */

.home_header h1 span.banner_graphic .inner {
    /* height: 80px; */
	animation: slide 5s infinite;
	position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto; 
}

@keyframes slide {
    0% {
      top: 0em;
    }
    25% {
        top: 0em;
    }
    50% {
      top: -1.2em;
    }
    75% {
        top: -1.2em;
    }
    100% {
      top: 0em;
    }
}

.scrolling-words-container {
	display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-left: -15%;
    margin-top: -25px;
}
  
.scrolling-words-box {
    height: 6.2rem;
    margin: auto;
    overflow: hidden;
}

.scrolling-words-box ul {
	padding: 0;
	animation: scrollUp 10s infinite;
}

.scrolling-words-box ul li {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 6rem;
    list-style: none;
    font-size: 85px;
    line-height: 95px;
	overflow: hidden;
	padding-bottom: 15px;
	background: #00000001;
}
  
.el .scrolling-words-box ul li {
	font-size: 75px;
    line-height: 85px;
}
  
@keyframes scrollUp {
	15%, 25% {
	  transform: translateY(-6rem);
	}
	40%, 50% {
	  transform: translateY(-12rem);
	}
	65%, 75% {
	  transform: translateY(-18rem);
	}
	90%, 100% {
	  transform: translateY(-24rem);
	}
}

.banner-shape1 {
    position: absolute;
    top: 11%;
    left: 18px;
}

.banner-shape1 img {
	-webkit-animation-name: rotateme;
    -moz-animation-name: rotateme;
    animation-name: rotateme;
    -webkit-animation-duration: 15s;
    -moz-animation-duration: 15s;
    animation-duration: 15s;
    -webkit-animation-iteration-count: infinite;
    -moz-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-animation-timing-function: linear;
    -moz-animation-timing-function: linear;
    animation-timing-function: linear;
    width: 100%;
    height: 125px;
}

.banner-shape2 {
    position: absolute;
    bottom: 10%;
    left: -40px;
}

.banner-shape2 img {
	-webkit-animation: movescale 4s linear infinite;
    -moz-animation: movescale 4s linear infinite;
    animation: movescale 4s linear infinite;
    width: 100%;
    height: 190px;
}

.banner-shape3 {
    position: absolute;
    right: 0%;
    bottom: 20%;
}

.banner-shape3 img {
	-webkit-animation: movebounce 5s linear infinite;
    -moz-animation: movebounce 5s linear infinite;
    animation: movebounce 5s linear infinite;
    width: 100%;
    height: 110px;
}

@-webkit-keyframes movebounce {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0)
	}
	50% {
		-webkit-transform: translateY(20px);
		transform: translateY(20px)
	}
	to {
		-webkit-transform: translateY(0);
		transform: translateY(0)
	}
}

@-moz-keyframes movebounce {
	0% {
		-webkit-transform: translateY(0);
		-moz-transform: translateY(0);
		transform: translateY(0)
	}
	50% {
		-webkit-transform: translateY(20px);
		-moz-transform: translateY(20px);
		transform: translateY(20px)
	}
	to {
		-webkit-transform: translateY(0);
		-moz-transform: translateY(0);
		transform: translateY(0)
	}
}

@keyframes movebounce {
	0% {
		-webkit-transform: translateY(0);
		-moz-transform: translateY(0);
		transform: translateY(0)
	}
	50% {
		-webkit-transform: translateY(20px);
		-moz-transform: translateY(20px);
		transform: translateY(20px)
	}
	to {
		-webkit-transform: translateY(0);
		-moz-transform: translateY(0);
		transform: translateY(0)
	}
}

@-webkit-keyframes rotateme {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg)
	}
	to {
		-webkit-transform: rotate(1turn);
		transform: rotate(1turn)
	}
}

@-moz-keyframes rotateme {
	0% {
		-webkit-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		transform: rotate(0deg)
	}
	to {
		-webkit-transform: rotate(1turn);
		-moz-transform: rotate(1turn);
		transform: rotate(1turn)
	}
}

@keyframes rotateme {
	0% {
		-webkit-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		transform: rotate(0deg)
	}
	to {
		-webkit-transform: rotate(1turn);
		-moz-transform: rotate(1turn);
		transform: rotate(1turn)
	}
}

@-webkit-keyframes movescale {
	0% {
		-webkit-transform: scale(.9);
		transform: scale(.9)
	}
	50% {
		-webkit-transform: scale(.8);
		transform: scale(.8)
	}
	to {
		-webkit-transform: scale(.9);
		transform: scale(.9)
	}
}

@-moz-keyframes movescale {
	0% {
		-webkit-transform: scale(.9);
		-moz-transform: scale(.9);
		transform: scale(.9)
	}
	50% {
		-webkit-transform: scale(.8);
		-moz-transform: scale(.8);
		transform: scale(.8)
	}
	to {
		-webkit-transform: scale(.9);
		-moz-transform: scale(.9);
		transform: scale(.9)
	}
}

@keyframes movescale {
	0% {
		-webkit-transform: scale(.9);
		-moz-transform: scale(.9);
		transform: scale(.9)
	}
	50% {
		-webkit-transform: scale(.8);
		-moz-transform: scale(.8);
		transform: scale(.8)
	}
	to {
		-webkit-transform: scale(.9);
		-moz-transform: scale(.9);
		transform: scale(.9)
	}
}
@-webkit-keyframes movescale_little {
	0% {
		-webkit-transform: scale(.99);
		transform: scale(.99)
	}
	50% {
		-webkit-transform: scale(.95);
		transform: scale(.95)
	}
	to {
		-webkit-transform: scale(.99);
		transform: scale(.99)
	}
}

@-moz-keyframes movescale_little {
	0% {
		-webkit-transform: scale(.99);
		-moz-transform: scale(.99);
		transform: scale(.99)
	}
	50% {
		-webkit-transform: scale(.95);
		-moz-transform: scale(.95);
		transform: scale(.95)
	}
	to {
		-webkit-transform: scale(.99);
		-moz-transform: scale(.99);
		transform: scale(.99)
	}
}

@keyframes movescale_little {
	0% {
		-webkit-transform: scale(.99);
		-moz-transform: scale(.99);
		transform: scale(.99)
	}
	50% {
		-webkit-transform: scale(.95);
		-moz-transform: scale(.95);
		transform: scale(.95)
	}
	to {
		-webkit-transform: scale(.99);
		-moz-transform: scale(.99);
		transform: scale(.99)
	}
}

.room_details  ul li {
    margin: 0;
    padding: 0px 15px 0 15px;
    border-right: 1px solid #fff;
    font-size: 24px;
    font-weight: 300;
    color: #fff;
    display: inline-block;
    line-height: 30px;
    background: none;
    transition: all 0.3s ease 0s;
	overflow: hidden;
}

.room_details ul li:last-child {
	border-right: none;
}

.rooms_more {
	position: absolute;
    bottom: 140px;
    color: #fff;
    font-size: 26px;
    font-weight: 100;
    border-bottom: 1px solid #fff;
    padding-bottom: 10px;
    padding-right: 11px;
    right: 0px;
	margin-right: 100px;
	transition: all 0.3s ease-in-out;
}

.room_buttons .room_more {
	font-size: 21px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: bold;
    color: #000;
    border: 1px solid #535353;
    padding: 20px 50px;
	margin: 32px 20px 0 20px;
    margin-top: 25px;
    display: inline-block;
}

.room_buttons .room_book {
	color: #fff;
    background: #338484;
	border: 1px solid #338484;
    font-size: 21px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: bold;
    padding: 20px 40px;
    display: inline-block;
	margin: 32px 20px 0 20px;
	transition: all 0.3s ease-in-out;
}

.room_buttons .room_book:hover {
	border: 1px solid #3a3a3a;
	background: transparent;
	color: #3a3a3a;
}

.gallery_view {
	width: 100%;
	overflow: hidden;
}

.buttons_shadow {
	height: 30%;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
	background: linear-gradient(0deg, rgba(0,0,0,0.7) 10%, rgba(255,255,255,0) 90%, rgba(255,255,255,0) 100%);
    z-index: 1;
}

.rooms_left_image {}
.rooms_left_image img {max-width:100%;}

.rooms_right_image {max-width:100%;position: relative;z-index: 2;}

.room_right_image img { width: 70%; float: right; }

.stay_mob {
	display: none;
}

.rooms_home {
	padding-right: 100px;
	overflow: hidden;
}

.rooms_home img {
	border-radius: 50px;
}

.rooms_home .about_text {
    padding-top: 60px;
}

.rooms_home .about_text.facilities_intro {
	padding-bottom: 60px;
}

.facilities_intro button {
	margin-top: 20px;
    float: right;
    border: none;
    background: none;
    color: #9a9f87;
    font-size: 15px;
}

.facilities_intro button img {
	width: 25px;
    margin-right: 8px;
}

.facilities_reverse .room_right_image img {
    width: 100%;
	float: right;
}

.rooms_home ol {
	list-style: inside;
	margin-top: 20px;
	margin-bottom: 20px;
}

.page_text h5 {
	color: #9a9f87;
    font-size: 28px;
    border-bottom: 1px solid #9a9f87;
    width: fit-content;
    margin-bottom: 20px;
    font-weight: 400;
}

.rooms_home ol li {
	color: #606060;
    font-size: 20px;
	font-weight: 100;
	line-height: 35px;
}

.rooms_home ul {
	list-style: revert;
}

.rooms_home ul li {
	font-size: 20px;
    width: 49%;
    display: inline-block;
    line-height: 40px;
    color: #000;
    margin-bottom: 10px;
}

.list_spa {
	display: inline-block;
    width: 49%;
}

.facility_box {
	position: relative;
    overflow: hidden;
}

.facilities .facility_box img {
    width: 100%;
    border-radius: 17px;
	opacity: 0.4;
	transition: all 0.5s ease-in-out;
}

.facilities .facility_box:hover img {
	opacity: 1;
}

.facilities h3 {
	position: absolute;
    top: 0;
    font-size: 44px;
    font-weight: 600;
    text-transform: uppercase;
    margin-top: 30px;
    margin-left: 45px;
    padding-right: 15px;
}

.content.facilities p {
    font-size: 21px;
    font-weight: 300;
    line-height: 35px;
    margin-top: 80px;
    margin-left: 50px;
    margin-right: 45px;
}

.rooms_home .home_half_text {
    padding: 5px 15px 5px 100px;
}

.swiper-slide .rooms_description {
	display: none;
}

.swiper-slide.swiper-slide-active .rooms_description {
	display: block;
	padding: 10px 30px 0px 50px;
}

.rooms_description_wrapper {
	padding-top: 30px;
    display: block;
    position: relative;
}

.swiper-slide.swiper-slide-active .rooms_description .more {
	font-family: 'Source Serif Pro', sans-serif;
	font-weight: 600;
    font-size: 20px;
	z-index: 0;
}

.swiper-slide .room_number {
	display: none;
}

.swiper-slide.swiper-slide-active .room_number {
	display: block;
    position: absolute;
    top: -85px;
    width: 170px;
    border: 1px solid #fff;
    right: 0;
    left: 0;
    height: 170px;
    overflow: hidden;
    z-index: 1;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.suites_swiper_wrapper {
	overflow: hidden;
	padding-top: 25px;
    padding-bottom: 30px;
}

.swiper-slide.swiper-slide-active .room_number span {
	font-size: 95px;
    position: absolute;
    color: #fff;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 300;
	background: #00000001;
}

.swiper_btn_mob {
	display: none;
}

.swiper_buttons .more {
	margin-left: 25%;
    margin-top: 40px;
}

.reverse-rooms .rooms_description {
	float: right;
}

.rooms_description h2 {
	color: #B0ADA8;
    font-size: 48px;
    line-height: 60px;
    padding: 20px 0 50px 0;
    font-family: 'Manrope', sans-serif;
}

.rooms_description p {
	font-size: 19px;
    font-weight: 200;
    line-height: 32px;
    color: #000;
    position: relative;
}

.room_title p {
	font-size: 45px;
    color: #3B3B3B;
    font-family: 'Source Serif Pro', sans-serif;
    line-height: 55px;
    font-weight: 600;
    padding-right: 50px
}

.swiper_img {
	padding: 0;
}

.rooms_description ul li {
	font-size: 29px;
    color: #000;
    background: none;
    padding-left: 0;
    overflow: hidden;
    line-height: 40px;
    padding-bottom: 30px;
    font-weight: 300;
}

.rooms_description ul li:before {
	content: '';
    position: absolute;
    border-top: 1px solid #000;
    width: 75px;
    height: 1px;
    margin-top: 55px;
}

.rooms_description ul li:last-child::before {
	display: none;
}

.icon_img {
	width: 75%;
    height: 100%;
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 auto;
    z-index: 1;
    bottom: 0px;
}

.swiper-slide .room_title {
	display: none;
}

.swiper-slide.swiper-slide-active .room_title {
	display: block;
}

.page_text .room_title h1 {
	font-size: 38px;
    font-weight: bold;
    color: #444;
    line-height: 48px;
    position: relative;
    margin-bottom: 30px;
    padding: 0 65px;
}

.room_title h1:before {
	display: none;
}

.room_title .rooms_more {
	bottom: 0px;
    right: 50px;
    float: right;
    position: relative;
}

p.total_rooms {
	position: absolute;
    margin-top: 0px;
    right: 0;
    font-size: 35px;
    font-family: 'Source Serif Pro', sans-serif;
    color: #000;
    font-weight: 200;
}

.beige_bg.rooms {
    height: 25px;
    width: 41.67%;
    position: absolute;
    bottom: -85px;
    right: 0;
    margin-bottom: 60px;
    background: #ebeae6;
}

.reverse-rooms .beige_bg.rooms {
    height: 25px;
    width: 41.67%;
    position: absolute;
    bottom: -85px;
    left: 0;
    margin-bottom: 60px;
    background: #ebeae6;
}

.icon_room {
	width: 260px;
    height: 200px;
    margin: 0 auto 40px auto;
}

.room_intro {
	text-align: center;
}

.room_intro h2 {
	font-size: 27px;
    font-weight: 300;
    color: #338484;
    padding-bottom: 140px;
    position: relative;
}

.room_intro h2:after {
	content: '';
    border-right: 1px solid #338484;
    width: 1px;
    height: 85px;
    left: 0;
    right: 0;
    margin: 0 auto;
    position: absolute;
    bottom: 25px;
}

.room_intro h1 {
	color: #3A3A3A;
    font-size: 53px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: bold;
    padding: 0 150px;
	margin-bottom: 40px;
}

.room_intro p {
	font-size: 19px;
    font-weight: 200;
    line-height: 32px;
    color: #000;
    position: relative;
    padding: 0 50px;
    margin-bottom: 15px;
}

.room_intro .more {
	font-size: 18px;
	margin: 60px auto 0 auto;
}

.room_intro .num_photos {
    bottom: 50px;
}

.page_text.room_intro h1 {
    font-size: 60px;
    margin-bottom: 0;
    padding-left: 0;
    margin-left: 0;
    line-height: 60px;
}

.extra_image {
	height: 100vh;
	/* margin: 50px 0; */
	background-repeat: no-repeat;
	background-position: center;
	/* animation:grow 40s linear 10ms infinite; */
}

.page_text.features h1 {
    margin-bottom: 30px;
    padding-left: 0;
    margin-left: 0;
}

.small_img {
	margin-top: -28%;
    position: absolute;
    margin-left: 10%;
}

.small_img img {
	width: 65%;
}

.page_text.other_rooms h1 {
	text-align: left;
    color: #fff;
    font-size: 60px;
    font-weight: 400;
	margin-bottom: 65px;
	background: #00000001;
}

.other_rooms {
    padding-top: 160px;
    padding-bottom: 90px;
    overflow: visible!important;
    background: #CFCDC8;
	margin-top: -70px;
}

.other_rooms.page_text h2 {
	color: #3B3B3B;
    font-weight: 600;
    margin-top: 40px;
    margin-bottom: 0;
    width: 72%;
}

.icon_other {
	width: 200px;
    height: 150px;
    margin: 0 auto 20px auto;
	opacity: 0.7;
}

.rooms_view .room_right_image {
	width: 70%;
    float: right;
    background: #ebeae6e3;
    padding-bottom: 60%;
    position: relative;
}

.rooms_view .room_right_image img {
	width: 100%;
    float: right;
}

.rooms_view .room_book {
    color: #606060;
    border-bottom: 2px solid #606060;
	bottom: 27%;
}

.rooms_view {
	padding-bottom: 0;
}

.features {
	position: relative;
    overflow: visible!important;
    padding-top: 100px;
}

.features_bg {
	position: absolute;
	width: 85%;
    height: calc(100% + 40px);
    background-color: #E3DFDA;
    top: -40px;
    z-index: -1;
    right: 0;
}

.room_features {
	background-color: #E3DFDA;
}

.features_list {
	width: 100%;
	padding: 210px 0 0 10%;
}

.features_list ul li {
	margin: 0;
    padding: 10px 0px 10px 20px;
    font-size: 21px;
    color: #777;
    font-weight: 200;
    line-height: normal;
    transition: all 0.3s ease 0s;
    width: 100%;
    display: inline-block;
    background: transparent url(../img/layout/dot_dark.svg) no-repeat 0 20px;
    background-size: 12px;
}

.features_list.facility_list ul li {
	width: 49%;
	border-right: none;
}

.page_text .features_list.facility_list h2 {
	font-size: 34px;
    font-weight: 300;
    margin-top: 0;
    margin-bottom: 32px;
    font-family: 'Manrope';
    color: #666;
}

/* .features_list.facility_list ul li:nth-last-child(2n) {
    border-right: 2px solid #BFBDBB;
} */

.features_list ul li:last-child, .features_list ul li:nth-last-child(4) {
	border-right: none;
}

.swiper-slide .total_rooms.gallery {
	display: none;
}

.swiper-slide.swiper-slide-active .total_rooms.gallery {
	display: block;
}

.total_rooms.gallery {
	text-align: center;
    width: fit-content;
    left: 0;
    right: 0;
    bottom: -116px;
    margin: 0 auto;
}

.total_rooms.gallery span {
	z-index: 2;
    color: #000;
    position: relative;
}

.mar_neg{margin-top: -5%;border:5px solid #fff;}
.image_subtitle { display:block; margin-top:10px; margin-bottom:30px; font-size:18px; color:#4C5870;}

.sight_container { position:relative; min-height:350px;  }
.sight_container.inner_sight_container {  min-height:600px; overflow:hidden; margin-bottom:50px; }
.sight_box { position:absolute;bottom:0px; }
.sight_box .sight_image { position:relative;	overflow:hidden; }
.sight_box img {max-width:100%; transition: all 0.3s ease 0s;}
.sight_box .sight_subtitle { display:block; margin-top:10px; margin-bottom:10px; color:#4C5870; font-size:18px; text-align:right; transition: all 0.3s ease 0s;}
.sight_box:hover .sight_subtitle{ color:#3D3D3B; transition: all 0.3s ease 0s;}
.sight_box:hover img{  transform: scale(1.05); transition: all 0.3s ease 0s;}

.fragment-banner{height:40vh;overflow:hidden;position: relative;background-size:100%;border:1px solid #f1f1f1;background-color: #000;overflow:hidden;transition: all 0.3s ease 0s;background-size: cover; background-position: center;}
.fragment-banner:hover{transition: all 0.3s ease 0s;    -webkit-transform: translateX(4px) translateZ(0) scale(1.05);
    transform: translateX(4px) translateZ(0) scale(1.05); }


.home_half_text{padding:5px 100px;}
.home_half_text.mar_top{margin-top:100px;}
.home_half_text p{
    margin-top: 25px;
    margin-bottom: 40px;
}

.home_half_text a {
	color: #9a9f87;
}

.home_half_text p.first_line, .suites_description p.first_line, .home_center_title p.first_line{
    font-size: 16px;
    line-height: normal;
    letter-spacing: 1.7px;
    color: #fffbeb;
    text-transform: uppercase;
    margin-top: 25px;
    margin-bottom: 10px;
    font-weight: 400;
    background: #000;
    display: inline-block;
    padding: 5px 15px;

}
.home_half_text h4{
    font-size: 40px;
    line-height: 54px;
    color: #674439;
    margin-top: 10px;
    margin-bottom: 50px;
	font-weight: 400;
	font-family: 'Alegreya', serif;
}
.home_left_image{
	position: relative;
    margin-top: 50px;
}

.home_left_image img{
	width: 100%;
}

.padd.about-section {
	padding-bottom: 0;
}

.about-section {
	z-index: 1;
	position: relative;
}

.page_text .about_left_text p {
	margin-bottom: 40px;
}

.about_right_text {
	padding: 180px 0 0 90px;
}

.about_text {
	position: relative;
    display: flex;
    padding-bottom: 90px;
}

.about_bg {
	background-image: url(../img/layout/bg_graphic.svg);
    background-size: 85%;
    background-repeat: no-repeat;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    right: 0;
    top: 16%;
    background-position: top right;
}

.about_bg.villas {
	z-index: 0;
}

.location_text {
	position: relative;
    overflow: hidden;
    display: block;
    padding-right: 100px;
}

.home_right_image{
	position: relative;
	padding-left: 50px;
    padding-top: 110px;
}
.home_right_image img{
	width:105%;
	z-index: 2;
    position: relative;
}

.parallax{ display: flex; justify-content: center; align-items: center; background-repeat: no-repeat; background-position: center center;}

.parallax_text {
	display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.parallax_text h2 {
	font-size: 80px;
    font-weight: 300;
    margin-bottom: 15px;
    color: #fff;
    font-family: 'Source Serif Pro', sans-serif;
    position: relative;
    line-height: 95px;
}

.parallax_text p {
	color: #fff;
    font-family: 'Source Serif Pro', sans-serif;
    font-size: 32px;
    margin-top: 40px;
    font-weight: 300;
    letter-spacing: 0.5px;
}

.slide_title {
	transition: all 1s ease-in-out;
}

.slide_title h2 {
	font-size: 70px;
    letter-spacing: 1px;
    color: #fffc;
    font-weight: 100;
    font-family: 'Manrope', sans-serif;
    position: absolute;
    bottom: -30px;
    width: 100%;
    left: -33px;
}

.slide_title h2 a {
    color: #fffc;
}

.rooms_grid_inner{  display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.grid_item{
	width:16.66667%;
	clear:both;
}
.grid_icon_rooms img{
	width:70px;
	margin-bottom:15px;
	transform: scale(0.95); transition: all 0.3s ease 0s;
}
.grid_item:hover .grid_icon_rooms img{
	transform: scale(1.00); transition: all 0.3s ease 0s;
}
.grid_icon_rooms_title{
	display: block;
	text-align:center;
	line-height:20px;
	letter-spacing:1px;
}

.sec_line{display:block;}


.page_home_bg:before {
    content: "";
	height: 180px;
    width: 2px;
    background: #a37f72;
    display: block;
    position: absolute;
    top: -90px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}
.page_home_bg {
	width: 100%;
	height: 70vh;
	margin-top: 0;
	/* margin-bottom: 15vh; */
	margin-bottom: 0;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
}
.page_home_bg .more{color:#fff;}
.page_home_bg_text { text-align: center;   background: rgba(51 51 51 / 70%);    padding: 20px; }
.page_home_bg.hotel_home_page .page_home_bg_text {
	position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page_home_bg_text h2{ color: #fff;letter-spacing: 0px;font-size: 40px;font-weight: 300;line-height: 1.1;letter-spacing: 6px;text-transform: uppercase;margin-top:50px;}
.page_home_bg_text p{     font-size: 18px;    font-weight: 300;    line-height: 30px;    color: #fff;    text-shadow: 1px 0 50px rgb(0 0 0 / 80%);    display: block;    margin-bottom: 20px;}

.space_between_suites{
	z-index: 0;
    position: relative;
}

.home_rooms_wrapper {
	padding: 130px 0 110px 0;
    margin-top: -80px;
	flex-direction: column;
}

.thea_left {
	background: #844540;
    padding: 15% 23%;
    height: 100vh;
	position: relative;
	display: flex;
    align-items: center;
}

.activities_right {
	background: #6A774F;
    padding: 15% 23%;
    height: 100vh;
    position: relative;
    display: flex;
    align-items: center;
}

.thea_left a, .activities_right a {
	color: #fff;
    margin: 0 auto;
    display: block;
    font-size: 20px;
    font-weight: 200;
    position: absolute;
    top: 7%;
    left: 0;
    right: 0;
    text-align: center;
}

.thea_left a:after, .activities_right a:after {
	content: '';
    position: absolute;
    border-right: 1px solid #fff;
    height: 250px;
    margin: 45px auto 0 auto;
    z-index: 1;
    left: 0;
    right: 0;
    width: fit-content;
}

.thea_left .thea_logo {
	width: 430px;
    position: absolute;
    top: 41%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.thea_right, .activities_left {
	height: 100vh;
	overflow: hidden;
}

.thea_text, .activities_text {
	height: 55vh;
    padding: 15%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.thea_image, .activities_image {
	height: 45vh;
}

.thea_bg_img, .activities_bg_img {
	height: 45vh;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.thea_right .more, .activities_left .more {
	margin-top: 60px;
    padding: 18px 40px;
    color: #3b3b3b;
    background: transparent;
    border: 1px solid #3b3b3b;
	transition: all 0.3s ease-in-out;
}

.thea_right .more:hover, .activities_left .more:hover {
	color: #fff;
	border: 1px solid #F6F4EE;
}

.page_text .activities_right h1 {
	color: #fff;
    font-size: 75px;
    font-weight: 600;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
	text-align: center;
}

.activities_right img {
	filter: brightness(0.7);
}

.service_left {
	padding: 50px 65px 0 8%;
}

.service_right {
	padding: 0px 8% 0 17%;
	position: relative;
}

.service_right:before {
	content: '';
    position: absolute;
    background-color: #338484;
    width: calc(100% - 35%);
    height: 75%;
    left: 0;
    top: 50%;
    transform: translate(10%, -50%);
}

#swiper_services .swiper-slide {
	height: 85vh;
    background-size: 100%;
    background-repeat: no-repeat;
	background-size: cover;
}

.service_right .suite-button-prev {
	left: 25px;
    top: 72%;
}

.service_right .suite-button-next {
	right: auto;
	left: 25px;
	top: 60%;
}

.page_text .service_left h2 {
	margin-bottom: 50px;
}

.service_left .more {
	margin-top: 60px;
    padding: 18px 30px;
    color: #3b3b3b;
    background: transparent;
    border: 1px solid #3b3b3b;
}

.service_left .more:hover {
	color: #fff;
    border: 1px solid #f6f4ee;
}

.basic_text h1 {
	font-size: 72px;
    font-weight: 400;
    color: #fff;
    font-family: 'Source Serif Pro', sans-serif;
    position: relative;
    line-height: normal;
	background: #00000001;
}

.basic_text h1 span {
	margin-left: 5%;
	font-style: italic;
}

.space_between_suites.mob {
	display: none;
}

.dynamic_right_image {
	width: 75%;
    float: right;
    position: relative;
    margin: 0;
}

.dynamic_right_image:after {
	content: '';
    background: #fff;
    height: 100%;
    position: absolute;
    width: 100%;
    padding-bottom: 100vh;
}

.activities_boxes {
	position: relative;
    display: block;
    margin-top: 100px;
}

.activities_boxes h2 {
	position: absolute;
    background: #f4f3f2;
    color: #555;
    bottom: 0;
    margin: 0;
    padding: 12px 0;
    display: block;
    width: 100%;
	z-index: 1;
}

.activities_all_left {
	padding-right: 65px;
    position: relative;
    display: block;
    width: 49%;
	float: left;
}

.activities_all_right {
	padding-left: 65px;
	position: relative;
    display: inline-block;
    width: 49%;
	float: right;
}

.page_text.activities_intro .basic_text p {
	line-height: 65px;
	font-size: 52px;
}

.activities_all_left .experience_img, .activities_all_right .experience_img {
	overflow: hidden;
	transition: all 0.3s ease-in-out;
}

.activities_all_left .experience_img img, .activities_all_right .experience_img img {
	transition: all 0.3s ease-in-out;
}

.activities_all_left .experience_img:hover img, .activities_all_right .experience_img:hover img  {
	transform: scale(1.1);
	filter: brightness(0.7);
}


.experience_img {
	overflow: hidden;
}

.page_text .activity_description h3 {
    font-size: 28px;
    margin-bottom: 35px;
}

.activity_images .swiper-slide {
	height: 70vh;
    background-repeat: no-repeat;
    background-size: cover;
    filter: brightness(0.8);
}

.activity_images .num_photos {
	left: 50px;
    right: auto;
    bottom: 50px;
}

.activity_images .swiper-button-prev {
    bottom: 55px;
}

.activity_images .swiper-button-next {
    bottom: 55px;
}

.activity_images .swiper-slide a {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.page_text .basic_text .small_p p {
	font-size: 30px!important;
    line-height: 40px!important;
    margin-top: 35px!important;
}

.gallery {
    margin-bottom: 30px;
    transition: all 1s ease;
}

.gallery img {
    width: 100%;
    box-shadow: 0px 0px 10px #ccc;
    transition: all 1s ease;
}

.activity_description {
	padding: 100px 100px;
}

.page_description .room_details_wrap:after {
	display: none;
}

.page_gallery_wrapper {
	padding: 130px 0 0px 0;
    margin-top: -80px;
	flex-direction: column;
}

.page_description .frame_left, .page_description .frame_right {
	height: calc(100% + 20px);
}

.page_description .room_details_wrap {
	z-index: 1;
}

.page_description .page_inner_left {
	padding: 40px 50px 40px 0px;
}

.page_description .page_inner_right {
	padding: 40px 0px 40px 50px;
}

.page_text.page_description h3 {
	font-weight: 600;
}

.page_text .activity_info p {
	padding-right: 50px;
}

.activity_info {
	margin-bottom: 70px;
}

.activities_right_text {
	padding: 100px 40px 100px 70px;
}

.page_text .activities_right_text h2 {
    font-size: 40px;
    line-height: 55px;
}

.page_text .activity_info h2 {
	color: #3A3A3A;
	margin-top: 40px;
    font-size: 43px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 600;
    margin-bottom: 20px;
}

.activity_info .more {
	background: transparent;
    color: #3b3b3b;
    border: 1px solid #3b3b3b;
    padding: 18px 45px;
}

.activity_info .more:hover {
	color: #fff;
	border: 1px solid #338484;
}

.activity_wrapper {
	position: relative;
	display: block;
    overflow: hidden;
	transition: all 0.5s ease-in-out;
}

.activity_wrapper.sec {
	margin-top: 80px;
    margin-left: 15px;
	margin-right: 15px;
}

.activity_wrapper.sec h2 {
	top: 0;
    bottom: auto;
}


.activity_wrapper img {
	transition: all 0.5s ease-in-out;
}

.activity_wrapper:hover img {
	transform: scale(1.05);
	transition: all 0.5s ease-in-out;
}

.page_text .activity_info h1 {
    padding-left: 0;
    margin-left: 0;
}

.activity_number {
	position: relative;
    right: 0;
    top: 0px;
}

.activity_number p {
    top: 0px;
    font-size: 55px;
    position: relative;
    color: #899666;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 300;
    float: right;
    padding-right: 25px;
}

.beach_img {
	z-index: 2;
    position: relative;
}

.beach_info {
	background: #fff;
    position: relative;
    top: -40px;
    margin-left: -7%;
    right: 0;
    padding: 8% 15px 8% 70px;
}

.beach_info.left {
	margin-right: -7%;
    margin-left: 0;
    padding: 8% 70px 8% 40px;
}

.page_text .beach_info.left p {
	text-align: right;
    display: inline-block;
}

.page_text .beach_info h2 {
    font-size: 35px;
    border-bottom: 1px solid #444;
    font-family: 'Source Serif Pro', sans-serif;
    width: fit-content;
    font-style: italic;
    font-weight: 300;
    margin-bottom: 35px;
}

.page_text .beach_info.left h2 {
	float: right;
    display: block;
	text-align: right;
}

.beach_info.left .activity_number {
	right: auto;
    left: 0;
    top: 0;
    float: left;
}

.page_text .page_description  ul {
    list-style: inside;
}

.page_text .page_description ul li {
	background: none;
    font-size: 20px;
    margin: 7px 0;
}

h2.location_title {
	color: #84827E;
    font-size: 75px;
    font-weight: 100;
    font-family: 'Manrope', sans-serif;
    margin-bottom: 80px;
    line-height: 90px;
    margin-left: 100px;
}

.map {
	padding: 100px 0;
	background: #E3DFDA;
	position: relative;
	display: block;
	overflow: hidden;
}



@media(max-width:1499px){
	.shrinkIt{font-size:14px !important;}
	.home_half_text h4{font-size:36px;margin-bottom:30px;}
	.home_half_text{
		padding: 0px 40px;
	}
	.home_half_text p {
		margin-top: 10px;
		margin-bottom: 20px;
	}
	.home_half_text.mar_top{margin-top:30px;}
	.mar_neg{margin-top: 10px;}
	.logo_bg_footer {padding:40px 0;}
}
@media(max-width:1199px){
	.home_half_text{
		padding: 0px 20px;
	}
	.home_half_text h4 {
		font-size: 26px;
		line-height: 30px;
		margin-bottom: 10px;
	}
	.home_half_text p {
		font-size: 19px;
		line-height: 35px;
	}
	.footer_box_container ul li a{
		font-size:15px;
	}
}
@media(max-width:991px){
	.shrinkIt{font-size:21px !important}
	.footer_box_container ul li a{
		font-size:10px;
	}
	.grid_icon_rooms img{
		width: 60px;
	}
	.grid_icon_rooms_title{
		font-size: 12px;
		line-height:16px;
	}
}
@media(max-width:767px){
	.footer_box_container.noshow{
		display: none;
	}
	.home_half_text.mar_top{
		padding:5px;
	}
	.grid_icon_rooms img{
		width: 50px;
	}
	.grid_icon_rooms_title{
		font-size: 10px;
		line-height:16px;
		letter-spacing: 0;
	}
	
}
@media(max-width:585px){
	.grid_icon_rooms img{
		width: 40px;
		margin-bottom:5px;
	}
	.grid_icon_rooms_title{
		font-size: 7px;
		line-height:10px;
		letter-spacing: 0;
	}
}
@media(max-width:420px){
	.grid_icon_rooms img{
		width: 35px;
		margin-bottom:5px;
	}
	.grid_icon_rooms_title{
		font-size: 7px;
		line-height:10px;
		letter-spacing: -0.5px;
	}
}

/* ==================== BOOKING FORM ==================== */

.booking_form{background: #E3DFDA;}
.book_info {
	padding-top: 30px;
    padding-bottom: 30px;
    border-right: 2px solid #B3B2B1;
    height: 170px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.book_info_numbers {
	flex-direction: row;
}

.book_info label{
	font-family: 'Alegreya', serif;
	font-size: 22px;
    display: block;
    color: #000;
    font-weight: 100;
    text-align: center;
	margin-top: 15px;
    margin-bottom: 10px;
}
.book_info input {
	padding: 10px 5px;
    font-size: 20px;
    width: 100%;
    display: block;
    color: #333;
    font-weight: 300;
    text-align: center;
    background: transparent;
    border: none;
    background-image: url(../img/layout/arrow_down_black.svg);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: top center;
}
.book_info.book_info_numbers input { width: 28px; }
.book_info select{
	font-size: 20px;
    width: 100%;
    padding-top: 15px;
    display: block;
    color: #000;
    font-weight: 300;
    text-align: center;
    background: transparent;
    border: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none !important;
    background-image: url(../img/layout/arrow_down_black.svg);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: top center;
}

.book_info .minus, .book_info .plus {
	display: block;
	position:absolute;
	top:50px;
	right:40px;
  font-weight: 700;
  font-size: 24px;
  color: #000;
}

.book_info_bottom input {
  text-align: unset;
}

.book_info .minus { top:80px;  }
.book_info .minus img, .book_info .plus img{ width:24px;}
.book_submit {
	padding-bottom: 15px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 170px;
}
.book_submit button {
	background: none;
    border: none;
    color: #000;
    padding: 0px;
    font-size: 22px;
    font-weight: 100;
    line-height: 80px;
    font-family: 'Alegreya', serif;
}

.book_submit button img {
	width: 35px;
	height: 35px;
	display: inline-block;
	margin-left: 10px;
}

.book_info_date img, .book_info_numbers img {
	width: 23px;
}

.book_info_bottom {
	width: 30px;
	display: flex;
	/* background: red; */
	position: relative;
	justify-content: center;
	align-content: center;
	text-align: center;
}

.shadow_wrapper {
	position: absolute;
}

.booking_shadow {
	background: #00000021;
    height: 105px;
    position: absolute;
    z-index: 9;
    top: -105px;
    width: 100%;
}

.book_arrows {
  display: block;
  width: 100%;
  margin-top:3px;
}

.book_info .minus, .book_info .plus {
  display: block;
  position: relative;
}

.book_info .minus img, .book_info .plus img {
  width: 16px;
}

.book_info .minus {
    top: unset;
}

.book_info .minus, .book_info .plus {
    position: relative;
    top: unset;
    right: unset;
	}

.booking_date {
  display: block;
  width: 100%;
  overflow: hidden;
}

.booking_phone{
	text-align:center;
	margin-top:20px;
}
.booking_phone p{
    font-size: 16px;
    line-height: 26px;
	padding:5px;
    margin-bottom: 40px;
    color: #000;
    font-weight: 300;
	font-style: italic;
	border-bottom:1px solid #000;
	display: inline-block;
	transition: all 0.3s ease 0s;   
}

.booking_phone p i{
	font-weight: 300;
}
.booking_phone p span{
	font-weight: 700;
	color: #674439;
}
.booking_phone:hover p{
	letter-spacing:0.1px;
	transition: all 0.3s ease 0s;     
}

@media(min-width:1500px){}

@media(max-width:1499px){
	.book_info .minus img, .book_info .plus img {
    width: 16px;
	}

}
@media(max-width:1199px){}

@media(max-width:991px){
	.booking_date {
		display: none;
	}
}

@media(max-width:767px){}

@media(max-width:585px){}

@media(max-width:420px){}

/* ==================== END BOOKING FORM ==================== */



/* ==================== HOME VIDEO ==================== */
.video_container_general{  width: 100%;    position: relative;    top: 0;    left: 0;    margin: 0 auto;    padding: 55.921875% 0 0;    z-index: 1;}
.video_container_general video {width: 100%; height: auto; position: absolute; left: 0; top: 0; right: 0;  bottom: 0;}

.video_caption{position:absolute;top:40%;width:100%;z-index:1;text-align:center;}
.video_caption p{font-size:20px;color:#fff;text-shadow:0px 0px 8px #000;}
.video_caption p.header_video{font-size:60px;font-weight:300;}
.video_caption a{padding:15px 15px 10px 15px;border:1px solid #fff;color:#fff;display:inline-block;background:rgba(0,0,0,0.2);margin-top:20px;transition: all 0.2s ease-in; font-weight: 300; font-size:18px;letter-spacing:1px;}
.video_caption a:hover{border:1px solid #000;background:rgba(0,0,0,1);transition: all 0.2s ease-in;}

@media(max-width: 767px) {
  .video_caption{top:35%;}
  .video_caption p.header_video{font-size:40px;}
} 
@media(max-width: 530px) {
  .video_caption{top:20%;}
  .video_caption p.header_video{font-size:30px;}
  .video_caption p{font-size:18px;}
  .video_caption a{padding:15px 15px 10px 15px;margin-top:15px;}
} 

@media(max-width: 420px) {
  .video_caption{top:5%;}
  .video_caption p{display:none;}
  .video_caption p.header_video{display:block;}
  .video_caption a{padding:5px 5px 2px 5px;margin-top:25%;font-size:14px;}
}

/* END HOME VIDEO
================================================== */

/* ROOMS PAGE
================================================== */

.room_box {
    position: relative;
    display: block;
    border-right: 1px solid #fff;
    margin: 10px 0px
}

.room_box.last {
	border-right: none;
    margin-left: 20px;
}

.room_box.even:before {
    content: '';
    position: absolute;
    border-top: 1px solid #fff;
    width: 100vw;
    top: -10px;
}

.room_box h3 {
    position: absolute;
    top: 0;
    font-size: 50px;
	line-height: 50px;
    font-weight: 700;
    text-transform: uppercase;
    margin-top: 25px;
	margin-left: 85px;
    z-index: 1;
    display: flex;
    align-items: center;
	background-color: transparent;
	transition: all 0.5s ease-in-out;
}

.room_box h3:before {
	content: '';
	background-image: url('../img/layout/room_arrow.svg');
	background-repeat: no-repeat;
	background-size: 25px;
	width: 25px;
	height: 25px;
	position: absolute;
	left: -55px;
	opacity: 1;
	transition: all 0.5s ease-in-out;
}

.room_box:hover h3 {
	color: #1a1a1a;
	background-color: #fff;
}

.room_box:hover h3:before {
	opacity: 0;
}

.room_box .room_image {
    background-repeat: no-repeat;
    background-size: cover;
    height: 350px;
    position: relative;
    background-position: center;
	filter: brightness(0.8);
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
    opacity: 0.3;
	transition: all 0.5s ease-in-out;
}

.room_box:hover .room_image {
	opacity: 1;
}

.facilities_img {
	margin-top: 150px;
    width: 65%;
    border-radius: 20px;
}

.room_facilities {
	margin-top: 50px;
}

.room_facilities ul {
	display: flex;
	flex-wrap: wrap;
}

.room_facilities ul li {
	display: inline-block;
    width: 49%;
    font-size: 25px;
    font-weight: 300;
    line-height: 32px;
    border-bottom: 1px solid #fff;
    padding: 10px 0;
}

.room_list .page_description {
	width: 58%;
}

.swiper-rooms-gallery .swiper-slide img {
	border-radius: 20px;
}

.gallery_text {
	position: absolute;
    background: #fff;
    color: #1a1a1a;
    width: 180px;
    height: 180px;
    font-size: 21px;
    font-weight: 500;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    bottom: -90px;
	cursor: pointer;
}

/* .gallery_text a {
	height: 100%;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
} */

.book_room_link {    position: absolute;    left: 0;    top: 30px; z-index:99;    }
.book_room_link a {    
	z-index:999;
	position:relative;
	display: block;
	font-weight: 400;
    letter-spacing: 0.5px;
	color: #fff;
	background: #4c586f;	 
	border: 2px solid #4c586f;  	
	padding: 10px 20px 10px 20px;
	transition: all 0.3s ease 0s;     
}
.book_room_link:hover a{
    color:#3D3D3B;
	background: none;
	transition: all 0.3s ease 0s;
}	

.more_rooms  { margin-bottom:20px; position: relative; margin-top: 50px; }
.more_rooms img  {width:100%;display:block;height: auto;}
.more_rooms a {	}

.more_rooms a span{
	font-size: 16px;
    line-height: normal;
    letter-spacing: 1.7px;
    color: #fffbeb;
    text-transform: uppercase;
    margin-top: 0px;
    margin-bottom: 10px;
    font-weight: 400;
    background: #000;
    display: block;
    padding: 7px 0px;
	text-align: center;
	width: 100%;

}

.other_rooms .rooms_description h2 {
    color: #606060;
	position: relative;
    top: -60px;
	line-height: 70px;
}


.other_rooms a {
    color: #444;
    height: 100%;
    font-size: 40px;
	font-weight: 300;
    font-family: 'Source Serif Pro', sans-serif;
}

.other_rooms .rooms_description {
	display: flex;
    align-items: flex-end;
}

.page_text .basic_text p {
	line-height: 70px;
    font-size: 55px;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 400;
    color: #3A3A3A;
}

.room .room_number {
	position: absolute;
    top: -47px;
    z-index: 0;
    overflow: hidden;
}

.room {
	margin-top: 0px;
    margin-bottom: 130px;
    position: relative;
    display: flex;
    transition: all 0.5s ease-in-out;
    padding-top: 20px;
}

.room img {
	position: relative;
	width: 100%;
	z-index: 1;
	transition: all 0.5s ease-in-out;
}

.page_text .room .room_number p {
	font-size: 57px;
    position: relative;
    color: #338484;
    font-family: 'Source Serif Pro', sans-serif;
    font-weight: 300;
    line-height: 57px;
    border: 1px solid #338484;
    padding: 20px 23px;
    margin-bottom: 50px;
}

.room_number p:before {
    content: '';
    position: absolute;
    border-right: 1px solid #338484;
    height: 50px;
    right: 0;
    left: 0;
    margin: 0px auto;
    width: 1px;
    bottom: -50px;
}

.room .room_image {
	position: relative;
    overflow: hidden;
    display: block;
    padding-left: 90px;
}

.room.reverse-991 .room_image {
    padding-left: 0px;
    padding-right: 90px;
}

.room .icon_img {
	transition: all 0.5s ease-in-out;
}

.room:hover .icon_img {
	opacity: 1;
}

.room .icon_img {
	width: 370px;
    height: 320px;
    right: auto;
    margin: 0;
    left: -240px;
    top: -120px;
    z-index: 3;
    opacity: 0.4;
}

.room .rooms_description {
	z-index: 3;
    position: absolute;
    padding: 115px 30px 50px 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background: #FFFCF6;
    width: 153%;
    top: 50%;
    transform: translate(0%, -50%);
}

.room.reverse-991 .rooms_description {
    left: -53%;
}

.num_photos {
	position: absolute;
    right: 50px;
    bottom: 50px;
    border: 1px solid #fff;
    color: #fff;
    z-index: 2;
    padding: 10px 17px;
	width: 70px;
    height: 70px;
	background: #00000001;
}

.room.reverse-991 .num_photos {
	right: auto;
    left: 50px;
}

.all_photos {
	font-size: 20px;
    font-weight: 100;
    padding-left: 15px;
    text-align: right;
    position: relative;
}

.all_photos:before {
	content: '/';
    position: absolute;
    top: -18px;
    width: 15px;
    height: 15px;
    transform: rotate(26deg);
    left: 9px;
}

.room .room_bg {
	width: 100%;
    position: absolute;
    height: 70%;
    bottom: -50px;
    left: -85px;
    background-color: #CFCDC8;
}

.room.reverse-991 .room_bg {
	left: auto;
    right: -85px;
}

.room .rooms_description p.last {
	border-bottom: none;
	padding-bottom: 0px;
}

.room .swiper_buttons .more {
    margin-left: 210px;
	font-size: 18px;
	z-index: 11;
}

.home_header_content.rooms_view h1 {
	padding: 0 35%;
}

.complex.mob {
	display: none;
}

.page_text .complex h2 {
	font-family: 'Source Serif Pro', sans-serif;
    font-size: 40px;
    font-weight: 100;
    margin-top: 135px;
	margin-bottom: 55px;
}

.page_text .complex h2:before {
	content: '';
    position: absolute;
    border-top: 1px solid #899666;
    width: 77px;
    transform: rotate(90deg);
    left: 0;
    right: 0;
    margin: 0 auto 0 auto;
    top: 65px;
}

.level-box {
	display: flex;
    align-items: center;
    position: relative;
}

p.complex_middle {
	color: #8A9666;
    font-weight: 400;
    font-size: 37px;
    margin-left: 60px;
    font-family: 'Source Serif Pro', sans-serif;
}

p.complex_middle:before {
	content: '';
    border-top: 1px solid #8A9666;
    width: 60%;
    left: -100px;
    position: absolute;
    margin-top: 15px;
}

p.complex_middle:after {
    content: '';
    background-image: url(../img/layout/arrow_up_levels.svg);
    background-size: 20px;
    width: 20px;
    background-repeat: no-repeat;
    height: 50px;
    position: absolute;
    margin-top: 100px;
    margin-left: -68px;
}

.level_text {
	text-align: left;
}

.level3 {
	width: 75%;
	margin-left: 10%;
}

.level2 {
	width: 126%;
    margin-left: -10%;
}

.level-box.level-2 {
	margin-top: -5px;
}

.level1 {
	width: 140%;
	margin-left: -17%;
}

.level-box.level-1 {
	margin-top: -5px;
}

.level-box.level-2 p.complex_middle:before {
    width: 40%;
    left: -20px;
}

.level-box.level-1 p.complex_middle:before {
	width: 22%;
    left: 50px;
}

.level-box.level-2 p.complex_middle:after {
    margin-top: 140px;
}

.level-box.level-1 p.complex_middle:after {
	display: none;
}

.room_info{text-align:center;position:relative;margin-bottom:50px;padding-bottom:100px;}
.room_info p{}
.room_info::after {
    content: "";
    height: 80px;
    width: 1px;
    background: #29365b;
    display: block;
    position: absolute;
    bottom: 0px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}
.room_plan{
	text-align:center;
}

.room_plan a{
	border-top:1px solid #000;
	padding:10px;
	font-weight:700;
	color: #29365b;
	display: block;
}

.room_plan a.not_show{
	display: none;
}
.link_gallery{
	height:70vh;
	text-align:center;
}

.link_gallery a{
	margin-top:33vh;
	font-size: 18px;
	font-weight: 300;
	color: #000;
	padding: 10px 20px;
	border: 1px solid #fff;
	display: inline-block;
	position: relative;
	cursor: pointer;
	text-transform: uppercase;
	overflow: hidden;
	background-color: #F6F3EA;
	-webkit-transform: scaleX(1.01);  -ms-transform: scaleX(1.01);  transform: scaleX(1.01);  -webkit-transform-origin: left;  -ms-transform-origin: left;  transform-origin: left; -webkit-transition: .37s cubic-bezier(.25,.04,0,.93);  -o-transition: .37s cubic-bezier(.25,.04,0,.93);  transition: .37s cubic-bezier(.25,.04,0,.93);  -webkit-backface-visibility: hidden;  backface-visibility: hidden;
}

.link_gallery a:hover{
	-webkit-transform: scaleX(1.03);  -ms-transform: scaleX(1.03);  transform: scaleX(1.03)
}

.left_image_amenities{
	width:70%;
}
.amenities_container{
	position:relative;
	padding:50px;
}

.page_text .amenities_container h3{
    font-size: 40px;
    font-weight: 300;
    line-height: 50px;
    color: #674439;
    text-transform: uppercase;
    font-family: 'Alegreya', serif;
}

.page_text .amenities_container ul li{
	display: inline-block;
	width: 49%;
	margin:2px 0 2px 0;
}

.room_more_title{
	text-align:center;
	position:relative;
    padding-bottom: 70px;
    margin-bottom: 20px;
}

.room_more_title::after {
    content: "";
    height: 60px;
    width: 1px;
    background: #29365b;
    display: block;
    position: absolute;
    bottom: 0px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

.room_more_title h4{
	font-size: 28px;
    font-weight: 300;
    line-height: 40px;
    color: #674439;
    text-transform: uppercase;
    font-family: 'Alegreya', serif;
}

/* FACILITIES PAGE
================================================== */

.facility_text { padding-top:80px;}

.facility_left_image {}
.facility_left_image img {max-width:100%;}

.facility_right_image {text-align:right;}
.facility_right_image img {max-width:100%;}

.benatura_logo { float:right; margin:0 0 20px 20px;}
.enjoy_logo { float:right; margin:0 0 20px 20px;}


/* SIGHTS PAGE
================================================== */
.sight_content {  float:left; margin-bottom:40px;}

.sight_description {
	background: #fff;
    width: 85%;
    padding: 3% 13%;
    position: relative;
	height: calc(65vh + 80px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.sight_description.left {
	float: right;
	height: calc(65vh + 80px);
}

.sight_wrapper {
	position: relative;
    display: inline-flex;
    background: #E3DFDA;
}

h3.sight_title {
    font-size: 40px;
    line-height: 45px;
    font-weight: 400;
    letter-spacing: normal;
    margin-bottom: 40px;
    color: #333;
    font-family: 'Manrope', sans-serif;
}

.sight-image {
	height: calc(65vh + 80px);
}

.beige_bg.sights {
	height: 80px;
    width: 58.33%;
    position: absolute;
    top: 0;
    right: 0;
    background: #e3dfda;
    z-index: 998;
}

.beige_bg.sights.left {
	left: 0;
	bottom: -80px;
	top: auto;
}



/* OFFERS PAGE
================================================== */


/* BLOG PAGE
================================================== */
.blog_box {  margin-top:20px;margin-bottom:20px;}
.blog_box .blog_image {  margin-bottom:20px;}


/* GALLERY PAGE
================================================== */

#tabs {
	width: 73%;
	float: right;
	margin-right: 30px;
}

.tabs_section.page_text h1 {
    padding-left: 0;
    margin-left: 0;
    text-align: center;
}

.tabs_section.page_text p {
	text-align: center;
    margin-bottom: 50px;
}

.page_text #tabs li {
    margin: 5px 0 5px 0;
    padding: 0px 10px 0 10px;
    font-size: 23px;
    font-weight: 400;
    line-height: 30px;
    background: none;
    font-family: 'Source Serif Pro', sans-serif;
    transition: all 0.3s ease 0s;
    display: inline-block;
}

.image_onmouse {
    position: absolute;
	display: none;
	width: 330px;
    height: 330px;
    pointer-events: none;
    background-repeat: no-repeat;
    border-radius: 35px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 330px;
	z-index: 2;
	filter: brightness(0.8);
}

#tabs li {
	position: relative;
}

#tabs li a {
	color: rgba(255,255,255,1);
    cursor: pointer;
    font-size: 40px;
	line-height: 52px;
    text-transform: uppercase;
    display: block;
	padding: 15px 0 15px 40px;
    font-weight: 800;
    width: fit-content;
    position: relative;
	z-index: 3;
	text-shadow: 0px 1px 0px #000;
	transition: all 0.3s ease-in-out;
}

#tabs li a:before {
	content: '';
    position: absolute;
    background-image: url(../img/layout/room_arrow.svg);
    background-repeat: no-repeat;
    background-size: 19px;
    width: 19px;
    height: 19px;
    background-position: 0px 0px;
    left: 0;
    top: 25px;
	opacity: 0;
	transition: all 0.3s ease-in-out;
}

#tabs li a.inactive:before {
	opacity: 1;
}

#tabs li a.inactive {
    color: rgba(255,255,255,.7);
    border-bottom: none;
    background: none;
    padding: 15px 0 15px 40px;
    line-height: 52px;
    font-weight: 400;
    margin: 0;
	z-index: 1;
}

.gallery_title {text-align:center;}
.gallery_page h3{font-size: 40px;    font-weight: 300;    line-height: 60px;    color: #674439;    text-transform: uppercase; font-family: 'Alegreya', serif;}

.gallery_box {
	margin-bottom: 20px;
    position: relative;
    padding-left: 130px;
    background: #EBEAE6;
	margin-top: 50px;
	width: calc(50% - 70px);
}
.gallery_box.right {
	margin-bottom: 20px;
    position: relative;
    padding-left: 0px;
	padding-right: 130px;
    background: #EBEAE6;
	margin-top: 160px;
    margin-left: 70px;
}
.gallery_box .gallery_image { position:relative;	overflow:hidden; }
.gallery_box img {width:100%; transition: all 0.3s ease 0s;}
.gallery_box .gallery_text {  z-index:9;width:100%;text-align:left;display:block;  transition: all 0.3s ease 0s;}
.gallery_box.right .gallery_text { text-align: right; }
.gallery_box .gallery_text span{
	font-size: 35px;
    line-height: normal;
    letter-spacing: 1px;
    color: #606060;
    font-weight: 100;
    background: #fff;
    display: block;
    padding: 45px 35px;
    transition: all 0.3s ease 0s;
}

.gallery_text span p {
	font-size: 20px;
    line-height: normal;
    margin-top: 15px;
	letter-spacing: 1px;
}

.gallery_box:hover .gallery_text span { letter-spacing: 1.5px; transition: all 0.3s ease 0s; }
.gallery_box:hover .gallery_text span p { letter-spacing: 1px; }

/* Shine */
.gallery_box .gallery_image::before {
	position: absolute;
	top: 0;
	left: -95%;
	z-index: 2;
	display: block;
	content: '';
	width: 50%;
	height: 100%;
	background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	-webkit-transform: skewX(-25deg);
	transform: skewX(-25deg);
}
.gallery_box:hover .gallery_image::before {
	-webkit-animation: shine 1s;
	animation: shine 1s;
}
@-webkit-keyframes shine {
	100% {
		left: 125%;
	}
}
@keyframes shine {
	100% {
		left: 125%;
	}
}

/* .gallery_box:hover img{  transform: scale(1.05); transition: all 0.3s ease 0s;} */
/* .gallery_box:hover span{ color:#f1f1f1; transition: all 0.3s ease 0s;} */

.albums_swiper {
    position: relative;
    display: block;
    overflow: hidden;
    margin-left: 8%;
	padding-bottom: 120px;
}

.gallery_page {
	background-color: #EBEAE6;
	padding-bottom: 0px;
	margin-top: 70px;
	padding-top: 0;
}


/* LOCATION PAGE
================================================== */



/* CONTACT PAGE
================================================== */
#map{
    width: calc(100% - 15px);
    height: 100%;
    min-height: 500px;
    border-radius: 20px;
    display: block;
}

input:-internal-autofill-selected {
    appearance: menulist-button;
    background-image: none !important;
    background-color: -#1a1a1a;
}

.page_text .contact_wrapper h1 {
	font-size: 70px;
    font-weight: 400;
    color: #3A3A3A;
    margin-bottom: 180px;
	z-index: 1;
}

.contact_info img {
	width: 26px;
    margin-right: 20px;
}

.contact_info img.facebook {
	width: 15px;
}

.contact_info img.twitter {
	width: 28px;
}

.container-fluid.no-padding.contact_intro {
	overflow: visible!important;
}

.contact_wrapper {
	position: relative;
    display: block;
    overflow: hidden;
    background: #f6f4ee;
	padding: 160px 120px 70px 120px;
    margin: -380px 5% 0 5%;
}

.page_text .contact_title h1 {
    padding-left: 0;
    margin-left: 0;
    line-height: 60px;
	font-size: 57px;
}

.contact_title p {
	font-size: 28px;
    color: #606060;
    line-height: 38px;
}

.contact_info {
	background: #338484;
    padding: 60px 60px 45px 60px;
}

.contact_left {
	width: 75%;
	position: relative;
    top: -146px;
}

.contact_info a {
	color: #fff;
}

.contact_info p {
	margin-bottom: 17px;
    font-size: 22px;
    color: #fff;
    font-weight: 100;
	background: #00000001;
}

.contact_social {
	position: absolute;
    bottom: 65px;
    right: 80px;
}

p.last a.more {
	margin-top: 40px;
	z-index: 1;
}

.contact_info p.last i {
	top: 2px;
    margin-left: 5px;
    position: relative;
}

p.contact_details {
	margin-top: 45px;
    padding-right: 100px;
    line-height: 32px;
}

.contact_form{
	border: 1px solid #fff;
    margin-top: 80px;
    border-radius: 20px;
    margin-right: 14px;
	margin-bottom: 150px;
}
.contact_form h1 {
	padding: 20px 0;
    text-align: center;
    font-size: 80px;
    font-weight: 700;
    position: relative;
    border-bottom: 1px solid #fff;
    margin-top: -67px;
}

.contact_form ul {
	display: flex;
    justify-content: center;
    padding: 35px 0;
    border-bottom: 1px solid #fff;
}

.contact_form ul li {
	display: inline-flex;
	position: relative;
	font-size: 21px;
	font-weight: 300;
	line-height: 25px;
	margin: 0px 40px;
	padding-left: 40px;
	color: #fff;
	text-transform: uppercase;
}

.contact_form ul li:before {
	content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 100%;
    left: 0;
    top: 5px;
}

.contact_form ul li a {
	color: #fff;
}


.contact_form form {
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.contactform div.input{
    float: left;
    margin: 0;
    width: 50%;
    display: inline-block;
    position: relative;
    background: none;
    border-right: 1px solid #fff;
}

.contactform .security_code {
	width: 100%;
}

.contactform .security_code div.input{
	width: 100%;
}

.contactform div.textarea {
    float: left;
    padding: 0;
    width: 70%;
}

.contactform div.submit{
    width: 30%;
    padding: 0;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}


.contactform div.input.checkbox {
	width: 49%;
}

.contactform div.input label {
	font-size: 20px;
    margin-bottom: 15px;
    display: none;
}

.contactform input[type="text"], .contactform textarea {
    width: 100%;
    padding: 50px 35px;
    margin: 0px;
    font-size: 21px;
    background: transparent;
    color: #fff;
    transition: all 0.4s ease;
    text-align: left;
    float: left;
    font-weight: 300;
    border: 0px none;
    border-bottom: 1px solid #fff;
}

.contactform input[type="text"]::placeholder, .contactform textarea::placeholder {
	color: #fff;
	font-weight: 300;
}

.contactform textarea {	
    width: 100%;
    height: 250px;
    border-bottom: none;
}

.contactform div.input.textarea label, .contactform div.input.checkbox label {
    color: #fff;
    font-weight: 300;
}

.terms_link a {
	border-bottom: 1px solid #666;
}

.checkbox input[type=checkbox] {
    margin-left: 0;
}

.contactform div.submit input{
    border: none;
    color: #fff;
    cursor: pointer;
    text-align: center;
    background: none;
    border: 1px solid #fff;
    display: block;
    padding: 23px 120px 23px 120px;
    font-size: 21px;
    font-weight: 300;
    border-radius: 65px;
    transition: all 0.3s ease 0s;
}

.contact_form p {
	font-size: 18px;
    float: left;
    bottom: 0;
    color: #555;
    position: absolute;
    font-weight: 200;
}

.contactform div.submit input:hover{	
	color: #1a1a1a;
    background: #fff;
    transition: all 0.3s ease 0s;
}
.contactform div.submit input:active{	
	color: #1a1a1a;
    background: #fff;
    transition: all 0.3s ease 0s;
}

.contactform .required label:after {
	color:#e32;
	content:'*';
	display:inline;
}
.contactform div label.error{
    color: #e32;
    font-size: 14px;
    width: 100%;
    text-align: left;
    left: 35px;
    bottom: 0;
    position: absolute;
}

.info-window-content{padding:10px;}
.info-window-content p.balloon-first{
	font-size: 21px;
    margin: 10px 0;
    color: #1a1a1a;
    line-height: 28px;
    font-weight: 400;
    border-bottom: 2px solid #1a1a1a;
}
.info-window-content p.balloon-second{
	font-size: 14px;
    text-decoration: none;
    margin: 0px 0 0px 0;
    font-weight: 300;
    color: #333;
    line-height: 22px;
}
.info-window-content p span{float: right;font-size: 22px;margin-top: -20px;margin-left: 40px;}
.info-window-content p span.balloon-envelope{margin-top: -5px;}

.no_bullet{margin-right:5px !important;}
.no_bullet::after{display: none;}
.con_info{font-size: small;}

/* FLASH MESSAGES
================================================== */
.hello-bar {
    position: absolute;
    top: 0;
    left: 0;
    color: #1a1a1a;
    font-size: 19px;
    text-align: center;
    background: #fff;
    width: 100%;
    z-index: 2000;
    font-weight: 400;
    zoom: 1;
    padding: 22px 0 22px 0;
}

.hello-bar:after, .hello-bar:before {
    content: "";
    display: table;
}

.hello-bar:after {
    clear: both;
}

.hello-bar .close {
    text-indent: -9999em;
    background: url(../img/layout/hello-bar-close.png) no-repeat top left;
    width: 21px;
    height: 21px;
    position: absolute;
    top: 25px;
    right: 15px;
}

.hello-bar .close:hover {
    background-position: bottom left;
}


#scrollUp {
	background: #fff none repeat scroll 0 0;
    border-radius: 5px;
    bottom: 20px;
    color: #000;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    opacity: 1;
    padding: 10px 15px;
    left: 20px;
    text-decoration: none;
    transition: background 200ms linear 0s;
}




/* MEDIA QUERIES
================================================== */

@media only screen and (max-width: 1600px) {
	.room_title p {
		padding-right: 0;
	}

	.room_facilities ul li {
		font-size: 24px;
	}

	.room_box h3 {
		font-size: 45px;
		margin-left: 80px;
	}

	.facilities h3 {
		font-size: 40px;
		margin-left: 30px;
	}

	.content.facilities p {
		margin-top: 60px;
		margin-left: 25px;
		margin-right: 20px;
	}

	.content.about.dynamic {
		width: 80%;
	}

	.home_header h1 {
		font-size: 85px;
		width: 95%;
	}

	.home_header.el h1 {
		font-size: 80px;
	}

	.el .scrolling-words-box ul li {
		font-size: 70px;
		line-height: 80px;
	}

	.scrolling-words-box ul li {
		font-size: 80px;
		line-height: 90px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 80%;
		width: 58%;
	}

	.banner-shape3 {
		right: 2%;
	}

	.banner-shape3 img {
		height: 100px;
	}

	.room .rooms_description {
		padding: 90px 20px 40px 20px;
	}

	.room_intro p {
		padding: 0 5px;
	}

	.room_buttons .room_more {
		margin: 20px 20px 0 20px;
	}

	.page_text .room_title h1 {
		font-size: 35px;
		line-height: 40px;
		margin-bottom: 15px;
	}

	.room_buttons .room_book {
		margin: 20px 20px 0 20px;
	}

	.room_details_wrap {
		padding: 90px 90px;
	}

	.room_intro h1 {
		padding: 0 95px;
	}

	.space_between_suites .swiper-suites .swiper-slide, .suites_swiper_wrapper .swiper-suites .swiper-slide {
		margin-top: 134px;
	}

	.contact_social {
		position: relative;
		bottom: 0;
		right: 0;
	}

	.activities_right_text {
		padding: 100px 0px 100px 70px;
	}
}

@media only screen and (max-width: 1499px) {
	.offer_box h3 {
		font-size: 45px;
	}

	.copyright span {
		display: block;
	}

	.home_header.el h1 {
		font-size: 75px;
	}

	.el .scrolling-words-box ul li {
		font-size: 60px;
		line-height: 70px;
	}

	.facilities_img {
		width: 80%;
	}

	.image_onmouse {
		width: 310px;
		height: 310px;
		background-size: 310px;
	}

	.room_box h3 {
		font-size: 40px;
		margin-left: 70px;
	}

	.room_box h3:before {
		background-size: 22px;
		width: 22px;
		height: 22px;
		left: -45px;
	}

	.content.about {
		width: 80%;
	}

	.page_heading_image {
		margin: 85px 85px 40px 85px;
	}

	.page_banner_content h1 {
		font-size: 75px;
	}

	.facilities h3 {
		font-size: 32px;
		margin-left: 25px;
	}

	.content.facilities p {
		margin-top: 50px;
		margin-left: 0px;
		margin-right: 0px;
		font-size: 20px;
		line-height: 30px;
	}

	.contact_form h1 {
		font-size: 72px;
		margin-top: -60px;
	}

	.contact_form ul li {
		margin: 0px 20px;
		padding-left: 35px;
	}

	.contactform div.submit input {
		padding: 23px 100px 23px 100px;
	}

	.header_content h1 {
		font-size: 70px;
	}

	.home_header h1 {
		font-size: 80px;
		width: 100%;
	}

	.rooms_home {
		padding-right: 0;
	}

	#tabs {
		width: 80%;
	}

	.banner-shape3 img {
		height: 90px;
	}

	#tabs li a, #tabs li a.inactive {
		font-size: 36px;
		line-height: 45px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 75%;
		width: 58%;
	}

	.banner-shape3 {
		right: 7%;
	}

	.banner-shape2 {
		bottom: 13%;
		left: -40px;
	}

	.banner-shape2 img {
		height: 170px;
	}

	.scrolling-words-container {
		margin-top: -5px;
	}

	.scrolling-words-box ul li {
		font-size: 75px;
		line-height: 85px;
	}

	.content p {
		font-size: 38px;
		font-weight: 400;
		line-height: 48px;
	}

	.more {
		margin-top: 160px;
	}	

	.content.location {
		padding-bottom: 210px;
		padding-top: 200px;
	}

	.offer_box {
		padding-right: 30px;
	}

	.offer_box.last {
		padding-left: 30px;
		padding-right: 30px;
	}

	.offer_box ul li {
		font-size: 20px;
	}

	.content .offer_box p {
		font-size: 24px;
	}

	.content .offer_box .book_offer p {
		font-size: 26px;
	}

	.book_offer .more {
		padding: 22px 50px;
	}

	.book_offer {
		margin-top: 70px;
	}
}

@media only screen and (max-width:1349px) {
	.offer_box h3 {
		font-size: 40px;
		margin-bottom: 25px;
	}

	.home_header.el h1 {
		font-size: 60px;
	}

	.el .scrolling-words-box ul li {
		font-size: 50px;
		line-height: 60px;
	}

	.room_facilities ul li {
		font-size: 22px;
		line-height: 30px;
	}

	.image_onmouse {
		width: 300px;
		height: 300px;
		background-size: 300px;
	}

	.room_box h3 {
		font-size: 35px;
		line-height: 45px;
		margin-left: 55px;
	}

	.room_box h3:before {
		background-size: 20px;
		width: 20px;
		height: 20px;
		left: -35px;
	}

	.page_banner_content h1 {
		font-size: 70px;
	}

	.page_banner_content h1 span.first {
		padding-left: 85px;
	}

	.content.about.dynamic {
		width: 85%;
	}

	.facilities h3 {
		font-size: 30px;
		margin-left: 20px;
		margin-top: 25px;
	}

	.content.facilities p {
		margin-top: 40px;
		font-size: 19px;
		line-height: 27px;
	}

	.content .page_description p {
		font-size: 22px;
		line-height: 32px;
	}

	.contact_form ul li {
		margin: 0px 15px;
		padding-left: 30px;
		font-size: 20px;
	}

	.contact_form ul li:before {
		width: 16px;
		height: 16px;
		top: 4px;
	}

	.header_content h1 {
		font-size: 65px;
	}

	.home_header h1 {
		font-size: 70px;
		width: 95%;
	}

	.home_header h1 span.left {
		text-align: center;
	}

	.home_header h1 span.banner_graphic {
		margin-left: -20px;
	}

	.scrolling-words-box ul li {
		font-size: 62px;
		line-height: 72px;
	}

	.content.about {
		width: 85%;
	}

	#tabs li a, #tabs li a.inactive {
		font-size: 34px;
		line-height: 40px;
	}

	.content.location {
		padding-bottom: 170px;
		padding-top: 170px;
	}

	.content p {
		font-size: 33px;
		line-height: 43px;
	}

	.location1 {
		width: 250px;
	}

	.location2 {
		width: 250px;
	}

	.location3 {
		width: 400px;
	}

	.more {
		margin-top: 130px;
		padding: 22px 100px;
	}

	.content .offer_box p {
		font-size: 23px;
		line-height: 32px;
	}

	.offer_box ul li {
		font-size: 19px;
		padding-left: 30px;
	}

	.book_offer {
		align-items: flex-start;
		flex-direction: column;
		margin-top: 55px;
	}

	.book_offer .more {
		margin-top: 25px;
	}

	.offer_box ul li:before {
		width: 16px;
		height: 16px;
	}
}  

@media only screen and (max-width:1199px) {
	.menu li a {
		font-size: 21px;
	}

	.copyright span {
        display: unset;
    }

	.home_header.el h1 {
		font-size: 52px;
	}

	.room_facilities ul li {
		display: inline-block;
		width: 50%;
	}

	.facilities_img {
		width: 100%;
		margin-top: 60px;
	}

	.room_list .page_description {
		width: 100%;
		padding-top: 60px;
	}

	.image_onmouse {
		width: 280px;
		height: 280px;
		background-size: 280px;
	}

	.room_box {
		border-bottom: 1px solid #fff;
		border-right: none;
		padding-bottom: 10px;
		margin-bottom: 0;
	}

	.room_box.last_room {
		border-bottom: none;
	}

	.page_banner_content h1 {
		font-size: 60px;
	}

	.room_box.last {
    	border-bottom: none;
	}

	.room_box.last {
		margin-left: 0px;
	}

	.page_banner_content h1 span.first {
		padding-left: 40px;
	}

	.page_heading_image {
		margin: 85px 85px 20px 85px;
	}

	.content.about.dynamic {
		width: 90%;
	}

	.page_banner_content {
		margin-top: -35px;
	}

	.facilities h3 {
		font-size: 35px;
		margin-left: 45px;
		margin-top: 35px;
	}

	.content.facilities p {
		margin-top: 30px;
		margin-bottom: 50px;
	}

	.facility_box {
		margin-left: -15px;
	}

	.content .page_description p {
		font-size: 20px;
		line-height: 28px;
	}

	.dynamic_img {
		margin-top: 105px;
		margin-bottom: 50px;
	}

	.page_description {
		padding-top: 105px;
		padding-bottom: 150px;
	}

	.contact_form h1 {
		font-size: 65px;
		margin-top: -55px;
	}

	.contactform div.submit input {
		padding: 23px 70px 23px 70px;
	}

	.contact_form ul {
		flex-wrap: wrap;
		padding: 25px 0;
	}

	.contactform input[type="text"], .contactform textarea {
		padding: 45px 35px;
	}	

	.contact_form ul li {
		margin: 5px 10px;
		padding-left: 30px;
		font-size: 20px;
	}

	.header_content h1 {
		font-size: 60px;
	}

	.content.about {
		width: 90%;
		padding-bottom: 200px;
	}

	.scrolling-words-box ul li {
		font-size: 60px;
		line-height: 70px;
	}

	.banner-shape1 {
		top: 14%;
		left: 5px;
	}

	.banner-shape1 img {
		height: 105px;
	}

	.banner-shape2 img {
		height: 140px;
	}

	.banner-shape2 {
		bottom: 16%;
		left: -80px;
	}

	.banner-shape3 {
		right: 4%;
		bottom: 16%;
	}

	.banner-shape3 img {
		height: 80px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 90%;
	}

	.home_header h1 {
		font-size: 65px;
	}

	.content.about h2 {
		margin-right: 70px;
		top: -5px;
	}

	#tabs {
		width: 85%;
	}

	#tabs li a, #tabs li a.inactive {
		font-size: 30px;
		line-height: 35px;
	}

	.more {
		margin-top: 90px;
		padding: 20px 90px;
		font-size: 20px;
	}

	.content p {
		font-size: 28px;
		line-height: 38px;
	}

	.location1 {
		width: 200px;
		margin-left: 40px;
	}

	.location2 {
		width: 200px;
	}

	.location3 {
		width: 350px;
	}

	.book_offer {
		align-items: center;
		flex-direction: row;
	}

	.book_offer .more {
		margin-top: 0;
	}

	.offer_box {
		border-right: none;
	}

	.content .offer_box p {
		min-height: 70px;
	}

	.offer_box.last {
		padding-left: 0px;
		padding-right: 30px;
		margin-top: 40px;
		border-top: 1px solid #fff;
		padding-top: 40px;
	}

	.menu li img {
		width: 32px;
		height: 32px;
		margin-bottom: 30px;
	}

	.content .footer_box p {
		line-height: 34px;
		font-size: 22px;
	}

	img.footer_logo {
		max-width: 70%;
		margin-right: 50px;
	}

	.footer_box {
		margin-bottom: 65px;
	}

	.footer_box p a {
		font-size: 24px;
	}

	.content .footer_box p {
		line-height: 34px;
		font-size: 24px;
	}
}

@media (max-width:991px){
	.header {
		padding: 25px 60px;
	}

	.copyright span {
        display: block;
    }

	#language {
		width: 60px;
		flex-direction: column;
		align-items: center;
	}

	.room_facilities ul li {
		font-size: 21px;
		line-height: 28px;
	}

	.page_heading_image {
		margin: 75px 60px 20px 60px;
	}

	.page_banner_content h1 {
		font-size: 50px;
	}

	.page_banner_content h1 {
		font-size: 50px;
	}

	.page_banner_content {
		margin-top: -28px;
	}

	.page_banner_content h1 span.first {
		padding-left: 40px;
	}

	.content.about.dynamic {
		width: 100%;
		padding-top: 40px;
	}

	.dynamic_img {
		margin-top: 60px;
		margin-bottom: 0px;
		width: 100%;
	}

	.page_description {
		padding-top: 70px;
		padding-bottom: 120px;
		width: 100%;
	}

	.contact_form h1 {
		font-size: 60px;
		margin-top: -54px;
	}

	.contact_form {
		margin-bottom: 100px;
	}

	.contactform input[type="text"], .contactform textarea {
		padding: 40px 30px;
		font-size: 20px;
	}

	.contactform div.submit input {
		padding: 20px 55px 20px 55px;
		font-size: 20px;
	}

	.contact_form ul li {
		margin: 5px 15px;
		padding-left: 30px;
		font-size: 19px;
	}

	.contact_form ul li:before {
		width: 14px;
		height: 14px;
		top: 6px;
	}

	.header_content {
		padding: 25px 0;
		margin-bottom: 25px;
	}	

	.header_content h1 {
		font-size: 55px;
	}

	.home_header h1 span.left {
		top: 8%;
		width: fit-content;
		position: relative;
	}

	.home_header {
	    width: calc(100% - 60px);
    	float: left;
	}

	.home_header h1 span.banner_graphic {
		margin-left: 70px;
	}

	.home_header h1 {
		flex-direction: column;
	}

	.home_header h1 {
		font-size: 60px;
		width: 100%;
	}

	.home_header h1 span.banner_graphic {
		background-size: 94%;
		width: 75%;
	}

	.scrolling-words-box ul li {
		font-size: 55px;
		line-height: 65px;
	}

	.banner-shape3 {
		right: 5%;
		bottom: 21%;
	}

	.banner-shape3 img {
		height: 70px;
	}

	.banner-shape2 img {
		height: 115px;
	}

	.banner-shape1 img {
		height: 95px;
	}

	.banner-shape1 {
		top: 18%;
		left: -22px;
	}

	.banner-shape2 {
		bottom: 22%;
		left: -60px;
	}

	.about_img {
		display: block;
		margin-top: 30px;
	}

	.content.about {
		width: 100%;
		padding-bottom: 130px;
	}

	.content.about p {
		display: block;
		padding-right: 30px;
	}

	.content.about h2 {
		margin-right: 70px;
		top: 0;
		margin-bottom: 25px;
	}

	.stay {
		display: none;
	}

	.stay_mob {
		display: block;
	}

	.stay_mob .room_box {
		border-right: none;
		margin: 10px 0px 30px 0px;
	}

	.stay_mob .room_box .room_image {
		height: 300px;
		filter: brightness(1);
		border-radius: 20px;
		opacity: 0.6;
	}

	.stay_mob .room_box h3 {
		font-size: 35px;
    	line-height: 45px;
	}

	.stay_mob .room_box h3:before {
		background-size: 22px;
		width: 22px;
		height: 22px;
		left: -35px;
	}

	.location .more {
		position: absolute;
		right: 40px;
		margin-top: 120px;
	}

	.location3 {
		margin-right: -15px;
	}

	.location2 {
		width: 230px;
		float: left;
		margin-right: 0;
		margin-left: -15px;
		margin-top: 50px;
	}

	.location1 {
		position: absolute;
		top: -145px;
		right: 0;
	}

	.footer_box p a {
		font-size: 22px;
	}

	.content .footer_box p {
		font-size: 22px;
	}

	.footer_social {
		padding: 20px 0px 25px 0px;
	}

	img.footer_logo {
		max-width: 70%;
		margin-right: 30px;
	}

	.content {
		padding-left: 75px;
		padding-right: 75px;
	}

	.book_now a.book_link {
		font-size: 25px;
		letter-spacing: 20px;
		padding: 0px 20px 0px 20px;
	}

	.menu li img {
		width: 28px;
		height: 28px;
		margin-bottom: 25px;
	}

	.menu li a {
		font-size: 16px;
	}
}
  

@media (max-width:767px){
	.menu li a {
		display: none;
	}

	.el .scrolling-words-box ul li {
		font-size: 42px;
		line-height: 52px;
	}

	.home_header.el h1 {
		font-size: 45px;
	}

	ul.menu {
		display: none;
	}

	.logo.mob {
		display: flex;
		justify-content: space-between;
		margin-bottom: 20px;
		position: relative;
	}

	.sticky .logo.mob {
		display: none;
	}

	.gallery_text {
		width: 130px;
		height: 130px;
		font-size: 18px;
		bottom: -70px;
	}

	.room_facilities ul li {
		font-size: 19px;
		line-height: 26px;
	}

	.facilities_img {
		width: calc(100% - 20px);
		margin-top: 50px;
	}

	.room_facilities {
		margin-top: 40px;
	}

	.room_list .page_description {
		padding-top: 50px;
	}

	.room_box .room_image {
		height: 300px;
	}

	.room_box {
		margin-right: 20px;
	}

	.room_box h3 {
		font-size: 32px;
		line-height: 42px;
		margin-left: 45px;
	}

	.content.facilities p {
		margin-right: 20px;
	}

	.page_heading_image {
		margin: 60px 60px 20px 50px;
	}

	.page_banner_content h1 {
		font-size: 45px;
	}

	.page_banner_content {
		margin-top: -24px;
	}

	.page_heading_image {
		height: 80vh;
	}

	.page_heading_shadow {
		height: 80vh;
	}

	.facilities h3 {
		font-size: 32px;
		margin-left: 30px;
		margin-top: 30px;
	}

	.dynamic_img {
		margin-top: 50px;
		width: calc(100% - 20px);
	}

	.contact_form {
		margin-top: 60px;
		margin-bottom: 80px;
		margin-right: 20px;
	}

	.content .page_description p {
		font-size: 19px;
		line-height: 27px;
	}

	.dynamic_img {
		width: 100%;
	}
	
	.page_description {
		padding-top: 50px;
		padding-bottom: 100px;
		width: calc(100% - 25px);
		float: left;
	}

	.contact_form ul li {
		margin: 3px 10px;
		padding-left: 25px;
		font-size: 18px;
	}

	.contactform div.submit {
		width: 100%;
		border-top: 1px solid #fff;
		padding: 20px 0;
	}

	.contactform div.input {
		width: 100%;
		border-right: none;
	}

	.contactform input[type="text"], .contactform textarea {
		padding: 30px 20px;
		font-size: 19px;
	}

	.contactform div.submit input {
		font-size: 19px;
	}

	.contactform div.textarea {
		width: 100%;
	}

	.contact_form ul li:before {
		width: 12px;
		height: 12px;
		top: 7px;
	}

	.contact_form h1 {
		font-size: 55px;
		margin-top: -50px;
	}

	.header_content h1 {
		font-size: 50px;
	}

	.banner-shape1 img {
		height: 85px;
	}

	.banner-shape1 {
		top: 14%;
		left: 0;
	}

	.home_header h1 {
		font-size: 55px;
	}

	.banner-shape3 img {
		height: 60px;
	}

	.banner-shape3 {
		right: 0;
		bottom: 23%;
	}

	.scrolling-words-box {
		height: 5.2rem;
	}

	.scrolling-words-box ul li {
		height: 5rem;
	}

	@keyframes scrollUp {
		15%, 25% {
		  transform: translateY(-5rem);
		}
		40%, 50% {
		  transform: translateY(-10rem);
		}
		65%, 75% {
		  transform: translateY(-15rem);
		}
		90%, 100% {
		  transform: translateY(-20rem);
		}
	}

	.banner-shape2 {
		bottom: 14%;
		left: -20px;
	}

	.banner-shape2 img {
		height: 100px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 95%;
		width: 100%;
		margin-right: 0px;
		margin-left: 0;
	}

	.home_header h1 span.left {
		width: 100%;
		top: 10%;
		position: relative;
	}

	.home_header h1 {
		width: 92%;
	}

	.content.location {
		padding-top: 120px;
	}

	.about_img {
		padding-right: 20px;
	}

	.home_header {
		width: calc(100% - 60px);
	}

	.stay_mob .room_box {
		margin: 10px 20px 30px 0px;
	}

	.stay_mob .room_box .room_image {
		height: 280px;
	}

	.stay_mob .room_box h3 {
		font-size: 32px;
		line-height: 42px;
	}

	.stay_mob .room_box h3:before {
		background-size: 18px;
		width: 18px;
		height: 18px;
	}

	.location .more {
		font-size: 19px;
		padding: 18px 70px;
	}

	.content.location p {
		font-size: 26px;
		line-height: 35px;
		margin-right: 15px;
	}

	.offer_box ul {
		margin-top: 40px;
	}

	.content .offer_box .book_offer p {
		font-size: 22px;
		line-height: 28px;
	}

	.location1 {
		position: absolute;
		right: 22px;
		width: 180px;
	}

	.location2 {
		width: 190px;
	}

	.location3 {
		margin-right: 0;
		width: 320px;
	}

	.book_offer .more {
		padding: 19px 45px;
		font-size: 18px;
	}

	.book_offer {
		margin-top: 40px;
	}

	.offer_box ul li {
		font-size: 19px;
		width: 100%;
		padding: 10px 0;
		padding-left: 30px;
	}

	.offer_box ul li:before {
		width: 14px;
		height: 14px;
		top: 15px;
	}

	.content h2 {
		padding-bottom: 20px;
		margin-bottom: 30px;
	}

	.content .offer_box p {
		font-size: 22px;
		line-height: 32px;
		min-height: auto;
	}

	.offer_box ul {
		margin-top: 40px;
		min-height: auto;
	}

	.offer_box h3 {
		font-size: 35px;
		margin-bottom: 20px;
	}

	.logo.mob img {
		width: 27px;
		height: 27px;
	}

	.flex_center {
		flex-wrap: wrap;
	}

	.open_menu {
		display: block;
		margin: 0 auto;
		text-align: center;
		width: fit-content;
	}

	.open_menu img {
		width: 50px;
		height: 50px;
	}

	.sticky .header {
		padding: 17px 40px;
	}

	.sticky .open_menu img, .sticky .close_menu {
		width: 45px;
		height: 45px;
		background-size: 45px;
	}

	.copyright_wrapper {
		display: none;
	}

	.copyright_wrapper.mob {
		display: block;
		width: 100%;
		margin-left: -15px;
	}

	img.footer_logo {
		max-width: 40%;
		margin: 0 auto;
		float: none;
	}

	.logo_footer {
		margin-left: -15px;
	}

	.footer_box {
		margin-bottom: 50px;
	}

	.content {
	    padding-left: 55px;
    	padding-right: 55px;
	}
}

@media only screen and (max-width:549px){
	.book_now {
	    height: auto;
		width: 100%;
		writing-mode: unset;
		border-left: none;
		border-top: 1px solid #fff;
		background: #1a1a1a;
		z-index: 99;
	}

	#map {
		width: 100%;
	}

	.more.directions {
		padding: 20px 60px;
		font-size: 19px;
	}

	.responsive_menu .contact_menu ul li a {
		font-size: 15px;
		padding: 0;
	}

	.responsive_menu ul li {
		font-size: 15px;
	}

	.responsive_menu .contact_menu ul li {
		margin-bottom: 6px;
	}

	#language {
		display: none;
	}

	#language.mob {
		display: flex;
		flex-direction: row;
		margin-right: 15px;
		top: 5px;
		bottom: auto;	
	}

	.home_header {
		width: 100%;
	}

	.gallery_text {
		display: none;
	}

	.facilities_img {
		width: 100%;
	}

	.room_facilities ul li {
		width: 100%;
	}

	.room_box.even:before {
		width: 100%;
	}

	.room_box h3 {
		font-size: 28px;
		line-height: 38px;
		margin-left: 45px;
	}

	.room_box h3:before {
		background-size: 17px;
		width: 17px;
		height: 17px;
		left: -30px;
	}

	.room_box {
		margin-right: 0px;
	}

	.room_box .room_image {
		height: 260px;
		border-radius: 20px;
	}

	.content.facilities p {
		margin-right: 0px;
	}

	.page_banner_content h1 {
		font-size: 40px;
	}

	.page_heading_image {
		height: 70vh;
	}

	.page_heading_shadow {
		height: 70vh;
	}

	.content.about {
		padding-right: 25px;
	}

	.page_heading_image {
		margin: 50px 30px 20px 30px;
	}

	.page_banner_content h1 span.first {
		padding-left: 25px;
	}

	.page_banner_content {
		margin-top: -20px;
	}

	.facility_box {
		width: calc(100% + 30px);
	}

	.content.facilities p {
		font-size: 18px;
		line-height: 26px;
		margin-top: 20px;
		margin-bottom: 35px;
	}

	.content.about h2 {
		margin-right: 0px;
	}

	.page_description {
		padding-top: 40px;
		padding-bottom: 90px;
		width: 100%;
	}

	.contactform div.submit input {
		padding: 17px 50px 17px 50px;
	}

	.contactform div label.error {
		font-size: 13px;
		left: 20px;
		bottom: -7px;
	}

	.contact_form {
		margin-top: 50px;
		margin-right: 0px;
	}

	.contact_form ul {
		padding: 20px 0;
	}

	.contactform input[type="text"], .contactform textarea {
		font-size: 18px;
	}

	.contact_form ul li:before {
		width: 10px;
		height: 10px;
		top: 7px;
	}

	.contact_form ul li {
		margin: 2px 0px;
		padding-left: 22px;
		font-size: 17px;
	}

	.contact_form h1 {
		font-size: 50px;
		margin-top: -47px;
	}

	.header_content {
		padding: 20px 0;
		margin-bottom: 15px;
	}

	.header_content h1 {
		font-size: 45px;
	}

	.mobile_graphic {
		width: 30%;
		height: 30%;
		left: 10px;
	}

	.responsive_menu ul li a {
		font-size: 24px;
	}

	.responsive_menu .contact_menu {
		padding: 25px 35px;
		margin: 7% 5% 0 5%;
	}

	.banner-shape1 {
		top: 18%;
		left: -20px;
	}

	.scrolling-words-box ul li {
		font-size: 50px;
		line-height: 60px;
	}

	.scrolling-words-container {
		margin-top: 15px;
	}

	.banner-shape2 {
		bottom: 21%;
		left: -50px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 92%;
		width: 100%;
		margin-right: -60px;
	}

	.home_header h1 {
		width: 100%;
		font-size: 50px;
	}

	.content p {
		font-size: 26px;
		line-height: 36px;
	}

	.content.about {
		padding-right: 0;
	}

	.about_img {
		padding-right: 0px;
	}

	.stay_mob .room_box h3 {
		font-size: 28px;
		line-height: 38px;
	}

	.stay_mob .room_box {
		margin: 10px 0px 25px 0px;
	}

	.stay_mob .room_box .room_image {
		height: 230px;
	}

	.location3 {
		margin-right: -15px;
		width: 300px;
	}

	.location1 {
		right: 0;
		width: 170px;
	}

	.location .more {
		font-size: 18px;
		padding: 16px 60px;
		right: 0;
	}

	.offer_box ul {
		margin-top: 20px;
	}

	.book_offer .more {
		margin-top: 25px;
	}

	.book_offer {
		margin-top: 20px;
		flex-direction: column;
		align-items: flex-start;
	}

	.content .offer_box p {
		font-size: 21px;
		line-height: 30px;
	}

	.offer_box h3 {
		font-size: 32px;
	}

	.offer_box {
		padding-right: 0px;
	}

	.offer_box.last {
		padding-right: 0px;
		padding-top: 30px;
	}

	.book_now a.book_link {
		font-size: 22px;
		letter-spacing: 12px;
		padding: 20px;
	}

	.book_now a.book_link.el {
		font-size: 18px;
		letter-spacing: 10px;
	}

	.footer {
		padding-bottom: 70px;
	}

	.copyright {
		text-align: center;
	}

	.footer .col-lg-4 {
		padding-left: 0;
		padding-right: 0;
	}
	
	.logo_footer {
		text-align: center;
	}

	#wapp a {
		margin: 0 auto;
	}

	.copyright_wrapper.mob {
		margin-left: 0;
	}

	.logo_footer {
		margin-left: 0px;
	}

	.content {
		padding-left: 45px;
		padding-right: 45px;
	}
}

@media only screen and (max-width:479px) {	
	.logo.mob img {
		width: 24px;
		height: 24px;
	}

	.el .scrolling-words-box ul li {
		font-size: 36px;
		line-height: 46px;
	}

	.home_header.el h1 {
		font-size: 40px;
	}

	.responsive_menu ul li {
		font-size: 14px;
	}

	.responsive_menu .contact_menu ul li {
		margin-bottom: 2px;
	}

	.responsive_menu ul li a {
		font-size: 23px;
	}

	.footer_social img.instagram {
		width: 23px;
	}

	.home_header h1 span.banner_graphic {
		margin-top: 0;
	}

	.footer_box p.hide {
		display: block!important;
	}

	.footer_social.mob {
		display: block;
		padding-top: 0;
		padding-bottom: 40px;
		margin: 0 auto;
		text-align: center;
	}

	.footer_box.first {
		width: 31%;
		display: inline-block;
	}

	.footer_social {
		display: none;
	}

	.footer_box.sec {
		width: 67%;
		text-align: right;
		display: inline-block;
	}

	.footer_box.last {
		display: none;
	}

	.home_header {
		height: calc(100vh - 201px)!important;
	}

	.page_banner_content h1 span.first {
		padding-left: 15px;
	}

	.room_box .room_image {
		height: 230px;
	}

	.room_box h3 {
		font-size: 25px;
		line-height: 35px;
	}

	.content.about {
		padding-bottom: 110px;
	}

	.page_banner_content h1 {
		font-size: 35px;
	}

	.facilities h3 {
		font-size: 30px;
		margin-left: 25px;
		margin-top: 25px;
	}

	.dynamic_img {
		margin-top: 35px;
	}

	.content .page_description p {
		font-size: 18px;
		line-height: 26px;
	}

	.contact_form h1 {
		font-size: 45px;
		margin-top: -45px;
	}

	.contactform input[type="text"], .contactform textarea {
		font-size: 17px;
		padding: 25px 15px;
	}

	.header_content h1 {
		font-size: 40px;
	}

	.responsive_menu {
		top: 144px;
		height: calc(100vh - 144px);
	}

	.responsive_menu .contact_menu ul li a {
		font-size: 14px;
	}

	.responsive_menu .contact_menu ul li a {
		font-size: 14px;
	}

	.responsive_menu .contact_menu {
		padding: 20px 35px;
		margin: 7% 5% 0 5%;
	}

	.scrolling-words-box ul li {
		font-size: 45px;
		line-height: 55px;
	}

	.home_header h1 {
		width: 95%;
		font-size: 45px;
	}

	.home_header h1 span.left {
		top: 10%;
	}

	.content p {
		font-size: 24px;
		line-height: 34px;
	}

	.content.location {
		padding-bottom: 115px;
		padding-top: 120px;
	}

	.stay_mob .room_box h3:before {
		background-size: 16px;
		width: 16px;
		height: 16px;
		left: -27px;
		margin-top: 9px;
	}

	.stay_mob .room_box h3 {
		font-size: 25px;
		line-height: 36px;
		margin-left: 40px;
		padding-right: 15px;
		align-items: flex-start;
	}

	.content.location p {
		font-size: 24px;
		line-height: 32px;
		margin-right: 0;
		padding-top: 30px;
	}

	.location3 {
		width: 280px;
	}

	.location1 {
		right: 0;
		width: 170px;
		top: -205px;
	}

	.location .more {
		font-size: 17px;
		padding: 15px 50px;
	}

	.location2 {
		width: 170px;
		margin-top: 35px;
	}

	.offer_box h3 {
		font-size: 30px;
	}

	.book_offer .more {
		padding: 16px 40px;
		font-size: 17px;
		border-radius: 40px;
	}

	.content .offer_box .book_offer p {
		font-size: 21px;
	}

	.content .offer_box p {
		font-size: 20px;
		line-height: 27px;
	}

	.offer_box ul li:before {
		width: 12px;
		height: 12px;
		top: 17px;
	}

	.offer_box ul li {
		font-size: 18px;
	}

	.content h2 {
		font-size: 20px;
		padding-left: 30px;
		padding-bottom: 15px;
		margin-bottom: 25px;
	}

	.content h2:before {
		width: 16px;
		height: 16px;
	}

	.book_now a {
		font-size: 21px;
		letter-spacing: 10px;
	}

	.copyright {
		font-size: 17px;
	}

	.header {
		padding: 20px 35px;
	}

	.content .footer_box p {
		font-size: 16px;
		line-height: 26px;
	}

	.footer_box p a {
		font-size: 16px;
	}

	.footer_social img {
		width: 24px;
		margin: 0 10px;
	}

	.footer_box {
		margin-bottom: 35px;
	}

	.footer_social {
		padding: 15px 0px;
	}
}

@media only screen and (max-width: 420px) {	
	.header {
		padding: 20px 25px;
	}

	.book_now a.book_link {
		padding: 20px 10px;
	}

	.more.directions {
		padding: 18px 35px;
		font-size: 17px;
	}

	.el .scrolling-words-box ul li {
		font-size: 29px;
		line-height: 39px;
	}

	.home_header.el h1 {
		font-size: 36px;
	}

	.copyright {
		font-size: 11px;
		line-height: 16px;
	}

	.home_header {
		height: calc(100vh - 171px)!important;
	}

	.languages a {
		font-size: 13px;
	}	

	.facilities_img {
		margin-top: 40px;
	}

	.room_list .page_description {
		padding-top: 40px;
	}

	.room_facilities {
		margin-top: 30px;
	}

	.room_facilities ul li {
		font-size: 18px;
		line-height: 23px;
	}

	.room_box .room_image {
		height: 200px;
	}

	.room_box h3 {
		font-size: 22px;
		line-height: 30px;
		margin-left: 35px;
		margin-top: 15px;
		padding-right: 10px;
		align-items: flex-start;
	}

	.room_box h3:before {
		background-size: 14px;
		width: 14px;
		height: 14px;
		left: -25px;
		margin-top: 8px;
	}

	.page_heading_image {
		margin: 45px 20px 15px 20px;
	}

	.content.about h2 {
		margin-right: 15px;
	}

	.content .page_description p {
		margin-bottom: 10px;
	}

	.page_banner_content h1 {
		font-size: 30px;
	}

	.page_banner_content h1 span.first {
		padding-left: 10px;
	}

	.facilities h3 {
		font-size: 23px;
		margin-left: 17px;
		margin-top: 20px;
	}

	.content.facilities p {
		font-size: 18px;
		line-height: 24px;
		margin-top: 20px;
		margin-bottom: 30px;
	}

	.contact_form {
		margin-top: 45px;
		margin-bottom: 70px;
	}

	.contactform textarea {
		height: 200px;
	}

	.contact_form ul li {
		margin: 2px 0px;
		padding-left: 20px;
		font-size: 15px;
		text-align: center;
	}

	.info-window-content p.balloon-first {
		font-size: 18px;
	}

	.info-window-content {
		padding: 5px;
	}

	.contact_form h1 {
		font-size: 38px;
		margin-top: -40px;
	}

	.contactform div.submit input {
		font-size: 18px;
		padding: 15px 50px 15px 50px;
	}

	.contactform input[type="text"], .contactform textarea {
		font-size: 15px;
		padding: 22px 15px;
	}

	.header_content {
		padding: 15px 0;
		margin-bottom: 10px;
	}

	.header_content h1 {
		font-size: 35px;
	}

	.sticky .responsive_menu {
		top: 75px;
		height: calc(100vh - 75px);
	}

	.responsive_menu {
		top: 124px;
		height: calc(100vh - 124px);
	}

	.responsive_menu ul li a {
		font-size: 22px;
		padding: 8px 0px;
	}

	.responsive_menu .menu_social img {
		width: 22px;
		margin: 0 7px;
	}

	.responsive_menu ul li {
		font-size: 14px;
	}

	.responsive_menu .contact_menu {
		padding: 20px 20px;
	}

	.home_header h1 {
		width: 100%;
		font-size: 40px;
	}

	.home_header h1 span.left {
		width: 75%;
	}

	.scrolling-words-box ul li {
		font-size: 35px;
		line-height: 45px;
	}

	.banner-shape1 {
		top: 20%;
		left: -25px;
	}

	.banner-shape1 img {
		height: 75px;
	}

	.banner-shape3 img {
		height: 55px;
	}

	.home_header h1 span.banner_graphic {
		background-size: 100%;
		width: 104%;
		margin-right: -55px;
	}

	.banner-shape2 {
		bottom: 26%;
		left: -50px;
	}

	.banner-shape2 img {
		height: 85px;
	}

	.content p {
		font-size: 22px;
		line-height: 32px;
	}

	.content.about {
		padding-top: 30px;
	}

	.stay_mob .room_box h3 {
		font-size: 22px;
		line-height: 30px;
		margin-left: 35px;
		margin-top: 15px;
		padding-right: 10px;
	}

	.stay_mob .room_box .room_image {
		height: 190px;
	}

	.stay_mob .room_box h3:before {
		background-size: 14px;
		width: 14px;
		height: 14px;
		left: -25px;
		margin-top: 8px;
	}

	.location .more {
		font-size: 17px;
		position: relative;
		padding: 15px 50px;
		margin-top: 40px;
	}

	.content.location p {
		font-size: 21px;
		line-height: 28px;
	}

	.location1 {
		right: 0;
		width: 140px;
		top: -290px;
	}

	.location3 {
		width: 260px;
	}

	.content h2:before {
		width: 14px;
		height: 14px;
	}

	.book_offer .more {
		padding: 15px 40px;
		font-size: 16px;
		border-radius: 30px;
	}

	.offer_box.last {
		padding-top: 25px;
		margin-top: 30px;
	}

	.content .offer_box p {
		font-size: 18px;
		line-height: 26px;
	}

	.offer_box ul li {
		font-size: 16px;
		padding: 7px 0;
		padding-left: 20px;
	}

	.content .offer_box .book_offer p {
		font-size: 20px;
	}

	.offer_box ul li:before {
		width: 10px;
		height: 10px;
		top: 14px;
	}

	.offer_box h3 {
		font-size: 25px;
	}

	.content h2 {
		font-size: 18px;
		padding-left: 27px;
		padding-bottom: 12px;
		margin-bottom: 20px;
	}

	.book_now a {
		font-size: 20px;
		letter-spacing: 4px;
		padding: 15px;
	}

	.footer {
		padding-bottom: 60px;
	}

	.sticky .open_menu img, .sticky .close_menu {
		width: 40px;
		height: 40px;
		background-size: 40px;
	}

	#wapp a {
		width: 82px;
		height: 22px;
	}

	.content {
		padding-left: 40px;
		padding-right: 40px;
	}

	.footer_box p a {
		font-size: 14px;
	}

	.content .footer_box p {
		font-size: 14px;
		line-height: 24px;
	}

	.footer_social img {
		width: 24px;
		margin-right: 15px;
	}

	.footer_social img.instagram {
		width: 22px;
	}

	.logo.mob img {
		width: 22px;
		height: 22px;
	}

	.open_menu img, .close_menu {
		width: 40px;
		height: 40px;
		background-size: 40px;
	}

	.footer_social img {
		width: 22px;
		margin: 0 7px;
	}

	.footer_social img.instagram {
		width: 20px;
	}
}

@media(max-width:360px){
	.content .footer_box p {
		font-size: 12px;
		line-height: 20px;
	}

	.footer_box p a {
		font-size: 12px;
	}
}


/* ===========================>
		ERROR PAGE
   <========================== */
   .tit-er{color:#fff !important;}
   .tex-er {
	color: #fff;
    font-size: 22px;
    line-height: 30px;
    padding-left: 25px;
    font-weight: 300;
    margin-top: -40px;
    text-align: center;
	z-index: 1;
    position: relative;
	height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
   }

   .btn-er{
	display: flex;
	justify-content: center;
	z-index: 1;
    position: relative;
   }

   .btn-er a {
	margin-top: 50px;
   }

  @media(min-width:768px){
	
	
  }
  @media(max-width:767px){
	.tex-er{
		border-left: unset;
		padding-left: unset;
		margin-top: 20px;
		font-size: 18px;
		line-height: normal;
	}
  }

  @media(max-width: 479px) {
	.tex-er {
		font-size: 17px;
	}
  }

@media(max-width: 350px) {
  .book_now a.book_link.el {
		font-size: 14px;
	}
}