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_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;}

:root {
	--spf-text: #000;
	--spf-blue: #416aa2;
	--spf-green: #1d9680;
	--spf-neutral: #f2f2ef;
}


* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; background: #fff; color: var(--spf-text); font: 18px/27px Nunito, sans-serif; }
p { margin: 15px 0; }
ul { margin: 15px 30px; }
ol { margin: 15px 30px; }
a { color: var(--spf-blue); }
a:hover { text-decoration: none; opacity: 0.5; }
b, strong { font-weight: 600; }
img { max-width: 100%; height: auto!important; }

h1, h2, h3, h4, h5, h6 { color: var(--spf-blue); margin: 20px 0; font-weight: 700;  }
h1, h2.frontnewshead { font-size: 36px; line-height: 42px; margin-top: 0; }
h2 { font-size: 28px; line-height: 32px; }
h3, .lhs h4, .linkbox { font-size: 24px; line-height: 28px; }
h4 { font-size: 20px; line-height: 24px; }
h5 { font-size: 18px; line-height: 22px; }
h1 b, h1 strong, h2 b, h2 strong, h3 b, h3 strong, h4 b, h4 strong, h5 b, 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!important; padding: 10px; background: var(--spf-blue); }
.skipto a:focus { margin-left: 0; width: auto; height: auto; opacity: 1; z-index: 50; }

.wrapper { max-width: 1200px; margin: 0 auto; padding: 0 25px; position: relative; }

header { padding: 25px 0; background: #fff; position: fixed; top: 0; left: 0; right: 0; z-index: 50; transition: all 0.5s ease-out; border-bottom: 1px solid var(--spf-neutral); }
.logo { width: 204px; height: 150px; display: inline-block; vertical-align: top; transition: all 0.5s ease-out; position: relative; }
.logo:hover { opacity: 1; }
.scrolled header { padding: 15px 0; }
.scrolled .logo { width: 102px; height: 75px; }

header form.search { position: absolute; top: 0; right: 25px; margin: 0; }
input.searchtext { width: 200px; height: 30px; font-size: 12px; 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(--spf-blue) url('../gfx/magnify-white.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(--spf-blue)!important; }

#menu { position: absolute; right: 25px; bottom: -14px; }
.fl_menu { list-style: none; }
.fl_menu>li { margin-left: 20px; }
.fl_menu li, .fl_menu a { font-size: 14px; line-height: 40px; font-weight: 700; display: inline-block; position: relative; vertical-align: top; color: var(--spf-text); }
.fl_menu a { text-decoration: none; }
.fl_menu>li.current>a, .fl_menu>li.curparent>a, .fl_menu>li.curhighparent>a { color: var(--spf-blue); }

.fl_menu ul { position: absolute; margin: 0; z-index: 20; top: 40px; max-height: 0; right: -10px; width: 200px; overflow: hidden; transition-duration: 0.25s; transition-property: max-height; text-align: right; }
.fl_menu ul li { background: #fff; }
.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; }
.fl_menu ul ul { display: none; }

main { padding-top: 201px; min-height: calc(100vh - 542px); padding-bottom: 10px; }

.pagetop { background: var(--spf-neutral); overflow: hidden; }
.pagetop .wrapper { height: 450px; align-content: center; }
#fadeimg { position: absolute; top: 0; left: 25px; right: 50%; bottom: 0; }
#fadeimg .img { position: absolute; top: 0; left: 0; right: 0; bottom: 0; display: none; }
#fadeimg .img:first-child { display: block; }
#fadeimg img { display: block; width: 100%; height: 100%!important; object-fit: cover; object-position: center; }
#fadeimg.fadejs .img { display: block; opacity: 0; transition: opacity 2s; }
#fadeimg.fadejs .img.showimg { opacity: 1; }

.introbox { padding-left: 25px; margin-left: 50%; position: relative; z-index: 10; font-size: 24px; line-height: 30px; }
.breadcrumbs { font-size: 14px; line-height: 20px; margin-bottom: 15px;  }
.breadcrumbs span:before { content: '\2022'; color: #999; margin: 0 10px; }
.introbox h1 { display: table; background: var(--spf-blue); color: #fff; padding: 10px 20px 10px 50px; margin-left: -50px; margin-bottom: 15px; }
.breadcrumbs a:last-of-type, .breadcrumbs span:last-of-type { display: none; }


.lhs { width: 175px; padding-right: 25px; display: inline-block; vertical-align: top; margin-top: 10px; position: sticky; top: 106px; }
.rhs { width: calc(100% - 200px); display: inline-block; vertical-align: top; margin-top: 10px; }

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

blockquote { margin: 20px; padding: 5px 25px; background: var(--spf-neutral); position: relative; }
.rhs li { margin-top: 3px; }
.rhs ul { list-style: none; }
.rhs ul li:before { color: var(--spf-blue); content: "\2022"; position: absolute; margin: -1px 0 0 -20px; font-size: 0.8em; }
.rhs h2, .rhs h3, .rhs h4, .rhs h5 { display: table; background: var(--spf-blue); color: #fff; padding: 10px; }
form { margin: 15px 0; }
.rhs h2 a, .rhs h3 a, .rhs h4 a, .rhs h5 a { color: inherit; }

.publications { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; margin: 15px 0; }
.publications a { display: block; }
.publications a.downloadimage { display: block; background: var(--spf-blue); height: 0; padding-bottom: 100%; margin-bottom: 5px; position: relative; }
.downloadimage span { position: absolute; top: 1px; left: 1px; bottom: 1px; right: 1px; background-color: #fff; background-size: contain; background-position: center; background-repeat: no-repeat; }
.publications a.downloadimage.downloadgeneric { padding-bottom: 40%; }
.publications a.downloadimage:hover span { transform: scale3d(0.98,0.98,1); }
.downloadimage span.downloadgeneric { background: #fff url('../gfx/spf.svg') no-repeat center; background-size: 60% auto; }
.publications a.downloadtitle { font-weight: bold; }
.publications a.downloadimage:hover { opacity: 1; }

.lhs h4 { margin-top: 15px; }
.lhs ul { margin: 0; list-style: none; }
.lhs li { margin: 10px 0; display: block; }
.lhs li a { color: inherit; }
.lhs li a.current { opacity: 0.5; text-decoration: none; cursor: default; }

.page_front main { padding-bottom: 0; min-height: calc(100vh - 532px); }
.page_front .lhs { display: none; }
.page_front .rhs { width: auto; display: block; margin-top: 25px; }

.frontthree, .frontnewsitems { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; }
.frontnewsitems { grid-template-columns: repeat(4, 1fr); }
.frontthree div, .frontnewsitems a { display: block; padding-top: 250px; background: #fff; border-radius: 10px; box-shadow: 0 0 10px rgba(0,0,0,0.1); position: relative; padding-bottom: 5px; overflow: hidden; }
.frontthree div a, .frontnewsitems a { color: inherit; text-decoration: none; }
.frontthree div a:before { position: absolute; top: 0; left: 0; right: 0; bottom: 0; content: ''; z-index: 10; }
.frontthree div a:hover, .frontnewsitems a:hover { opacity: 1; }
.frontthree div:hover, .frontnewsitems a:hover { transform: scale3d(1.02,1.02,1); }
.frontthree div h2, .frontnewsitems a h3 { padding-left: 20px; }
.frontthree div p, .frontnewsitems a p { padding: 0 20px; }
.frontnewsitems a { padding-top: 0; }
.frontthree div img { position: absolute; top: 0; left: 0; right: 0; width: 100%!important; height:250px!important; background: var(--spf-neutral); margin: 0; object-fit: cover; object-position: center; }
.frontthree div h2 { margin-top: -20px; position: relative; z-index: 8; }
.frontnewsitems a h3 { display: block; margin-top: 0; padding: 20px; }

h2.frontnewshead { display: table; background: var(--spf-blue); color: #fff; padding: 10px 20px 10px 5000px; margin-left: -5000px; margin-top: 25px; margin-bottom: 0; position: relative; z-index: 8; }
.frontnews { background: var(--spf-neutral); margin-top: -25px; position: relative; padding: 50px 0 25px; box-shadow: 0 0 0 100vmax var(--spf-neutral); clip-path: inset(0 -100vmax); }
.frontnews a.newslatest { position: absolute; top: 10px; right: 0; }


footer { font-size: 14px; line-height: 20px; background: #222; position: relative; color: #fff; padding: 45px 0; text-align: center; }
footer a { color: #fff; }
footer p { margin: 5px 0; }
footer .divider { width: 25px; display: inline-block; }

.fl_blogintro, .fl_blogpost1, .fl_blogpost2 { margin-top: 15px; border-bottom: 1px solid var(--spf-neutral); margin-bottom: 30px; padding-bottom: 15px; }
#fl_commsbox { clear: both; margin: 0; padding: 0; border: 0; background: transparent; }
.fl_commentname, .fl_commentmessage { margin-left: 0; }
.fl_blogentrytitle, .fl_newspreview h2 { margin-bottom: 10px; }
.fl_postinfo { font-size: 12px; line-height: 16px; text-transform: none; margin-bottom: 20px; color: #666; }
.fl_comment1, .fl_comment2 { padding: 20px; font-size: 16px; line-height: 20px; }
.fl_comment1 { background: var(--ah-neutral); }
.fl_comment2 { background: transparent; }
.fl_commentname { font-size: 12px; line-height: 16px; }
.fl_blogfooter { color: #999; margin-top: 20px; }
h2.fl_blogentrytitle { margin-top: 0; }
.fl_rsslinks, #fl_tracksbox { display: none; }
.page_blogs .fl_rsslinks { display: block; margin-bottom: 10px; }
.fl_commform { margin-bottom: 20px; }
.fl_tags { font-size: 12px; text-transform: uppercase; }

.fl_mailform label, .fl_commform label, .rhs label { display: block; font-size: 14px; line-height: 18px; margin: 10px 0 5px; font-weight: 600; }
input, textarea { -webkit-appearance: none; border-radius: 0; width: 100%; box-sizing: border-box; }
input, textarea, .fl_mailform textarea, select, button { font: 14px Nunito, sans-serif; color: #666; border: 0; background: var(--spf-neutral); width: 100%; margin-right: 5px; display: block; padding: 10px; border-radius: 2px; box-sizing: border-box; height: 40px; position: relative; }
textarea, .fl_mailform textarea { height: 250px; }
input.checkbox, input[type=checkbox] { border: 0; width: auto; display: inline; background: transparent; -webkit-appearance: checkbox; height: auto; }
input:hover, textarea:hover, select:hover { background-color: var(--spf-neutral); }
input:focus, textarea:focus, select:focus { background-color: var(--spf-neutral); color: #222; }

a.button { text-decoration: none; text-align: center; display: inline-block; }
input.emailsub, input.commentsub, input.formsub, .button { display: block; width: auto; font-weight: 700; font-size: 18px; line-height: 30px; height: 50px; margin: 10px 5px 10px 0; padding: 10px 20px; color: #fff!important; border: 0; background: var(--spf-blue) linear-gradient(25deg, rgba(0,0,0,0.2), var(--spf-blue)); border-radius: 10px; cursor: pointer; text-decoration: none; box-sizing: border-box; }
input.emailsub:hover, input.commentsub:hover, input.formsub:hover, .button:hover { transform: scale3d(1.05,1.05,1); opacity: 1; }
input.emailsub:active, input.commentsub:active, input.formsub:active, .button:active { position: relative; top: 2px; }
.page_front a.button { margin-top: 0; }

.linkswrap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; margin: 25px 0; }
.linkbox { display: block; background: var(--spf-blue) linear-gradient(25deg, rgba(0,0,0,0.2), var(--spf-blue)); border-radius: 10px; position: relative; text-decoration: none; padding: 10px; color: #fff; font-size: 24px; line-height: 28px; font-weight: 700; text-align: center; align-content: center; min-height: 75px; }
.linkbox:hover { transform: scale3d(1.05,1.05,1); opacity: 1; }

summary { background: var(--spf-green); font-weight: bold; color: #fff; position: relative; list-style: none; cursor: pointer; padding: 0 30px 0 10px; border-radius: 0; line-height: 40px; z-index: 2; transition: opacity 0.25s; }
summary::-webkit-details-marker { display: none; }
summary:after { position: absolute; top: 50%; margin-top: -10px; line-height: 20px; right: 10px; content: '\25B6'; font-size: 0.8em; transition: transform 0.25s; }
summary:hover { opacity: 0.5; }

details { margin: 10px 0; }
details[open] summary { border-radius: 0; }
details[open] summary:after { transform: rotate(90deg); }

.detailswrap { opacity: 1; padding: 10px; background: var(--spf-neutral); border-radius: 0; position: relative; z-index: 1; animation: none; }
.detailswrap > *:first-child { margin-top: 0; }
.detailswrap > *:last-child { margin-bottom: 0; }

details {

  @media (prefers-reduced-motion: no-preference) {
    interpolate-size: allow-keywords;
  }

  &::details-content {
    block-size: 0;
    overflow-y: clip;
	transition: content-visibility 0.5s allow-discrete, block-size 0.5s;
  }

  &[open]::details-content {
    block-size: auto;
  }
}

@supports not (interpolate-size: allow-keywords) {
	details[open] .detailswrap { animation: 0.5s linear details-in; animation-fill-mode: forwards; }
}

@keyframes details-in {
  from {
    transform: translate3d(0,-20px,0);
    opacity: 0;
  }
  to {
    transform: translate3d(0,0,0);
    opacity: 1;
  }
}

#fl_loading { display: none; position: fixed; top: 10px; right: 10px; background: #fff; padding: 3px; border: 1px solid #ccc; z-index: 50; width: 32px; height: 32px; }
#cookiebar { font-size: 12px; line-height: 16px; }
#cookiebar a { display: inline-block; }

iframe { max-width: 100%; }

#msgbar { font-family: Nunito, sans-serif; }

@keyframes slide-in {
  0% {
    opacity: 0;
    transform: translate3d(0,50px,0);
  }

  100% {
    opacity: 1;
    transform: translate3d(0,0,0);
  }
}

.hasjs .blockready { opacity: 0; transform: translate3d(0,50px,0); }
.hasjs .blockdisp { animation-duration: 0.75s; animation-iteration-count: 1; animation-name: slide-in; animation-fill-mode: forwards; }

a, input, .publications a.downloadimage span, .frontthree div { transition-duration: 0.25s; transition-property: color,background,border,opacity,transform; }

#fl_gallwrap { z-index: 50; }

.lastupdateboxes { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.searchcats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.searchcats input { display: inline-block; width: 20px; height: 20px; vertical-align: bottom; }
.searchcats label span { line-height: 40px; }
.pf_search hr { display: none; }

.result { margin: 20px 0 15px; padding-left: 90px; position: relative; }
.result a.resulttitle { font-size: 1.2em; line-height: 1.2em; font-weight: bold; display: inline-block; margin-bottom: 5px; }
.result img { position: absolute; top: 3px; left: 0; width: 80px; height: 80px!important; object-fit: contain; object-position: center; object-repeat: no-repeat; outline: 1px solid var(--spf-neutral); transition: outline 0.5s; }
.result a:hover img { outline-color: var(--spf-blue); }
.resultlu, .resultcat, .resultscore, .resulturl { text-align: right; font-size: 0.8em; line-height: 1.4em; color: #666; word-wrap: break-word; }
.resultlu:before { content: 'Last update: '; opacity: 0.8; }
.resultcat:before { content: 'Category: '; opacity: 0.8; }
.resultscore:before { content: 'Score: '; opacity: 0.8; }
.resulturl:before { content: 'URL:\00a0'; opacity: 0.8; }
.pages { margin: 20px 0; line-height: 40px; }
.pages:before { content: 'Pages: '; }
.pages span, .pages a { display: inline-block; height: 40px; box-sizing: border-box; line-height: 38px; border: 1px solid #ccc; width: 40px; text-align: center; font-size: 0.8em; margin-left: 5px; font-weight: bold; text-decoration: none; }
.pages span { font-style: italic; cursor: default; }
.pages a:hover { background: var(--spf-blue); color: #fff; opacity: 1; }
#resultswrap { position: relative; }
#results { position: absolute; top: -150px; height: 150px; width: 10px; pointer-events: none;}

.fl_gallinc { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.gallthumbnail { width: auto!important; height: auto!important; float: none; border: 0; margin: 0; }
.gallthumbnail a, .gallthumbnail img { display: block; }
.gallthumbnail a { border: 1px solid var(--spf-blue); }

form#searchform { position: relative; }
button#advancedtoggle { position: absolute; bottom: 0; right: 0; cursor: pointer; background: none; font-size: 14px; color: var(--spf-blue); transition: opacity 0.5s; width: auto; margin: 0; padding: 0; }
button#advancedtoggle:hover { opacity: 0.5; }
button#advancedtoggle:before { content: 'Show advanced options'; }
#search_advanced { display: none; }
.advancedshow #search_advanced { display: block; }
.advancedshow button#advancedtoggle:before { content: 'Hide advanced options'; }

@media (max-width: 1250px) {
    html, body { min-width: 320px; -webkit-text-size-adjust:none; }
	#fadeimg { left: 0; }
}
@media (max-width: 1099px) {
	.cms_imgleft, .cms_imgright { max-width: 250px; }
}
@media (max-width: 979px) {
	#menubutton { position: absolute; bottom: 0; right: 20px; width: 40px; height: 40px; cursor: pointer; z-index: 40; transition: all 0.5s; }
	#menubutton .rowbar { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: var(--spf-blue); border-radius: 2px; transition: all 0.5s; }
	#menubutton .rowtop { top: 13px; }
	#menubutton .rowbottom { top: 25px; }

	.menushown #menubutton .rowtop, .menushown #menubutton .rowbottom { opacity: 0; }
	.menushown #menubutton .rowbar:nth-child(2) { transform: rotate(-45deg); }
	.menushown #menubutton .rowbar:nth-child(3) { transform: rotate(45deg); }
	
	body.menushown main, body.menushown footer { pointer-events: none; filter: blur(5px); }
	
	header form, .logo { z-index: 10; }
	
	#menu { position: fixed; top: 0; left: 0; right: 0; height: 100vh; background: rgba(255,255,255,0.8); z-index: 9; transform: translate3d(0,-100%,0); transition: transform 0.5s ease-in-out; }
	.menushown #menu { transform: translate3d(0,0,0); }
	.fl_menu { position: absolute; top: 220px; left: 50px; right: 50px; text-align: center; margin: 0; bottom: auto; }
	.scrolled .fl_menu { top: 125px; }
	.fl_menu li, .fl_menu a { display: block; }
	.fl_menu li { margin: 5px 0; }
	.fl_menu li:after, .fl_menu ul { display: none!important; }

	main>.wrapper { display: flex; flex-direction: column-reverse;}
	.lhs, .rhs { width: auto; display: block; padding-right: 0; }
	.lhs { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--spf-neutral); }
	.lhs:empty { display: none; }

	.cms_imgleft, .cms_imgright { max-width: 300px; }

}
@media (max-width: 849px) {
	.frontthree, .frontnewsitems { grid-template-columns: repeat(2, 1fr); }
	.frontthree>div:nth-of-type(3) { position: relative; left: 50%; }
}
@media (max-width: 799px) {
	.linkswrap { grid-template-columns: repeat(2, 1fr); }
	.cms_imgleft, .cms_imgright { max-width: 250px; }
}
@media (max-width: 699px) {
	html, body { font-size: 16px; line-height: 25px; }
	h1, h2.frontnewshead { font-size: 32px; line-height: 36px; }
	h2 { font-size: 24px; line-height: 28px; }
	h3, .lhs h4, .linkbox { font-size: 20px; line-height: 24px; }
	h4, .introbox { font-size: 18px; line-height: 22px; }
	h5 { font-size: 16px; line-height: 20px; }
	footer { font-size: 12px; line-height: 18px; }
	
	header { padding: 15px 0; }
	.logo { margin: 0 auto; width: 102px; height: 75px; display: block; }
	#menubutton { left: 20px; right: auto; bottom: auto; top: 50%; margin-top: -20px; }
	header form input#search { display: none; }
	header form.search { position: static; }
	header form input.gosearch, header form input.gosearch:hover { position: absolute; right: 20px; top: 50%; margin: -20px 0 0; width: 40px; height: 40px; background: url('../gfx/magnify-blue.svg') no-repeat center / 50% auto!important; border-radius: 0; }
	
	.pagetop .wrapper { height: auto; padding: 0; }
	main { padding-top: 106px; min-height: calc(100vh - 444px); }
	#fadeimg { position: relative; right: 0; bottom: auto; height: 400px; max-height: 40vh; min-height: 250px; overflow: hidden; }
	.introbox { margin-left: 0; padding: 25px 25px 10px; }
	.page_front .introbox { padding-top: 0; }
	.page_front .introbox h1 { position: relative; top: -25px; }
	.page_front .introbox div:first-of-type { margin-top: -25px; }
	
	.fl_menu { top: 125px; }

	.cms_imgleft, .cms_imgright { max-width: 200px; }
}
@media (max-width: 649px) {
	.publications { grid-template-columns: repeat(2, 1fr); }
	.fl_gallinc { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 599px) {
	.searchcats { grid-template-columns: 1fr; }
	.cms_imgleft, .cms_imgright { display: block; float: none; max-width: none; margin: 10px auto; }
}
@media (max-width: 499px) {
	.result { padding-left: 70px; }
	.result img { width: 60px; height: 60px!important; }
	.resultlu, .resultcat, .resulturl { margin-left: -70px; }
	.frontthree { grid-template-columns: 1fr; }
	.frontthree>div:nth-of-type(3) { position: static; }
}
@media (max-width: 399px) {
	.linkswrap, .lastupdateboxes { grid-template-columns: 1fr; }
	#cf-turnstile { transform: scale(0.8); transform-origin: top left; }
	.publications, .frontnewsitems { grid-template-columns: 1fr; }
	.fl_gallinc { grid-template-columns: repeat(2, 1fr); }
}

@media (max-height: 499px) {
	.logo { z-index: 8; }
	.fl_menu { top: 50%; z-index: 50; transform: translateY(-50%); }
}