/*   
Theme Name: Millwoods Christian School Society
Description: Millwoods Christian School Society website
Author: Odvod Media
Version: 1
*/

/* default
-------------------------------------------------------------------------------*/

html, body, body div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
}									

article, aside, figure, footer, header, hgroup, nav, section {display: block;}

/* Responsive images and other embedded objects
   Note: keeping IMG here will cause problems if you're using foreground images as sprites, like, say for Google Maps custom placemarkers. 
   There has been a report of problems with standard Google maps as well, but we haven't been able to duplicate or diagnose the issue. */
img,
object,
embed {width: 100%; height:auto}

/* force a vertical scrollbar to prevent a jumpy page */
html {overflow-y: scroll;}

/* we use a lot of ULs that aren't bulleted. 
	don't forget to restore the bullets within content. */
ul {list-style: none;}

blockquote, q {quotes: none;}

blockquote:before, 
blockquote:after, 
q:before, 
q:after {content: ''; content: none;}

a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent; color:#666; text-decoration:none; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
a > span { transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
a:hover{ text-decoration:underline}

del {text-decoration: line-through;}

abbr[title], dfn[title] {border-bottom: 1px dotted #000; cursor: help;}

/* tables still need cellspacing="0" in the markup */
table {border-collapse: collapse; border-spacing: 0;}
th {font-weight: bold; vertical-align: bottom;}
td {font-weight: normal; vertical-align: top;}

h1,h2,h3,h4,h5,h6{ font-weight:400}

hr {display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0;}

input, select {vertical-align: middle;}

pre {
	white-space: pre; /* CSS2 */
	white-space: pre-wrap; /* CSS 2.1 */
	white-space: pre-line; /* CSS 3 (and 2.1 as well, actually) */
	word-wrap: break-word; /* IE */
}

input[type="radio"] {vertical-align: text-bottom;}
input[type="checkbox"] {vertical-align: bottom; *vertical-align: baseline;}
.ie6 input {vertical-align: text-bottom;}

select, input, textarea {font: 99% sans-serif;}

table {font-size: inherit; font: 100%;}
 
/* Accessible focus treatment
	people.opera.com/patrickl/experiments/keyboard/test */
a:hover, a:active {outline: none;}

small {font-size: 85%;}

strong, b, th {font-weight: 600; }
em, i {  }

td, td img {vertical-align: top;} 

/* Make sure sup and sub don't screw with your line-heights
	gist.github.com/413930 */
sub, sup {font-size: 75%; line-height: 0; position: relative;}
sup {top: -0.5em;}
sub {bottom: -0.25em;}

/* standardize any monospaced elements */
pre, code, kbd, samp {font-family: monospace, sans-serif;}

/* hand cursor on clickable elements */
.clickable,
label, 
input[type=button], 
input[type=submit], 
button {cursor: pointer;}

/* Webkit browsers add a 2px margin outside the chrome of form elements */
button, input, select, textarea {margin: 0;}

/* make buttons play nice in IE */
button {width: auto; overflow: visible;}
 
/* scale images in IE7 more attractively */
.ie7 img {-ms-interpolation-mode: bicubic;}

/* prevent BG image flicker upon hover */
.ie6 html {filter: expression(document.execCommand("BackgroundImageCache", false, true));}

/* let's clear some floats */
.clearfix:before, .clearfix:after { content: "\0020"; display: block; height: 0; overflow: hidden; }  
.clearfix:after { clear: both; }  
/*.clearfix { zoom: 1; }  */

.clear { clear: both; }

.hide { display: none !important; }

img { display: block; /*transition: all .6s; -moz-transition: all .6s; -webkit-transition: all .6s; -o-transition: all .6s;*/ }

.show-right:before { position: relative; left: 100%; display: block; width: 100%; float: left; margin: 0 0 0 -100%; }

.left { float: left !important; }
.middle { float: none !important; }
.right { float: right !important; }

.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }

.ab-right { position: absolute !important; right: 0; }
.ab-bottom { position: absolute !important; bottom: 0; }

.uppercase { text-transform: uppercase; letter-spacing: 1.2px; }

.background { background-position: center center; background-repeat: no-repeat; background-size: cover; }
.overlay { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; }

.transition { text-decoration:none; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }

span.break { display: block !important; margin: 0 !important; padding: 0 !important; }

.no-padding-bottom { padding-bottom: 0 !important; }

/*** site variables ***/

:root {
  --font-heading: 'Kreon', serif;
  --font-content: 'Barlow', sans-serif;
  
  --colour1: #ffffff; /* white */
  --colour2: #000000; /* black */
  --colour3: #13294b; /* deep indigo */
  --colour4: #343a40; /* indigo */
  --colour5: #42546f; /* soft indigo */
  --colour6: #a6192e; /* burgundy */
  --colour7: #fef5d7; /* soft yellow */
  --colour8: #48536b; /* light indigo */
  --colour9: #adb5bd; /* grey */
  --colour10: #e9ecef; /* light grey */
  
  --padding-width: 50px;
  --padding-width-2: 100px;
  --padding-width-seperator: 50px;
  
  --padding-height: 40px;
  --padding-height-2: 80px;
  
  --gap-width: 150px;
  --gap-width-2: 20px;
	--gap-width-3: 40px;
  --gap-width-seperator: 150px;
}


/*** site defaults ***/

html, BODY { height: 100%; }
BODY { background: var(--colour3); font-family: var(--font-content); font-weight: 400; font-size: 20px; color: var(--colour4); line-height: 1.3; text-align: center; overflow-wrap: break-word; }

h1, h2, h3, h4, h5 { margin: 0 0 25px; padding: 0; line-height: 1.3; font-family: var(--font-content); color: var(--colour4); font-weight: 700; }
h1 { font-size: 52px; font-family: var(--font-heading); }
h2 { font-size: 28px; color: var(--colour6); margin-bottom: 20px; line-height: 1; }
h3, h4, h5 { font-size: 20px; margin-bottom: 5px; }
h3:last-child { margin-bottom: 0; }
h3.page-title:last-child { margin-bottom: 15px; }

h1.page-title { font-size: 52px; font-family: var(--font-heading); margin-bottom: 50px; }
h2.page-title { font-size: 42px; color: var(--colour3); margin-bottom: 25px; margin-top: -10px; }
h3.page-title { font-size: 28px; margin-top: -7px; line-height: 1.2; }
.title-only h1.page-title { margin-bottom: 0; }

.size12 { font-size: 12px; }
.size13 { font-size: 13px; }
.size14 { font-size: 14px; }
.size16 { font-size: 16px; }
.size17 { font-size: 17px; }
.size18 { font-size: 18px; }
.size20 { font-size: 20px; }
.size22 { font-size: 22px; }
.size24 { font-size: 24px; }
.size32 { font-size: 32px; }
.size56 { font-size: 56px; }

.weightLight { font-weight: 300; }
.weightReg { font-weight: 400; }
.weightMedium { font-weight: 500; }
.weightSemi { font-weight: 600; }
.weightBold { font-weight: 700; }

.fontHeading { font-family: var(--font-heading); }
.fontContent { font-family: var(--font-content); }

.background-3, .background-6, .show-documents { display: block !important; }
.background-3 > .col-1 { background-color: var(--colour3); padding: 50px; }
.background-6 > .col-1 { background: var(--colour6); /*background: linear-gradient(180deg, rgba(19,41,75,1) 0%, rgba(166,25,46,1) 100%);*/ padding: 50px; border-radius: 10px; font-size: 18px; }
.background-6 > .col-1 h3.page-title:after { position: relative; display: block; content: ''; border-bottom: 1px solid var(--colour1); padding-top: 15px; }

a { color: var(--colour3); text-decoration: none; font-weight: 500; }
a:hover { color: var(--colour6); text-decoration: none; }

p { padding: 0 0 25px; margin: 0; line-height: 1.3; }
p:last-child, p:last-of-type { padding-bottom: 0; }

ul, ol { margin: 0 0 30px 2px; padding: 0; list-style-type: disc; }
ol { list-style-type: decimal; }
li { margin: 0 0 10px 50px; padding: 0 0 0 2px; }
ul:last-child, ul:last-of-type, ol:last-child, ol:last-of-type { margin-bottom: 0; }
li:last-child, li:last-of-type { margin-bottom: 0; }
li > ul, li > ol { margin-top: 0; margin-left: 0; padding-top: 10px; }
ul:last-child + p, ol:last-child + p, .image-wrapper + ul, .image-wrapper + ol { padding-top: 30px; }
p:last-child + ul, p:last-of-type + ul, p:last-child + ol, p:last-of-type + ol { margin-top: 0; padding: 20px 0 0; }
p:last-of-type + h2, p:last-of-type + h3 { padding-top: 30px; }
ul + h3, h3 + h3 { padding-top: 30px; }
ul + p { padding-top: 10px; }
p + ul, p + ol { margin-top: -15px; }
p + h2 { padding-top: 15px; }

hr { border-top-color: var(--colour3); opacity: .2; margin: var(--padding-height-2) 0; }
p + hr { margin-top: calc(var(--padding-height-2) - 20px); }
p:last-of-type + hr { margin-top: var(--padding-height-2); }

.wrap, .inner, .row, .col { position: relative; display: block; box-sizing: border-box; -moz-box-sizing: border-box; overflow: hidden; }
.show-hidden { overflow: visible; }

.read-more { padding-top: 10px; }

.grid { display: grid; grid-template-columns: auto; grid-template-rows: auto; grid-auto-rows: minmax(min-content, max-content); }

.width-banner { width: 100%; max-width: 2330px; margin: 0 auto; }
.width-banner-content { width: 100%; max-width: 740px; }
.width-section { width: 100%; max-width: 1370px; margin: 0 auto; }
.width-content { width: 100%; max-width: 1460px; margin: 0 auto; }
.width-single { width: 100%; max-width: 1100px; margin: 0 auto; }

.vert-bottom { display: grid; align-content: flex-end; }
.vert-middle { display: grid; align-content: center; }

.horiz-right { justify-content: right; }

.flyout-btn { display: none; }
.flyout-btn a { text-decoration: none; color: var(--colour1); font-size: 40px; }
.flyout-btn a:hover { text-decoration: none; color: var(--colour7) !important; }

#flyout-menu { position: fixed; top: 0; left: 0; display: none; width: 100%; height: 100%; background: var(--colour3); z-index: 9999999; overflow-y: auto; border-top: 3px solid var(--colour6); }
#flyout-menu-top { margin: 0; padding: 30px 20px; }
#flyout-menu-top .row-1 { grid-template-columns: 1fr auto; gap: 0 0; }
#flyout-menu-top .row-1 .logo { width: 135px; }
#flyout-menu-top .row-1 ul, #flyout-menu-top .row-1 li, #flyout-menu-main .row-1 ul, #flyout-menu-main .row-1 li, #flyout-menu-main .row-2 ul, #flyout-menu-main .row-2 li { list-style-type: none; margin: 0; padding: 0; }
#flyout-menu-top .row-1 li a { text-decoration: none; color: var(--colour1); font-size: 24px; }
#flyout-menu-top .row-1 li a:hover { text-decoration: none; color: var(--colour4); }
#flyout-menu-top .btn-close a { font-size: 30px; font-weight: 300; }
#flyout-menu-top .btn-close a:hover { color: var(--colour7) !important; }

#flyout-menu-main { grid-template-rows: auto 1fr auto; height: 100%; }
#flyout-menu-main .row-1 { background: var(--colour5); }

#flyout-menu-main .row-2 { grid-template-columns: auto; gap: 30px 0; }
#flyout-menu-main .row-2 .col-1 { overflow-y: auto; }
#flyout-menu-main .row-2 .col-1 li { display: block; border-bottom: 1px solid rgba(255, 255, 255, .2); }
#flyout-menu-main .row-2 .col-1 li a { display: block; background: var(--colour3); color: var(--colour1); font-size: 20px; font-weight: 500; letter-spacing: 1.2px; text-decoration: none; text-align: left; line-height: 60px; padding: 0 20px; box-sizing: border-box; -moz-box-sizing: border-box; }
.firefox #flyout-menu-main .row-1 li a { line-height: 1; padding-top: 20px; padding-bottom: 20px; }
#flyout-menu-main .row-2 .col-1 li a:hover, #flyout-menu-main .row-1 .col-1 li.current-menu-item a:hover { background: rgba(66,84,111,.5); color: var(--colour1); text-decoration: none; }

#flyout-menu-main .row-2 .col-1 li ul, #flyout-menu-main .row-2 .col-1 li ul ul { width: 100%; display: block; }
#flyout-menu-main .row-2 .col-1 li ul li { position: relative; display: none; border-top: 1px solid rgba(255, 255, 255, .2); border-bottom: none; }
#flyout-menu-main .row-2 .col-1 li ul li a { background: rgba(66,84,111,.5); color: var(--colour1); padding-left: 40px; }
#flyout-menu-main .row-2 .col-1 li ul li a:hover { background: var(--colour3); color: var(--colour1); }

#flyout-menu-main .row-2 .col-1 li ul li li a { padding-left: 60px; }

#flyout-menu-main .row-2 ul li > ul::before { position: absolute; top: 22px; right: 20px; display: block; content: '\e804'; font-family: 'fontello'; font-size: 16px; color: #fff; transform: rotate(90deg); }
#flyout-menu-main .row-2 ul li:hover ul::before { transform: rotate(270deg); }

#flyout-menu-main .row-2 .col > ul > li:hover a, #flyout-menu-main .row-2 .col > ul > li a:hover { background: rgba(66,84,111,.5) !important; }
#flyout-menu-main .row-2 .col ul li:hover > ul li { display: block; }
#flyout-menu-main .row-2 .col ul li > ul li:hover a, #flyout-menu-main .row-2 .col ul li > ul li a:hover { background: var(--colour3) !important; }
#flyout-menu-main .row-2 .col ul li > ul li:hover ul li a { background: rgba(66,84,111,.5) !important; }
#flyout-menu-main .row-2 .col ul li > ul li:hover ul li:hover a { background: var(--colour3) !important; }

#flyout-menu-main .row-2 .col-2 { font-size: 16px; }
#flyout-menu-main .row-2 .col-3 a { color: var(--colour3); text-decoration: none; font-size: 24px; }
#flyout-menu-main .row-2 .col-3 a:hover { color: var(--colour4); text-decoration: none; }

#flyout-menu-main .social { margin-bottom: 20px; padding-top: 20px; }
#flyout-menu-main .social li { margin-left: 30px; }
#flyout-menu-main .social li:first-of-type { margin-left: 0; }
#flyout-menu-main .social a { color: var(--colour1); }
#flyout-menu-main .social a:hover { color: var(--colour8); }
#flyout-menu-main .logo { width: 245px; margin: 0 auto; }
#flyout-menu-sub { display: none; }

.menu ul, .menu li { display: inline-block; list-style-type: none; padding: 0; margin: 0; }
.menu li { margin-left: var(--gap-width-3); }
.menu li:first-of-type { margin-left: 0; }
.menu.stack ul, .menu.stack li { display: block; margin-left: 0; }
.menu li a { text-decoration: none; color: var(--colour3); }
.menu li a:hover, .menu li.current-menu-item a { text-decoration: none; color: var(--colour3); }
.menu ul ul { display: none; }

a.btn { display: block; background: var(--colour1); color: var(--colour3); border: 1px solid var(--colour9); font-size: 20px; font-weight: 500; letter-spacing: 1.2px; text-decoration: none; text-align: center; line-height: 50px; padding: 0 20px; border-radius: 5px; box-sizing: border-box; -moz-box-sizing: border-box; }
/*.firefox a.btn { line-height: 1; padding-top: 16px; padding-bottom: 11px; }*/
a.btn:hover { background: var(--colour5); color: var(--colour1); text-decoration: none; }
a.btn.btn-2 { background: rgb(255,255,255); background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(253,241,199,1) 57%, rgba(251,221,122,1) 100%); }
a.btn.btn-2:hover { color: var(--colour3); background: var(--colour7); }
a.btn.btn-3 { background: var(--colour6); color: var(--colour1); }
a.btn.btn-3:hover { color: var(--colour1); background: var(--colour2); }

a.btn.min-width { display: inline-block; min-width: 275px; }

.register-button { position: relative; display: block; }
.register-button + .register-button { padding-top: 30px; }
.register-button a { position: relative; display: grid; grid-template-columns: 1fr 200px; gap: 0 40px; padding: 40px 60px; background: #8894a4; color: #fff; border-radius: 10px; }
.register-button a .col { position: relative; display: block; }
.register-button a .col.col-1 .title { position: relative; display: block; padding: 0 0 5px; font-size: 24px; font-weight: 700; font-family: var(--font-heading); }
.register-button a .col.col-1 .content { position: relative; display: block; font-size: 18px; }
.register-button a .col.col-2 { display: grid; align-content: center; }
.register-button a .col.col-2 .button { display: block; padding: 10px 20px; border-radius: 5px; color: #000010; background: #fff; font-size: 20px; box-shadow: 1px 1px 2px 2px #666; font-weight: 500; text-align: center; text-decoration:none; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
.register-button a:hover { color: #fff; }
.register-button a:hover .col.col-2 .button { color: #fff; background: var(--colour3); }



form label { position: relative; display: block; font-size: 20px; font-weight: 500; color: #fff; -webkit-transition: all 0.2s ease-out; transition: all 0.2s ease-out; z-index: 1; padding: 0 0 10px; }
form input, form select, form textarea, form select { position: relative; width: 100%; padding: 8px 15px; background: #8894a4; color: #fff; border: 1px solid #adb5bd; border-radius: 5px; font-family: var(--font-content); font-size: 20px; font-weight: 400; letter-spacing: .02rem; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-transition: all 0.3s ease-out; transition: all 0.2s ease-out; -webkit-appearance: none; -moz-appearance: none; appearance: none; }
form textarea { height: 100%; min-height: 100px; }

.wpcf7-form select {
  appearance: auto;
}

form input[type="submit"] { padding: 15px 20px; background: #fff; color: #13294b; border: 1px solid #adb5bd; border-radius: 5px; font-size: 20px; font-weight: 500; letter-spacing: 1.2px; max-width: 180px; }
.firefox form input[type="submit"] { line-height: 1; padding-top: 13px; padding-bottom: 12px; }
form input[type="submit"]:hover { background: #13294b; color: #fff; border: 1px solid #adb5bd; }


form .ajax-loader, form .wpcf7-spinner { display: none; }
form .wpcf7-response-output { margin: 20px 0 0 !important; padding: 15px 30px !important; border: none !important; background: var(--colour4); color: var(--colour1); text-align: center; }
form.invalid .wpcf7-response-output { background: #cc0000; color: var(--colour1); }

form .responsive-hide { display: none; }
form .responsive-hide input, form .responsive-hide select { display: none; }

#wpcf7-f531-o1 form .ajax-loader, #wpcf7-f531-o1 form .wpcf7-spinner { display: inline-block; }

form .contact-information label { color: #000; }
form .contact-information input, form .contact-information select, form .contact-information textarea, form .contact-information select { background: var(--colour3); }
form .contact-information input[type="submit"] { color: #fff; }

input.placeholder, textarea.placeholder { color: #fff; font-family: var(--font-content); font-weight: 400; letter-spacing: .03rem; }
::-webkit-input-placeholder { /* WebKit browsers */
	color: #fff;
	font-family: var(--font-content); font-weight: 400; letter-spacing: .03rem;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #fff;
	font-family: var(--font-content); font-weight: 400; letter-spacing: .03rem;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
	color: #fff;
	font-family: var(--font-content); font-weight: 400; letter-spacing: .03rem;
}
:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #fff;
	font-family: var(--font-content); font-weight: 400; letter-spacing: .03rem;
}

.grecaptcha-badge { display: none !important; }
.page-id-237 .grecaptcha-badge { display: block !important; }


/*** site styles ***/

header { background: var(--colour1); }
header .main { background: var(--colour3); padding: 0 var(--padding-width) 20px; }
header .main .row-1.grid { grid-template-columns: 220px 1fr; gap: 0 var(--gap-width-3); }
header .nav { padding: 0 var(--padding-width); }
header .logo { width: 220px; }
header .row-1.grid > .col-3 ul, header .row-1.grid > .col-3 li { list-style-type: none; margin: 0; padding: 0; }

header .main .menu li, #flyout-menu-main .row-1 li { margin-left: 18px; }
header .main .menu li::before, #flyout-menu-main .row-1 li:before { position: relative; display: inline-block; color: var(--colour1); content: '|'; padding-right: 20px; }
header .main .menu li:first-of-type, #flyout-menu-main .row-1 li:first-of-type { margin-left: 0; }
header .main .menu li:first-of-type::before, #flyout-menu-main .row-1 li:first-of-type::before { display: none; }
header .main .menu li a, #flyout-menu-main .row-1 li a { text-decoration: none; color: var(--colour1); font-family: var(--font-heading); }
header .main .menu li a:hover, header .main .menu li.current-menu-item a, #flyout-menu-main .row-1 li a:hover { text-decoration: none; color: var(--colour7); }

header .main .menu ul li:hover > ul { position: absolute; display: block; z-index: 99; padding-top: 10px; }
header .main .menu ul li > ul li { position: relative; display: block; float: none; }
header .main .menu ul li > ul li a { padding: 8px 12px; background: var(--colour6); font-weight: 500; width: 260px; font-size: 20px; }
header .main .menu ul li > ul li:hover a, header .main .menu ul li > ul li a:hover { background: var(--colour2) !important; color: var(--colour1); }
header .main .menu ul li > ul li ul { position: absolute; display: block; top: 0; left: 100%; }
header .main .menu ul li > ul li ul li { display: none; }
header .main .menu ul li > ul li:hover ul li { display: block; }
header .main .menu ul li > ul li ul::before { position: absolute; top: 18px; left: -20px; display: block; content: '\e804'; font-family: 'fontello'; font-size: 12px; }
header .main .menu ul li > ul li:hover ul li a { background: var(--colour6); }
header .main .menu ul li > ul li:hover ul li:hover a { background: var(--colour1) !important; }




#flyout-menu-main .row-1 li { padding-top: 20px; padding-bottom: 20px; }
#flyout-menu-main .row-1 li a { font-size: 21px; }

header .nav .menu { height: 56px; }
header .nav .menu > ul { float: left; }
header .nav .menu li { float: left; margin-left: 0; }
header .nav .menu li a { display: block; color: var(--colour3); padding: 15px var(--gap-width-2); font-weight: 600; box-sizing: border-box; -moz-box-sizing: border-box; }
header .nav .menu li:first-of-type a { padding-left: 0; }
header .nav .menu li:hover a, header .nav .menu li a:hover, header .nav .menu li.current-menu-item a { color: var(--colour3); background: var(--colour10); padding-left: var(--gap-width-2); }

header .nav .menu ul li:hover > ul { position: absolute; display: block; z-index: 99; }
header .nav .menu ul li > ul li { position: relative; display: block; float: none; }
header .nav .menu ul li > ul li a { padding: 12px var(--gap-width-2); background: rgba(255,255,255,.75) !important; font-weight: 500; width: 260px; }
header .nav .menu ul li > ul li:hover a, header .nav .menu ul li > ul li a:hover { background: var(--colour1) !important; }
header .nav .menu ul li > ul li ul { position: absolute; display: block; top: 0; left: 100%; }
header .nav .menu ul li > ul li ul li { display: none; }
header .nav .menu ul li > ul li:hover ul li { display: block; }
header .nav .menu ul li > ul li ul::before { position: absolute; top: 18px; left: -20px; display: block; content: '\e804'; font-family: 'fontello'; font-size: 12px; }
header .nav .menu ul li > ul li:hover ul li a { background: rgba(255,255,255,.75) !important; }
header .nav .menu ul li > ul li:hover ul li:hover a { background: var(--colour1) !important; }

header .main .row-1.grid.top-menu { grid-template-columns: 1fr; text-align: right; }
header .main .row-1.grid.top-menu .menu ul { display: inline-block; background: var(--colour6); padding: 8px 20px; border-radius: 0px 0px 5px 5px; }
header .main .row-1.grid.top-menu .menu ul a:hover { color: var(--colour3); }


.alert { background: var(--colour6); color: var(--colour1); padding: 10px var(--padding-width); }
.bar-wrapper { background-color: var(--colour1); }
.bar { background: var(--colour6); height: 4px; }

ul.slick-dots { position: absolute; left: 57%; bottom: 0; display: block; margin: 0; padding: 0 var(--padding-width) 55px var(--padding-width-2); box-sizing: border-box; -moz-box-sizing: border-box; list-style-type: none; }
.slick-dots li { display: inline-block; list-style-type: none; margin: 0 0 0 30px; padding: 0; }
.slick-dots li:first-of-type { margin-left: 0; }
.slick-dots li button { font-size: 1px; line-height: 1; padding: 0; border: none; width: 10px; height: 10px; overflow: hidden; border-radius: 10px; color: var(--colour3); background: var(--colour3); opacity: .5; }
.slick-dots li.slick-active button { opacity: 1; }

.slick-slider button.slick-arrow { position: absolute; left: 30px; top: 50%; width: 20px; height: 38px; margin-top: -19px; z-index: 99; border: none; background: none; font-size: 0; }
.slick-slider button.slick-arrow.slick-next { left: auto; right: 30px; }
.slick-slider button.slick-arrow.slick-prev::before, .slick-slider button.slick-arrow.slick-next::before { display: block; content: '\e803'; font-size: 38px; line-height: 1; font-family: 'fontello'; color: var(--colour1); opacity: .5; }
.slick-slider button.slick-arrow.slick-next::before { content: '\e804'; }

.banners { background: var(--colour1); height: 700px; overflow: hidden; }
.banners .banner { display: none; }
.banners .banner.banner-1 { display: block; }
.banners .banner .background { width: 100%; height: 100%; }
.banners .banner { background: var(--colour5); }
.banners .banner > .row-1.grid { grid-template-columns: 57% 43%; gap: 0 0; }
.banners .banner > .row-1.grid > .col-1 { min-height: 700px; }
.banners .banner > .row-1.grid > .col-1 img { display: none; }
.banners .banner > .row-1.grid > .col-2 { padding: var(--padding-height) var(--padding-width) var(--padding-height) var(--padding-width-2); }
.banners .banner .banner-content { max-width: 450px; }

.content-boxes { background-color: var(--colour1); padding: var(--padding-height-2) var(--gap-width); }
.content-boxes.no-padding { padding: 0; }
.content-boxes p + h3 { padding-top: 10px; }
.content-boxes p:last-of-type + h3 { padding-top: 30px; }
.content-boxes p + div { padding-top: 5px; }
.content-boxes div + p, .content-boxes p:last-of-type + div, .content-boxes .content-text .col + .button { padding-top: 35px; }
.content-boxes div + h3 { padding-top: 35px; }
.content-boxes p img { margin-bottom: 30px; }

/*.content-boxes, .content-box.content-box-cols-1 .content-text { padding: var(--padding-height-2) var(--padding-width); }*/
.content-boxes .content-type-content_bg .content-text .col + .button { padding-top: var(--padding-height); }
.content-boxes + .combine { padding-top: 0; }
.content-boxes.title-only { padding-bottom: 10px; }
.content-boxes.title-only + .content-boxes { padding-top: 25px; }

.page-id-532 .content-boxes { background-color: var(--colour8); opacity: 1; text-align: left; }
.page-id-532 .content-boxes h1.page-title { color: var(--colour1); }

.content-boxes.content-box-cols-2 > .row-1 > .col-1.grid { grid-template-columns: 1fr 1fr; gap: 0 var(--gap-width); }
.content-boxes.content-box-cols-2 > .row-1 > .col-1.grid.gap-width-half { gap: 0 var(--gap-width-3); }
.content-boxes .content-type-content_bg { min-height: 410px; padding: 80px var(--padding-width); }
/*.content-boxes.content-box-cols-2 .content-type-content_bg .col-1.grid { max-width: 400px; margin: 0 auto; }*/
.content-boxes.content-box-cols-2.content-boxes-content-sidebar > .row-1 > .col-1.grid { grid-template-columns: 1fr 25%; gap: 0 var(--gap-width); }
.content-boxes.content-box-cols-2.content-boxes-content-news > .row-1 > .col-1.grid { grid-template-columns: 1fr 28%; gap: 0 var(--gap-width); }

/*.content-boxes.content-box-cols-1 .content-type-content { max-width: 900px; padding: 30px var(--padding-width); margin-left: auto; margin-right: auto; }*/

.content-boxes.content-box-cols-2.separator > .row-1 > .col-1.grid { gap: 0 var(--gap-width-seperator); }
.content-boxes.separator .content-box::after { position: absolute; left: calc(var(--padding-width-seperator) * -1); display: block; width: 1px; height: 100%; background: var(--colour3); content: ''; }
.content-boxes.separator .content-box:first-of-type::after { display: none; }
.content-boxes.separator .content-box { overflow: visible; }


.content-boxes.board-members {}
.content-boxes.board-members > .row-1 > .col-1 > .grid { grid-template-columns: repeat(5, 1fr); gap: var(--padding-height-2) var(--gap-width-3); }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member { text-align: left; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a { text-decoration: none; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .image { position: relative; display: block; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .image::after { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; content: ''; background-color: var(--colour3); opacity: 0; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .image + .details { position: relative; display: block; padding: 10px 0 0; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-name { position: relative; display: block; font-weight: 700; font-size: 20px; color: var(--colour4); margin: 0 0 3px; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-position { position: relative; display: block; font-size: 16px; font-weight: 500; color: var(--colour4); transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }

.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a:hover { text-decoration: none; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a:hover .image::after { opacity: .3; }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a:hover .details .details-name { color: var(--colour6); }
.content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a:hover .details .details-position { color: var(--colour6); }



.bio { position: relative; display: block; text-align: left; background-color: #fff; }
.bio .image + .details { position: relative; display: block; padding-top: 20px; }
.bio .details { position: relative; display: block; padding: 20px; }
.bio .details .details-name { position: relative; display: block; font-family: var(--font-heading); font-weight: 700; font-size: 24px; margin-bottom: 3px; }
.bio .details .details-position { position: relative; display: block; font-family: var(--font-heading); font-weight: 500; font-size: 20px; margin-bottom: 20px; }
.bio .details .details-content { position: relative; display: block; font-size: 18px; }


.content-boxes .content-box.border-right { overflow: visible !important; }
.content-boxes .content-box.border-right::after { position: absolute; right: -80px; display: block; width: 1px; height: 100%; background: #e9ecef; content: ''; }

.content-boxes .content-box.content-type-sidebar .content-text { text-align: left; }
.content-boxes .content-box.content-type-sidebar .content-text h3 { text-align: center; }

.content-boxes .content-box.content-type-sidebar > .col + .col { padding-top: var(--gap-width-3); }
.content-boxes .content-box.content-type-sidebar.show-documents > .col + .col { padding-top: 0; }
.content-boxes .content-box.content-type-sidebar .col-documents { }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text { text-align: center; background: rgba(19, 42, 76, .8); color: var(--colour1); padding: 50px; border-radius: 10px; }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text h3.page-title { color: var(--colour1); }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul { list-style-type: none; margin: 0; padding: 5px 0 0; }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul li { list-style-type: none; margin: 0; padding: 0; font-size: 18px; }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul li + li { padding-top: 15px; }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul li a { color: var(--colour1); }
.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul li a:hover { color: var(--colour6); }


.content-boxes .content-box.content-type-gallery .content-gallery { max-width: 600px; }
.content-boxes .content-box.content-type-gallery .content-gallery.grid { grid-template-columns: repeat(6, 1fr); gap: 30px 30px; }
.content-boxes .slick-slider button.slick-arrow { width: 40px; left: 0; padding: 10px; height: 52px; background: var(--colour6); color: #fff; }
.content-boxes .slick-slider button.slick-arrow.slick-next { width: 40px; left: auto; right: 0; padding: 10px; height: 52px; background: var(--colour6); color: #fff; }


.content-boxes h4 + ul, .content-boxes p + ul { padding: 12px 0 20px; margin: 0; }
.content-boxes ul:last-of-type + p { padding-top: 20px; }


form .row.row-1 { grid-template-columns: 1fr; gap: 25px 0; }
form .row.row-1 .col.grid { gap: 0 0; }
form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr 1fr; gap: 20px 20px; }
form .row.row-3 { padding-top: 20px; }
form .row .child { margin-bottom: 20px; }
form .row .child .col + .col { padding-top: 25px; }
form .row .child .col.col-2 { padding-top: 0; }
form .col.child-buttons { margin-bottom: 30px; }
form .col.child-buttons input { background: #eaeaea; color: #000; transition: all .4s; -moz-transition: all .4s; -webkit-transition: all .4s; -o-transition: all .4s; }
form .col.child-buttons input:hover { background: #000; color: #fff }


.page-id-532 .content-boxes .content-type-content_bg { padding-top: 0; }
.page-id-532 .content-text { color: #fff; }
.page-id-532 .content-text a { color: var(--colour7); }
.page-id-532 .content-text a:hover { color: #fff; }


footer { background: var(--colour11); color: var(--colour7); padding: var(--padding-height-2) var(--padding-width); }
footer .row-1.grid.top, footer .row-1.grid.bottom { grid-template-columns: 210px 1fr 500px; gap: 25px 85px; padding-bottom: 25px; }
footer .row-1.grid.top .row-3.grid { grid-template-columns: 1fr 1fr; gap: 0 20px; }

footer .row-1 .col-2 .row-1.grid { grid-template-columns: 1fr 1fr auto; gap: 25px 30px; }
footer .row-1 .col-3 .row-1.grid { grid-template-columns: 1fr 1fr; gap: 25px 30px; }


footer .logo { width: 220px; }
footer a { color: var(--colour7); text-decoration: underline; font-weight: 400; }
footer a:hover { color: var(--colour7); text-decoration: none; }

footer .bottom { border-top: 1px solid var(--colour5); color: var(--colour8); padding-top: 25px; padding-bottom: 0; }
footer .bottom .logo { width: 245px; }
footer .bottom a { color: var(--colour8); }
footer .bottom a:hover { color: var(--colour8); }


footer .menu.social li { margin-left: 30px; }
footer .menu.social li:first-of-type { margin-left: 0; }
footer .menu.social a { color: var(--colour7); }
footer .menu.social a:hover { color: var(--colour1); }


/*** unique section styles ***/

.content-boxes.content-box-cols-2 > .row-1 > .col-1.grid.split-news { grid-template-columns: 66% 34%; }
.article-list { padding-top: 10px; }
.article-list .article-list-item { margin-bottom: var(--padding-height); }
.article-list .article-list-item p.article-name { padding-bottom: 10px; }

.article .article-date { margin-top: -10px; }
.article .article-next { padding-top: var(--padding-height-2); }




@viewport { width: auto; }

@media only screen and (max-width: 1420px) {
  
  .size56 { font-size: 50px; }
  
  h1 { font-size: 46px; }
  
}

@media only screen and (max-width: 1320px) {
	
  :root {
		--gap-width: 80px;
  }
  
  .content-boxes.content-box-cols-2.content-boxes-content-news > .row-1 > .col-1.grid { grid-template-columns: 1fr 25%; }
  .content-boxes .content-box.border-right::after { right: -40px; }
  
  footer .row-1.grid.top, footer .row-1.grid.bottom { gap: 25px 65px; }
  footer .menu.social li { margin-left: 25px; }
  
}

@media only screen and (max-width: 1200px) {
  
  :root {
    --padding-width-2: 50px;
    --gap-width-seperator: 100px;
  }
  
  .size56 { font-size: 42px; }
  .size24 { font-size: 22px; }
  
  h1.page-title { font-size: 46px; }
	h3.page-title { font-size: 24px; }
	
	.background-3 > .col-1, .background-6 > .col-1, .content-boxes .content-box.content-type-sidebar .col-documents .content-text { padding: 40px 30px; }
	
	.content-boxes.content-box-cols-2.content-boxes-content-sidebar > .row-1 > .col-1.grid { grid-template-columns: 1fr 33.33%; }
	
	.content-boxes.board-members > .row-1 > .col-1 > .grid { grid-template-columns: repeat(4, 1fr); }
  
  footer { padding-bottom: 20px; }
  footer .row-1.grid.top { grid-template-columns: 250px 1fr 250px; }
  footer .row-1.grid.top .row-3.grid { grid-template-columns: 1fr; gap: 0 20px; }
  
  footer .row-1 .col-2 .row-1.grid { grid-template-columns: 1fr 1fr; grid-template-areas: "col-1 col-2" "col-3 col-3"; }
  footer .row-1 .col-2 .row-1.grid .col-1 { grid-area: col-1; }
  footer .row-1 .col-2 .row-1.grid .col-2 { grid-area: col-2; }
  footer .row-1 .col-2 .row-1.grid .col-3 { grid-area: col-3; }
  
  footer .row-1.grid.bottom { grid-template-columns: 250px 1fr; }
  
  
  footer .row-1.grid.top { grid-template-columns: 250px 1fr; grid-template-areas: "col-1 col-2" "col-3 col-3"; gap: 35px 65px; }
  footer .row-1.grid.top > .col-1 { grid-area: col-1; }
  footer .row-1.grid.top > .col-2 { grid-area: col-2; }
  footer .row-1.grid.top > .col-3 { grid-area: col-3; }
  footer .row-1.grid.top > .col-3 .btn { max-width: 250px; margin: 0 auto; }
  
}

@media only screen and (max-width: 1100px) {
  
  .content-boxes.board-members > .row-1 > .col-1 > .grid { grid-template-columns: repeat(3, 1fr); }
  
}

@media only screen and (max-width: 900px) {
  
  :root {
    --padding-height-2: 50px;
    
    --padding-width: 30px;
    --padding-width-2: 30px;
    
    --gap-width-seperator: 80px;
    --padding-width-seperator: 40px;
		
		--gap-width: 60px;
  }
	
	h3.page-title { font-size: 22px; }
  
  .size56 { font-size: 38px; }
  
  .banners { height: auto !important; }
  .banners .banner > .row-1.grid > .col-1 { min-height: 400px; }
  .banners .banner > .row-1.grid > .col-2 { padding-right: 55px; }
  
  .content-boxes.content-box-cols-2.content-boxes-content-news > .row-1 > .col-1.grid { gap: 0 70px; }
  .content-boxes .content-box.border-right::after { right: -35px; }
  
  form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr; }
  
  .page-id-532 .content-boxes.content-box-cols-2 > .row-1 > .col-1.grid { grid-template-columns: 1fr; }
  .page-id-532 form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr 1fr; }
  .page-id-532 .row-2.content-type-content .row-1.content-text > .col-1 { display: none; margin-top: -20px; }
  
  footer .logo { margin: 0 auto 10px; }
  footer > .grid > .col-1 { grid-area: col-1; }
  footer > .grid > .col-2 { grid-area: col-2; }
  footer > .grid > .col-3 { grid-area: col-3; }
  footer .row-1.grid.top { grid-template-columns: 1fr; grid-template-areas: "col-1" "col-2" "col-3"; padding-bottom: 0; }
  footer .row-1.grid.top .row-2.grid { grid-template-columns: 1fr; grid-template-areas: "col-1"; }
  footer .row-1.grid.top .row-3.grid { grid-template-columns: 1fr 1fr; grid-template-areas: "col-1 col-2"; }
  footer .row-1.grid.bottom { grid-template-columns: 1fr auto; grid-template-areas: "col-1 col-1" "col-2 col-3"; gap: 20px 0; border-top: none; }
  footer .row-1.grid.bottom .col-2, footer .row-1.grid.bottom .col-3 { border-top: 1px solid var(--colour5); padding-top: 20px; }
  footer .row-1.grid.bottom .col-3 { padding-left: 30px; }
  footer .row-1.grid.bottom .logo { margin-bottom: 0; }
  
  footer .menu { text-align: center; }
  
  
}

@media only screen and (max-width: 800px) {
  
  :root {
		--gap-width: 40px;
    --padding-height: 30px;
  }
  
  .size56 { font-size: 36px; }
  
  h1, h1.page-title { font-size: 40px; }
  
  h2.page-title { font-size: 36px; margin-top: 0; }
  h3.page-title { margin-top: 0; }
  a.btn.min-width { display: block; }
  .register-button a { padding: 30px 40px; }
  
  header #menu-top-menu, header #menu-top-menu-1, header .nav { display: none; }
  header .flyout-btn { display: block; }
  
  .banners .banner > .row-1.grid { grid-template-columns: 1fr; }
  .banners .banner > .row-1.grid > .col-1 { min-height: 300px; }
  .banners .banner .banner-content { max-width: none; padding-bottom: 30px; }
  .banners .banner > .row-1.grid > .col-2 { padding-bottom: 0; padding-left: 60px; padding-right: 60px; }
  
  .banners-slick { background: var(--colour5); }
  ul.slick-dots { position: relative; left: 0; bottom: 0; width: 100%; background: var(--colour5); padding-bottom: 20px; padding-top: 20px; }
  .slick-slider button.slick-arrow { left: 15px; top: 75%; }
  .slick-slider button.slick-arrow.slick-next { left: auto; right: 15px; }
  
  .content-boxes.content-box-cols-2 > .row-1 > .col-1.grid.split-news { grid-template-columns: 1fr; gap: 40px 0; }
  .content-boxes.content-box-cols-2 > .row-1 > .col-1.grid.split-news > .row-2 { padding-top: 40px; border-top: 1px solid var(--colour3); }
  
  .content-boxes.board-members > .row-1 > .col-1 > .grid { grid-template-columns: repeat(2, 1fr); }
  
  footer { padding-bottom: 0; }
  
}

@media only screen and (max-width: 667px) {
  
  :root {
    --padding-height-2: 30px;
    --padding-width: 20px;
    --gap-width: 25px;
  }
  
  BODY { font-size: 18px; }
  
  h1, h1.page-title { font-size: 32px; }
  h2 { font-size: 24px; }
  h3, h4, h5 { font-size: 20px; }
  
  .size56 { font-size: 34px; }
  .size24 { font-size: 20px; }
  .size18 { font-size: 16px; }
  
  .register-button a { grid-template-columns: auto; gap: 30px 40px; }
  .content-boxes.content-box-cols-2 > .row-1 > .col-1.grid { grid-template-columns: auto; gap: 30px var(--gap-width); }
  
  header .logo { width: 180px; }
  header .main .row-1.grid.top-menu { margin-bottom: 15px; }

}

@media only screen and (max-width: 600px) {
  
  h1, h1.page-title { font-size: 28px; margin-bottom: 30px; }
	.content-boxes.title-only + .content-boxes { padding-top: 30px; }
	li { margin-left: 30px; }
  
  .content-boxes .content-type-content_bg { padding: 40px var(--padding-width); }
  .content-boxes.content-box-cols-2 > .row-1 > .col-1.grid { grid-template-columns: auto; }
  form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr 1fr; }
  #map { min-height: 400px; }
  form label, form input, form select, form textarea, form input[type="submit"] { font-size: 16px; }
  
  .content-boxes.content-box-cols-2.content-boxes-content-sidebar > .row-1 > .col-1.grid, .content-boxes.content-box-cols-2.content-boxes-content-news > .row-1 > .col-1.grid { grid-template-columns: 1fr; gap: var(--gap-width) var(--gap-width); }
  
  .content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-name { font-size: 18px; }
  .content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-position { font-size: 14px; }
  .bio .details .details-position { font-size: 18px; }

}

@media only screen and (max-width: 480px) {
  
  BODY { font-size: 16px; }
  
  h2.page-title { font-size: 24px; }
  h3.page-title { font-size: 20px; }
  
  .size56 { font-size: 32px; }
  
  a.btn { font-size: 16px; }

  header .logo { width: 135px; }
  .flyout-btn a { font-size: 30px; }
  
  .banners .banner > .row-1.grid > .col-1 { min-height: 230px; }
  .slick-slider button.slick-arrow.slick-prev::before, .slick-slider button.slick-arrow.slick-next::before { font-size: 28px; }
  
  .split-content { grid-template-columns: repeat(1, 1fr) !important;  gap: 3px 20px !important; }
  
  form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr; }
  
  .content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-name { font-size: 16px; }
  .content-boxes.board-members > .row-1 > .col-1 > .grid .board-member a .details .details-position { font-size: 13px; }
  .bio .details .details-position { font-size: 16px; }
  .bio .details .details-content { font-size: 16px; }
	
	.content-boxes .content-box.content-type-sidebar .col-documents .content-text ul li { font-size: 16px; }
  
  .page-id-532 form .row.row-1 .col.grid .row.grid { grid-template-columns: 1fr; }

  footer .logo { width: 215px; }
  
  footer .row-1 .col-2 .row-1.grid { grid-template-columns: 1fr; grid-template-areas: "col-1" "col-2" "col-3"; }
  footer .row-1 .col-2 .row-1.grid .col { text-align: center !important; }
  
  
  header .main .row-1.grid.top-menu .menu ul { padding: 8px 10px; }
  header .main .row-1.grid.top-menu .menu li { margin-left: 10px; }
  header .main .row-1.grid.top-menu .menu li::before { padding-right: 10px; }
  header .main .row-1.grid.top-menu .menu li a { font-size: 14px; }
  
}

@media only screen and (max-width: 420px) {
  
  .content-boxes.board-members > .row-1 > .col-1 > .grid { grid-template-columns: repeat(1, 1fr); }
  
  footer .row-1 .col-3 .row-1.grid { grid-template-columns: 1fr; }
  
}

@media only screen and (max-width: 360px) {
  
  .register-button a { padding: 25px 25px; }
  
}