/*
    Theme Name: Sperling Starter
    Theme URI: https://www.sperlinginteractive.com
    Description: Sperling Interactive WordPress Starter Theme
    Version: 1.0
    Author: Sperling Interactive
  Theme URI: https://www.sperlinginteractive.com
*/
/*------------------------------------*\
    
\*------------------------------------*/
/* global box-sizing */

*,
*:after,
*:before {
    box-sizing: border-box;
    font-smoothing: antialiased;
	-webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}


:root{
	--lightgray: #F2F2F2;
	--yellow: #F5B400;
	--purple: #6E3CBE;
	--red: #F06400;
	--lightblue: #0A9BCD;
	--green: #F06400;
}

/* html element 62.5% font-size for REM use */
html {
    font-size: 62.5%;
    scroll-behavior: smooth;
}

/* clear */
.clear:before,
.clear:after {
    content: ' ';
    display: table;
}

.clear:after {
    clear: both;
}

.clear {
    *zoom: 1;
}

img {
    max-width: 100%;
    vertical-align: bottom;
    height: auto;
}

Kyocers.maincolor{
	color:#832D91;
}
.tooltip{
    display: inline;
    position: relative;
}
.tooltip:hover:after{
    background: #333;
    background: rgba(0,0,0,.8);
    border-radius: 5px;
    bottom: -26px;
    color: #f2f2f2;
    content: attr(title);
    left: 10%;
    padding: 5px 25px;
    position: absolute;
    z-index: 98;
    width: 110px;

}
.comingsoon{
font-weight: bold;
font-size: 1.09em;
color:#2F4291;
}
.comingsoon:hover{
cursor:pointer;

}

/*.tooltip:hover:before{
    border: solid;
    border-color: #333 transparent;
    border-width: 6px 6px 0 6px;
    bottom: 20px;
    content: "";
    left: 50%;
    position: absolute;
    z-index: 99;
}*/
.maincolorbg{
	background-color: var(--yellow);
	/* background-color: #fbb900; */
}
/*this should be a dark color*/

.secondcolor{
	color:#282828;
}

.secondcolorbg{
	background-color:#282828;
}
/*this should be a dark color*/

.thirdcolor{
	color:#FCEFC7;
}

.thirdcolorbg{
	/* background-color:#ececec; */
	background-color: var(--lightgray);
	border-radius: 10px;
}
/*this should be a very light color*/

.fourthcolor{
	color:var(--red);
}

.fourthcolorbg{
	background-color:var(--red);
}

.fifthcolorbg{
	background-color: var(--yellow);
}

.whitebg{
	background-color:white;
}

.red{
	color:red;
}

.lightblue{
	color: var(--lightblue);
}

.centered {
	text-align: center;
}

.text-right {
	text-align: right;
}

.img-center {
	text-align: center;
	margin: 0 auto;
}
.center {
	text-align: center;
}

.error{
	color:red;
	font-weight:bold;
	font-size:14px;
	padding:5px 0 5px 0;
	margin:0;
}

.success{
	font-weight:bold;
	font-size:14px;
	padding:5px 0 5px 0;
	margin:0;
}

.bigger{
	font-size:16px;
	margin-bottom:0;
}

.evenbigger{
	font-size:24px;

}

.subheading{
	font-size:20px;
}

.homeheading{
	font-size:32px;
	padding:0;
	margin: 2rem 0;
}


.reservationFormHeading {
	display: none;
}

.formheading{
	font-size:20px;
	margin:40px 0 0 0;
	padding:0;
}

h1, h2, h3, h4 {
	font-weight:normal;
	margin:0 0 15px 0;
	padding:0;
	color: var(--purple);
	font-weight: 600;
}

h1 {
    font-size: 3.6rem;
}

h2 {
    font-size: 3.2rem;
}

h3 {
    font-size: 2.8rem;
}

h4 {
    font-size: 2.4rem;
}

h5 {
    font-size: 2.0rem;
}

h6 {
    font-size: 1.6rem;
}

.strong {
	font-weight: 600;
}

.imgborder img{
	border:1px solid white;
}

a {
	text-decoration:none;
	color: var(--purple);
	font-weight:bold;
	opacity: 1;;
	transition: .4s ease;
}

/* a:link, a:visited {
	text-decoration:none;
	color: var(--purple);
	font-weight:bold;
	opacity: 1;;
} */
a:hover:not(.logo-img), 
a:active, 
a:visited {
	opacity: .6;
}



p, 
ul,
ol {
	font-size: 14px;
	padding:0;
	margin:0 0 15px 0;
	line-height: 1.4;
}

li{
	font-size:13px;
	padding:0;
	margin:0 0 10px 0;
}



body {
	margin:0;
	text-align: center;
	color:#282828;
	/* font-family:century gothic, verdana, arial, sans-serif; */
	font-family: verdana, sans-serif;
	padding: 0 1rem;

}

#wrapper {
	max-width: 960px;
    width:100%;
	margin: 3rem auto;
    text-align:left;
	position:relative;
	background-color:#f2f2f2;
	padding: 2rem 0;
	border-radius: 10px;
	box-shadow: 0px 3px 6px rgba(0,0,0,0.20);
	overflow: hidden;
}

#topborder{
	margin-left: auto;
    margin-right: auto;
    margin-top:10px;
    width:960px;
    height:26px;
    text-align:left;
	position:relative;
	top:5px;
}

#topborder img{
	padding:0;
	margin:0;
}

#bottomborder{
	margin-left: auto;
    margin-right: auto;
    width:960px;
    text-align:left;
	position:relative;
	margin-bottom:10px;
}

#header {
	width: 100%;
	position:relative;
}

#logo{
	position:relate;
}

/* #logo img{
	width: 220px;
} */

#starburst {
	position: absolute;
	bottom: 100px;
	right: 20px;
}


.sub-header {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	padding: 1rem 2rem;
	flex-wrap: wrap;
}


#date p{
	margin:0;
	padding:0;
	line-height:22px;
	font-weight:bold;
	text-transform:uppercase;
	/* font-family: 'Source Sans Pro', sans-serif; */
}

.date {
	font-size: 2.4rem;
	font-weight: bold;
}

#main {
	display: flex;
    flex-direction: column;
    margin: 0 auto;
    /* min-height: 100vh; */
    position: relative;
    width: 100%;
    max-width: 2560px;
}

.container {
    max-width:960px; 
    align-self: center;
    flex: 1 auto;
    margin: 0 auto;
    width: 100%;
    /* height: 100%; */
    padding: 0 20px;
}

.reverse-row {
	flex-direction: row-reverse;
}

.flexed-row {
	display: flex;
	flex-direction: column;

}

.desktop {
	display: none;
}

.tablet {
	display: block;
}

.menu-container{
	text-align: right;
	padding: 0 2rem;
}


#toggle-menu {
	cursor: pointer;
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: center;
	min-height: 21px;
	opacity: 1 !important;
}

#toggle-menu .bar {
	transition: .4s ease;
}


#toggle-menu .bar:nth-of-type(2) {
	background-color: #282828;
    height: 3px;
    width: 28px;
    position: relative;
    display: block;
}

#toggle-menu.active .bar:nth-of-type(1) {
	transform: rotate(45deg) translate3d(0,0.5rem,0)
}

#toggle-menu.active .bar:nth-of-type(2) {
	opacity: 0;
	visibility: hidden;
}

#toggle-menu.active .bar:nth-of-type(3) {
	transform: translate3d(-.3rem,-1.3rem,0) rotate(-45deg)
}

#toggle-menu .bar:nth-of-type(1) {
	content: '';
	background-color: #282828;
    height: 3px;
    width: 28px;
    position: relative;
    display: block;
	top: -5px;
}

#toggle-menu .bar:nth-of-type(3) {
	content: '';
	background-color: #282828;
    height: 3px;
    width: 28px;
    position: relative;
    display: block;
	top: 5px;
}

#toggle-menu i {
	font-size: 2rem;
}
 

#maincontent{
	position:relative;
}

.mobile-wrapper {
	position: absolute;
    z-index: 2;
    background: #f2f2f2;
    right: 0;
    top: 16%;
	box-shadow: 0px 6px 6px rgba(0,0,0,.25);
	transition: .4s ease;
	transform: translateX(100%);
	display: block;
	opacity: 1;
	visibility: visible;
}

.mobile-wrapper.active{
	transform: translateX(0);
}

.mobile-wrapper ul {
	list-style-type: none;
	padding: 0;
	margin: 0
}

.mobile-wrapper ul li {
	margin: 0;
}

.mobile-wrapper ul li a {
	padding: 1.5rem 2rem;
	border-bottom: 1px solid var(--purple);
	width: 100%;
	display: inline-block;
	transition: .4s ease;
	opacity: 1 !important;
}

.mobile-wrapper ul li a:hover {
	background-color: var(--purple);
	color: #fff;
}

.mobile-wrapper ul li:last-of-type  a{
	border-bottom: none;
}

table tr td{
	vertical-align:top;
	padding-bottom: 1rem;
}

.border{
	position:relative;
	padding:0;
	margin:0;
	width:960px;
	height:10px;
}
#makeMeScrollable
		{
			width:100%;
			height: 100%;
			position: relative;
			
		}
		
		#makeMeScrollable div.scrollableArea img
		{
			position: relative;
			float: left;
			margin: 0 2px 0 0;
			padding: 0;
			/* If you don't want the images in the scroller to be selectable, try the following
			   block of code. It's just a nice feature that prevent the images from
			   accidentally becoming selected/inverted when the user interacts with the scroller. */
			-webkit-user-select: none;
			-khtml-user-select: none;
			-moz-user-select: none;
			-o-user-select: none;
			-user-select: none;
		}

#promo{
	position:relative;
	height:330px;
}

#promo:before {
	content: '';
	/* background-image: url('images/gradienttop2.png'); */
	/* background-position: center; */
	width: 100%;
	height: 30%;
	top: 0;
	left: 0;
	/* background-size: cover; */
	background: linear-gradient(to bottom, rgba(242, 242, 242, 1), transparent);
	position: absolute;
	z-index: 1;
}

#promo:after {
	content: '';
	width: 100%;
	height: 30%;
	bottom: 0;
	left: 0;
	position: absolute;
	z-index: 1;
	background: linear-gradient(to top, rgba(242, 242, 242, 1), transparent);

}

#gradient{
	position:absolute;
	bottom:-3px;
	left:0;
	height:100px;
}

#gradienttop{
	position:absolute;
	top:-2px;
	left:0;
	height:100px;
}


#intro{
	position:relative;
	left:0;
	top:0;
	padding: 0 0 2rem;
	border-radius: 10px;
}

#insideintro{
	position:relative;
	top:0;
}

/* #mainbottom{
	width:600px;
	position:relative;
	top:-25px;
	height:25px;
	padding:0;
	margin:0;
} */


.insidebox{
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;
	position:relative;
	padding:20px;
	margin:10px;
}

#half{
	position:relative;
	left:0;
	width:450px;
	top:0;
}


#halftwo{
	position:relative;
	left:20px;
	width:450px;
	top:0;
}

#insidehalf{
	position:relative;
	padding:2rem;
	top:0;
	border-radius: 10px;
	
}
.sj-img-wrapper {
	width: 100%;
	margin: 0 auto;
	text-align: center;
}
img.sj {
	width: 345px;
	margin: 0 auto;
}
#halfbottom{
	width:450px;
	position:relative;
	top:-25px;
	height:25px;
	padding:0;
	margin:0;
}

#halfbottomtwo{
	width:450px;
	position:relative;
	top:-25px;
	height:25px;
	padding:0;
	margin:0;
	left:20px;
}

.sidebar{
	position:relative;
	color:black;
	/* padding: 2rem; */
	/* margin-bottom: 2rem; */
	border-radius: 10px;
}

.sidebarinside {
	position:relative;
	padding:0 0 23px 0;
}

.sideheading{
	text-align:center;
	font-size:20px;
	padding:0;
	margin:0 0 10px 0;
}
	

.sidebottom{
	width:300px;
	position:relative;
	top:-23px;
	height:23px;
	margin:0;
	padding:0;
	left:20px;

}


#itinerary .whiterow{
	background-color:white;
}

#stateroompics img{
	margin:0 0 10px 0;
}


.floatleft{
	float:left;
	margin:0 10px 10px 0;
}

.floatright{
	float:right;
	margin:0 0 10px 10px;
}

.floatright img, .floatleft img{
	border:1px solid #5763B9;
}

.floatleft.max-width-image {
	max-width: 250px;
}

footer {
	padding-bottom: 2rem;
}

#footer {
	color:white;
}

#footer p{
	font-size:11px;
}

#footer a:link, #footer a:visited {
	text-decoration:none;
	color:white;
}

#footer a:hover, #footer :active {
	color:#047777;
}

/* CONTACT */

#contact a:link, #contact a:visited {
	text-decoration:none;
	color:white;
}

#contact {
	position:relative;
	top:0;
	left:0;
	padding-bottom:0;
	font-size:12px;
}

#contact p {
	margin-left:0px;
}

#contact ul li {
	list-style-type:none;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

#contact ul {
	margin: 0; padding: 0;
    left:0;
}


fieldset {
	border:0;
	margin:0;
	padding:0;
}

label {  
	text-align:left;
	font-size:12px;
	font-weight: 600;
	margin-bottom: 5px;
}

.formstyle {
	background-color:white;
	border-color:black;
	border-width:1px;
	border-style:solid;
	margin-bottom:10px;
	font-size:13px;
	/* font-family:century gothic, tahoma, verdana, sans-serif; */
	width: 100%;
	min-height: 30px;
}

.fulltext {
	background-color:white;
	border-color:black;
	border-width:1px;
	border-style:solid;
	height:150px;
	font-size:13px;
	/* font-family:century gothic, tahoma, verdana, sans-serif; */
	width: 100%;
}

.submitbutton, 
.button {
	border-style:solid;
	border-color:white;
	border-width:1px;
	margin: 1rem 0;
	color:white;
	background-color: var(--yellow);
	padding: 1rem 3rem;
	display: inline-block;
	transition: .4s ease;
	box-shadow: 0px 3px 6px rgba(0,0,0, 0.29);
	cursor: pointer;
	font-size: 1.6rem;
	text-transform: uppercase;
}

.submitbutton:hover {
	background-color: #f2f2f2;
	color: #000;

}

.formmessage {
	color:black;
	position:relative;
	top:-35px;
	float:right;
	margin:0; padding:0;
}

.redtext {
	color:red;
	position:relative;
	top:-35px;
	float:right;
	margin:0; padding:0;
}

.bluetext {
	position:relative;
	top:-35px;
	float:right;
	margin:0; padding:0;
	color:blue;
}

/*NAVIGATION*/




#navcontainer {
	width:100%;
	left:0;
	z-index: 120;
	position:relative;
	padding: 1rem 0 2rem;
}

#nav {
	/* position:absolute;
	padding:0;
	text-align:right;
	top:0;
	right:10px; */
	padding: 0 2rem;
}

#nav ul{
	margin: 0; padding: 0;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}
        
#nav ul li{
	display:inline;
	list-style-type:none;
}


#navlist
{	margin: 0;
	padding: 0;}

#navlist li
{	margin: 0;
	padding: 0 5px 0 5px;
	list-style: none;
	float: left;
	}

#navlist li a
{	display: block;
	margin: 0 5px 0 0;
	padding: 0;
	color: #000000;
	text-align: center;
	text-decoration: none;

	font-size:14px;
	}

#navlist li a:hover
{		color:#fbb900;}

#navlist div
{	position: absolute;
	visibility: hidden;
	margin: 0;
	padding: 0;
	background: #FFFFFF;
	width:250px;
	border:1px solid #fbb900;
	z-index: 121;
	color:#000000;
	}

	#navlist div a
	{	position: relative;
		display: block;
		margin: 0;
		padding: 5px 10px;
		width: auto;
		white-space: nowrap;
		text-align: left;
		text-decoration: none;
		background: #FFFFFF;
		color: #fbb900;
		font-size:12px;
		}

	#navlist div a:hover
	{	background: #fbb900;
		color: white;}

#relative{
	position:relative;
}






.leftform{
	position:relative;
	padding:10px 10px 15px 10px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	border-radius: 15px;
	margin:0;
}


.rightform{
	position:relative;
	padding:10px 10px 15px 10px;
	-moz-border-radius: 15px;
	-webkit-border-radius: 15px;
	border-radius: 15px;
}

.leftform label, .leftform .formheading {
	color:#f2f2f2;
}

.rightform .formheading, .leftform .formheading{
	margin-top:0;
}

.rightform .formheading,
.rightform label {
	color: #282828;
}

.third{
	width:110px;
	margin-right:4px;
}

.thirdtwo{
	width:144px;
	margin-right:5px;
}

.thirdthree{
	width:140px;
}

.twothirds{
	width:297px;
}

.half{
	width:205px;
	margin-right:5px;
}

.halftwo{
	width:218px;
	margin-right:10px;
}

.fourth{
	width:109px;
	margin-right:5px;
}

.full{
	width:100%;
}

.tiny{
	width:30px;
}

.smaller{
	width:60px;
}

.small{
	width:90px;
}

.newtripuser label{
	font-size:13px;
}

.newtripuser input[type="text"],
.newtripuser select {
	width: 100%;
	min-height: 30px;
}

.newtripuser table {
	width: 100%;
}

#radiobuttons input{
	padding:0;
	margin:2px 0 0 0;
}

input, textarea, select{
	/* font-family:century gothic, tahoma, verdana, sans-serif; */
	font-size:13px;
}

.newtripuser #doSubmit{
	background:#832D91;
	box-shadow: 0px 3px 6px rgba(0,0,0,0.20);
	color:#f2f2f2;
	transition: .4s ease;
	font-size: 2rem;
	padding: 1.5rem 4rem;
	border: none;
	cursor: pointer;
}

.newtripuser #doSubmit:hover{
	color:#832D91;
	background-color: #fff;
}

ol{
	margin:0 0 15px 20px;
	padding:0;
}

ol li{
	margin:0;
	padding:0 0 0 0;
}


.caption{
	font-size:10px;
	margin:5px 0 0 0;
	text-align:center;
}

.golfhandicap {
	width:30px;
}

.topform{
	margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.topform li{
	display: flex;
	flex-direction: column;
	list-style: none;
}

.topform li input:not(type="checkbox"){
	margin-right:10px;
	min-height: 30px;
}

.yellow{
	padding:10px;
	background:yellow;
	color:black;
	font-size:20px;
	float:right;
	border:1px solid black;
}

.yellow:hover, .yellow:active{
	background:#FFDD00;
}



/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/
@media only screen and (min-width:320px) {}

@media only screen and (min-width:480px) {}

@media only screen and (min-width:769px) {}

@media only screen and (min-width:1024px) {
	.desktop {
		display: block;
	}

	.tablet {
		display: none;
	}

	.mobile-wrapper {	
		display: none;
		opacity: 0;
		visibility: hidden;
	}
}

@media only screen and (min-width:1140px) {}

@media only screen and (min-width:1280px) {}