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;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;z-index:99;}
#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 {
	--esas-red: #df4448;
	--esas-yellow: #faad43;
	--esas-purple: #9a6fb0;
	--esas-green: #43a186;
	--esas-body: #000;
	--esas-faded: #444;
	--esas-neutral: #f2f2f2;
}


* { margin: 0; padding: 0; border: 0; }
html, body { min-height: 100%; background: #fff; color: var(--esas-body); font: 18px/24px "Nunito", sans-serif; }
p { margin: 25px 0; }
ul, ol { margin: 25px 40px; }
a { color: var(--esas-red); }
a:hover { text-decoration: none; color: var(--esas-yellow); }
img { max-width: 100%; height: auto!important; }

h1, h2, h3, h4 { margin: 25px 0; color: var(--esas-red); font-weight: 600; font-family: "Barlow Condensed", sans-serif; }
h1 { font-size: 48px; line-height: 48px; margin-top: 0; }
h2 { font-size: 36px; line-height: 36px; }
h3 { font-size: 28px; line-height: 28px; }
h4 { font-size: 24px; line-height: 24px; }
h5 { font-size: 20px; 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: 600; }
.textlabel { position: absolute; margin-left: -9999px; }
h1:empty { display: none; }
.wrapper { max-width: 1200px; margin: 0 auto; padding: 0 50px; position: relative; }

.skipto a { position: absolute; margin-left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; color: var(--esas-body)!important; padding: 10px; background: var(--esas-yellow); }
.skipto a:focus { margin-left: 0; width: auto; height: auto; }

.headerwrap { position: relative; overflow: hidden; height: 270px; width: 100%; max-width: 2000px; margin: 0 auto; }

header { background: var(--esas-red); transform: rotate(-18deg); transform-origin: bottom left; padding: 150px 0 10px 100px; margin: 0 0 0 0; position: fixed; top: 0; left: 0; right: 0; z-index: 45; }
.headerbehind { background: rgba(255,255,255,0.75); transform: rotate(-18deg); transform-origin: bottom left; padding: 180px 0 10px 50px; margin: 0 0 0 0; position: fixed; top: 0; left: 0; right: 0; z-index: 43; height: 100px; -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); }

header .wrapper { height: 100px; max-width: none; padding: 0; }
.logo { display: block; width: 420px; position: absolute; bottom: -33px; left: 0; }
.logo img { display: block; }
nav { background: var(--esas-yellow); transform: rotate(6deg); transform-origin: bottom right; padding: 150px 50px 10px 0; margin: -50px 0 0 0; text-align: right; position: fixed; top: 0; left: 0; right: 0; z-index: 44; }

#menu input { display: none; }

.fl_menu li, .fl_menu a { display: inline-block; position: relative; vertical-align: top; font-size: 16px; line-height: 24px; }
.fl_menu li { margin-left: 20px; }
.fl_menu a { text-decoration: none; color: var(--esas-body); font: 600 24px/24px "Barlow Condensed", sans-serif; }
.fl_menu li.current a:after { position: absolute; width: 14px; height: 14px; bottom: -18px; left: 50%; margin-left: -6px; content: ''; background: url('../gfx/tri.svg') no-repeat; background-size: contain; }
.fl_menu a:hover { transform: scale3d(1.1,1.1,1); }

body.bg-1:before { position: absolute; top: 50px; right: 0; width: 600px; height: 350px; background: url('../gfx/tri-right-1.svg') no-repeat top right -200px; background-size: auto 350px; content: ''; }
body.bg-2:before { position: absolute; top: 50px; right: 0; width: 600px; height: 350px; background: url('../gfx/tri-right-2.svg') no-repeat top right -10px; background-size: auto 350px; content: ''; }
body.bg-3:before { position: absolute; top: 20px; right: 0; width: 600px; height: 350px; background: url('../gfx/tri-right-3.svg') no-repeat top right -30px; background-size: auto 350px; content: ''; }
body.bg-4:before { position: absolute; top: 20px; right: 0; width: 600px; height: 350px; background: url('../gfx/tri-right-4.svg') no-repeat top right -30px; background-size: auto 350px; content: ''; }
body.bg-5:before { position: absolute; top: 0px; right: 0; width: 600px; height: 350px; background: url('../gfx/tri-right-5.svg') no-repeat top right -70px; background-size: auto 350px; content: ''; }

main { padding-bottom: 100px; min-height: calc(100vh - 645px); }

.lhs { width: 220px; margin: 0 0 0 -50px; padding: 50px 50px 100px; position: relative; font: 600 24px/28px "Barlow Condensed", sans-serif; display: inline-block; vertical-align: top; }
.lhs:before { position: absolute; top: 0; right: 0; width: 5000px; bottom: 0; background: var(--esas-neutral);; content: ''; transform: rotate(2deg); transform-origin: top right; pointer-events: none; }
.lhs ul:before { position: absolute; top: -250px; right: 0; background: #fff; content: ''; width: 5000px; height: 250px; transform: rotate(-6deg); transform-origin: bottom right; pointer-events: none; }
.lhs ul:after { position: absolute; bottom: -250px; right: 0; background: #fff; content: ''; width: 5000px; height: 250px; transform: rotate(11deg); transform-origin: bottom right; pointer-events: none; }
.lhs ul { list-style: none; margin: 10px 0; }
.lhs a { text-decoration: none; position: relative; color: var(--esas-faded); }
.lhs .curcat a { color: var(--esas-body); }
.lhs a:hover { color: var(--esas-yellow); }
.lhs ul ul { margin: 10px 0 10px 20px; display: none; font-size: 18px; line-height: 22px; }
.lhs li.curcat ul { display: block; }
.lhs>ul>li { margin-top: 20px; }
.lhs ul ul li { margin-top: 10px; }

.lhs li a:before { content: ''; width: 12px; height: 12px; position: absolute; left: -20px; top: 50%; margin-top: -6px; background-repeat: no-repeat; background-position: left; background-color: transparent; background-size: contain; display: none; }
.lhs .cursect>a:before, .lhs .curtk>a:before { background-image: url('../gfx/tri-yellow.svg'); display: block; }

.lhs:after { content: ''; position: absolute; right: 0; bottom: -280px; height: 350px; background: url('../gfx/tri-left-1.svg') no-repeat top right; background-size: contain; width: 5000px; z-index: 0; }
.lhs-2:after { background-image: url('../gfx/tri-left-2.svg'); }
.lhs-3:after { background-image: url('../gfx/tri-left-3.svg'); }
.lhs-4:after { background-image: url('../gfx/tri-left-4.svg'); }
.lhs-5:after { background-image: url('../gfx/tri-left-5.svg'); }

.rhs { box-sizing: border-box; }
.pf-toolkit .rhs, .pf-improvement-plan .rhs { width: calc(100% - 320px); display: inline-block; vertical-align: top; box-sizing: border-box; padding: 30px 0 20px 50px; position: relative; }

.cms_imgleft { max-width: 250px; border: 0; margin: 3px 10px 10px 0; float: left; }
.cms_imgright { max-width: 250px; border: 0; margin: 3px 0 10px 10px; float: right; }
.cms_inplace { display: block; margin: 20px auto; }
.rhs li { margin-top: 10px; position: relative; }
.rhs ul { list-style: none; }
.rhs ul li:before { background: url('../gfx/tri-purple.svg') no-repeat top left; position: absolute; margin: 5px 0 0 -25px; width: 12px; height: 12px; content: ''; background-size: contain; }
blockquote { background: var(--esas-neutral); margin: 30px; padding: 1px 25px; border-left: 2px solid var(--esas-yellow); }
iframe { max-width: 100%; }

form.formnarrow, .pagecol form { max-width: 800px; margin: 0 auto; box-sizing: border-box; padding: 15px 25px; background: rgba(242,242,242,0.25); }
.pagecol { display: inline-block; width: 50%; vertical-align: top; box-sizing: border-box; }
.pagecol:first-child { padding-right: 25px; margin-top: -25px; }
.pagecol:nth-child(2) { padding-left: 25px; }

.rhs ul.gridlist, .rhs ul#gridbox { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 25px 0; }
.rhs ul.gridlist li, .rhs ul#gridbox li { display: block; padding: 15px; background: var(--esas-neutral); text-align: center; margin: 0; align-content: center; border-top: 2px solid var(--esas-purple); }
.rhs ul#gridbox li { align-content: flex-start; }
.rhs ul.gridlist li:hover, .rhs ul#gridbox li:hover { background: var(--esas-purple); color: #fff; }
.rhs ul.gridlist li:before, .rhs ul#gridbox li:before { display: none; }
.gridlist .cms_inplace, #gridbox .cms_inplace { margin: 0 auto 10px; }

.diagramlevels { position: relative; width: 700px; height: 390px; background: var(--esas-red); margin: 0 auto; }
.diagramleft, .diagramright { width: 50%; height: 100%; background: #fff; }
.diagramleft { float: left; shape-outside: polygon(0 0, 0 100%, 100% 0); clip-path: polygon(0 0, 0 100%, 100% 0); }
.diagramright { float: right; shape-outside: polygon(0 0, 100% 0, 100% 100%); clip-path: polygon(0 0, 100% 0, 100% 100%); }
.diagramlevels p { margin: 0; padding: 10px; text-align: center; color: #fff; }
.diagramlevels p.level3 { background: var(--esas-green); } 
.diagramlevels p.level2 { background: var(--esas-yellow); color: var(--esas-body); } 
.diagramlevels p.level1 { background: var(--esas-red); } 

.vidembed { position: relative; height: 0; padding-bottom: 56.25%; margin-bottom: 25px; }
.vidembed iframe { position: absolute; top; 0; bottom: 0; left: 0; right: 0; width: 100%; height: 100%; }

.videowatch, form.assessmenthidden { display: none; }

.faqjs { max-height: 20000px; overflow: hidden; }
.faqjs.faqhidden { max-height: 0; }
.questiontitle { background: var(--esas-yellow); padding: 9px 40px 11px 20px; margin: 0; position: relative; cursor: pointer; text-align: left; margin-top: 5px; transition: all 0.25s; color: var(--esas-body)!important; }
.questiontitle.questionhl { background: var(--esas-green); color: #fff!important; }
.faqjs .questiontitle.questionhl:after { background-image: url('../gfx/tri-white.svg'); }
.faqjs .questiontitle:after { content: ''; position: absolute; right: 10px; top: 50%; margin-top: -6px; transition: all 0.5s; background: url('../gfx/tri-black.svg') no-repeat center; background-size: contain; width: 12px; height: 12px; }
.questiontitle:hover { background: var(--esas-purple); color: #fff!important; }
.faqjs.faqshown .questiontitle:after { transform: rotate(90deg); }
.questionanswer { padding: 0 20px; box-sizing: border-box; position: relative; background: var(--esas-neutral); }
.questionanswer h2, .questionanswer h3, .questionanswer h4 { text-align: left; margin: 10px 0; }
.questionanswer>*:first-child { margin-top: 0; padding-top: 20px; }
.questionanswer>p:first-of-type { margin-top: 0; }
.questionanswer>*:last-child { margin-bottom: 0; padding-bottom: 20px; }
.questionanswer { transition: 0.2s max-height; overflow: hidden; }
.faq .questionanswer { max-height: 0!important; }
.faqshown .faqa { max-height: 1000px; }
.questionanswer.notrans { transition:none; }
.questionanswer.answershown { max-height: 40000px!important; }

.subcats { display: grid; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 1fr; gap: 25px; margin-bottom: 50px; }
.subpages { grid-template-columns: repeat(3, 1fr); }
.subcats a { display: flex; align-items: center; box-sizing: border-box; padding: 15px; text-align: center; justify-content: center; background: var(--esas-yellow); color: var(--esas-body); font: 600 28px/32px "Barlow Condensed", sans-serif; text-decoration: none; }

.page-front main { padding-bottom: 50px; }
.page-front>.wrapper { max-width: none; padding: 0; }
.page-front .frontcontent { max-width: 1000px; margin: 0 auto; padding: 0 50px; }
.page-front h1.maintitle { display: none; }
.page-front h1, .page-front h2 { font-size: 64px; line-height: 64px; }
.page-front .front-intro { margin-top: -50px; min-height: 620px; background: url('../gfx/bg-front-intro@2x.png') no-repeat center; background-size: auto 620px; }
.page-front .front-intro .frontcontentwrap { padding: 30px 0 0 43%; }
.page-front .front-intro p:first-of-type { font-size: 24px; line-height: 32px; }
.page-front .front-intro .fronttriangle { float: left; shape-outside: polygon(0 0, 0 100%, 100% 100%); clip-path: polygon(0 0, 0 100%, 100% 100%); background: transparent; width: 187px; height: 500px; pointer-events: none; }

.page-front .front-how { margin-top: -100px; min-height: 595px; background: url('../gfx/bg-front-how@2x.png') no-repeat center; background-size: auto 595px; }
.page-front .front-how .frontcontentwrap { padding-right: 62%; }
.page-front .front-how h2 { max-width: 80%; }

.page-front .front-account { margin-top: -220px; min-height: 589px; background: url('../gfx/bg-front-account@2x.png') no-repeat top; background-size: auto 589px; }
.page-front .front-account .frontcontentwrap { text-align: center; padding: 190px 200px 0; }


.footerwrap { position: relative; overflow: hidden; padding-top: 100px; width: 100%; max-width: 2000px; margin: 0 auto; }

footer { font: 600 16px/20px "Barlow Condensed", sans-serif; position: relative; }
.footwrap { padding: 0 0 50px; background: #e6e6e6; position: relative; z-index: 5; }
footer:before { position: absolute; top: -100px; left: 0; right: -100px; height: 100px; content: ''; background: rgba(0,0,0,0.05); transform-origin: top left; transform: rotate(3deg); }
footer:after { position: absolute; top: -100px; left: -100px; right: 0; height: 100px; content: ''; background: rgba(0,0,0,0.05); transform-origin: top right; transform: rotate(-2deg); }
footer .links .linktitle { display: block; font-weight: 600; margin: 0 0 -10px 20px; }
footer a, footer a:hover { color: var(--esas-body); }
footer a:hover { color: rgba(0,0,0,0.6); }
.footerleft, .footerright { display: inline-block; width: 50%; vertical-align: top; box-sizing: border-box; }
.footerright { padding-left: 50px; text-align: right; }
footer p { margin: 10px 0; }
.footerlogos img { display: inline-block; vertical-align: top; }
.footerlogos a { display: inline-block; vertical-align: top; margin-left: 20px; }
.footerlogos a:first-child { margin-left: 0; }
.footerlogos:last-of-type { margin-top: 20px; }
footer a.fuzzy { color: var(--esas-faded)!important; }

.hasjs .blockmightfade { opacity: 1; transition: all 1s; }
.hasjs .blockready { transform: translate3d(0,50px,0); opacity: 0; }


form label { display: block; font-size: 14px; line-height: 18px; margin: 10px 0 2px; color: var(--esas-fade); 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; }
input[type=checkbox] { -webkit-appearance: checkbox; }
label .reqd { margin-left: 5px; }

input, textarea, .fl_mailform textarea, select { background: var(--esas-neutral); border: 0; font: 14px/20px "Nunito", sans-serif; color: var(--esas-fade); 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(--esas-neutral); color: var(--esas-fade); }
input:focus, textarea:focus, select:focus { background: var(--esas-neutral); color: var(--esas-body); }
option { padding: 3px 10px; }

input.emailsub, input.formsub, a.button, span.button, button { display: block; width: auto; height: auto; font: 600 24px/28px "Barlow Condensed", sans-serif, sans-serif; margin: 10px 5px 10px 0; padding: 12px 25px; color: var(--esas-body)!important; border: 0; background: var(--esas-yellow); border-radius: 0; cursor: pointer; text-decoration: none; text-align: center; }
input.emailsub:hover, input.formsub:hover, a.button:hover, span.button:hover, button:hover, input.emailsub:focus, input.formsub:focus, a.button:focus, span.button:focus, button:focus, .subcats a:hover, .subcats a:focus { transform: scale3d(1.05,1.05,1); }
input.emailsub:active, input.formsub:active, a.button:active, span.button:active, button:active, .subcats a:active { position: relative; top: 2px; }
a.button { display: inline-block; }

.button .dlicon { display: inline-block; width: 20px; height: 20px; background: url('../gfx/icon-download.svg') no-repeat center; background-size: contain; margin-right: 10px;}

.buttons { margin-top: 25px; }
.prevnext { margin: 20px 0 0; border-top: 1px solid #e6e6e6; display: flex; padding-top: 20px; position: relative; }
.blockdl { text-align: right; margin-top: 10px; }
.blockdl a.button { margin-right: 0; }
a.buttonprev, a.buttonnext, .prevspacer, .nextspacer { display: flex; width: calc(50% - 50px); vertical-align: top; min-height: 40px; margin: 0; position: relative; align-items: center; box-sizing: border-box; flex-grow: 1; font-size: 24px; line-height: 28px; }
a.buttonprev, .prevspacer { margin-right: 100px; }
a.buttonprev { text-align: left; justify-content: left; padding-left: 40px; }
a.buttonnext { text-align: right; justify-content: right; padding-right: 40px; }
a.buttonprev:before { content: '«'; position: absolute; top: 50%; left: 20px; font-size: 24px; line-height: 28px; margin-top: -14px;  }
a.buttonnext:before { content: '»'; position: absolute; top: 50%; right: 20px; font-size: 24px; line-height: 28px; margin-top: -14px; }

.boxpattern, .buttonnext, .buttonprev { overflow: hidden; position: relative; }
.buttonprev .boxpattern, .buttonnext .boxpattern { position: static; }
.buttonlabel { position: relative; z-index: 1; }
.boxpattern:before, .boxpattern:after { position: absolute; content: ''; background-repeat: no-repeat; background-position: center; background-size: contain; z-index: 0; transition: transform 0.5s; }

.boxpattern:hover:before, .boxpattern:hover:after, a:hover .boxpattern:before, a:hover .boxpattern:after { transform: scale3d(1.5,1.5,1); }

.boxpatternl1:before { background-image: url('../gfx/button-tri-purple.svg'); top: -75px; bottom: 50%; left: -50px; width: 100px; }
.boxpatternr1:after { background-image: url('../gfx/button-tri-purple.svg'); top: -75px; bottom: -150px; right: -50px; width: 100px; transform: rotate(165deg); }

.boxpatternr1:hover:after, a:hover .boxpatternr1:after { transform: scale3d(1.5,1.5,1) rotate(165deg); }

.boxpatternl2:before { background-image: url('../gfx/button-tri-green.svg'); top: -75px; bottom: -150px; right: -25px; width: 100px; transform: rotate(165deg); }
.boxpatternr2:after { background-image: url('../gfx/button-tri-green.svg'); top: 50%; bottom: -75%; left: -40px; width: 100px; }

.boxpatternl2:hover:before, a:hover .boxpatternl2:before { transform: scale3d(1.5,1.5,1) rotate(165deg); }

.boxpatternl3:before { background-image: url('../gfx/button-tri-red.svg'); top: 20%; bottom: -10%; left: -20px; width: 100px; background-position: bottom left; }
.boxpatternr3:after { background-image: url('../gfx/button-tri-red.svg'); top: 50%; bottom: -50px; right: -50px; width: 100px; transform: rotate(195deg); }

.boxpatternr3:hover:after, a:hover .boxpatternr3:after { transform: scale3d(1.5,1.5,1) rotate(195deg); }

.boxpatternl4:before { background-image: url('../gfx/button-tri-blue.svg'); top: -25%; bottom: 50%; right: -50px; width: 100px; transform: rotate(195deg); }
.boxpatternr4:after { background-image: url('../gfx/button-tri-blue.svg'); top: 25%; bottom: -25%; left: -30px; width: 150px; background-position: bottom left; }

.boxpatternl4:hover:before, a:hover .boxpatternl4:before { transform: scale3d(1.5,1.5,1) rotate(195deg); }

.boxpatternl5:before { background-image: url('../gfx/button-tri-neutral.svg'); top: -5%; bottom: 25%; left: -20px; width: 250px; background-position: bottom left; }
.boxpatternr5:after { background-image: url('../gfx/button-tri-neutral.svg'); top: -50%; bottom: -50%; right: -125px; width: 200px; transform: rotate(-5deg); }

.boxpatternr5:hover:after, a:hover .boxpatternr5:after { transform: scale3d(1.5,1.5,1) rotate(-5deg); }

.assessmentcatslist, .assessmentoptions { display: grid; grid-template-columns: 1fr 1fr; gap: 25px; }
.assessmentoptions { grid-template-columns: 1fr 1fr 1fr; margin-bottom: 50px; }
.assessmentcatslist label, .assessmentoptions label { padding: 20px; text-align: center; background: var(--esas-neutral); font-size: 18px; line-height: 24px; margin: 0; cursor: pointer; align-content: center; }
.assessmentcatslist input:checked+label { background: var(--esas-purple); color: #fff; }
.assessmentcatslist input, .assessmentoptions input { position: absolute; left: -9999px; }
.assessmentcatslist { margin-bottom: 25px; }

.assessmentcatslist label:hover, .assessmentoptions label:hover { transform: scale3d(1.05,1.05,1); }
.assessmentoptions input:checked+label.assessmentalways { background: var(--esas-green); color: #fff; }
.assessmentoptions input:checked+label.assessmentnever { background: var(--esas-red); color: #fff; }
.assessmentoptions input:checked+label.assessmentsometimes { background: var(--esas-yellow); color: #fff; }

.assessmentcat { margin-top: 20px; padding-top: 20px; border-top: 1px solid #e6e6e6; }
.assessmentcat:first-of-type { margin-top: 0; padding-top: 0; border-top: 0; }

.assessmentoptions>div { display: block; text-align: center; padding: 20px 10px; opacity: 0.5; background: var(--esas-neutral); }
.assessmentoptions>div.assessmentselected { opacity: 1; color: #fff; font-weight: 600; }
.assessmentoptions>div.assessmentselected.assessmentalways { background: var(--esas-green); }
.assessmentoptions>div.assessmentselected.assessmentnever { background: var(--esas-red); }
.assessmentoptions>div.assessmentselected.assessmentsometimes { background: var(--esas-yellow); }


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

.err, .reqd { font-weight: 700; color: var(--esas-red); }

a, a:after, input, span.button, button, .assessmentcatslist label, .assessmentoptions label, .rhs ul.gridlist li, .rhs ul#gridbox li { transition: 0.25s; transition-property: opacity, color, background-color, border-color, transform, padding; }

@media all and (max-width: 1199px) {
	html, body { min-width: 320px; -webkit-text-size-adjust: none; }
	.diagramlevels { width: 660px; }
}
@media all and (max-width: 1129px) {
	header { padding-left: 50px; padding-top: 100px; }
	.headerbehind { padding-top: 130px; }
	nav { padding-top: 120px; }
	.headerwrap { height: 235px; }
	main { min-height: calc(100vh - 610px); }
	.lhs { width: 170px; }
	.pf-toolkit .rhs, .pf-improvement-plan .rhs { width: calc(100% - 270px); }
	.diagramlevels { width: 600px; }
}
@media all and (max-width: 1049px) {
	header { padding-left: 25px; }
	nav { padding-right: 25px; }
}
@media all and (max-width: 1029px) {
	.fl_menu a { font-size: 20px; }
	.fl_menu li { margin-left: 15px; }
	.footerleft { width: 60%; }
	.footerright { width: 40%; padding-left: 20px; }
	.diagramlevels { width: 500px; height: 430px; }
	
}
@media all and (max-width: 979px) {
	.fl_menu { display: none; }
	.footerleft, .footerright { display: block; width: auto; text-align: left; }
	.footerright { padding: 10px 0 0; }
	main { min-height: calc(100vh - 740px); }

	#menuToggle { display: block; position: absolute; bottom: 0; right: 65px; width: 40px; height: 40px; z-index: 20; }
	#menuToggle input { position: absolute; top: 0; bottom: 0; left: 0; width: 95px; opacity: 0; z-index: 29; display: block; cursor: pointer; -webkit-touch-callout: none; }
	
	#menuButton { position: absolute; top: 0; bottom: 0; left: 0; right: 0; }
	#menuButton span, #menuButton span:first-child:before, #menuButton span:first-child:after { position: absolute; top: 19px; left: 11px; width: 18px; height: 3px; background: var(--esas-body); border-radius: 2px; z-index: 28; content: ''; transition: all 0.5s; }
	#menuButton span:first-child:before { top: -6px; left: 0; background: inherit; }
	#menuButton span:first-child:after { top: 6px; left: 0; background: inherit; }
	#menuButton:after { content: 'Menu'; font: 600 24px/24px "Barlow Condensed", sans-serif; position: absolute; margin-top: 7px; }
	
	#menuToggle ul { display: block; width: auto; background: var(--esas-yellow); position: fixed; top: 0; left: -200px; right: -200px; transform: translate3d(0, -100%, 0) rotate(-6deg); transform-origin: top right; transition: transform 0.5s; padding-top: 130px; z-index: -1; }
	#menuToggle li { display: block; text-align: center; margin: 0!important; }
	#menuToggle a { display: block; line-height: 40px; text-align: right; padding: 0 225px; }
	.fl_menu a:hover { transform: none; padding-right: 235px!important; }
	.fl_menu li.current a:after { position: absolute; display: inline-block; right: 200px; left: auto; transform: rotate(-90deg); top: 50%; margin: -7px 0 0; }

	#menuToggle input:checked ~ #menuButton span:first-child { opacity: 0; }
	#menuToggle input:checked ~ #menuButton span:nth-child(2) { transform: rotate(-45deg); }
	#menuToggle input:checked ~ #menuButton span:last-child { transform: rotate(45deg); }
	#menuToggle input:checked ~ ul { transform: translate3d(0, 0, 0); }
	
	.pf-toolkit .rhs, .pf-improvement-plan .rhs { width: auto; display: block; padding: 0; }
	.lhs { position: fixed; z-index: 10; transform: translate3d(-190px, 0, 0); transition: transform 0.5s; cursor: pointer; padding: 5px 25px 25px; font-size: 18px; line-height: 22px; animation: bounce 2s 5; -webkit-animation: bounce 2s 5; -moz-animation: bounce 2s 5; -o-animation: bounce 2s 5; }
	.lhs.beenbefore { animation: bounce 2s 1; -webkit-animation: bounce 2s 1; -moz-animation: bounce 2s 1; -o-animation: bounce 2s 1; }
	.lhs.doneanim { animation: none; -webkit-animation: none; -moz-animation: none; -o-animation: none;}
	.lhs.indexshown { transform: translate3d(0, 0, 0); cursor: default; animation: none; -webkit-animation: none; -moz-animation: none; -o-animation: none;}
	.lhs:after { bottom: auto; top: 25%; background: transparent!important; width: auto; height: auto; text-align: center; transform: rotate(-88deg); content: 'Toolkit menu …'; right: -35px; cursor: pointer; z-index: 11; color: var(--esas-red); }
	.lhs.indexshown:after { content: 'Close menu'; right: -20px; }
	.lhs li ul, .lhs ul:after, .lhs ul:before { display: none!important; }

	.lhs .curcat>a:before { background-image: url('../gfx/tri-yellow.svg'); display: block; }

	@-webkit-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-190px, 0, 0);}
		40% {transform: translate3d(-160px, 0, 0);}
		60% {transform: translate3d(-175px, 0, 0);}
	}
	 
	@-moz-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-190px, 0, 0);}
		40% {transform: translate3d(-160px, 0, 0);}
		60% {transform: translate3d(-175px, 0, 0);}
	}
	 
	@-o-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-190px, 0, 0);}
		40% {transform: translate3d(-160px, 0, 0);}
		60% {transform: translate3d(-175px, 0, 0);}
	}

	@keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-190px, 0, 0);}
		40% {transform: translate3d(-160px, 0, 0);}
		60% {transform: translate3d(-175px, 0, 0);}
	}
	
	.page-front .front-account .frontcontentwrap { padding-left: 100px; padding-right: 100px; }
	.page-front .front-how	{ background-position: center right -500px; }
	.page-front .front-how .frontcontentwrap { padding-right: 500px; }
}
@media all and (max-width: 909px) {
	.page-front .front-how h2 { max-width: none; }

}
@media all and (max-width: 899px) {
	.page-front .front-intro { background-position: center left -600px; }
	.page-front .front-intro .frontcontentwrap { padding-left: 180px; }
	.page-front .front-how { margin-top: -150px; }
}
@media all and (max-width: 879px) {
	body:before { transform3d(50px,0,0); width: 400px!important; height: 200px!important; background-size: auto 200px!important; }
	.pagecol { display: block; width: auto; margin-top: 0!important; padding: 0!important; }
	.page-front .front-how	{ background-position: center right -600px; }
	.page-front .front-how .frontcontentwrap { padding-right: 400px; }

}
@media all and (max-width: 799px) {
	.subpages { grid-template-columns: repeat(2, 1fr); }
	.page-front .front-account .frontcontentwrap { padding-left: 50px; padding-right: 50px; }
}
@media all and (max-width: 767px) {
	.page-front .front-how { background-size: auto 500px; min-height: 500px; }
	.page-front .front-how .frontcontentwrap { padding-right: 250px; }
	.page-front .front-how h2 { max-width: 80%; }
}
@media all and (max-width: 749px) {
	.page-front .front-intro { background-size: auto 420px; background-position: top 50px left -350px; min-height: 470px; }
	.page-front .front-intro .fronttriangle { height: 320px; width: 130px; }
	.page-front .front-intro .frontcontentwrap { padding-left: 160px; }
	.page-front .front-intro p { margin-left: -160px; }
	.page-front .front-intro p:first-of-type { margin-left: 0!important; }
	.page-front .front-how { margin-top: 0; }
}
@media all and (max-width: 679px) {
	header, .headerbehind { right: -100px; }
	header { padding-top: 25px; }
	.headerbehind { padding-top: 45px; }
	.logo { width: 280px; bottom: -24px; }
	.wrapper, .page-front .frontcontent { padding: 0 25px; }
	.footerleft, .footerright { position: relative; top: -50px; }
	.footwrap { padding-bottom: 1px; }

	.headerwrap { height: 155px; }
	main { min-height: calc(100vh - 561px); padding-bottom: 50px; }
	
	html, body { font-size: 16px; line-height: 22px; }
	h1 { font-size: 36px; line-height: 36px; }
	h2 { font-size: 28px; line-height: 28px; }
	h3 { font-size: 24px; line-height: 24px; }
	h4 { font-size: 20px; line-height: 20px; }
	h5 { font-size: 18px; line-height: 18px; }
	.subcats a { font-size: 24px; line-height: 28px; }

	.diagramlevels { height: 390px; }
	.assessmentoptions label { padding: 15px 5px; font-size: 14px; line-height: 18px; }
	
	.lhs { transform: translate3d(-185px, 0, 0); padding-left: 35px; }
	.lhs:after { top: 15%; right: -37px; }
	.lhs.indexshown:after { right: -26px; }
	
	@-webkit-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-185px, 0, 0);}
		40% {transform: translate3d(-155px, 0, 0);}
		60% {transform: translate3d(-170px, 0, 0);}
	}
	 
	@-moz-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-185px, 0, 0);}
		40% {transform: translate3d(-155px, 0, 0);}
		60% {transform: translate3d(-170px, 0, 0);}
	}
	 
	@-o-keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-185px, 0, 0);}
		40% {transform: translate3d(-155px, 0, 0);}
		60% {transform: translate3d(-170px, 0, 0);}
	}

	@keyframes bounce {
		0%, 20%, 50%, 80%, 100% {transform: translate3d(-185px, 0, 0);}
		40% {transform: translate3d(-155px, 0, 0);}
		60% {transform: translate3d(-170px, 0, 0);}
	}
	
	.page-front h1, .page-front h2 { font-size: 42px; line-height: 42px; }
	.page-front .front-intro p:first-of-type { font-size: 18px; line-height: 24px; }
	.page-front .front-how { margin-top: -50px; }
	.page-front .front-how h2 { max-width: none; }
	.page-front .front-account { background-size: auto 400px; min-height: 400px; }
	.page-front .front-account .frontcontentwrap { min-height: 0; }

}
@media all and (max-width: 599px) {
	a.buttonprev, .prevspacer { margin-right: 25px; }
	a.buttonprev, a.buttonnext { font-size: 18px; line-height: 22px; }
	a.buttonprev:before { left: 10px; }
	a.buttonprev { padding-left: 30px; padding-right: 10px; }
	a.buttonnext:before { right: 10px; }
	a.buttonnext { padding-right: 30px; padding-left: 10px; }

	.page-front .front-how { background-size: auto 300px; min-height: 300px; background-position: top right -350px; margin-top: 0;  }
	.page-front .front-how .frontcontentwrap { padding-right: 150px; }

	.page-front .front-account { margin-top: -160px; }
}
@media all and (max-width: 559px) {
	.diagramlevels { width: 400px; height: 420px; }
}
@media all and (max-width: 499px) {
	.footerlogos>img { display: block; margin-bottom: 20px; }
	.footerlogos>a:first-of-type { margin-left: 0; }
	main { min-height: calc(100vh - 656px); }
}
@media all and (max-width: 489px) {
	.page-front .front-how .frontcontentwrap { padding-right: 0; }
	.page-front .front-how .frontcontentwrap:before { float: right; width: 170px; height: 200px; content: ''; }
}
@media all and (max-width: 479px) {
	.logo { width: 210px; height: 40px; bottom: -20px; background: url('../gfx/esas-noslogan.svg') no-repeat center; background-size: contain;  }
	.logo img, .headerbehind { display: none; }
	header { padding-top: 0; }
	.headerbehind { padding-top: 15px; }
	nav { margin-top: -75px; }
	.subpages { grid-template-columns: 1fr; }
	.headerwrap { height: 125px; }
	main { min-height: calc(100vh - 626px); }
	.assessmentoptions { gap: 15px; }
	.page-front .front-account { background-size: auto 300px; min-height: 300px; margin-top: -100px; }
	.page-front .front-account .frontcontentwrap { padding-left: 25px; padding-right: 25px; padding-top: 140px; }

	.page-front .front-intro { background-size: auto 320px; background-position: top 50px left -325px; min-height: 370px; }
	.page-front .front-intro .fronttriangle { height: 250px; width: 100px; }
	.page-front .front-intro .frontcontentwrap { padding-left: 70px; }
	.page-front .front-intro p { margin-left: -70px; }


}
@media all and (max-width: 429px) {
	.diagramlevels { font-size: 14px; line-height: 20px; width: 300px; height: 440px; }
	.assessmentcatslist { grid-template-columns: 1fr; }
}
@media all and (max-width: 399px) {
	header .wrapper { height: 90px; }
	header { padding-left: 15px; }
	.headerwrap { height: 115px; }
	main { min-height: calc(100vh - 616px); }
	#menuToggle { right: 50px; }
	#menuButton:after { font-size: 20px; }
	#cf-turnstile { transform: scale(0.8); transform-origin: top left; }
	a.buttondl { padding: 12px 10px; }
	.rhs ul#gridbox li { padding: 0 10px 15px; font-size: 14px; line-height: 20px; }
	.rhs ul.gridlist li { padding: 10px; font-size: 14px; line-height: 20px; }
	.rhs ul#gridbox li img { max-width: calc(100% + 20px); margin: 0 0 -10px -10px; }

	.page-front .front-intro { background-size: auto 300px; background-position: top 50px left -325px; }
	.page-front .front-intro .frontcontentwrap { padding-left: 40px; }
	.page-front .front-intro p { margin-left: -40px; }

	.page-front .front-how { background-size: auto 250px; min-height: 250px; background-position: top right -300px; }
	.page-front .front-how .frontcontentwrap:before { float: right; width: 120px; height: 175px; content: ''; }

}
@media all and (max-width: 374px) {
	.assessmentoptions { grid-template-columns: 1fr; gap: 15px; }
	.page-front .front-intro .fronttriangle { height: 260px; width: 104px; }
}
@media all and (max-width: 369px) {
	.page-front .front-intro .fronttriangle { height: 280px; width: 112px; }
}
@media all and (max-width: 359px) {
	.page-front .front-intro .fronttriangle { height: 300px; width: 120px; }
}
@media all and (max-width: 354px) {
	.page-front .front-intro p:first-of-type { font-size: inherit; line-height: inherit; }
	.page-front .front-intro .fronttriangle { height: 260px; width: 104px; }
}
@media all and (max-width: 339px) {
	.page-front .front-intro .fronttriangle { height: 280px; width: 112px; }
}
@media all and (max-width: 329px) {
	a.buttondl { font-size: 20px; line-height: 24px; }
	.diagramlevels { width: 290px; }
	#menuToggle { right: 40px; }
	#menuButton:after { margin-left: -5px; }
	.page-front .front-intro .fronttriangle { height: 300px; width: 120px; }
}
@media all and (max-width: 324px) {
	.page-front .front-intro .fronttriangle { height: 320px; width: 128px; }
}

@media print {
	blockquote, .assessmentoptions div { -webkit-print-color-adjust: exact; }
	.asssessmentoptions, blockquote { page-break-inside: avoid; page-break-before: avoid; }
	.headerbehind, .lhs, #menu, a.button, footer { display: none!important; }
	.rhs { width: auto!important; display: block!important; padding: 0!important; }
	.headerwrap { height: auto; overflow: visible; }
	header { transform: none; -webkit-print-color-adjust: exact; padding: 0 20px 12px; position: static; margin-bottom: 40px; }
	.rhs ul li:before { -webkit-print-color-adjust: exact; }
	body>.wrapper { padding: 0 20px; }
	main { padding-bottom: 0; }
}