/*
 Theme Name:   Platinum Pebble
 Template:     generatepress
 Author: Community Web Development
 Author URI: http://www.comminternet.com/
 Version: 1.0
*/

@font-face {
    font-family: 'bonvenocflight';
    src: url('fonts/BonvenoCF-Light-webfont.eot');
    src: url('fonts/BonvenoCF-Light-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/BonvenoCF-Light-webfont.woff2') format('woff2'),
         url('fonts/BonvenoCF-Light-webfont.woff') format('woff'),
         url('fonts/BonvenoCF-Light-webfont.ttf') format('truetype'),
         url('fonts/BonvenoCF-Light-webfont.svg#bonvenocflight') format('svg');
    font-weight: normal;
    font-style: normal;
}

/* clearfix */
.cf:before,
.cf:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.cf:after {
    clear: both;
}

.visually-hidden { 
    border: 0;
    padding: 0;
    margin: 0;
    position: absolute !important;
    height: 1px; 
    width: 1px;
    overflow: hidden;
    clip: rect(1px 1px 1px 1px); /* IE6, IE7 - a 0 height clip, off to the bottom right of the visible 1px box */
    clip: rect(1px, 1px, 1px, 1px); /*maybe deprecated but we need to support legacy browsers */
    clip-path: inset(50%); /*modern browsers, clip-path works inwards from each corner*/
    white-space: nowrap; /* added line to stop words getting smushed together (as they go onto seperate lines and some screen readers do not understand line feeds as a space */
}

/* prevent tel clicks on desktops */
a[href^="tel"] { pointer-events: none; }

/* allow tel clicks on phones */
@media (max-width: 767px) {
	a[href^="tel"] { pointer-events: auto; }
}

/* GLOBALS */

p:empty {
	display: none;
}

bold, strong {
	font-weight: 500px;
}

.flex-parent {
	display: flex;
}

.button, .wp-block-button .wp-block-button__link {
    padding: 13px 15px;
}

.alignleft, .alignright, .aligncenter {
	margin-top: 60px;
	margin-bottom: 60px;
}

.content-area img.alignleft,
.content-area img.alignright,
.content-area img.aligncenter,
.content-area img.alignnone,
.alert-box,
.wp-caption {
	background: var(--light-gray);
	border-top-right-radius: 30px;
	border-bottom-left-radius: 30px;
	overflow: hidden;
}

.wp-caption .wp-caption-text {
	text-align: center;
	padding: 1em 30px;
	margin: 0;
	color: #000;
}

.copyright-bar ul.menu {
	margin-left: 0;
}

.copyright-bar ul.menu li {
	display: inline;
	margin: 0 10px;
}

.copyright-bar p.branding {
	margin-bottom: 0;
}

.social-media li.other path {
	fill: currentColor;
}

.social-media li svg {
	height: 1em;
	width: 1em;
}

/*

FIX BUG WHERE TOP LEVEL HOVER COLOR REVERTS WHEN SELECTING A DROPDOWN MENU ITEM WHICH IS A DESCENDANT OF THE CURRENT PAGE

.main-navigation .main-nav ul li[class*="current-menu-"]:hover > a,
.main-navigation .main-nav ul li[class*="current-menu-"]:focus > a {
	color: #fff !important;
}

*/


body.nav-float-right .inside-header #site-navigation,
body .book-container {
	width: 300px;
	margin: 0;
}

body .main-navigation .book-container {
	width: auto;
	display: none;
}

body .inside-header {
	justify-content: space-between;
}

body .main-navigation .inside-navigation {
	justify-content: flex-end;
}

body.one-container .dark-mode {
	background: none !important;
}

.bi-instagram,
.bi-facebook {
	height: 21px !important;
	width: 21px !important;
	position: relative !important;
	top: 3px !important;
}

.book-container a.gb-button {
	border: 2px solid #fff;
	padding: 0 15px 0 40px;
	line-height: 44px;
	font-size: 14px;
	letter-spacing: 2px;
	background: none;
	display: inline-block;
	background: rgba(0,0,0,0.25);
	text-transform: uppercase;
}

.book-container .gb-icon {
	position: absolute;
	left: 16px;
	pointer-events: none;
}

.book-container:hover .gb-icon {
	color: var(--blue);
}

.book-container a.gb-button:hover {
	background: #fff;
	color: var(--blue);
}

.phone-container a.phone {
	font-size: 18px !important;
	letter-spacing: 3px;
}

body.sticky-enabled .main-navigation.is_stuck {
	background: #fff;
}

body #sticky-navigation .book-container {
	order: 1;
	display: inline-block;
}

body #sticky-navigation .book-container a.gb-button.button {
	background: var(--red);
	margin-right: 15px;
}

body #sticky-navigation .book-container a.gb-button.button:hover {
	background: var(--blue);
	color: #fff;
}

body #sticky-navigation .book-container:hover .gb-icon {
	color: #fff;
}

#sticky-navigation .phone-container {
	display: none;
	order: 1;
}

#sticky-navigation .phone-container .gb-icon,
#sticky-navigation .phone-container .gb-headline-text,
#sticky-navigation .phone-container .gb-headline-text a.phone {
	color: var(--contrast);
}

#sticky-navigation .phone-container .gb-headline {
	border-color: rgba(0,0,0,0.1);
}

#sticky-navigation .menu-bar-items {
	order: 2;
}

body .main-navigation.navigation-stick.has-sticky-branding .inside-navigation.grid-container,
body .inside-header {
	padding-right: 15px;
}

body li.check-rates a {
	border: 2px solid #fff;
	font-size: 18px;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-right: 15px;
	line-height: 44px;
}

.alertbar {
	position: sticky !important;
	top: 0;
}

/* video */

.video-container {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%; 
  overflow: hidden;
}

.video-container:after {
	content: "";
	background-image: linear-gradient(180deg, var(--contrast) 0%, rgba(0, 0, 0, 0) 100%);
	z-index: 0;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	pointer-events: none;
}

.video-container video {
  /* Make video to at least 100% wide and tall */
  min-width: 100%; 
  min-height: 100%; 

  /* Setting width & height to auto prevents the browser from stretching or squishing the video */
  width: auto;
  height: auto;

  /* Center the video */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  
}

#emd-videos .video-summary {
	display: none;
}

form.availability {
	display: flex;
	flex-wrap: wrap;
	text-align: left;
	justify-content: space-between;
}

form.availability p {
	width: 48%;
	margin: 0;
}

form.availability p.submit,
form.availability input,
form.availability button,
form.availability select,
form.availability label {
	width: 100%;
	margin: 0;
	border-radius: 0;
	display: block;
	-webkit-appearance: none;
	text-align: left;
}

form.availability p,
form.availability p.submit {
	margin-top: 15px;
}

form.availability p button {
	text-align: center;
}

form.availability p label {
	padding-bottom: 5px;
	text-align: center;
}

.stretch {
	align-self: stretch;
}

.sticky-porthole {
	position: sticky;
	top: 0;
}

.site-footer .alertbar {
	position: relative !important;
}

.social-media ul.social-media-links {
	margin: 0;
}

.social-media ul.social-media-links li {
	margin: 0 10px 0 0;
	display: inline;
	font-size: 1.25em;
}

.site-footer .sib-form,
.site-footer #sib-container,
.site-footer .sib-form .sib-form-block,
.site-footer .sib-form .sib-form-block .entry__field,
.site-footer .sib-form .sib-form-block .form__label-row--horizontal {
	padding: 0px !important;
	margin: 0px !important;
	border-radius: 0px !important;
}

.site-footer #sib-container {
	background: none !important;
}

.site-footer #sib-form {
	display: flex;
	align-items: flex-start;
	margin-bottom: 5px !important;
}

.site-footer .sib-form .sib-form-block button,
.site-footer .sib-form .sib-form-block input {
	padding: 0 10px !important;
	height: 38px !important;
	border-radius: 0px !important;
}

.site-footer .sib-form .sib-form-block button {
	height: 40px !important;
	font-size: 1em;
	font-weight: bold;
}

.site-footer form.availability p label {
	text-align: left;
	font-size: 0.85em;
}

.updates-block .gform_required_legend {
	display: none;
}

.updates-block .gfield--type-email.gfield--width-half {
	grid-column: span 8 !important;
}

.updates-block .gfield--type-submit.gfield--width-half {
	grid-column: span 4 !important;
}

.updates-block .gfield--type-submit.gfield--width-half input {
	background: var(--red) !important;
}

.updates-block .gfield--type-submit.gfield--width-half input:hover {
	background: var(--blue) !important;
}

.updates-block input {
	border-radius: 0 !important;
}

.alert-box.updates-block form.footer-signup {
	margin: 15px auto 30px auto;
}

.site-footer ul.menu {
	margin-left: 0;
}

.site-footer ul.menu li {
	margin: 0 5px;
	display: inline;
}

body .slideout-navigation.do-overlay .inside-navigation {
    padding: 30px;
}

.slideout-navigation a.avail-button {
	font-size: 18px;
	letter-spacing: 3px;
	text-transform: uppercase;
}

/* Rooms Pages */

.tr-widget.availability .tr-unit-calendar iframe {
	height: 322px;
}

.room-sidebar .avail-button {
	width: 100%;
	text-align: center;
	border-bottom-left-radius: 30px;
}

.100-percent-button .avail-button {
	width: 100%;
	text-align: center;
}

.rooms-nav {
	font-weight: 500;
	padding: 10px;
	border-top-right-radius:30px;
	border-bottom-left-radius:30px;
	text-align: center;
	background: var(--light-gray);
}

.rooms-nav a {
	margin: 0 10px;
}

.sticky-track {
	align-self: stretch;
}

.room-sidebar,
body.single-post .inside-right-sidebar .sticky-sidebar {
	position: sticky;
	top: 30px;
}

body.single-post .inside-right-sidebar {
	height: 100%;
	padding-left: 30px;
}

body.single-post .inside-right-sidebar .availability p {
	width: 100%;
}

body.single-post .inside-right-sidebar form.availability p label {
	text-align: left;
}

body .sfsi_shortcode_container .sfsi_wicons {
	z-index: 8 !important;
}

ul.pp-related-posts {
	margin-left: 0em;
	list-style-type: none;
	font-weight: 500;
	font-size: 16px;
}

ul.pp-related-posts li  {
	margin-bottom: 8px;
}

.flex-parent.room-view {
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	padding-top: 20px;
}

.flex-parent.room-view a.room-block {
	display: flex;
	align-items: flex-end;
	border-top-right-radius: 30px;
	border-bottom-left-radius: 30px;
	width: 22%;
	margin: 0 1.5% 30px 1.5%;
	height: 240px;
	background-size: cover !important;
	background-position: center center !important;
	overflow: hidden;
}

.flex-parent.room-view a.room-block span.room-name {
	display block;
	color: #fff;
	background: var(--red);
	padding: 10px;
	width: 100%;
	text-align: center;
	font-weight: 500;
	text-transform: uppercase;
	font-size: 16px;
	letter-spacing: 2px;
    transition: background-color 300ms;
}

.flex-parent.room-view a.room-block:hover span.room-name {
	background: var(--blue);
    transition: background-color 300ms;
}

.comment-list .comment .comment-content {
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
	border-top-right-radius: 30px;
	border-bottom-left-radius: 30px;
}

#comments input.submit {
	color: #fff;
	font-weight: 500;
}

/* Specials */

.specials-list {
	column-count: 2;
	column-gap: 60px;
}

.specials-list .special-card {
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
	margin-top: 60px;
	border-top-right-radius: 60px;
	border-bottom-left-radius: 60px;
	overflow: hidden;
	display: inline-block;
}

.specials-list .special-card:nth-of-type(1) {

}

.specials-list .special-card .feat-img {
	background-size: cover !important;
	height: 240px;
	width: 100%;
	background-position: center center !important;
	display: block;
}

.specials-list .special-card .content {
	padding: 30px 30px 0 30px;
}

.specials-list .special-card a.button {
	display: block;
	text-align: center;
}

.alert-box {
	padding: 30px 30px 0 30px;
	margin: 60px auto;
	background: #fff;
	background-image: linear-gradient(180deg, var(--base) 0%, var(--light-gray) 200%);
	box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1);
	max-width: 480px;
	width: 100%;
}

.alert-box .cwdblast {
	height: 220px !important;
	position: relative;
	top: -30px;
}

.alert-box h4 {
	margin: 0;
}

.blog-footer .alert-box {
	margin: 0 auto;
	background: none;
	box-shadow: none;
}

.blog-footer .norm_row {
	margin: 0 0 0 -12px !important;
}

.home .hide-home {
	display: none;
}

.popup-text h2 {
	font-size: 24px;
}

.popup-text p {
	margin: 0;
}

.map-column iframe {
	height: 324px !important;
}

.flex-stretch {
	align-items: stretch !important;
}

/* Blog featured image contain */

.gb-container[style*="2023-logo"] {
	background-size: contain !important;
}

/* hover bug where containers hover state is above sticky menu */

.adjust-hover .gb-container-link {
	z-index: 9 !important;
}

body .slideout-navigation.do-overlay .inside-navigation {
	padding-bottom: 60px !important;
}

/* Custom Breakpoint for iPad Landscape */
@media (max-width: 1080px) {

	.gb-container:before {
		background-attachment: initial !important;
	}
	
}

/* Landscape iPad breakpoint */
@media (max-width: 1024px) {

	.separate-containers .inside-article, .separate-containers .comments-area, .separate-containers .page-header, .separate-containers .paging-navigation, .one-container .site-content, .inside-page-header {
	  padding: 20px;
	}

	.alignleft, .alignright, .aligncenter {
		margin-top: 40px;
		margin-bottom: 40px;
	}

	.wp-caption .wp-caption-text {
		padding-right: 20px;
		padding-left: 20px;
	}

	body .slideout-navigation.do-overlay .inside-navigation {
		padding: 20px;
	}
	
	.content-area img.alignleft,
	.content-area img.alignright,
	.content-area img.aligncenter,
	.content-area img.alignnone,
	.alert-box,
	.wp-caption,
	.flex-parent.room-view a.room-block,
	.comment-list .comment .comment-content {
		border-top-right-radius: 20px;
		border-bottom-left-radius: 20px;
	}

	.room-sidebar .avail-button {
		border-bottom-left-radius: 20px;
	}

	body.single-post .inside-right-sidebar {
		padding-left: 0;
	}

	.specials-list .special-card .content,
	.alert-box {
		padding: 20px 20px 0 20px;
	}

	.alert-box {
		margin: 40px auto;
	}

	.room-sidebar,
	body.single-post .inside-right-sidebar .sticky-sidebar {
		top: 20px;
	}

	.specials-list {
		column-gap: 20px;
	}

	.specials-list .special-card {
		margin-top: 40px;
		border-top-right-radius: 40px;
		border-bottom-left-radius: 40px;
	}
	
	.video-wrapper iframe {
		height: 360px;
	}

	.flex-parent.room-view a.room-block {
		width: 47%;
		height: 320px;
	}
	
	.flex-parent.room-view.deluxe-king-rooms a.room-block {
		width: 30%;
		height: 240px;
	}

	.sticky-porthole,
	.sticky-porthole:before {
		background-size: 420px auto !important;
	}
	
	#sticky-navigation.main-navigation.navigation-stick .inside-navigation.grid-container {
		padding: 0 0 0 20px
	}
	
	#sticky-navigation.main-navigation.navigation-stick .menu-bar-item > a {
		padding-left: 20px;
		padding-right: 20px;
	}
	
	
	body #sticky-navigation .book-container a.gb-button.button {
		margin-right: 0;
	}

	.inside-header {
		padding: 10px 20px 10px 20px;
	}
  
	.rooms-nav {
		font-weight: 500;
		padding: 10px;
		border-top-right-radius:30px;
		border-bottom-left-radius:30px;
		text-align: center;
		background: var(--light-gray);
	}
	
	.gb-container-d9938cf7.gb-container-070adfb0 {
		background: var(--contrast);
	}

}

/* Custom breakpoint */
@media (max-width: 959px) {

	body .site-logo.mobile-header-logo img {
		height: 86px;
		padding: 20px 0;
	}

	body .main-navigation.navigation-stick.is_stuck .site-logo.mobile-header-logo img {
		height: 56px;
		padding: 10px 0;
	}  
	
	#mobile-header {
		background: var(--contrast);
	}
  
	body .main-navigation.navigation-stick .inside-navigation.grid-container {
		padding-right: 0px !important;
	}
	
	body .mobile-header-navigation .site-logo {
		margin-left: 20px;
	}
	
	body .main-navigation.navigation-stick .menu-toggle .gp-icon svg {
		fill: #fff;
	}

	.single-room-double-button .gb-container {
		max-width: 100% !important;
		margin: 0 0 20px 0 !important;
	}
	
	.single-room-double-button .gb-container .button {
		width: 100%;
		text-align: center;
	}
	
		
	.video-wrapper iframe {
		height: 300px;
	}
	
	.flex-parent.room-view a.room-block,
	.flex-parent.room-view.deluxe-king-rooms a.room-block {
		width: 47%;
		height: 240px;
	}
	
}

/* Portrait iPad breakpoint */
@media (max-width: 768px) {
	
	.video-wrapper iframe {
		height: 240px;
	}
	
}

/* Generatepress Preset Breakpoints under iPad*/
@media (max-width: 767px) {

	ol, ul {
	  margin: 0 0 1.5em 2em;
	}

	.flex-parent.room-view a.room-block,
	.flex-parent.room-view.deluxe-king-rooms a.room-block {
		width: 100%;
		height: 240px;
		margin: 10px auto;
		max-width: 560px;
	}

	.site-footer .sib-form {
		width: 260px;
		margin: 0 auto !important;
	}
	
	.site-footer .address-line .gb-icon {
		display: none !important;
	}
	
	.site-footer ul.menu {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	
	.site-footer ul.menu li {
		margin: 0;
		text-align: center;
	}
	
	.site-footer ul.menu li a {
		padding: 10px;
		display: inline-block;
		margin: 0 10px;
	}
	
	.specials-list {
		column-count: 1;
	}

    .single-room .gallery-item{
        max-width: 50%;
    }

	.sticky-porthole {
		position: relative !important;
	}
	
}


/**
 * MODERN ANIMATION EFFECTS FOR GP
 */
 
 /* Sub-menu effect */
.main-navigation ul ul {
	left: auto;
	transition: opacity 300ms ease-in-out, transform 200ms ease-in-out, height 200ms ease-in-out;
	transform: translateY(20px);
	height: auto;
}

.main-navigation:not(.toggled) ul li:hover>ul, .main-navigation:not(.toggled) ul li.sfHover>ul {
	transform: translateY(0);
}

.slideout-navigation.do-overlay .slideout-menu .sub-menu li a {
	display: block;
}


.secondary-navigation.toggled .main-nav > ul {
	max-height: 1000px;
	animation: navFadeInDown 500ms ease-in-out both;
	transition: opacity 500ms ease-in-out;
	opacity: 1;
	pointer-events: auto;
	transition-delay: 0;
}
    
@keyframes navFadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, -20%, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}