body{margin:0;padding:0;}
img{border:0;}
.fl_menu{list-style:none;margin:0;padding:0;}
.cms_imgleft{margin:3px 5px 5px 0;float:left;border:1px solid #000;}
.cms_imgright{margin:3px 0 5px 5px;float:right;border:1px solid #000;}
h1{margin:0;font-size:28pt;line-height:30pt;}
h2{font-size:20pt;line-height:24pt;}
h2, h3{margin:0 0 5px 0;}
.clear{clear:both;}
.gallthumbnail{float:left;border:2px solid #666;margin-right:5px;margin-bottom:5px;}
.fl_blogpostavatar{float:right;border:2px solid #666;margin:0 0 5px 5px;}
.fl_commentavatar{float:left;border:2px solid #666;margin:0 5px 0 0;}
.fl_commentname{display:block;margin-left:80px;text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_commentmessage{display:block;margin-left:80px;}
.fl_gtname{display:block;text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_gtmessage{display:block;}
.fl_blogpost1, .fl_blogpost2{border-bottom:1px dashed #f8422d;padding-bottom:5px;margin-bottom:5px;}
.fl_postinfo{text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_blogfooter{clear:both;}
.fl_comment1{display:block;padding:5px;margin-top:5px;}
.fl_comment2{display:block;padding:5px;background-color:#eee;margin-top:5px;}
.fl_commclear{display:block;clear:both;}
#fl_commsbox, #fl_tracksbox{clear:both;padding-top:15px;}
.fl_bigpic{border:2px solid #666;}
.fl_bigcaption{margin-top:10px;}
.fl_rssentry{clear:both;}
.fl_rssimg{float:right;display:block;border:2px solid #666;margin:0 0 5px 5px;}
.fl_rsstitle{font-size:18pt;line-height:24pt;font-weight:bold;}
.fl_rssby{text-transform:uppercase;margin-bottom:5px;font-size:8pt;}
.fl_gallpreview1{margin-bottom:10px;padding:5px;clear:both;}
.fl_gallpreview2{margin-bottom:10px;background-color:#eee;padding:5px;clear:both;}
.fl_gallpreview1 img, .fl_gallpreview2 img{float:left;border:2px solid #666;}
.fl_galllink, .fl_galltext{display:block;margin-left:110px;}
td.fl_label{display:block;width:100px;}
.fl_mailform textarea{width:400px;height:200px;}
.fl_votebar{background-color:#fff;height:10px;}
input.fl_regform{width:100px;}
.fl_postingform{display:none;}
.fl_postingform textarea{height:100px;}
.fl_rsslinks{padding-top:10px;clear:both;text-align:right;}
.fl_rsslinks a{text-transform:uppercase;font-size:8pt;text-decoration:none;margin-left:10px;}
.fl_rsslinks:empty{display:none;}
.fl_rating{float:right;text-align:right;}
#msgwrap{position:fixed;top:150px;left:50%;text-align:center;z-index:99;}
#msgbar{position:relative;color:#fff;border-width:3px;border-style:solid;padding:15px;font-size:28px;line-height:40px;width:300px;left:-168px;display:none;font-family:"Lucida Sans","Lucida Grande", Lucida, Tahoma, Verdana, Arial, Helvetica, sans-serif;cursor:default;}
#msgbar a{color:#fff;}
#topbar{display:none;position:fixed;z-index:99;background-color:#4ad;color:#fff;top:0;left:0;width:100%;font-size:12px;border-bottom:3px solid #079;text-align:center;}
#topbar a{color:#fff;}
#topcont{padding:10px;}
input, textarea{border:1px solid;padding:3px;background-color:#fff;border-color:#000;font-family:Verdana, Arial, Helvetica, sans-serif;font-size:12px;}
textarea{width:300px;height:150px;}
input:hover, input:focus, textarea:hover, textarea:focus{background-color:#eee;}
.fl_later{float:left;}
.fl_earlier{float:right;}
.flmsg_alert{background-color:#4ad;border-color:#079;}
.flmsg_error{background-color:#900;border-color:#600;}
.flmsg_success{background-color:#096;border-color:#066;}
.flmsg_generic{background-color:#666;border-color:#999;}
#fl_commsbox{margin:5px;padding:5px;border:1px dotted #333;background-color:#eee;}
#fl_gallwrap{position:fixed;top:0;left:0;margin:0;padding:0;width:100%;height:100%;display:none;font:11px Arial, Helvetica, sans-serif;line-height:20px;color:#333;text-align:left;}
#fl_gallcover{position:fixed;width:100%;height:100%;top:0;left:0;margin:0;padding:0;background-color:#000;opacity:0.8;filter:alpha(opacity=80);}
#fl_gallbox{position:relative;top:5%;margin:0 auto;background-color:#fff;padding:10px;width:100px;height:100px;}
#fl_gallpic{display:block;margin:0 auto;position:relative;top:35%;}
#fl_gallbelowpic{clear:both;display:none;padding:5px 10px 10px;margin:0 -10px;background-color:#fff;overflow:hidden;}
#fl_gallwrap a{color:#666;text-decoration:none;}
#fl_gallwrap a:hover{color:#444;}
#fl_gallprevnext{background:url('../scripting/blank.gif');position:relative;}
#fl_gallprev{position:absolute;z-index:50;}
#fl_gallnext{text-align:right;position:absolute;z-index:50;right:0;}
#fl_gallclose, #fl_gallslide{clear:right;float:right;}
a#fl_gallprev:hover, a#fl_gallnext:hover, a#fl_gallclose:hover{border-width:0;}
#fl_gallprev img, #fl_gallnext img{visibility:hidden;padding-top:50px;}
#fl_gallprev:hover img, #fl_gallnext:hover img{visibility:visible;}


@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/source-sans-3-v15-latin-regular.woff2') format('woff2');
}
@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: italic;
  font-weight: 400;
  src: url('fonts/source-sans-3-v15-latin-italic.woff2') format('woff2');
}
@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 600;
  src: url('fonts/source-sans-3-v15-latin-600.woff2') format('woff2');
}
@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: italic;
  font-weight: 600;
  src: url('fonts/source-sans-3-v15-latin-600italic.woff2') format('woff2');
}
@font-face {
  font-display: swap;
  font-family: 'Bariol';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/bariol_bold-webfont.woff2') format('woff2');
}

:root {
	--vh-body: #444;
	--vh-green: #4d917f;
	--vh-pink: #b83592;
	--vh-yellow: #fdd275;
	--vh-neutral: #eee;
	--vh-ltneutral: #f6f6f6;
}

* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; background: #fff; color: var(--vh-body); font: 16px/24px "Source Sans 3", sans-serif; }
p { margin: 10px 0; }
ul, ol { margin: 10px 20px; }
a { color: var(--vh-pink); text-decoration: underline; }
a:hover { text-decoration: none; color: var(--vh-yellow); }
img { max-width: 100%; height: auto!important; }
b, strong { font-weight: 600; }

h1, h2, h3, h4, h5 { margin: 20px 0; font-weight: 700; font-family: Bariol, sans-serif; color: var(--vh-green); }
h1 { font-size: 36px; line-height: 40px; }
h2 { font-size: 24px; line-height: 28px; color: var(--vh-dark); }
h3 { font-size: 24px; line-height: 28px; }
h4 { font-size: 18px; line-height: 22px; }
h5 { font-size: 16px; line-height: 20px; }
h1 b, h2 b, h3 b, h4 b, h5 b, h1 strong, h2 strong, h3 strong, h4 strong, h5 strong { font-weight: 700; }
.textlabel { position: absolute; margin-left: -9999px; }
h1:empty { display: none; }

.skipto a { position: absolute; margin-left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; color: #fff; padding: 10px; z-index: 50; background: var(--vh-pink); }
.skipto a:focus { margin-left: 0; width: auto; height: auto; color: #fff; }
.wrapper { max-width: 600px; margin: 0 auto; padding: 0 40px; position: relative; }

.topbar { background: var(--vh-ltneutral) url('../gfx/bg-white-texture.jpg') no-repeat center; background-size: cover; color: var(--vh-green); font-size: 14px; line-height: 30px; text-align: left; position: relative; padding: 0 40px; }
.topbar a.email { color: var(--vh-green); position: absolute; right: 40px; }
.topbar a.email:hover { color: var(--vh-yellow); }

header { padding: 40px 0; position: relative; }
.logo { display: block; width: 300px; margin: 0 auto; }
.logo img { display: block; }

#menu { position: relative; z-index: 10; text-align: center; padding: 10px 0; }
.fl_menu { margin: 0; list-style: none; }
.fl_menu li, .fl_menu a { display: inline-block; vertical-align: top; position: relative; }
.fl_menu>li { margin-right: 40px; }
.fl_menu>li:last-child { margin-right: 0; }
.fl_menu a { text-decoration: none; font: bold 16px/40px Bariol, sans-serif; color: var(--vh-body); }
.fl_menu a:hover { color: var(--vh-yellow); }
.fl_menu>li.current>a { color: var(--vh-green)!important; cursor: default; }

.pagetop { position: relative; height: 250px; overflow: hidden; background: var(--vh-ltneutral) url('../gfx/bg-white-texture.jpg') no-repeat center; background-size: cover; margin-bottom: 80px; padding-top: 60px; margin-top: -60px; display: flex; align-items: center; }
.pagetopcont { display: block; position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: url('../gfx/vsh.svg') no-repeat top 20% center; background-size: 1650px auto; opacity: 0.15; }
.pagetop .wrapper { display: block; text-align: center; }
.pagetop:before { position: absolute; top: 0; left: 0; right: 0; height: 60px; background: url('../gfx/curve-white.svg') no-repeat center bottom; background-size: cover; content: ''; z-index: 5; }
.pagetop:after { position: absolute; bottom: 0; left: 0; right: 0; height: 60px; background: url('../gfx/curve-reverse.svg') no-repeat center bottom; background-size: cover; content: ''; }


main { min-height: calc(100vh - 587px); }

footer { margin-top: 20px; text-align: center; font-size: 12px; line-height: 16px; background: var(--vh-ltneutral) url('../gfx/bg-white-texture.jpg') no-repeat center; background-size: cover; padding: 115px 40px 35px; box-sizing: border-box; color: var(--vh-dark); position: relative; }
footer:before { position: absolute; top: 0; left: 0; right: 0; height: 60px; background: url('../gfx/curve-white.svg') no-repeat center bottom; background-size: cover; content: ''; }
footer p { margin: 5px 0; position: relative; }
footer a { color: var(--vh-dark); }
footer .divider { width: 20px; display: inline-block; }

blockquote { background: var(--vh-ltneutral) url('../gfx/bg-white-texture.jpg') no-repeat center; background-size: cover; margin: 40px; padding: 40px; box-shadow: 0 0 10px rgba(0,0,0,0.25); }
blockquote>*:first-child { margin-top: 0!important; }
blockquote>*:last-child { margin-bottom: 0!important; }
.cms_imgleft { max-width: 200px; border: 0; margin: 3px 10px 10px 0; float: left; }
.cms_imgright { max-width: 200px; border: 0; margin: 3px 0 10px 10px; float: right; }
.cms_inplace { display: block; margin: 20px auto; }
main li { margin-top: 3px; }
main ul { list-style: none; }
main ul li:before { color: var(--vh-green); content: "\2022"; position: absolute; font-size: 14px; line-height: 18px; margin: 1px 0 0 -18px; }
.grid { display: grid; margin: 40px -40px; grid-template-columns: 1fr 1fr; gap: 40px; }
.grid .gridopt { background: var(--vh-ltneutral) url('../gfx/bg-white-texture.jpg') no-repeat center; background-size: cover; padding: 10px 20px; box-shadow: 0 0 10px rgba(0,0,0,0.25); }
.grid .gridopt>*:first-child { margin-top: 10px; }
.grid .gridopt>p:first-child img { display: block; margin: -20px -20px 20px; max-width: calc(100% + 40px); }

form { margin: 20px 0; }
form label { display: block; font-size: 12px; line-height: 17px; text-transform: uppercase; margin: 10px 0 2px; font-weight: 600; }
input, textarea { -webkit-appearance: none; border-radius: 2px; }
input.checkbox, input.button { border: 0; width: auto; display: inline; background: transparent; -webkit-appearance: checkbox; height: auto; margin-right: 5px; }
input[type=radio] { -webkit-appearance: radio; }
label .reqd { margin-left: 5px; }

input, textarea, .fl_mailform textarea, select { background: var(--vh-ltneutral); border: 0; font: 14px/20px Mulish, sans-serif; color: var(--vh-body); width: 100%; display: block; padding: 10px; -moz-box-sizing: border-box; box-sizing: border-box; }
input, select { height: 40px; }
input:hover, textarea:hover, select:hover { background: var(--vh-ltneutral); color: var(--vh-body); }
input:focus, textarea:focus, select:focus { background: var(--vh-ltneutral); color: var(--vh-dark); }
option { padding: 3px 10px; }

input.emailsub, input.passsub, input.commentsub, input.formsub, a.button { display: block; width: auto; height: auto; font: bold 18px/20px Bariol, sans-serif; margin: 10px 5px 10px 0; padding: 10px 25px; color: #fff!important; background: var(--vh-pink) linear-gradient(80deg, rgba(253,210,117,0.5) 25%, rgba(253,210,117,0))!important; border-radius: 20px; cursor: pointer; text-decoration: none; text-align: center; height: 40px; box-sizing: border-box; }
input.emailsub:hover, input.passsub:hover, input.commentsub:hover, input.formsub:hover, input.emailsub:focus, input.passsub:focus, input.commentsub:focus, input.formsub:focus, a.button:hover, a.button:focus { opacity: 1; transform: scale3d(1.02,1.02,1); }
input.emailsub:active, input.passsub:active, input.commentsub:active, input.formsub:active, a.button:active, .frontbox a:active { position: relative; top: 2px; }
a.button { display: inline-block; vertical-align: top; }

#fl_loading { display: none; position: fixed; top: 10px; right: 10px; background: #fff; padding: 3px; border: 1px solid #ccc; z-index: 150; width: 16px; z-index: 99; }
#cookiebar { font-size: 12px; line-height: 16px; }
#cookiebar a { display: inline-block; }
#msgbar { font-family: Bariol, sans-serif; font-weight: bold; }

a, input, #menubutton { transition: 0.25s; transition-property: opacity, color, background-color, transform; }

@media all and (max-width: 749px) {
	html, body { min-width: 320px; -webkit-text-size-adjust: none; }
	.grid { margin: 40px 0; }
}
@media all and (max-width: 649px) {

	.topbar { font-size: 12px; position: sticky; top: 0; z-index: 10; }
	header { padding: 20px 0; position: sticky; top: 30px; z-index: 10; background: #fff; border-bottom: 1px solid var(--vh-neutral); }
	.logo { width: 150px; }
	

	#menubutton { position: fixed; top: 80px; left: 30px; width: 40px; height: 40px; cursor: pointer; z-index: 40; }
	#menubutton .rowbar { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: var(--vh-green); border-radius: 2px; transition: all 0.5s; }
	#menubutton .rowtop { top: 13px; }
	#menubutton .rowbottom { top: 25px; }

	.menublock #menubutton { position: fixed; }
	.menublock #menubutton .rowtop, .menublock #menubutton .rowbottom { opacity: 0; }
	.menublock #menubutton .rowbar:nth-child(2) { transform: rotate(-45deg); }
	.menublock #menubutton .rowbar:nth-child(3) { transform: rotate(45deg); }

	header, main, footer { transition-property: filter, -webkit-filter; transition-duration: 0.5s; filter: blur(0); }
	body.menublock header, body.menublock main, body.menublock footer { pointer-events: none; filter: blur(25px); }
	
	#menu { position: fixed; top: 0; bottom: 0; left: 0; right: 0; z-index: 15; background: #fff; border: 0; transition: transform 0.5s ease-out; transform: translate3d(0,-100%,0); background-attachment: fixed; overflow: auto; -webkit-overflow-scrolling: touch; pointer-events: none; }
	body.menublock #menu { transform: translate3d(0,0,0); pointer-events: auto; }
	#menu:before { display: none!important; }
	
	.fl_menu { position: absolute; top: 50%; left: 40px; right: 40px; text-align: center; transform: translate3d(0,-50%,0); }
	.fl_menu:before { content: ''; width: 100px; height: 100px; background: url('../gfx/vsh.svg') no-repeat center; background-size: contain; margin: 0 auto; display: block; margin-bottom: 20px;  }
	
	.fl_menu li { display: block; border-top: 1px solid var(--vh-neutral); margin: 0; }
	.fl_menu a { display: block; font-size: 18px; line-height: 24px; padding: 15px 0; }
	.fl_menu li:first-child { border-top: 0; }
	
	.pagetop { margin-top: 0; padding-top: 0; }
	.pagetop:before { display: none; }
	.pagetop:after { position: absolute; bottom: 0; left: 0; right: 0; height: 20px; background: url('../gfx/curve-reverse.svg') no-repeat center bottom; background-size: cover; content: ''; }
	.pagetopcont { background-size: 900px auto; background-position: top 10% center; }
	footer { padding-top: 55px; }
	footer:before { height: 20px; }

}
@media all and (max-width: 599px) {
	body { font-size: 14px; line-height: 20px; }
	h1 { font-size: 28px; line-height: 32px; }
	h2, h3 { font-size: 20px; line-height: 24px; }
	h4 { font-size: 16px; line-height: 20px; }
	h5 { font-size: 14px; line-height: 18px; }
	.cms_imgleft, .cms_imgright { max-width: 100%; display: block; margin: 10px auto; float: none;  }
	.wrapper, .topbar { padding: 0 20px; }
	.fl_menu { left: 20px; right: 20px; }
	#menubutton { left: 10px; }
	
	.topbar a.email { right: 20px; }
	.grid { grid-template-columns: 1fr; gap: 20px; max-width: 320px; margin: 40px auto; }
	.pagetop { margin-bottom: 40px; height: auto; min-height: 200px; }
	.pagetop .wrapper { padding: 20px; }
	footer { margin-top: 40px; padding: 55px 20px 35px; }
}
@media all and (max-width: 399px) {
	.logo { width: 100px; }
	#menubutton { top: 64px; }
	#cf-turnstile { transform: scale(0.8); transform-origin: top left; }
}