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-family: 'note_thisregular';
    src: url('fonts/Note_this-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}


:root {
	--sppc-body: #444;
	--sppc-blue: #025394;
	--sppc-purple: #7456a5;
	--sppc-ltpurple: #aa92cc;
	--sppc-neutral: #ddd5ce;
	--sppc-ltneutral: #f4f3f0;
}

* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; background: #fff; color: var(--sppc-body); font: 16px/24px neue-haas-grotesk-text, sans-serif; }
p { margin: 10px 0; }
ul, ol { margin: 10px 20px; }
a { color: var(--sppc-purple); }
a:hover { text-decoration: none; color: var(--sppc-ltpurple); }
img { max-width: 100%; height: auto!important; }
b, strong { font-weight: 500; }

h1, h2, h3, h4 { margin: 20px 0; font-weight: bold; color: var(--sppc-blue); font-family: neue-haas-grotesk-display, sans-serif; }
h1 { font-size: 36px; line-height: 40px; }
h2 { font-size: 28px; line-height: 32px; }
h3 { font-size: 24px; line-height: 28px; }
h4 { font-size: 20px; line-height: 24px; }
h5 { font-size: 18px; line-height: 22px; }
h1 b, h2 b, h3 b, h4 b, h1 strong, h2 strong, h3 strong, h4 strong { font-weight: bold; }
.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; background: var(--sppc-purple); }
.skipto a:focus { margin-left: 0; width: auto; height: auto; color: #fff; }
.wrapper { max-width: 1100px; margin: 0 auto; padding: 0 25px; position: relative; }

header { padding: 25px 0; position: relative; }
.logo { display: block; width: 203px; height: 125px; }
.logo img { display: block; }
.logo:hover { opacity: 1; }
header a.button { position: absolute!important; top: 0; right: 25px; margin: 0; }
header a.button:before { content: ''; background: url('../gfx/icon-heart.svg') no-repeat center; background-size: contain; display: inline-block; width: 20px; height: 16px; vertical-align: middle; margin-right: 10px; position: relative; top: -2px; }

header form.searchform { position: absolute; right: 25px; bottom: 0; }
input.searchtext { width: 200px; height: 30px; font-size: 10px; box-sizing: border-box; padding: 10px 40px 10px 10px; border-radius: 5px; }
input.gosearch { position: absolute; top: 0; right: 0; width: 30px; height: 30px; box-sizing: border-box; cursor: pointer; background: var(--sppc-blue) url('../gfx/icon-magnify.svg') no-repeat center!important; background-size: 14px 14px!important; text-indent: -9999px; border-radius: 0 5px 5px 0; border: 0; }
input.gosearch:hover { background-size: 12px 12px!important; background-color: var(--sppc-ltpurple)!important; }

.menuwrapper { position: sticky; top: -1px; z-index: 17; background: #fff; border-bottom: 1px solid var(--sppc-neutral); }
#menu { padding: 0 25px; max-width: 1100px; margin: 0 auto; position: relative; }
.fl_menu { margin: 0; list-style: none; border-top: 1px solid var(--sppc-neutral); }
.fl_menu li, .fl_menu a { display: inline-block; vertical-align: top; position: relative; }
.fl_menu>li:before { content: '\2022'; padding: 0 20px; font-size: 18px; line-height: 40px; color: var(--sppc-ltpurple); }
.fl_menu a { text-decoration: none; font: bold 16px/40px neue-haas-grotesk-display, sans-serif; color: var(--sppc-body); }
.fl_menu a:hover { color: var(--sppc-ltpurple); }
.fl_menu>li:first-child:before { display: none; }

.fl_menu ul { position: absolute; background: rgba(255,255,255,0.9); margin: 0; z-index: 20; top: 40px; max-height: 0; left: 36px; width: 200px; overflow: hidden; transition-duration: 0.25s; transition-property: max-height; text-align: left; }
.fl_menu ul li, .fl_menu ul a { display: block; margin: 0; padding: 0; }
.fl_menu ul a { font-size: 14px; line-height: 22px; padding: 5px 10px; }
.fl_menu ul.size { -webkit-transition: none; transition: none; opacity: 0; }
.fl_menu li:hover ul { max-height: 500px; }
#menu_c_search, #menu_b_news_1, #menu_b_planning_1, .fl_menu ul ul { display: none!important; }

.fl_menu>li.current.hassubmenu>a:after, .fl_menu>li.curparent.hassubmenu>a:after, .fl_menu>li.curhighparent.hassubmenu>a:after { content: ''; position: absolute; bottom: -5px; z-index: 19; width: 10px; height: 10px; background: #fff; left: 50%; margin-left: -5px; transform: rotate(45deg); pointer-events: none; }

.hasvisiblesubmenu .fl_menu>li.current, .hasvisiblesubmenu .fl_menu>li.curparent, .hasvisiblesubmenu .fl_menu>li.curhighparent { position: static; }
.hasvisiblesubmenu .fl_menu>li.current ul, .hasvisiblesubmenu .fl_menu>li.curparent ul, .hasvisiblesubmenu .fl_menu>li.curhighparent ul { position: absolute; background: #3772a0; max-height: none!important; top: 41px; left: 0; right: 0; padding: 0 25px; width: auto; text-align: center; box-shadow: 0 0 0 100vmax #3772a0; clip-path: inset(0 -100vmax); z-index: 18; opacity: 1!important; overflow: auto; white-space: nowrap; height: 40px; -webkit-overflow-scrolling: touch; scrollbar-color: var(--sppc-ltpurple) transparent; scrollbar-width: thin; }
.hasvisiblesubmenu .fl_menu>li.current ul li, .hasvisiblesubmenu .fl_menu>li.curparent ul li, .hasvisiblesubmenu .fl_menu>li.curhighparent ul li { display: inline-block; }
.hasvisiblesubmenu .fl_menu>li.current ul a, .hasvisiblesubmenu .fl_menu>li.curparent ul a, .hasvisiblesubmenu .fl_menu>li.curhighparent ul a { line-height: 40px; display: inline-block; padding: 0; color: #fff; }
.hasvisiblesubmenu .fl_menu>li.current ul a:hover, .hasvisiblesubmenu .fl_menu>li.curparent ul a:hover, .hasvisiblesubmenu .fl_menu>li.curhighparent ul a:hover { color: var(--sppc-neutral); }
.hasvisiblesubmenu .fl_menu>li.current>ul>li:before, .hasvisiblesubmenu .fl_menu>li.curparent>ul>li:before, .hasvisiblesubmenu .fl_menu>li.curhighparent>ul>li:before { content: '\2022'; padding: 0 20px; font-size: 18px; line-height: 40px; color: rgba(255,255,255,0.5); position: relative; }
.hasvisiblesubmenu .fl_menu>li>ul>li:first-child:before { display: none!important; }

.hasvisiblesubmenu #menu:after { content: ''; position: absolute; right: 0; top: 42px; height: 39px; width: 25px; background: linear-gradient(to right, rgba(55,114,160,0), #3772a0); z-index: 20; }
.hasvisiblesubmenu #menu:before { content: ''; position: absolute; left: 0; top: 42px; height: 39px; width: 25px; background: linear-gradient(to left, rgba(55,114,160,0), #3772a0); z-index: 20; }

#menu .socmed { position: absolute; right: 25px; top: 5px; }
#menu .socmed a { display: inline-block; width: 20px; height: 30px; margin-left: 10px; }
#menu .socmed a.fb { background: url('../gfx/icon-fb.svg') no-repeat center; background-size: auto 16px; }
#menu .socmed a.x { background: url('../gfx/icon-x.svg') no-repeat center; background-size: 16px auto; }
#menu .socmed a.fb:hover { background-size: auto 14px; }
#menu .socmed a.x:hover { background-size: 14px auto; }

.pagetop { background: var(--sppc-blue); padding: 50px 0; color: #fff; margin-bottom: 25px; }
.pagetop h1, .pagetop a { color: inherit; }
.pagetop h1 { margin: 0; }
.breadcrumbs { font: bold 18px/22px neue-haas-grotesk-display, sans-serif; margin-bottom: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.breadcrumbs span { margin: 0 20px; }
.breadcrumbs span:before { content: '\2022'; font-size: 18px; opacity: 0.5; }
.breadcrumbs a:last-child, .breadcrumbs span:last-of-type { display: none; }
.breadcrumbs a:hover { color: var(--sppc-ltpurple); }
.hasvisiblesubmenu .pagetop { padding-top: 90px; }

.lhs { display: inline-block; vertical-align: top; width: calc(100% - 200px); box-sizing: border-box; padding-right: 25px; border-right: 1px solid var(--sppc-neutral); min-height: 200px; margin-bottom: 50px; }
.rhs { display: inline-block; vertical-align: top; width: 200px; box-sizing: border-box; padding-left: 25px; border-left: 1px solid var(--sppc-neutral); margin-left: -1px; margin-bottom: 50px; }
.lhs>*:first-child, .rhs>*:first-child { margin-top: 0; }
.lhs>*:nth-last-child(3), .rhs>*:last-child { margin-bottom: 0; }
.rhs ul { list-style: none; margin: 10px 0; font-size: 14px; line-height: 20px; }
.rhs ul ul { margin: 10px; }
.rhs h4 { margin-bottom: 10px; }
.rhs ul a { color: var(--sppc-body); }
.rhs li { margin-top: 5px; }
.rhs li.current>a { opacity: 0.5; cursor: default; text-decoration: none; }


footer { font-size: 12px; line-height: 18px; border-top: 1px solid var(--sppc-neutral); padding-top: 40px; }
footer a { color: var(--sppc-body); }
.footerlogos { text-align: center; border-bottom: 1px solid var(--sppc-ltneutral); padding-bottom: 40px; }
.footerlogos p { margin: 5px 0; }
.footerlogos img { display: inline-block; margin: 5px; }
.footerleft, .footerright { width: 50%; display: inline-block; vertical-align: top; box-sizing: border-box; margin-top: 15px; }
.footerleft { padding-right: 40px; }
.footerright { padding-left: 40px; text-align: right; }
.footerbottom { background: var(--sppc-ltneutral); text-align: center; font-size: 12px; line-height: 20px; padding: 15px; margin-top: 25px; }
footer a:hover { color: var(--sppc-ltpurple); }

footer .socmed a { display: inline-block; width: 30px; height: 30px; margin-right: 10px; }
footer .socmed a.fb { background: url('../gfx/icon-fb.svg') no-repeat center; background-size: auto 20px; }
footer .socmed a.x { background: url('../gfx/icon-x.svg') no-repeat center; background-size: 20px auto; }
footer .socmed a.fb:hover { background-size: auto 16px; }
footer .socmed a.x:hover { background-size: 16px auto; }

#searchresults .url { text-align: right; font-size: 0.8em; }

blockquote { background: var(--sppc-ltneutral); margin: 20px; padding: 20px; }
blockquote>*:first-child { margin-top: 0!important; }
blockquote>*:last-child { margin-bottom: 0!important; }

.cms_imgleft { max-width: 300px; border: 0; margin: 3px 10px 10px 0; float: left; }
.cms_imgright { max-width: 300px; border: 0; margin: 3px 0 10px 10px; float: right; }
.cms_inplace { display: block; margin: 20px auto; }

.faqjs .questiontitle { background: var(--sppc-purple); color: #fff!important; padding: 10px 50px 10px 20px; margin: 0; font-size: 18px; line-height: 24px; font-weight: 600; position: relative; cursor: pointer; text-align: left; margin-top: 1px; }
.faqjs .questiontitle:after { content: '\25bc'; position: absolute; right: 20px; top: 50%; margin-top: -12px; color: #fff; font-size: 12px; transform: rotate(-90deg); transition: transform 0.25s; }
.faqjs .questiontitle span { position: relative; }
.faqjs .questiontitle:hover { background: var(--sppc-ltpurple); }
.faqjs.faqshown .questiontitle:after { transform: rotate(0); }
.questionanswer { padding: 0 20px; background: var(--sppc-ltneutral); box-sizing: border-box; position: relative; font-size: 16px; line-height: 24px; }
.questionanswer>*:first-child { margin-top: 0; padding-top: 20px; }
.questionanswer>*:last-child { margin-bottom: 0; padding-bottom: 20px; }
.questionanswer { transition: 0.25s max-height; overflow: hidden; }
.faq .questionanswer { max-height: 0!important; }
.faqshown .faqa { max-height: 1000px; }
.questionanswer.notrans { transition:none; }
.questionanswer.answershown { max-height: 4000px!important; }
.questionanswer iframe { width: 100%!important; height: 300px!important; }
.faqsect { margin: 20px 0; }

.lhs li { margin-top: 5px; }
.lhs ul { list-style: none; }
.lhs ul li:before { color: var(--sppc-ltpurple); content: "\2022"; position: absolute; font-size: 18px; line-height: 18px; margin: 4px 0 0 -18px; }
.lhs ul.gridlist { margin: 20px 0; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 25px; }
.lhs ul.gridlist li { display: flex; flex-direction: column; text-align: center; border: 1px solid var(--sppc-ltneutral); justify-content: center; padding: 10px 20px; min-height: 98px; position: relative; }
.lhs ul.gridlist li:before { display: none; }
.lhs ul.gridlist li a { font-weight: 500; }
.lhs ul.gridlist li a:before { content: ''; position: absolute; top: 0; left: 0; bottom: 0; right: 0; }

#map-image { display: inline-block; width: 300px; vertical-align: top; }
ul.loclist { display: inline-block; vertical-align: top; width: calc(100% - 300px); box-sizing: border-box; margin: 0 0 20px; }
ul.loclist li { margin-top: 0; }
table { width: 100%; border-collapse: collapse; }
td { padding: 5px; }
tr.headerrow { background: var(--sppc-blue)!important; color: #fff; font-weight: 500; }
tr:not(.headerrow) { font-size: 0.8em; line-height: 1.4em; border-bottom: 1px solid var(--sppc-ltneutral); transition: background 0.25s; }
tr:not(.headerrow):hover { background: var(--sppc-ltneutral); }
table#services td { position: relative; }
table#services td a:before { position: absolute; top: 0; left: 0; bottom: 0; right: 0; content: ''; }


h2.fl_blogentrytitle, .fl_rsslinks, #fl_tracksbox { display: none; }
.fl_postinfo { font-size: 14px; line-height: 18px; clear: both; padding: 20px 0; text-align: right; text-transform: none; font-style: italic; margin: 0; }
.fl_blogpost1, .fl_blogpost2 { border-bottom: 1px solid var(--sppc-ltneutral); margin-bottom: 20px; padding-bottom: 0; }
.fl_pagelinks { font-size: 14px; line-height: 24px; }
#fl_commsbox { background: transparent; border: 0; border-top: 1px solid var(--sppc-neutral); }
.fl_comment2 { background: var(--sppc-ltneutral); }

.newsitems { display: grid; gap: 25px; grid-template-columns: 1fr 1fr 1fr; }
.newsitems a { display: block; background: var(--sppc-ltneutral); text-decoration: none; color: var(--sppc-body); transform: scale3d(1,1,1); }
.newsitems a .newsimagewrap { margin: 2px 2px 0; padding-bottom: 66.666666%; position: relative; }
.newsimagewrap .newsimage { position: absolute; top: 0; bottom: 0; left: 0; right: 0; background-size: cover; background-position: center; }
.newsitems a .newshead { padding: 0 20px; margin: 20px 0 10px; color: var(--sppc-purple); }
.newsitems a .newstext, .frontboxes a p { padding: 0 20px 10px; font-size: 14px; line-height: 22px; }
.newsitems a:hover { transform: scale3d(1.01,1.01,1); background: var(--sppc-neutral);}

.page-front .pagetop { padding: 0!important; background: #3772a0; position: static; }
.page-front .pagetop .fronttitle { display: inline-block; width: 178px; margin-right: 25px; vertical-align: top; text-align: right; padding: 50px 0; }
.page-front .pagetop .fronttitle:before { content: ''; position: absolute; top: 0; left: -9999px; width: 10227px; bottom: 0; background: var(--sppc-blue); }
.page-front .pagetop .fronttitle h1 { position: relative; }
.page-front .pagetop .frontintro { display: inline-block; width: calc(100% - 203px); box-sizing: border-box; vertical-align: top; padding: 50px 0 50px 25px; font: bold 24px/28px neue-haas-grotesk-display, sans-serif; }
.page-front .pagetop .frontintro>*:first-child { margin-top: 0; }
.page-front .pagetop .frontintro>*:last-child { margin-bottom: 0; }
.page-front .lhs { width: auto; display: block; padding-right: 0; border-right: 0; padding-left: 203px; margin-bottom: 0; }
.fronttop { font-size: 	18px; line-height: 26px; margin-bottom: 50px; }
.frontboxes a { padding-bottom: 10px; }
.frontboxes a .newshead { font-size: 24px; line-height: 28px; }
.frontboxes a p { margin: 0; font-size: 18px; line-height: 24px; font-weight: 500; }
.frontnews { background: var(--sppc-ltneutral); position: relative; margin-top: 25px; padding: 25px 0; box-shadow: 0 0 0 100vmax var(--sppc-ltneutral); clip-path: inset(0 -100vmax); }
.frontnews h2 { position: absolute; width: 228px; left: -228px; text-align: right; margin: 0; font-size: 36px; line-height: 40px; padding-right: 25px; box-sizing: border-box; }
.page-front .newsitems a { background: #fff; }
.page-front .newsitems a:hover { background: var(--sppc-neutral); }
.page-front .frontboxes a { background: var(--sppc-purple); color: #fff; }
.page-front .frontboxes a:hover { background: var(--sppc-ltpurple); }
.frontboxes a .newshead { color: inherit; }

form label { display: block; font-size: 12px; line-height: 17px; text-transform: uppercase; margin: 10px 0 2px; font-weight: 500; }
input, textarea { -webkit-appearance: none; border-radius: 0; }
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(--sppc-ltneutral); border: 0; font: 14px/20px neue-haas-grotesk-text, sans-serif; color: var(--sppc-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(--sppc-ltneutral); color: var(--sppc-body); }
input:focus, textarea:focus, select:focus { background: var(--sppc-ltneutral); color: var(--sppc-body); }
option { padding: 3px 10px; }

input.emailsub, input.passsub, input.commentsub, input.formsub, a.button, button { display: block; width: auto; height: auto; font: bold 12px/20px neue-haas-grotesk-display, sans-serif; margin: 10px 5px 10px 0; padding: 10px 20px; color: #fff!important; border: 0; background: var(--sppc-blue)!important; border-radius: 5px; cursor: pointer; text-decoration: none; text-align: center; height: 40px; box-sizing: border-box; text-transform: uppercase; }
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, button:hover, button:focus { background-color: var(--sppc-ltpurple)!important; }
input.emailsub:active, input.passsub:active, input.commentsub:active, input.formsub:active, a.button:active, .frontbox a:active, button:active { position: relative; top: 2px; }
a.button { display: inline-block; vertical-align: top; }

.subpages { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 25px; }
.subpages a { height: 150px; display: block; background: var(--sppc-purple); text-decoration: none; color: #fff!important; position: relative; }
.subpages a h4 { color: inherit; text-align: center; position: absolute; top: 50%; left: 20px; right: 20px; transform: translateY(-50%); margin: 0; }
.subpages a:hover { background: var(--sppc-ltpurple)!important; }

iframe { max-width: 100%; margin: 20px 0; }
div>iframe { margin: 0; }
.video { display: block; height: 0; padding-bottom: 56.25%; position: relative; background: #fff; }
.video iframe { position: absolute; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; margin: 0; }
#cf-turnstile iframe { margin: 0; }

#fl_loading { display: none; position: fixed; top: 10px; right: 10px; background: #fff; padding: 3px; border: 1px solid #ccc; z-index: 150; width: 32px; z-index: 99; }
#cookiebar { font-size: 12px; line-height: 16px; }
#cookiebar a { display: inline-block; }
#msgbar { font-family: neue-haas-grotesk-text, sans-serif; }
.err, .reqd { font-weight: 500; color: #c00; }

a, input, #menubutton, button, .faqjs .questiontitle { transition: 0.25s; transition-property: opacity, color, background-color, border-color, background-size, transform; }

@media all and (max-width: 939px) {
	html, body { min-width: 320px; -webkit-text-size-adjust: none; }
	.lhs { display: block; width: auto; padding-right: 0; border-right: 0; margin-bottom: 25px; }
	.rhs { display: block; width: auto; padding-left: 0; border-left: 0; padding-top: 25px; border-top: 1px solid var(--sppc-neutral); }
	.page-front .lhs { padding-left: 0; }
	.page-front .frontnews h2 { position: static; width: auto; margin: 0 0 25px; text-align: left; }
}
@media all and (max-width: 839px) {
	.cms_imgleft, .cms_imgright { max-width: 250px; }
	.subpages { grid-template-columns: 1fr 1fr; }
	.newsitems { grid-template-columns: 1fr 1fr; }
}
@media all and (max-width: 767px) {
	.pagetop { margin-bottom: 25px; padding: 25px 0!important; }
	.page-front .pagetop .fronttitle, .page-front .pagetop .frontintro { padding-top: 25px!important; padding-bottom: 25px!important; }
	header a.button, header form { display: none; }
	header { position: sticky; top: 0; background: #fff; border-bottom: 1px solid var(--sppc-neutral); z-index: 30; padding: 20px 0; }
	.logo { width: 130px; height: 80px; }
	.pagetop { position: static; }
	#menubutton { position: absolute; top: 50%; margin-top: -20px; right: 15px; width: 40px; height: 40px; border-radius: 0; cursor: pointer; z-index: 20;  }
	#menubutton:active { opacity: 0.6; }
	#menubutton .rowbar { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: var(--sppc-purple); border-radius: 2px; }
	#menubutton .rowtop { top: 13px; }
	#menubutton .rowbottom { top: 25px; }
	
	.menuwrapper { position: static; border: 0; }

	#menu { position: fixed; top: 0; left: 0; bottom: 0; width: 243px; z-index: 42; height: auto; right: auto; overflow: auto; padding: 0; -webkit-overflow-scrolling: touch; background: rgba(255,255,255,0.95); transform: translate3d(-100%, 0, 0); max-width: none; transition: transform 0.5s; }
	#menu.menublock, #menu:focus-within { transform: translate3d(0, 0, 0); border-right: 1px solid var(--sppc-neutral); }

	#menubg { transition: background 0.25s; }
	body.menublock #menubg { position: fixed; top: 0; left: 0; right: 0; bottom: -70px; z-index: 41; background: rgba(255,255,255,0.7); }

	.fl_menu { margin-left: 0; float: none; padding: 30px 0 0; border: 0;  }
	.fl_menu li, .fl_menu a { display: block!important; width: auto!important; float: none; }
	.fl_menu>li>a { padding: 10px 0!important; margin: 0; text-align: center!important; line-height: 24px!important; background: none!important; }
	.fl_menu>li { border-bottom: 1px solid var(--sppc-ltneutral)!important; margin: 0 10px!important; padding: 0; }
	.fl_menu>li:first-of-type { border-top: 1px solid var(--sppc-ltneutral); }

    .fl_menu ul { position: relative; width: auto; margin: 0 0 5px; padding: 0!important; background: none; top: 0!important; max-height: 2000px!important; width: auto!important; left: 0; right: 0; border: 0; text-align: left; transform: none; }
    .fl_menu ul, .fl_menu li:hover ul, .fl_menu li.hovered ul { display: none!important; }
	.fl_menu ul li { background: transparent; border: 0!important; }
	.fl_menu ul a { text-align: center; border: 0!important; background: transparent; }
	.fl_menu li.hassubmenu>a:before { content: "\25BC"; transform: rotate(-90deg); transition: transform 0.25s; }
	.fl_menu li.expanded>a:before, .fl_menu li:focus-within>a:before { transform: rotate(0); }
	.fl_menu ul.tapped, .fl_menu li:hover ul.tapped, .fl_menu li.hovered ul.tapped, .fl_menu li:focus-within ul { display: block!important; }

	.fl_menu>li a:before { position: absolute; right: 0; color: var(--sppc-purple); font-size: 0.6em; margin: 0; }
	.fl_menu li:before, .fl_menu>li.current.hassubmenu>a:after, .fl_menu>li.curparent.hassubmenu>a:after, .fl_menu>li.curhighparent.hassubmenu>a:after { display: none!important; }
	
	.hasvisiblesubmenu .fl_menu>li.current ul, .hasvisiblesubmenu .fl_menu>li.curparent ul, .hasvisiblesubmenu .fl_menu>li.curhighparent ul { position: static!important; background: none!important; box-shadow: none; clip-path: none; height: auto!important; white-space: normal; }
	.hasvisiblesubmenu .fl_menu>li.current ul a, .hasvisiblesubmenu .fl_menu>li.curparent ul a, .hasvisiblesubmenu .fl_menu>li.curhighparent ul a { color: var(--sppc-body); }
	.hasvisiblesubmenu .fl_menu>li.current ul a:hover, .hasvisiblesubmenu .fl_menu>li.curparent ul a:hover, .hasvisiblesubmenu .fl_menu>li.curhighparent ul a:hover { color: var(--sppc-ltpurple); }
	
	#menu .socmed { position: static; margin: 10px auto; text-align: center; }
	#menu_c_search{ display: block!important; }
	.hasvisiblesubmenu #menu:before, .hasvisiblesubmenu #menu:after { display: none; }
	
}

@media all and (max-width: 699px) {
	.footerleft { display: block; width: auto; margin-bottom: 20px; padding-right: 0; text-align: center; }
	.footerright { display: block; width: auto; text-align: center; padding-left: 0; }
	.footerright span.newline { display: none; }

	.cms_imgleft, .cms_imgright { max-width: 200px; }
	.cms_inplace { max-width: 100%; }

}
@media all and (max-width: 649px) {
	.logo { width: 98px; height: 60px; }
	header { padding: 10px 0; }
	.wallleft { grid-template-columns: 1fr 1fr; }
}
@media all and (max-width: 599px) {
	body { font-size: 14px; line-height: 22px; }
	h1, .frontnews h2 { font-size: 28px; line-height: 32px; }
	h2 { font-size: 24px; line-height: 28px; }
	h3 { font-size: 20px; line-height: 24px; }
	h4, .frontboxes a .newshead { font-size: 18px; line-height: 22px; }
	h5 { font-size: 16px; line-height: 20px; }
	.breadcrumbs { font-size: 14px; line-height: 20px; }

	.cms_imgleft, .cms_imgright { max-width: 100%; display: block; margin: 10px auto; float: none;  }
	.subpages, .newsitems, .wallleft { gap: 20px; }
	
	.fronttop, .frontboxes a p { font-size: 16px; line-height: 22px; }
	.page-front .pagetop .frontintro { font-size: 18px; line-height: 22px; }
	.page-front .pagetop .fronttitle { display: block; width: auto; background: var(--sppc-blue); margin: 0 -25px; text-align: left; padding: 25px; }
	.page-front .pagetop .fronttitle:before { display: none; }
	.page-front .pagetop .frontintro { display: block; width: auto; padding-left: 0; }
}

@media all and (max-width: 479px) {
	.wrapper { padding: 0 20px; }
	.page-front .pagetop .fronttitle { margin: 0 -20px; text-align: left; padding: 25px 20px; }
	#menubutton { right: 10px; }
	.subpages, .newsitems, .wallleft { grid-template-columns: 1fr; }
	.newsitems { max-width: 350px; margin: 0 auto; }
	.page-front .lhs { display: flex; flex-direction: column; }
	.page-front .lhs .fronttop { order: 2; margin: 15px 0; }
	.frontboxes { max-width: 350px; margin: 0 auto; order: 1; }
	.page-front .lhs .frontnews { order: 3; margin-top: 0; }
	#map-image { display: block; margin: 0 auto; }
	ul.loclist { display: block; width: auto; margin: 10px 20px 20px; }
}
@media all and (max-width: 449px) {
	#cf-turnstile { transform: scale(0.8); transform-origin: top left; }
}

.eventform .daterow select { display: inline-block; width: auto; margin-right: 5px; }
.resource { border-top: 1px solid var(--sppc-ltneutral); margin-top: 20px; padding-top: 20px; }
.resource:first-of-type { border-top: 0; margin-top: 0; padding-top: 0; }
.resource>a:first-child { float: right; width: 64px; }
.resource h2 { margin-top: 0; }