@font-face {
  font-family: "Font Awesome 7 Brands";
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url("fonts/fa-brands.woff2");
}
@font-face {
    font-family: 'S&S Nickson One';
    src: url('fonts/S&S Nickson One.woff2') format('woff2'),
         url('fonts/S&S Nickson One.woff') format('woff');
    font-style: normal;
}
@font-face {
    font-family: 'Franklin Gothic ATF';
    src: url('fonts/franklin-gothic-atf-regular.woff2') format('woff2'),
         url('fonts/franklin-gothic-atf-regular.woff') format('woff');
    font-style: normal;
    font-weight: 400;
}
@font-face {
    font-family: 'Franklin Gothic ATF';
    src: url('fonts/franklin-gothic-atf-bold.woff2') format('woff2'),
         url('fonts/franklin-gothic-atf-bold.woff') format('woff');
    font-style: normal;
    font-weight: 700;
}
.fab.fa-square-x-twitter,
.fab.fa-x-twitter {
	font-family: "Font Awesome 7 Brands";
}
.fa-square-x-twitter:before {
  content: "\e61a";
}

.fa-x-twitter:before {
  content: "\e61b";
}
blockquote {
    margin: 0;
    padding: 0;
}
blockquote:before {
    display: none;
}
.wp-block-image.size-full {
    margin: 20px 0;
}
.wp-block-image.size-full img {
	width: 100%;
}
.wp-block-image.size-full figcaption {
    background-color: #072139;
    color: #fff;
    text-align: center;
    padding: 15px;
    margin: 0;
}
.wp-fixed.generic-listing {
    padding-bottom: 0;
}
.shop-map .map .map-canvas {
    min-height: 500px;
}
.template-accommodation-detail .amenities .item .icon-container {
	display: flex;
	align-items: center;
	justify-content: center;
}
.template-accommodation-detail .amenities .item .icon-container svg {
	width: 25px;
}
.template-accommodation-detail .amenities .item .icon-container svg path {
	fill: #fff;
}
.template-accommodation-detail .content-area .main h1 {
	padding-top: 30px;
	font-weight: 600;
	font-size: 28px;
}
.booking-widget.sidebar h3 {
	font-size: 20px;
}
/* Header Menu */
header nav.primary .current-menu-item a:after {
    background-color: #072139;
}
.mobile-menu li.current-menu-item a {
    background-color: #10223F;
    color: #fff;
}
/* Header Menu */
.scrolled header .trading-hours {
    left: 150px;
}
header .trading-hours {
    padding-left: 30px;
}
.booking-widget .ui.form .field > label {
    text-transform: uppercase;
	color: #282625;
}
.from-the-hub.full-width .tiles .swiper-container {
    width: 100%;
}
@media (min-width: 1024px) {
    h2 {
        font-size: 48px;
    }
}
.featured-content .title {
    font-family: 'S&S Nickson One';
}
.from-the-hub h2,
.whats-on h2 {
    font-family: 'S&S Nickson One';
    font-weight: 700;
    letter-spacing: 1px;
}
.whats-on h2 {
    color: #282625;
}
footer .map-link:hover {
    color: #fff;
}
.booking-widget .ui.button.chevron-button {
    padding-left: 3em;
    padding-right: 3em;
	width: 100%;
	margin: 0;
}
.booking-widget .ui.button.chevron-button:hover {
	box-shadow: 0 0 0 2px #EFE4D2 inset;
}
.booking_widget form fieldset.inputs label {
	color: #fff;
}
.right-links .ui.button, .right-links .ui.buttons .button {
    background-color: transparent;
    color: #fff;
    text-shadow: none;
    font-weight: 400;
    background-image: none;
    box-shadow: 0 0 0 2px #fff inset;
}
.right-links .button.ui:hover {
    background-color: #EFE4D2;
    color: #281C12;
    box-shadow: 0 0 0 2px #EFE4D2 inset;
    text-decoration: none;
}
.homepage-promos .promo .background .pattern,
.homepage-promos .promo .background {
    background-size: cover;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    transition: all .5s ease;
    border-bottom-right-radius: 180px;
}
.homepage-promos .promo .background::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #072139;
    opacity: 0.5;
	border-bottom-right-radius: 180px;
}
.homepage-promos .promo .background .pattern {
	background-image: url('/wp-content/themes/hotel/assets/images/SDH_HoverState_Yellow.webp');
	opacity: 0;
}
.homepage-promos .promo:hover .background .pattern {
	opacity: 1;
	/*
    margin-top: -15px;
    -webkit-transform: scale(1.03);
    -ms-transform: scale(1.03);
    transform: scale(1.03);
	*/
}
.homepage-promos .promo:hover .arrow .icon::before {
    color: #281C12;
}
.subscribe-tile .ui.button:hover {
    background-color: transparent;
    box-shadow: 0 0 0 2px #fff inset;
}
/* Ninja Forms */
.nf-form-cont {
    max-width: 680px;
    margin: 0 auto;
}
.nf-form-cont .nf-before-form-content {
    display: none;
}
.nf-form-cont .nf-form-content .nf-field-label label {
    font-size: 16px;
    font-weight: 400;
    color: rgba(0,0,0,.87);
}
.nf-form-cont .nf-form-content .nf-field-element input[type=radio] {
	border: 0;
}
.nf-form-cont .nf-form-content .nf-field-element input {
    font-family: 'Franklin Gothic ATF',sans-serif;
    font-weight: 400;
    margin: 0;
    outline: 0;
    -webkit-appearance: none;
    tap-highlight-color: rgba(255,255,255,0);
    line-height: 1.21428571em;
    padding: 0.67857143em 1em;
    font-size: 1em;
    background: #fff;
    border: 1px solid rgba(34,36,38,.15);
    color: rgba(0,0,0,.87);
    border-radius: 0.28571429rem;
    box-shadow: 0 0 0 0 transparent inset;
    transition: color .1s ease,border-color .1s ease;
}
.nf-form-cont .nf-form-content .nf-field-element label {
    font-size: 14px;
    color: rgba(0,0,0,.87);
}
.sidebar-contact .nf-form-cont .nf-form-content .nf-field-label label {
    color: white;
}
.nf-form-cont .nf-form-content .nf-field-element select {
    display: block;
    height: auto;
    width: 100%;
    font-size: 14px;
    border: 1px solid rgba(34,36,38,.15);
    border-radius: 0.28571429rem;
    box-shadow: 0 0 0 0 transparent inset;
    padding: 0.62em 1em;
    color: rgba(0,0,0,.87);
    transition: color .1s ease,border-color .1s ease;
}
.nf-form-cont .nf-form-content .submit-container {
    text-align: center;
}
.nf-form-cont .nf-form-content .submit-container .nf-field-element {
    display: inline-block;
    font-family: "Font Awesome 5 Pro";
    width: auto;
    margin: 0 auto;
}
.sidebar-contact .nf-form-cont .nf-form-content .submit-container .nf-field-element,
.sidebar-contact .nf-form-cont .nf-form-content .submit-container .nf-field-element input {
    width: 100%;
}
.nf-form-cont .nf-form-content .submit-container .nf-field-element input[type=button] {
    position: relative;
    display: inline-block;
    font-family: 'Franklin Gothic ATF',sans-serif;
    background-color: #fec396;
    color: #1f3b50;
    text-shadow: none;
    font-weight: 400;
    box-shadow: 0 0 0 2px #fec396 inset;
    cursor: pointer;
    min-height: 1em;
    outline: 0;
    border: none;
    vertical-align: baseline;
    margin: 0 0.25em 0 0;
    padding: 1.3em 3em;
    text-transform: uppercase;
    line-height: 1em;
    font-style: normal;
    text-align: center;
    text-decoration: none;
    border-radius: 0.28571429rem;
    user-select: none;
    transition: opacity .3s ease,background-color .3s ease,color .3s ease,box-shadow .3s ease,background .3s ease;
    -webkit-tap-highlight-color: transparent;
}
.nf-form-cont .nf-form-content .submit-container .nf-field-element input[type=button]:hover {
    background-color: #b0d5dd;
    color: #1f3b50;
    text-shadow: none;
    box-shadow: 0 0 0 2px #b0d5dd inset;
}
.nf-form-cont .nf-form-content .nf-error.field-wrap .nf-field-element:after {
    display: none;
}
.nf-form-cont .nf-form-content .nf-error-msg {
    position: relative;
    display: inline-block;
    line-height: 1;
    margin: 0 0.14285714em;
    padding: 0.5833em 0.833em;
    font-size: 12px;
    color: #9f3a38;
    font-weight: 700;
    border: 1px solid rgb(224, 180, 180);
    border-radius: 0.28571429rem;
    transition: background .1s ease;
}
.sidebar-contact .nf-form-cont .nf-form-content .nf-error-msg {
    border: 0;
}
.nf-form-cont .nf-form-content .nf-error-msg:before {
    position: absolute;
    content: '';
    border: 1px solid rgb(224, 180, 180);
    border-right: 0;
    border-bottom: 0;
    background-color: white;
    -webkit-transform: translateX(-50%) translateY(-50%) rotate(45deg);
    -ms-transform: translateX(-50%) translateY(-50%) rotate(45deg);
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
    top: 0;
    left: 50%;
    z-index: 2;
    width: 0.6666em;
    height: 0.6666em;
    transition: background .1s ease;
}
.sidebar-contact .nf-form-cont .nf-form-content .nf-error-msg:before {
    border: 0;
    background-color: transparent;
}
.nf-form-cont .nf-form-content .nf-error .ninja-forms-field {
    border-color: #9f3a38;
}
.nf-form-cont .nf-form-content .nf-pass.field-wrap .nf-field-element:after {
    color: rgba(31,59,80,1);
}
.nf-error-msg.nf-error-field-errors {
    text-align: center;
    color: #9f3a38;
}
.nf-form-cont .nf-form-content .listradio-wrap .nf-field-element label.nf-checked-label:before {
    top: 0.35em;
}
.nf-form-cont .nf-form-content .listcheckbox-container .nf-field-element label:before {
    top: 2px;
    left: -26px;
    font-size: 16px;
}
.nf-form-content .list-select-wrap>div div {
    display: block;
    position: absolute;
    font-size: 16px;
    line-height: 16px;
    margin: 0;
    padding: 16px;
    height: 50px;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1;
}
.nf-form-content .listselect-wrap .nf-field-element div, .nf-form-content .ninja-forms-field:not(button) {
    font-size: 16px;
    margin: 0;
    padding: 12px;
}
.nf-form-content .listselect-wrap .nf-field-element div, .nf-form-content input.ninja-forms-field, .nf-form-content select.ninja-forms-field:not([multiple]) {
    height: 50px;
}
.nf-form-content .list-select-wrap .nf-field-element > div {
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0;
}
.nf-form-content .list-select-wrap>div div:after {
    content: "\f078";
    font-family: 'Font Awesome 5 Pro';
    font-size: 20px;
    color: rgba(0,0,0,.87);
    position: absolute;
    right: 10px;
    bottom: 0;
    height: 50px;
    line-height: 50px;
}
.nf-form-content .list-select-wrap .nf-field-element > select {
    position: relative;
    z-index: 1;
    background: transparent;
    appearance: none; 
    -webkit-appearance: none; 
    -moz-appearance: none;
}
.nf-form-content .list-select-wrap .nf-field-element > select::-ms-expand {
    display: none;
}
.nf-response-msg {
    margin-top: 60px;
    text-align: center;
    font-weight: 700;
}
.sidebar-contact .nf-response-msg {
	margin-top: 0;
}
.sidebar-contact .nf-response-msg span {
	color: white !important;
}
/* Ninja Forms */

/* Social Links */
.social-links i.icon {
    vertical-align: unset;
    margin-left: 0;
}

.social-links .fa-facebook-f:before {
    content: "\f39e";
}
/* Social Links */

/* Banners */
.homepage-promos .promos-container {
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
}
.homepage-promos .promos-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    margin: 0 -2px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: center;
    -ms-flex-align: center;
	flex-wrap: wrap;
    align-items: center;
	justify-content: space-between;
    transform: translate3d(0px, 0px, 0px);
    transition-duration: 0ms;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform,-webkit-transform;
    transition-timing-function: ease-out;
    box-sizing: content-box;
}
.homepage-promos .promos-wrapper .promo {
	width: calc(50% - 2px);
    cursor: pointer;
}
.homepage-promos .promo:nth-child(2n) {
	margin: 0 0 4px 2px;
}
.homepage-promos .promo:nth-child(2n + 1) {
	margin: 0 2px 4px 0;
}

.wp-block-column .booking-widget.sidebar {
	background-color: #efefef;
}
/* With admin bar */
.admin-bar header .top-bar,
.admin-bar header .top-items,
.admin-bar header .top-menu {
    top: 32px;
}
.admin-bar header .search-overlay,
.admin-bar header .main {
    top: 102px;
}
/* With admin bar */
header .trading-hours .icon.fa-phone,
header .trading-hours .phone-button .icon {
    top: 25%;
}
header .trading-hours .label .top-bar-button {
	margin-left: 0;
}
.desktop {
	display: none !important;
}
.stick-buttons {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	background-color: #E09A66;
	border-top: 1px solid #fff;
}
.stick-buttons.sticked {
	position: fixed;
	z-index: 99;
	bottom: 0;
	left: 0;
}
.stick-buttons .stick-button {
	display: block;
	width: 33.3333%;
	padding: 20px 0;
	font-size: 16px;
	color: #fff;
	line-height: 20px;
	text-transform: uppercase;
	text-align: center;
	text-decoration: none;
}
.stick-buttons .stick-button.light {
	background-color: #282625;
}
.whats-on .next:not(.swiper-button-disabled):hover,
.whats-on .prev:not(.swiper-button-disabled):hover{
    background-color:#EFE4D2;
    color:#281C12;
}
.whats-on-listing h2 {
    color: #E09A66;
    font-family: 'S&S Nickson One';
    font-weight: 700;
    letter-spacing: 1px;
    text-align: center;
    margin: 0 auto;
    margin-bottom: 20px;
}
header .search-input.ui.form .submit-container button i,
header .search-overlay .close-button button i,
header .top-items a.search-button i {
    display: inline-block;
    width: 40px;
    height: 40px;
    text-align: center;
    line-height: 40px;
    border-radius: 20px;
    transition: opacity .3s 
    ease, background-color .3s 
    ease, color .3s 
    ease, box-shadow .3s 
    ease, background .3s 
    ease;
}
header .search-input.ui.form .submit-container button i:hover,
header .search-overlay .close-button button i:hover,
header .top-items a.search-button:hover i {
    background-color: #EFE4D2;
    color: #281C12;
}
a.wp-block-button__link {
    position: relative;
    font-family: 'Franklin Gothic ATF', sans-serif;
    background-color: #281C12;
    color: #fff;
    text-shadow: none;
    font-weight: 700;
    background-image: none;
    box-shadow: 0 0 0 2px #281C12 inset;
    padding-top: 1em;
    padding-bottom: 1.1em;
    cursor: pointer;
    display: inline-block;
    min-height: 1em;
    outline: 0;
    border: none;
    vertical-align: baseline;
    margin: 0 .25em 0 0;
    padding: 1.3em 2.5em;
    text-transform: uppercase;
    font-weight: 700;
    line-height: 1em;
    font-size: 1rem;
    font-style: normal;
    text-align: center;
    text-decoration: none;
    border-radius: .28571429rem;
    box-shadow: 0 0 0 1px transparent inset, 0 0 0 0 rgba(34, 36, 38, .15) inset;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition: opacity .3s 
    ease, background-color .3s 
    ease, color .3s 
    ease, box-shadow .3s 
    ease, background .3s 
    ease;
    will-change: '';
    -webkit-tap-highlight-color: transparent;
}
a.wp-block-button__link:hover {
    background-color: #EFE4D2;
    color: #281C12;
    text-shadow: none;
    box-shadow: 0 0 0 2px #EFE4D2 inset;
}
a.wp-block-button__link:after {
    content: "\f054";
    font-family: 'Font Awesome 5 Pro';
    position: absolute;
    right: 15px;
    top: 36%;
    font-size: 13px;
}
a.wp-block-button__link:hover:after {
   right: 10px;
}
.subscribe .ui.transparent-white.button {
    padding-top: 1.1em;
    padding-bottom: 1.1em;
}
form .label-above .nf-field-label {
    margin-bottom: 0;
}
.nf-form-cont form .nf-form-content .nf-field-element input,
.nf-form-cont form .nf-form-content .nf-field-element select {
    padding: 1em;
}
.nf-form-cont form .nf-form-content .nf-field-element textarea {
    border: 1px solid rgba(34,36,38,.15);
}
.search-result select {
    padding: 10px 15px;
}
.detail-view.accommodation .row .main {
	width: calc(100% - 280px);
}
.detail-view.accommodation .foreground {
	margin-left: 0;
	padding-top: 40px;
}
.detail-view.accommodation .booking-widget.sidebar {
    margin: 40px 0 0 0;
	width: 100%;
    background-color: #dde2e4;
	box-sizing: border-box;
}
figure.nomar {
	margin: 0;
}
.dining-detail.detail-view .dining-info .hours .time {
	text-align: right;
}
.content-gallery .item {
	position: relative;
}
.content-gallery .item h2{
	position: absolute;
    left: 0;
    bottom: 0;
    text-align: center;
    background-color: rgba(40, 38, 37, .8);
    color: #fff;
    font-size: 16px;
    width: 100%;
    text-transform: unset;
    font-weight: 400;
    padding: 15px;
}
.scrolled.up header .top-menu {
	overflow: unset;
}
header nav.primary ul.menu > li {
	padding: 17px 0;
}
header nav.primary ul li.menu-item-has-children {
	position: relative;
}
header nav.primary ul li.menu-item-has-children:hover ul.sub-menu {
	opacity: 1;
	visibility: visible;
}
header nav.primary ul li.menu-item-has-children:hover > a:after{
	background-color: transparent;
}
header nav.primary ul li.menu-item-has-children li a:after {
	display: none;
}
header nav.primary ul li.menu-item-has-children li a:hover {
	background-color: #E09A66;
}
header nav.primary ul ul.sub-menu {
	flex-wrap: wrap;
	gap: 0;
    padding: 0;
    margin: 18px 0 0 0;
    left: -75px;
	right: -75px;
    position: absolute;
	opacity: 0;
	visibility: hidden;
    background-color: rgba(40, 38, 37, 1);
}
header nav.primary ul ul.sub-menu li {
	margin-left: 0;
	display: inline-block;
	width: 100%;
}
header nav.primary ul ul.sub-menu li:not(:last-child) {
	border-bottom: 1px solid #fff;
}
header nav.primary ul ul.sub-menu a {
	padding: 11px 10px;
	text-align: center;
	color: #fff;
	display: inline-block;
	width: 100%;
}
@media only screen and (min-width: 1025px) {
	.desktop {
		display: inherit !important;
	}
	.mobile {
		display: none !important;
	}
}
@media only screen and (max-width: 768px) {
	header .trading-hours {
		display: none;
	}
	.detail-view.accommodation .foreground {
		padding-left: 0;
	}
}
@media only screen and (max-width: 767px) {
	.detail-view.accommodation .foreground {
		padding-top: 20px;
	}
	.detail-view.accommodation .row .main {
		width: 100%;
	}
	.detail-view.accommodation .booking-widget.sidebar {
		max-width: 100%;
		margin-top: 20px;
	}
}
@media only screen and (max-width: 480px) {
	.stick-buttons .stick-button {
		width: 50%;
	}
	.stick-buttons .stick-button:last-child {
		width: 100%;
	}
}
@media (min-width:960px){
    .page-hero .foreground,
    .homepage-hero .foreground{
        max-width:780px;
    }
}
@media (min-width:1180px){
    .page-hero .foreground,
    .homepage-hero .foreground{
        max-width:960px;
    }
}
@media only screen and (max-width: 768px) {
    .admin-bar #wpadminbar {
        position: fixed;
    }
    .admin-bar header .top-bar,
    .admin-bar header .top-items,
    .admin-bar .mobile-menu.ui.right.sidebar {
        top: 46px;
    }
	header .trading-hours {
		display: none;
	}
}
@media only screen and (max-width: 480px) {
	.homepage-promos .promos-wrapper {
		flex-wrap: wrap;
		padding: 0 20px;
	}
	.homepage-promos .promos-wrapper .promo {
		width: calc(100% - 40px);
		margin: 0 0 4px 0;
	}
	.detail-view .foreground {
		padding-left: 0;
		padding-right: 0;
	}
	footer .top .links {
		justify-content: space-between;
	}
	footer .col {
		margin-bottom: 15px;
	}
}