
/*

font-family: "futura-pt", sans-serif;
font-weight: 300/400/500;

font-family: "ltc-bodoni-175", serif;
font-weight: 400;
font-style: italic/normal;

ZWART: #121212
BEIGE: #9F9E91

ROOD: #db3400
GROEN: #56b400

*/


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

/* general */

body {
	background: #121212;
	font-family: "futura-pt", sans-serif;
	font-size: 18px;
	font-weight: 300;
	color: #121212;
}

br.clear {
	clear: both;
}

.wrapper {
	margin: 0 auto;
	max-width: 1120px;
}

.wrapper960 {
	margin: 0 auto;
	max-width: 960px;
}

.wrapper800 {
	margin: 0 auto;
	max-width: 800px;
}

.wrapper640 {
	margin: 0 auto;
	max-width: 640px;
}

/* news */

.news {
	float: left;
	width: 100%;
	box-sizing: border-box;
	padding: 20px 25px;
	color: #FFF;
	background: #9F9E91;
	font-size: 22px;
	text-align: center;
}

.news a {
	color: #FFF;
}

.news a:hover {
	color: #EEE;
}

/* header */

.header {
	float: left;
	width: 100%;
}

/* logo */

.logo {
	float: left;
	width: 100%;
}

.logo img {
	float: left;
	width: 380px;
	margin-left: calc(50% - 190px);
	margin-bottom: 10px;
}

/* nav */

.nav_wrapper {
	float: left;
	width: 100%;
	margin-bottom: 30px;
}

ul.nav {
	float: left;
	width: 100%;
	display: flex;
	justify-content: space-between;
	list-style-type: none;
	margin: 0;
	padding: 0;
} 

ul.nav li {
	margin: 0;
	padding: 0;
}

ul.nav li a {
	display: inline-block;
	color: #FFF;
	font-size: 18px;
	line-height: 1em;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 400;
	border-bottom: 2px solid #121212;
	padding-bottom: 8px;
	margin: 0;
}

ul.nav li a:hover {
	color: #9F9E91;	
}

ul.nav li a.selected, 
ul.nav li a.selected:hover {
	color: #9F9E91;
	border-bottom: 2px solid #9F9E91;
}

/* mobile subnav */

ul.nav li ul {
	display: none;
}

/* hamburger */

.hamburger {
	float: right;
	margin-top: 12px !important;
	margin-right: 10px !important;
	outline: none;
	display: none !important;
}

/* slideshow */

.slideshow {
	float: left;
	width: 100%;
}

.slideshow img {
	float: left;
	width: 100%;
}

.slideshow {
	--f-transition-duration: 2.5s;
}

.slideshow {
    --f-progress-color: #ff3520;
}

/* subnav */

ul.subnav {
	float: left;
	width: 100%;
	list-style-type: none;
}

ul.subnav li {
	float: left;
	width: auto;
}

ul.subnav li a {
	float: left;
	width: auto;
	padding: 20px 0;
	color: #FFF;
	font-size: 16px;
	line-height: 1em;
	font-weight: 400;
	text-transform: uppercase;
	text-decoration: none;
	white-space: nowrap;
	margin-right: 35px;
}

ul.subnav li a:hover {
	color: #9F9E91;
}

ul.subnav li a.selected,  
ul.subnav li a.selected:hover {
	color: #9F9E91;
}

/* home: intro */

.home_intro {
	float: left;
	width: 100%;
	padding: 75px 0;
}

.home_intro h1 {
	float: left;
	width: 100%;
	color: #FFF;
	line-height: 1em;
	margin-bottom: 30px;
	font-size: 45px;
	font-weight: 300;
	letter-spacing: 1px;
}

.home_intro h1 em {
	color: #9F9E91;
	font-family: "ltc-bodoni-175", serif;
	font-weight: 400;
	font-size: 40px;
	font-style: normal;
}

.home_intro p {
	color: #FFF;
	font-size: 18px;
	line-height: 1.75em;
	margin: 0;
}

/* home: menu image + text */

.home_menu_wrapper {
	float: left;
	width: 100%;
	margin-top: 25px;
	margin-bottom: 50px;
}

.home_menu_image {
	float: left;
	width: 46%;
}

.home_menu_image img {
	float: left;
	width: 100%;
}

.home_menu_text {
	float: right;
	width: 46%;
}

.home_menu_text_wrapper {
	float: left;
	width:	100%;
	margin-bottom: 25px;
	font-size: 16px;
	box-sizing: border-box;
	padding: 0;
	border: 1px solid #AAA;
}

.home_menu_text_wrapper p {
	float: left;
	width: 100%;
	box-sizing: border-box;
	font-weight: 400;
	border-bottom: 1px solid #AAA;
	padding: 20px 25px;
	margin-bottom: 0 !important;
	text-align: center;
}

.home_menu_text_wrapper p:last-of-type {
	border: 0;
}

/* home: banners */

.banner_list {
	float: left;
	width: 100%;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

a.banner {
	float: left;
	width: 46%;
	margin-bottom: 30px;
	text-decoration: none;
	color: #121212;
	border: 0 !important;
}

a.banner img {
	float: left;
	width: 100%;
	box-sizing: border-box;
	border: 3px solid #9F9E91; 
	margin-bottom: 20px;
}

a.banner strong {
	float: left;
	width: 100%;
	font-weight: 400 !important;
	font-size: 25px;
	margin-bottom: 6px;
	letter-spacing: 1px;
}

a.banner span {
	float: left;
	width: 100%;
}

a.banner:hover {
	color: #121212;
}

a.banner:hover img {
	border: 3px solid #121212;
}

/* content */

.content {
	float: left;
	width: 100%;
	padding: 50px 0;
	background: #FBFBFB;
}

.content a {
	color: #121212;
	border-bottom: 1px solid #aaa;
	text-decoration: none;
}

.content a:hover {
	color: #121212;
	border-bottom: 1px solid #121212;
}

.content a.button {
	display: inline-block;
	color: #FFF;
	background: #121212;
	text-decoration: none;
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 500;
	padding: 8px 15px;
	margin-right: 10px;
	margin-bottom: 10px;
	border: 0;
}

.content a.button:hover {
	background: #9F9E91;
}

.content h1 {
	font-size: 45px;
	font-weight: 300;
	margin-bottom: 25px;
	line-height: 1em;
}

.content h1.center {
	text-align: center;
}

.content h2 {
	font-size: 28px;
	font-weight: 400;
	text-transform: uppercase;
	margin-bottom: 20px;
	line-height: 1em;
}

.content h2.center {
	text-align: center;
}

.content p {
	max-width: 700px;
	line-height: 1.5em;
	margin-bottom: 25px;
}

.content strong {
	font-weight: 500; 
}

.content ul {
	list-style-type: disc;
	margin-bottom: 25px;
}

.content ol {
	list-style-type: decimal;
	margin-left: 10px;
	margin-bottom: 25px;
	padding-left: 15px;	
}

.content li {
	line-height: 1.4em;
	margin-left: 25px;
	margin-bottom: 6px;
}

.content table {
	width: 100%;
	margin-bottom: 25px;
}

.content td {
	font-size: 18px;
	padding: 5px;
	vertical-align: top;
	line-height: 1.4em;	
}

.content table.menu {
	width: 100% !important;
	border-collapse: collapse;
	border: 1px solid #ccc;
	margin-bottom: 35px;
}

.content table.menu td {
	padding: 12px 15px;
	border-bottom: 1px solid #ccc;
}

.content table.menu td p {
	margin-bottom: 0;
}

.content table.menu td.price {
	background: #FFF;
}

.content table.menu td.price strong {
	font-size: 20px;
	font-weight: 500;
}

.content img.left {
	float: left;
	margin: 0 15px 15px 0;
}

.content hr {
	float: left;
	width: 100%;
	border-bottom: 1px solid #AAA;
	margin-bottom: 25px;
}

.content hr.spacer1 {
	border-bottom: 0;
	margin-bottom: 0;
}

.content hr.spacer10 {
	border-bottom: 0;
	margin-bottom: 10px;
}

.content hr.spacer15 {
	border-bottom: 0;
	margin-bottom: 15px;
}

.content hr.spacer20 {
	border-bottom: 0;
	margin-bottom: 20px;
}

.content hr.spacer25 {
	border-bottom: 0;
	margin-bottom: 25px;
}

.content hr.spacer30 {
	border-bottom: 0;
	margin-bottom: 30px;
}

.content hr.spacer50 {
	border-bottom: 0;
	margin-bottom: 50px;
}

.content hr.spacer75 {
	border-bottom: 0;
	margin-bottom: 75px;
}

.content hr.spacer100 {
	border-bottom: 0;
	margin-bottom: 100px;
}

.responsive_iframe_wrapper {
    float: none;
    clear: both;
    width: 100%;
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 25px;
    height: 0;
}

.responsive_iframe_wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* image albums */

.image_album {
	float: left;
	width: 100%;
	margin-bottom: 50px;
}

.image_album .item {
	overflow: hidden;
	margin: 10px !important;
	box-sizing: content-box;
}

.image_album .item img {
	transition: all 0.2s;
}

.image_album .item:hover img { 
	transform: scale(1.03);
}

/* images */

img.image {
	float: left;
	width: 18%;
	margin: 0 1%;
	margin-bottom: 20px;
	opacity: 1;
}

img.image:hover {
	opacity: 0.7;
}

/* calendar */

#calendar {
	float: left;
	width: 100% !important;
	margin-bottom: 30px;
	margin-top: 10px;
	border: 1px solid #ccc;
	border-collapse: collapse;
}

#calendar td {
	font-size: 15px;
	padding: 10px;
	text-align: center;
	vertical-align: middle;
	line-height: 1.4em;
	background: #FFF;
	border: 1px solid #ccc;
}

#calendar td.table_header {
	color: #FFF;
	background: #121212;
	font-weight: 500;
	font-size: 20px;
	padding: 10px 12px;
	border: 0;
}

#calendar td.table_header a {
	font-size: 25px;
	color: #9F9E91;
	text-decoration: none;
	border: 0;
}

#calendar td.table_header a:hover {
	color: #FFF;
}

#calendar td.day {
	width: 14%;
	padding: 10px;
	background: none;
	font-weight: 500;
	text-transform: uppercase;
	border-bottom: 1px solid #ccc;
}

/* closed */

#calendar td.closed {
	color: #FFF;
	font-weight: 400;
	background: url('/_graphics/bg_closed.png');
}

/* complete */

#calendar td.complete {
	font-weight: 400; 
	color: #FFF; 
	background: #db3400;
}

/* available */

#calendar td.available {
	font-weight: 400; 
	color: #FFF; 
	background: #56b400;
}

#calendar td.available a {
	color: #EEE;
	font-weight: 500;
	border: 0;
	padding: 10px 30px;
}

#calendar td.available a:hover {
	color: #FFF;
}

/* empty */

#calendar td.empty {
	background: #fbfbfb;
}

/* past */

#calendar td.past {
	color: #999;
	background: #EEE;
}

/* calendar legend */

div.legend {
	float: left;
	margin-right: 20px;
	margin-bottom: 10px;
	font-size: 18px;
	line-height: 1em;
	font-weight: 400;
}

div.legend span {
	float: left;
	display: block; 
	width: 20px; 
	height: 20px; 
	margin-right: 8px;
}

div.legend span.closed {
	background: url('/_graphics/bg_closed.png');
}

div.legend span.complete {
	background: #db3400;
}

div.legend span.available {
	background: #56b400;
}

/* sitemap */

ul#sitemap {

}

ul#sitemap li ul {
	list-style-type: square;
	margin-top: 5px;
	padding-left: 15px;
}

ul#sitemap li ul li {

}

/* suite calendar */

#suite_calendar_block {
	float: right;
	width: 45%;
}

#suite_calendar {
	float: left;
	width: 100%;
	margin-bottom: 30px;
	margin-top: 10px;
	border: 1px solid #ccc;
	border-collapse: collapse;
}

#suite_calendar td {
	font-size: 15px;
	padding: 5px;
	text-align: center;
	vertical-align: middle;
	line-height: 1.4em;
	background: #FFF;
	border: 1px solid #ccc;
}

#suite_calendar td.table_header {
	color: #FFF;
	background: #121212;
	font-weight: 500;
	font-size: 20px;
	padding: 10px 12px;
	border: 0;
}

#suite_calendar td.table_header a {
	font-size: 25px;
	color: #9F9E91;
	text-decoration: none;
	border: 0;
}

#suite_calendar td.table_header a:hover {
	color: #FFF;
}

#suite_calendar td.day {
	width: 14%;
	padding: 10px;
	background: none;
	font-weight: 500;
	text-transform: uppercase;
	border-bottom: 1px solid #ccc;
}

#suite_calendar td.closed {
	color: #FFF;
	font-weight: 400;
	background: url('/_graphics/bg_closed.png');
}

#suite_calendar td.complete {
	font-weight: 400; 
	color: #FFF; 
	background: #db3400;
}

#suite_calendar td.available {
	font-weight: 400; 
	color: #FFF; 
	background: #56b400;
}

#suite_calendar td.empty {
	background: #fbfbfb;
}

#suite_calendar td.past {
	color: #999;
	background: #EEE;
}

/* menus */

.menus_left {
	float: left;
	width: 50%;
}

.menus_right {
	float: right;
	width: 43%;
	box-sizing: border-box;
	padding: 40px 30px 30px 30px;
	color: #FFF;
	background: #121212;
	margin-top: 10px;
	text-align: center;
}

.menus_right a {
	color: #FFF;
	border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}

.menus_right a:hover {
	color: #FFF;
	border-bottom: 1px solid #FFF;
}

.menus_right p {
	float: left;
	width: 100%;
	box-sizing: border-box;
	font-weight: 400;
	border-bottom: 1px solid #818181;
	padding: 20px 25px;
	margin-bottom: 0;
	text-align: center;
}

.menus_right p:last-of-type {
	border: 0;
}

.content a.menus_button {
	float: left;
	width: 100%;
	box-sizing: border-box;
	margin: 30px 0 0 0;
	padding-top: 15px;
	padding-bottom: 15px;
	color: #121212;
	background: #fbfbfb;
}

.content a.menus_button:hover {
	color: #FFF;
}

/* contact */

.contact_left {
	float: left;
	width: 50%;
}

.contact_right {
	float: right;
	width: 40%;
	box-sizing: border-box;
	padding: 25px;
	background: rgba(159, 158, 145, 0.2);
}

/* form */

#form {
	float: left;
	width: 45%;
}

.contact_right #form {
	width: 100%;
}

/* labels */

#form span.label, 
#form span.label_error, 
#form span.hint, 
#form span.error {
	float: left;
	width: 100%;
	font-weight: 400;
	margin-right: -5px;
	line-height: 1.3em;
}

#form span.label, 
#form span.label_error {
	margin-bottom: 2px;
}

#form span.label_error {
	color: #c00;
}

#form span.error {
	font-size: 12px;
	color: #c00;
	margin-bottom: 4px;
}

#form span.hint {
	font-weight: normal;
	font-size: 12px;
	color: #999;
	margin-top: -4px;
	margin-bottom: 14px;
}

#form span.hint a {
	color: #777;
}

#form span.hint a:hover {
	color: #555;
}

#form span.checkbox, 
#form span.checkbox_error {
	float: left;
	width: 100%;
	margin-top: 4px;
	margin-right: -5px;
	margin-bottom: 4px;
}

#form span.checkbox_error {
	color: #c00;
}

#form span.checkbox_error a {
	color: #c00;
	border-bottom: 1px solid #c00;
}

#form span.label b, 
#form span.checkbox b {
	color: #9F9E91;
	font-weight: 400;
}

#form span.label_error b, 
#form span.checkbox_error b {
	color: #c00;
	font-weight: 400;
}

/* fields */

#form input.text {
	float: left;
	width: 98%;
	height: 26px;
	background: #FFF;
	border: 1px solid #ccc;
	padding: 6px;
	margin-top: 2px;
	margin-bottom: 10px;
	color: #121212;
	font-family: "futura-pt", sans-serif;
	font-size: 18px;
}

#form textarea {
	float: left;
	width: 98%;
	height: 200px;
	background: #FFF;
	border: 1px solid #ccc;
	padding: 6px;
	margin-bottom: 10px;
	color: #121212;
	font-family: "futura-pt", sans-serif;
	font-size: 18px;
}

#form select {
	float: left;
	width: 98%;
	background: #FFF;
	border: 1px solid #ccc;
	margin-bottom: 5px;
	padding: 2px 0 2px 2px;
	color: #121212;
	font-size: 18px;
	font-family: "futura-pt", sans-serif;
}

#form select option {
	padding: 2px;
}

#form input.checkbox {
	float: left;
	vertical-align: top;
	display: block;
	overflow: hidden;
	padding: 0; 
	border: 0;
	margin: 2px 4px 2px 0;
	width: 13px;
	height: 13px;
	line-height: 1em;
}

#form div.form_break {
	float: left;
	width: 100%;
	height: 16px;
	margin-top: 15px;
	border-top: 1px dashed #ccc;
}

#form div.form_title {
	float: left;
	width: 100%;
	font-size: 13px;
	color: #000;
	margin-top: 10px;
	margin-bottom: 10px;
}

/* feedback */

div.feedback {
	float: left;
	width: 100%;
	padding: 10px 0;
	font-size: 22px;
	font-weight: 500;
	color: #59b200;
	margin-bottom: 10px;
}

div.feedback img {
	vertical-align: middle;
}

div.feedback span {
	color: #c00;
}

/* button */

form button::-moz-focus-inner { 
    border: 0;
    padding: 0;
}

form button {
	display: inline-block;
	color: #FFF;
	background: #121212;
	text-decoration: none;
	text-transform: uppercase;
	font-family: "futura-pt", sans-serif;
	font-size: 15px;
	font-weight: 500;
	padding: 15px 20px;
	margin-right: 10px;
	margin-bottom: 10px;
	border: 0;
	cursor: pointer;
	outline: none;
}

form button:hover {
	background: #9F9E91;
}

/* footer */

.footer {
	float: left;
	width: 100%;
	padding: 30px 0;
	color: #EEE;
	line-height: 1.75em;
	text-align: center;
}

.footer b {
	font-weight: 400;
}

.footer a {
	color: #EEE;
	text-decoration: none;
	border-bottom: 1px solid #AAA;
	white-space: nowrap;
}

.footer a:hover {
	color: #FFF;
	border-bottom: 1px solid #FFF;
}

/* quoted */

img.quoted {
	vertical-align: middle;
	height: 15px;
	margin-left: 10px;
	opacity: 0.75;
}

img.quoted:hover {
	opacity: 1;
}

/* accept cookies */

.accept_cookies {
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 9999;
	color: #FFF;
	background: #9F9E91;
	width: 90%;
	padding: 15px 5%;
	font-size: 16px;
	line-height: 1.5em;
	text-align: center;
	transition: bottom 1s;
}

.accept_cookies a {
	color: #FFF;
	white-space: nowrap;
	transition: color 0.3s, background 0.3s;
}

.accept_cookies a:hover {
	color: #ddd;
}

.accept_cookies a.accept_cookies_button {
	color: #121212;
	background: #FFF;
	padding: 3px 6px;
	text-decoration: none;
	border-radius: 3px;
}

.accept_cookies a.accept_cookies_button:hover {
	background: #ddd;
}
