/* font imports -------------------------------------------------------------------------------------------------------------------------------------------------------- */

@import url('https://fonts.googleapis.com/css?family=Playfair+Display:400,700');
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@400;700&display=swap');

/* end font imports ----------------------------------------------------------------------------------------------------------------------------------------------------- */


/* cross browser default styles ----------------------------------------------------------------------------------------------------------------------------------------- */

*{
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	-o-font-smoothing: antialiased;
	font-smoothing: antialiased;
}

img{
	border: 0px;
}

a{
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
	-ms-transition: all 300ms ease;
	-o-transition: all 300ms ease;
	transition: all 300ms ease;
}

body{
	-webkit-text-size-adjust: 100%;
	min-width: 220px;
	margin: 0px;
	padding: 0px;
	font-family: 'Raleway', sans-serif;
}

[tabindex="-1"]:focus:not(:focus-visible){
	outline: 0 !important;
}

/* end cross browser default styles ------------------------------------------------------------------------------------------------------------------------------------- */


/* main container, padding styles --------------------------------------------------------------------------------------------------------------------------------------- */

.clear-rows{
	clear: both;
}

.container{
	max-width: 1280px;
	width: 100%;
	margin: 0px auto;
	padding: 0px 20px;
	box-sizing: border-box;
}

.col-70{
	width: 70%;
	float: left;
}

.col-50{
	float: left;
	width: 50%;
}

.col-50-margin-top{
	margin: 0px 0px px 0px;
}

.col-50-margin-bottom{
	margin: 0px 0px 20px 0px;
}

.col-50-inner{
	padding: 0px 10px;
}

.col-50-inner-right{
	padding: 0px 10px 0px 0px;
}

.col-50-inner-left{
	padding: 0px 0px 0px 10px;
}

.col-50-padding{
	padding: 0px 0px 10px 10px;
}

.col-30{
	width: 30%;
	float: right;
}

.col-30-padding{
	padding: 0px 0px 0px 20px;
}

.align-left{
	text-align: left;
	margin: 0px auto 0px 0px;
}

.align-right{
	text-align: right;
	margin: 0px 0px 0px auto;
}

.flex-row{
	display: flex;
}

.flex-justify-content-space-between{
	justify-content: space-between;
}

.flex-align-items-center{
	align-items: center;
}

.grid{
	display: grid;
}

.grid-cols-4{
	grid-template-columns: repeat(4,1fr);
}

.grid-gap-50{
	grid-gap: 50px;
}

/* end main container, padding styles ----------------------------------------------------------------------------------------------------------------------------------- */

/* cookie styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#header-notice{
	position: fixed;
	bottom: 0px;
	left: 0px;
	right: 0px;
	margin: 0px;
	padding: 10px 20px;
	background-color: rgba(220,237,200,0.8);
	box-sizing: border-box;
	z-index: 999;
}

#header-notice p{
	font-size: 14px;
	font-weight: normal;
	color: #2a2b2e;
	line-height: 18px;
	margin: 0px;
	padding: 0px 20px 0px 0px;
}

#header-notice strong{
	color: #339DB9;
	font-weight: bold;
}

/* end cookie styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#header{
	width: 100%;
	margin: 0px;
	padding: 25px 0px;
	background-color: #20364d;
	box-shadow: 0px 2px 10px 0px rgba(0,0,0,0.2);
}

.header-left{
	text-align: left;
	padding: 0px 0px 0px 0px;
	flex: 1 1;
}

.header-left img{
	width: 100%;
	max-width: 250px;
}

.header-middle{
	text-align: right;
	padding: 0px 0px 0px 0px;
}

.header-middle ul{
	display: inline-block;
	list-style-type: none;
	margin: 0px;
	padding: 0px 20px 0px 0px;
}

.header-middle ul li{
	display: inline-block;
	margin: 0px 0px 0px 20px;
	position: relative;
	cursor: pointer;
}

.header-middle ul li:hover > ul{
	display: block;
}

.header-middle ul li a{
	display: flex;
	font-size: 16px;
	color: #fff;
	font-weight: 400;
	text-decoration: none;
	padding: 0px 0px;
	line-height: 50px;
	align-items: center;
}

.header-middle ul li a i{
	font-size: 12px;
	color: #fff;
	padding: 0px 0px 0px 5px;
}

.header-middle ul ul{
	position: absolute;
	top: 100%;
	left: -15px;
	width: 250px;
	background-color: #fff;
	box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.2);
	z-index: 999;
	display: none;
	padding: 10px 0px;
}

.header-middle ul ul li{
	width: 100%;
	text-align: left;
	margin: 0px;
}

.header-middle ul ul li a{
	padding: 10px 20px;
	color: #20364d;
	line-height: normal;
}

.header-right{
	text-align: right;
	padding: 0px 0px 0px 0px;
}

.header-right ul{
	display: inline-block;
	list-style-type: none;
	margin: 0px;
	padding: 0px 0px 0px 0px;
}

.header-right ul li{
	display: inline-block;
	margin: 0px 0px 0px 5px;
}

.header-right ul li a{
	display: flex;
	font-size: 16px;
	background-color: #fff;
	color: #20364d;
	font-weight: 600;
	text-decoration: none;
	padding: 0px 20px;
	line-height: 40px;
	border-radius: 30px;
	align-items: center;
}

.header-right ul li a i{
	font-size: 16px;
	color: #20364d;
	padding: 0px 8px 0px 0px;
	line-height: 40px;
}

#footer-top{
	width: 100%;
	margin: 0px;
	padding: 50px 0px;
	background-color: #20364d;
}

#footer-top h3{
	font-size: 22px;
	font-weight: 600;
	color: #fff;
	margin: 0px;
	padding: 0px 0px 30px 0px;
}

#footer-top p{
	font-size: 14px;
	font-weight: 400;
	color: #fff;
	margin: 0px;
	padding: 0px 0px 10px 0px;
	line-height: 22px;
}

#footer-top p a{
	text-decoration: none;
	color: #fff;
}

#footer-top .links{
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

#footer-top .links li{
	width: 100%;
}

#footer-top .links li a{
	display: block;
	font-size: 14px;
	font-weight: 400;
	color: #fff;
	line-height: 22px;
	padding: 0px 0px 5px 0px;
}

#footer-top .social{
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

#footer-top .social li{
	display: inline-block;
	margin: 0px 5px 0px 0px;
}

#footer-top .social li a{
	display: block;
	color: #fff;
	width: 40px;
	height: 40px;
	background-color: #fff;
	border-radius: 50%;
	text-align: center;
}

#footer-top .social li a i{
	line-height: 40px;
	color: #2a2f36;
}

#footer-bottom{
	width: 100%;
	margin: 0px;
	padding: 30px 0px;
	background-color: #20364d;
	border-top: 1px solid #8c98a5;
	text-align: center;
}

#footer-bottom p{
	font-size: 14px;
	font-weight: 400;
	color: #fff;
	margin: 0px;
	padding: 0px 0px 0px 0px;
	line-height: 22px;
}

/* mobile styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

.header-mobile{
	flex: 0 0 150px;
	text-align: left;
	display: none;
}

.header-mobile ul{
	display: inline-block;
	list-style-type: none;
	margin: 0px;
	padding: 0px 0px 0px 0px;
}

.header-mobile ul li{
	display: inline-block;
	margin: 0px 0px 0px 0px;
	cursor: pointer;
}

.header-mobile ul li a{
	display: flex;
	font-size: 16px;
	background-color: #fff;
	color: #20364d;
	font-weight: 600;
	text-decoration: none;
	padding: 0px 0px;
	border-radius: 30px;
	width: 40px;
	height: 40px;
	justify-content: center;
	align-items: center;
}

.header-mobile ul li a i{
	font-size: 16px;
	color: #20364d;
	padding: 0px 0px 0px 0px;
	line-height: 40px;
}

#mobile-navigation{
	width: 100%;
	display: none;
	background-color: #f1f1f1;
	padding: 15px 0px;
}

#mobile-navigation ul{
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

#mobile-navigation ul li{
	width: 100%;
	padding: 5px 20px;
	box-sizing: border-box;
	position: relative;
}

#mobile-navigation ul li a{
	display: block;
	padding: 10px 5px;
	font-size: 16px;
	color: #333;
	text-decoration:  none;
}

#mobile-navigation ul li a i{
	position: absolute;
	top: 15px;
	right: 20px;
	font-size: 16px;
	color: #333;
}

#mobile-navigation ul li a.book{
	background-color: #20364d;
	border-radius: 30px;
	text-align: center;
	font-weight: 600;
	color: #fff;
	text-decoration: none;
}

#mobile-navigation ul ul{
	display: none;
}

#loading{
	position: fixed;
	z-index: 999;
	top: 50%;
	left: 50%;
	display: none;
	background-color: #fff;
	transform: translate(-50%,-50%);
	box-sizing: border-box;
	padding: 15px 20px;
	text-align: center;
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.2);
	max-width: 300px;
}

#loading h3{
	font-family: 'Playfair Display', serif;
	text-align: center;
	padding: 0px 0px 10px 0px;
	margin: 0px;
	font-size: 22px;
	font-weight: 700;
	color: #323232;
}

#loading p{
	text-align: center;
	padding: 0px 0px 0px 0px;
	margin: 0px;
	font-size: 14px;
	font-weight: 400;
	color: #323232;
	line-height: 22px;
}

/* end mobile styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#fixed-buttons{
	position: fixed;
	right: 0px;
	top: 15%; z-index: 999;
	transform: rotate(-90deg);
	transform-origin: 100% 100%;
}

#header-shop-now{
	cursor: pointer;
	position: fixed;
	right: 0px;
	top: 15%; z-index: 999;
	transform: rotate(-90deg);
	background-color: #0c354b;
	transform-origin: 100% 100%;
	padding: 7px 20px;
	border-radius: 15px 15px 0px 0px;
	font-size: 16px;
	color: #fff;
	-webkit-box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
	box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
	-webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

#header-book-now{
	cursor: pointer;
	position: fixed;
	right: 0px;
	top: 15%;
	z-index: 999;
	transform: rotate(-90deg);
	background-color: #0c354b;
	transform-origin: 100% 100%;
	padding: 7px 20px;
	margin-top: 80px;
	border-radius: 15px 15px 0px 0px;
	font-size: 16px;
	color: #fff;
	-webkit-box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
	box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
	-webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* end header styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

/* banner styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#banner{
	width: 100%;
	margin: 0px 0px 0px 0px;
	box-shadow: 0px 4px 4px -2px rgba(0,0,0,0.2);
	position: relative;
}

.owl-carousel-inner{
	width: 100%;
	max-width: 600px;
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
}

.owl-carousel h2{
	font-family: 'Playfair Display', serif;
	font-weight: 700;
	font-size: 72px;
	margin: 0px;
	padding: 0px 0px 20px 0px;
	color: #323232;
}

.owl-carousel p{
	font-weight: 400;
	font-size: 16px;
	margin: 0px;
	padding: 0px 0px 20px 0px;
	line-height: 28px;
	color: #666666;
}

.owl-carousel-image{
	height: 700px;
	width: 100%;
	position: relative;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

/* end banner styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

/* homepage styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#homepage{
	width: 100%;
	margin: 0px;
	padding: 0px 0px;
}

#homepage-navigation{
	width: 100%;
	margin: 0px;
	padding: 0px;
	background-color: #E4E4E4;
	box-shadow: 0px 4px 4px -2px rgba(0,0,0,0.2);
}

#homepage-navigation ul{
	list-style-type: none;
	margin: 0px;
	padding: 0px;
	display: table;
	width: 100%;
}

#homepage-navigation ul li{
	vertical-align: middle;
    display: table-cell;
    text-align: center;
    border-right: 1px solid #D9D9D9;
}

#homepage-navigation ul li:first-child{
	border-left: 1px solid #D9D9D9;
}

#homepage-navigation ul li a{
	display: block;
	padding: 10px 0px;
	text-decoration: none;
	font-size: 14px;
	color: #3A3A3A;
	text-transform: uppercase;
	font-weight: normal;
}

#homepage-navigation ul li a:hover{
	background-color: #383838;
	color: #fff;
}

/* homepage styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

/* products styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

.product-col-20{
	width: 20%;
	float: left;
}

.product-col-25{
	width: 25%;
	float: left;
}

.product-col-33{
	width: 33.3333%;
	float: left;
}

.product-col-40{
	width: 40%;
	float: left;
}

.product-col-50{
	width: 50%;
	float: left;
}

.product-col-60{
	width: 60%;
	float: left;
}


.product-col-padding-left{
	padding-left: 40px;
	box-sizing: border-box;
}

.product-col-outer{
	padding: 10px 10px 10px 10px;
	position: relative;
}

.product-col-inner{
	width: 100%;
}

.product-offer{
	position: absolute;
	top: 5px;
	right: 5px;
	width: 60px;
	height: 50px;
	border-radius: 40px;
	background-color: #F09226;
	border: 1px solid #fff;
	text-align: center;
	padding: 10px 0px 0px 0px;
}

.product-offer h3{
	color: #fff;
	font-size: 16px;
	margin: 0px;
	padding: 0px;
}

.product-col-grey{
	background-color: #fff;
}

.product-col-grey:hover{
	/*box-shadow: 0px 0px 8px 2px rgba(0,0,0,0.1);*/
}

.product-col-white{
	background-color: #fff;
}

.product-col-white:hover{
	/*box-shadow: 0px 0px 8px 2px rgba(100,100,100,0.1);*/
}

.product-col-inner-padding{
	padding: 10px 10px;
	border: 1px solid #eee;
}

.product-col-inner-image{
	width: 100%;
	height: 220px;
	background-color: #fff;
	cursor: pointer;
	box-sizing: border-box;
	padding: 0px 0px;
	/*padding: 15px 20px;*/
	text-align: center;
	background-position: center center;
    background-size: contain;
    background-repeat: no-repeat;
}

.product-col-inner-body{
	width: 100%;
	text-align: center;
	padding: 10px 0px 10px 0px;
	background-color: #fff;
}

.product-col-inner-body-title, .product-col-inner-body-category{
    overflow: hidden;
    display: block;
    display: -webkit-box;
    text-overflow: ellipsis;
    height: 25px;
    line-height: 1;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

.product-col-inner-body a{
	font-size: 14px;
	font-weight: normal;
	color: #0c354b;
	margin: 0px;
	padding: 0px 0px 0px 0px;
	text-decoration: none;
	line-height: 22px;
	font-weight: 600;
}

.product-col-inner-body p{
	font-size: 14px;
	font-weight: normal;
	color: #2a2b2e;
	margin: 0px;
	padding: 0px 0px 0px 0px;
	text-decoration: none;
	line-height: 22px;
	font-weight: 600;
}

.product-col-inner-body p{
	font-weight: normal;
}

.product-col-inner-body a:hover{
	color: #0F4B4F;
}

.product-col-inner-body h4{
	font-size: 14px;
	font-weight: normal;
	color: #CC3300;
	margin: 0px;
	padding: 0px 0px 0px 0px;
	text-decoration: none;
	line-height: 22px;
	font-weight: 600;
}

/* end products styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

/* product option styles */

.product-options-outer-box{
	width: 100%;
	border: 1px solid #c0c0c0;
	border-radius: 3px;
	background-color: #fff;
	position: relative;
	height: 32px;
	background-image: url('../images/arrow.jpg');
	background-position: right top;
	background-repeat: no-repeat;
	cursor: pointer;
}

.product-options-inner-box{
	right: -1px;
	border: 1px solid #c0c0c0;
	border-radius: 3px;
	display: none;
	position: absolute;
	left: -1px;
	top: 32px;
	background-color: #fff;
	z-index: 6;
}

.product-option-sub-options{
	width: 100%;
	line-height: 32px;
	font-size: 13px;
	color: #333333;
	text-align: left;
}

.product-option-sub-options tr:hover{
	background-color: #1E90FF;
	color: #fff;
}

.product-options-outer-box-table{
	width: 100%;
	line-height: 32px;
	font-size: 13px;
	color: #333333;
}

/* main body styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#main-body-white{
	width: 100%;
	padding: 50px 0px;
}

#main-body-white h2{
	font-family: 'Playfair Display', serif;
	text-align: center;
	padding: 0px 0px 10px 0px;
	margin: 0px;
	font-size: 30px;
	font-weight: 700;
	color: #323232;
}

#main-body-grey{
	width: 100%;
	padding: 50px 0px;
	background-color: #f8f8f8;
}

#main-body-grey h2{
	font-family: 'Playfair Display', serif;
	text-align: center;
	padding: 0px 0px 10px 0px;
	margin: 0px;
	font-size: 30px;
	font-weight: 700;
	color: #323232;
}

#main-body-left-col{
	float: left;
	width: 25%;
}

#main-body-left-col-inner{
	padding: 0px 20px 0px 0px;
}

#main-body-right-col{
	float: left;
	width: 75%;
}

.main-body-left{
	overflow-x: hidden;
	margin: 0px;
	padding: 0px;
}

.main-body-left2{
	overflow-x: hidden;
	margin: 0px;
	padding: 0px;
}

.main-body-left-inner{
	padding: 10px 15px;
}

.main-body-right{
	float: right;
	width: 350px;
	margin: 0px 0px 0px 15px;
	padding: 0px;
}

.main-body-right2{
	float: right;
	width: 200px;
	margin: 0px 0px 0px 15px;
	padding: 0px;
}

.main-body-right3{
	float: right;
	width: 350px;
	margin: 0px 0px 0px 40px;
	padding: 0px;
}

.main-body-right-box{
	width: 100%;
	background-color: #f1f1f1;
	margin: 0px 0px 10px 0px;
	overflow: hidden;
	border-radius: 0px;
}

.main-body-right-box-header{
	width: 100%;
	background-color: #666666;
	text-align: center;
}

.main-body-right-box-header h2{
	padding: 10px 0px!important;
	margin: 0px!important;
	color: #fff!important;
	font-size: 18px!important;
	font-weight: 400!important;
	text-shadow: 0px;
}


.main-body-right-box-inner{
	padding: 10px 15px;
}



/* end main body styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

#map {
    width: 100%;
    margin: 0px;
    padding: 0px 0px;
    height: 550px;
}

/* login styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

.login-box{
	width: 100%;
	max-width: 400px;
	margin: 20px auto;
	padding: 0px;
	border: 1px solid #DDDDDD;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.login-header{
	width: 100%;
	padding: 12px 15px;
	box-sizing: border-box;
	border-bottom: 1px solid #DDDDDD;
	background-color: #EEEEEE;
}

.login-header h3{
	color: #000000!important;
	font-size: 14px!important;
	font-weight: 600!important;
	padding: 0px!important;
	margin: 0px!important;
	text-align: left!important;
}

.login-body{
	width: 100%;
	padding: 0px 0px;
}

.login-body table p{
	font-size: 14px;
	color: #000;
	margin: 0px;
	padding: 0px 0px 5px 0px;
	font-weight: 400;
}
.login-body a{
	color: #22A6AC;
	text-decoration: none;
	font-size: 14px;
}

.login-box-inner{
	padding: 15px 15px;
}

/* end login styles ------------------------------------------------------------------------------------------------------------------------------------------------- */


#validation-error-box, #redirect-error-box{
	width: 100%;
	border-radius: 0px;
	border: 1px solid #EA4335;
	margin: 0px 0px 15px 0px;
}

#validation-error-box-header, #redirect-error-box-header{
	width: 100%;
	padding: 8px 15px;
	margin: 0px;
	color: #fff;
	font-size: 14px;
	box-sizing: border-box;
	background-color: #EA4335;
}

#validation-error-box-body, #redirect-error-box-body{
	width: 100%;
	padding: 8px 15px 10px 15px;
	margin: 0px;
	box-sizing: border-box;
}

#validation-error-box-body span, #redirect-error-box-body span{
	color: #000;
	font-size: 14px;
	display: block;
	width: 100%;
}

/* input styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

.input-label-sm p, .input-label-lg p{
	margin: 0px;
	padding: 0px 0px 5px 0px;
	font-size: 14px;
}

.input-group-sm{
	display: table;
	width: 100%;
	margin: 0px 0px 10px 0px;
}

.input-label-sm{
	display: table-cell;
	width: 220px;
	vertical-align: middle;
}

.input-field-sm{
	display: table-cell;
	vertical-align: middle;
}

.input-group-lg{
	width: 100%;
	margin: 0px 0px 10px 0px;
}

.input-label-lg{
	width: 100%;
}

.input-field-lg{
	width: 100%;
}

.input-field-max-400{
	max-width: 400px;
}


.input-box{
	width: 100%;
	cursor: default;
	margin: 0;
	padding: 10px 10px;
	border: 1px solid #b7b7b7;
	-webkit-border-radius: 3px;
	border-radius: 3px;
	color: rgba(100,100,100,1);
	background: rgba(252,252,252,1);
	-webkit-box-shadow: 0px 0px 0px 0 rgba(0,0,0,0.1) inset;
	box-shadow: 0px 0px 0px 0 rgba(0,0,0,0.1) inset;
	/*text-shadow: 1px 1px 0 rgba(255,255,255,0.66) ;*/
	font-family: 'Open Sans', sans-serif;
	font-size: 14px;
}

.button-sm{
	background-color: #22A4AA;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border-radius: 4px;
	border: none;
	display: inline-block;
	cursor: pointer;
	color: #ffffff!important;
	font-family: 'Open Sans', sans-serif;
	font-size: 15px;
	padding: 6px 15px;
	text-decoration: none;
}

.button-green:before{
	content: '\f07a';
    font-family: 'FontAwesome';
    text-shadow: none;
	text-align: center;
    background-color: #333333;
    position: absolute;
    vertical-align: middle;
    top: -1px;
    left: -1px;
    width: 40px;
    bottom: -1px;
    padding: 9px 0px;
    border-radius: 8px 0px 0px 8px;
}

.button-green{
	position: relative;
	background-position: 0% 0%;
	color: white;
    border: 1px solid #9cbd2e;
	letter-spacing: -0.4px;
	border-radius: 8px;
	cursor: pointer;
	font-size: 16px;
	font-family: 'Open Sans', sans-serif;
	font-weight: 500;
	text-shadow: 2px 2px rgba(156,189,46,1);
	padding: 6px 15px 6px 50px;
	background-image: linear-gradient(#b4d34b 0%, #9cbd2e 100%);
	background-color: #9cbd2e;
	background-repeat: repeat;
	background-attachment: scroll;
	display: block;
}

.button-green:hover{
	background-image: linear-gradient(#9cbd2e 0%, #b4d34b 100%);
}

.button-orange:before{
	content: '\f1ec';
    font-family: 'FontAwesome';
    font-size: 18px;
    text-shadow: none;
	text-align: center;
    background-color: #333333;
    position: absolute;
    vertical-align: middle;
    top: -1px;
    left: -1px;
    width: 40px;
    bottom: -1px;
    padding: 9px 0px;
    border-radius: 8px 0px 0px 8px;
}

.button-orange2:before{
	content: '\f291';
	font-size: 18px;
    font-family: 'FontAwesome';
    text-shadow: none;
	text-align: center;
    background-color: #333333;
    position: absolute;
    vertical-align: middle;
    top: -1px;
    left: -1px;
    width: 40px;
    bottom: -1px;
    padding: 9px 0px;
    border-radius: 8px 0px 0px 8px;
}

.button-orange, .button-orange2{
	position: relative;
	background-position: 0% 0%;
	color: white;
   	letter-spacing: -0.4px;
	border-radius: 8px;
	cursor: pointer;
	font-size: 16px;
	font-family: 'Open Sans', sans-serif;
	font-weight: 500;
	text-shadow: 2px 2px rgba(229,128,12,1);
	padding: 6px 15px 6px 50px;
	border: 1px solid #e5800c;
	background-image: linear-gradient(#f49930 0%, #e5800c 100%);
	background-repeat: repeat;
	background-attachment: scroll;
	display: block;
}

.button-orange:hover, .button-orange2:hover{
	background-image: linear-gradient(#e5800c 0%, #f49930 100%);
}


.button-lg{
	position: relative;
	background-color: #22A6AC;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border-radius: 4px;
	border: none;
	display: block;
	width: 100%;
	cursor: pointer;
	color: #ffffff!important;
	font-family: 'Open Sans', sans-serif;
	font-size: 15px;
	padding: 6px 15px;
	text-decoration: none;
	box-sizing: border-box;
	text-align: center;
}

.button-sm:hover, .button-lg:hover{
	background-color: #333333;
}






.btn-blue{
    background: #0c354b;
    color: #fff;
    border: 1px solid #0c354b;
    border-radius: 30px;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
    box-shadow: 0px 0px 20px 0px rgba(229,29,137,0.2);
    display: inline-block;
    padding: 10px 20px;
    font-size: 16px;
    text-decoration: none;
    cursor: pointer;
}

.btn-white{
    background: #ffffff;
    color: #666;
    border: 1px solid #eee;
    border-radius: 30px;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(100,100,100,0.2);
    box-shadow: 0px 0px 20px 0px rgba(100,100,100,0.2);
    display: inline-block;
    padding: 10px 20px;
    font-size: 16px;
    text-decoration: none;
    cursor: pointer;
}


/* end input styles ------------------------------------------------------------------------------------------------------------------------------------------------- */




.category-navigation-box{
	width: 100%;
	margin: 10px 0px 15px 0px;
}

.category-navigation-box-header{
	width: 100%;
	box-sizing: border-box;
	padding: 12px 15px;
	background-color: #2DBBCA;
	border-radius: 6px 6px;
}

.category-navigation-box-header p{
	padding: 0px 0px!important;
	margin: 0px!important;
	color: #fff!important;
	font-size: 14px!important;
	font-weight: 600!important;
	text-shadow: 0px;
}

.category-navigation-box-body{
	width: 100%;
	padding: 15px 0px;
}

.category-navigation-box-body-inner{
	padding: 10px 0px;
}

.category-navigation-box-body i{
	font-size: 12px;
	color: #ccc;
	padding: 0px 5px 0px 0px;
}

.category-navigation-box-body a{
	display: block;
	padding: 5px 0px 5px 0px;
	margin: 0px;
	font-size: 14px;
	text-decoration: none;
	color: #555;
}

.category-navigation-box-body a:hover{
	text-decoration: underline;
}




#product-section{
	width: 100%;
	padding: 50px 0px;
}

#product-section h2{
	font-family: 'Playfair Display', serif;
	text-align: center;
	padding: 0px 0px 30px 0px;
	margin: 0px;
	font-size: 30px;
	font-weight: 700;
	color: #323232;
}

#product-section h3{
	font-family: 'Playfair Display', serif;
	text-align: left;
	padding: 0px 0px 10px 0px;
	margin: 0px;
	font-size: 20px;
	font-weight: 700;
	color: #323232;
}

#product-section p{
	font-size: 16px;
	color: #666666;
	padding: 0px 0px 20px 0px;
	margin: 0px;
	font-weight: 400;
	line-height: 28px;
}

.product-table{
	width: 100%;
	max-width: 300px;
}


.product-table p{
	font-size: 16px;
	color: #666666;
	padding: 0px 0px 0px 0px!important;
	margin: 0px;
	font-weight: 400;
	line-height: 28px;
}

.product-table h2, #product-price{
	font-family: 'Playfair Display', serif;
	text-align: left;
	padding: 0px 0px 10px 0px!important;
	margin: 0px!important;
	font-size: 20px!important;
	font-weight: 700;
	color: #323232;
}

.product-images{
	width: 100%;
	border: 1px solid #f3f3f3;
	padding: 40px;
	box-sizing: border-box;
}










#page-body-white{
	width: 100%;
	padding: 50px 0px;
}

#page-body-white h2{
	font-family: 'Playfair Display', serif;
	text-align: left;
	padding: 0px 0px 20px 0px;
	margin: 0px;
	font-size: 30px;
	font-weight: 700;
	color: #323232;
}

#page-body-white p{
	padding: 0px 0px 0px 0px;
	margin: 0px;
	font-size: 16px;
	font-weight: 400;
	line-height: 28px;
	color: #666666;
}


#contact-form-body-white{
	width: 100%;
	padding: 50px 0px;
}

#contact-form-body-white h2{
	font-family: 'Playfair Display', serif;
	text-align: left;
	padding: 0px 0px 20px 0px;
	margin: 0px;
	font-size: 30px;
	font-weight: 700;
	color: #323232;
}

#contact-form-body-white p{
	padding: 0px 0px 10px 0px;
	margin: 0px;
	font-size: 14px;
	font-weight: 400;
	line-height: 22px;
	color: #666666;
}

#contact-form-body-white a{
	padding: 0px 0px 0px 0px;
	margin: 0px;
	font-size: 14px;
	font-weight: 400;
	line-height: 22px;
	color: #666666;
}

.contact-form-col{
	float: left;
	width: 50%;
	box-sizing: border-box;
}

.contact-form-col-padding-right{
	padding: 0px 10px 0px 0px;
}

.contact-form-col-padding-left{
	padding: 0px 0px 0px 10px;
}


.view-basket-table{
	border-collapse: collapse;
	border: 1px solid #DDDDDD;
}

.view-basket-table tr{
	border-bottom: 1px solid #DDDDDD;
}

.view-basket-table th{
	padding: 12px 10px;
	font-weight: 600;
	font-size: 14px;
	background-color: #EEEEEE;
}

.view-basket-table td{
	padding: 10px 10px;
	font-size: 14px;
	vertical-align: top;
	background-color: #fff;
}

.view-basket-table td p{
	margin: 0px;
	padding: 0px;
}






#error-box{
	 width: 100%;
	 background-color: #EE8C82;
	 border-radius: 0px;
	 margin: 0px 0px 10px 0px;
	 font-size: 14px;
}

#error-box-inner{
	padding: 8px 10px;
	color: #fff;
}










input, button, select, textarea{
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	outline: none;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.form-control{
	display: block;
	width: 100%;
	padding: 0.90rem 0.75rem;
	font-size: 14px;
	font-weight: 400;
	line-height: inherit;
	color: #495057;
	background-color: #fff;
	background-clip: padding-box;
	border: 1px solid #ced4da;
	border-radius: 0.25rem;
	transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, padding 0.2s ease-out;
}

select.form-control{
	padding: 0.75rem 0.75rem 0.75rem 0.5rem;
}

.form-control::-ms-expand {
  background-color: transparent;
  border: 0;
}

.form-control:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #495057;
}

.form-control:focus {
  color: #495057;
  background-color: #fff;
  border-color: #80bdff;
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.form-control.is-invalid{
  border-color: #dc3545;
  padding-right: calc(1.5em + 0.75rem);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

.form-control.is-invalid:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

textarea.form-control.is-invalid {
  padding-right: calc(1.5em + 0.75rem);
  background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.form-control::-webkit-input-placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control::-moz-placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control:-ms-input-placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control::-ms-input-placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control::placeholder {
  color: #6c757d;
  opacity: 1;
}

.form-control:disabled, .form-control[readonly] {
  background-color: #e9ecef;
  opacity: 1;
}

.form-group{
  margin-bottom: 1rem;
}

.form-text{
  display: block;
  margin-top: 0.25rem;
}

.form-row{
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -5px;
  margin-left: -5px;
}

.form-row > .col, .form-row > [class*="col-"] {
  padding-right: 5px;
  padding-left: 5px;
}

.form-control-wrapper{
	position: relative;
	text-align: left;
}

textarea{
	height: 250px!important;
	resize: none;
}

.form-control-label{
	font-size: 12px;
    font-weight: normal;
    position: absolute;
    top: 0;
    width: 100%;
    margin-top: 8px;
    margin-left: 1px;
    padding: 0px 0.75rem;
    z-index: 1;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
    pointer-events: none;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    opacity: 0;
	transition: all 0.2s ease-out;
}

.form-control-label.active{
	opacity: 1;
	-webkit-transform: translateY(0px);
    transform: translateY(0px);
}

.form-control.active{
	padding: 1.30rem 0.75rem 0.50rem 0.75rem;
}

select.form-control.active{
	padding: 1.30rem 0.75rem 0.20rem 0.5rem;
}

.form-control-validation-message{
	font-size: 14px;
	width: 100%;
	margin: 0px;
	padding: 0.5rem 0px 0px 0px;
	color: #dc3545;
	opacity: 0;
	visibility: hidden;
	display: none;
}

.form-control-validation-message.active{
	opacity: 1;
	visibility: visible;
	display: block;
}






.modal-open {
  overflow: hidden;
}

.modal-open .modal {
  overflow-x: hidden;
  overflow-y: auto;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  display: none;
  width: 100%;
  height: 100%;
  overflow: hidden;
  outline: 0;
}

.modal-dialog {
  position: relative;
  width: auto;
  margin: 0.5rem auto;
  pointer-events: none;
  max-width: 500px;
}

.modal.fade .modal-dialog {
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-transform: translate(0, -50px);
  transform: translate(0, -50px);
}

.modal.show .modal-dialog {
  -webkit-transform: none;
  transform: none;
}

.modal.modal-static .modal-dialog {
  -webkit-transform: scale(1.02);
  transform: scale(1.02);
}

.modal-dialog-scrollable {
  display: -ms-flexbox;
  display: flex;
  max-height: calc(100% - 1rem);
}

.modal-dialog-scrollable .modal-content {
  max-height: calc(100vh - 1rem);
  overflow: hidden;
}

.modal-dialog-scrollable .modal-header,
.modal-dialog-scrollable .modal-footer {
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.modal-dialog-scrollable .modal-body {
  overflow-y: auto;
}

.modal-dialog-centered {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  min-height: calc(100% - 1rem);
}

.modal-dialog-centered::before {
  display: block;
  height: calc(100vh - 1rem);
  height: -webkit-min-content;
  height: -moz-min-content;
  height: min-content;
  content: "";
}

.modal-dialog-centered.modal-dialog-scrollable {
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-pack: center;
  justify-content: center;
  height: 100%;
}

.modal-dialog-centered.modal-dialog-scrollable .modal-content {
  max-height: none;
}

.modal-dialog-centered.modal-dialog-scrollable::before {
  content: none;
}

.modal-content {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0.3rem;
  outline: 0;
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #000;
  display: none;
}

.modal-backdrop.fade {
  opacity: 0;
}

.modal-backdrop.show {
  opacity: 0.5;
  display: block;
}

.modal-header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 1rem 1rem;
  border-bottom: 1px solid #dee2e6;
  border-top-left-radius: calc(0.3rem - 1px);
  border-top-right-radius: calc(0.3rem - 1px);
}

.modal-header .close {
  padding: 1rem 1rem;
  margin: -1rem -1rem -1rem auto;
  outline: none;
  border: 0px;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}

.modal-title {
  line-height: 1.5;
  font-size: 18px;
  margin: 0px;
  font-weight: 500;
}

.modal-body {
  position: relative;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  padding: 1rem;
  font-size: 14px;
  color: #333333;
}

.modal-footer {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding: 0.75rem;
  border-top: 1px solid #dee2e6;
  border-bottom-right-radius: calc(0.3rem - 1px);
  border-bottom-left-radius: calc(0.3rem - 1px);
}

.modal-footer > * {
  margin: 0.25rem;
}

.modal-scrollbar-measure {
  position: absolute;
  top: -9999px;
  width: 50px;
  height: 50px;
  overflow: scroll;
}






/* media queries styles ------------------------------------------------------------------------------------------------------------------------------------------------- */

@media only screen and (max-width: 992px)
{
	.product-col-50{
		width: 100%;
	}
	.product-col-padding-left{
		padding: 40px 0px 0px 0px;
	}

	.owl-carousel-inner{
		max-width: 400px;
	}

	.main-body-left2{
		width: 100%;
		float: left;
	}
	.main-body-right3{
		width: 100%;
		float: left;
		margin: 0px;
		padding: 0px 0px 20px 0px;
	}

	.header-left{
		text-align: center;
	}
	.header-left img{
		max-width: 200px;
	}
	.header-middle{
		display: none;
	}
	.header-right{
		flex: 0 0 150px;
	}
	.header-right ul li a span{
		display: none;
	}
	.header-right ul li a{
		padding: 0px;
		width: 40px;
		height: 40px;
		justify-content: center;
	}
	.header-right ul li a i{
		padding: 0px;
	}
	.header-mobile{
		display: flex;
	}
	#footer-top{
		text-align: center;
	}
	#footer-top .grid-cols-4{
		grid-template-columns: repeat(1,1fr);
	}
}

@media only screen and (max-width: 820px)
{
	.align-right{
		text-align: left;
	}
	#main-body-left-col{
		width: 35%;
	}
	#main-body-right-col{
		width: 65%;
	}
	.product-col-25{
		width: 50%;
	}
	.product-col-33{
		width: 50%;
	}
	.desktop-header-icons{
		display: none!important;
	}

	.owl-carousel-inner{
		max-width: 300px;
	}
	.owl-carousel-image{
		height: 500px;
	}
	.owl-carousel h2{
		font-size: 52px;
	}
	.owl-carousel p{
		font-size: 14px;
	}

	.contact-form-col{
		width: 100%;
	}
	.contact-form-col-padding-right{
		padding: 0px 0px 0px 0px;
	}
	.contact-form-col-padding-left{
		padding: 0px 0px 0px 0px;
	}

}

@media only screen and (max-width: 700px)
{
	.main-body-left{
		float: left;
		width: 100%;
	}
	.main-body-left-inner{
		padding: 0px;
	}
	.main-body-right{
		width: 100%;
		margin: 0px;
	}
	.col-70{
		width: 100%;
	}
	.col-30{
		width: 100%;
		float: left;
	}
	.col-30-padding{
		padding: 0px 0px 0px 0px;
	}

}

@media only screen and (max-width: 600px)
{
	#main-body-left-col{
		display: none;
	}
	#main-body-right-col{
		width: 100%;
	}
	.col-50{
		width: 100%;
	}
	.col-50-padding{
		padding: 0px 0px 10px 0px;
	}
	.col-50-inner{
		padding: 0px;
	}
	.col-50-inner-right{
		padding: 0px;
	}
	.col-50-inner-left{
		padding: 0px;
	}
	.col-50-margin-top{
		margin: 15px 0px 0px 0px;
	}
	.login-box{
		margin: 20px auto 0px auto;
	}

	.owl-carousel h2{
		font-size: 42px;
	}
	.owl-carousel-inner{
		max-width: 260px;
	}
	.owl-carousel-image{
		height: 440px;
	}
}

@media only screen and (max-width: 576px)
{
	.header-right{
		flex: 0 0 50px;
	}
	.header-mobile{
		flex: 0 0 50px;
	}
	.header-right ul li.header-shop{
		display: none!important;
	}
	.header-right ul li.header-book{
		display: none!important;
	}

	.product-col-33{
		width: 100%;
	}
	.product-col-25{
		width: 100%;
	}
	.product-col-inner-image{
	}
}

/* end media queries styles --------------------------------------------------------------------------------------------------------------------------------------------- */
