/*   
Theme Name: Odvod Publishing
Description: Odvod Publishing website
Author: Odvod Media
Version: 2
*/

/* 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: 'mr-eaves-xl-sans', sans-serif;
  --font-sub-heading: 'brother-1816', sans-serif;
  --font-content: 'Jost', sans-serif;
  
  --colour1: #000000; /* black */
  --colour2: #ffffff; /* white */
  --colour3: #e60a1c; /* red */
  
  --colour-a: #e60a1c; /* red */
  --colour-a-hover: #000000; /* black */
  
  --colour-body-text: #000000; /* black */
  --colour-background: #ffffff; /* white */
  --colour-background-footer: #000000; /* black */
  
  --colour-background-button: #000000; /* black */
  --colour-background-button-hover: #ffffff; /* red */
  --colour-background-button-text: #ffffff; /* white */
  --colour-background-button-text-hover: #000000; /* black */
  --colour-background-button-border: #000000; /* black */
  --colour-background-button-border-hover: #000000; /* black */
  
  --colour-background-button-alt: #000000; /* black */
  --colour-background-button-hover-alt: #e60a1c; /* red */
  --colour-background-button-text-alt: #ffffff; /* white */
  --colour-background-button-text-hover-alt: #ffffff; /* white */
  --colour-background-button-border-alt: #e60a1c; /* red */
  --colour-background-button-border-hover-alt: #e60a1c; /* red */
  
  --colour-background-button-alt2: #e60a1c; /* red */
  --colour-background-button-hover-alt2: #ffffff; /* white */
  --colour-background-button-text-alt2: #ffffff; /* white */
  --colour-background-button-text-hover-alt2: #000000; /* black */
  --colour-background-button-border-alt2: #e60a1c; /* red */
  --colour-background-button-border-hover-alt2: #e60a1c; /* red */
  
  --colour-background-button-alt3: #ffffff; /* white */
  --colour-background-button-hover-alt3: #000000; /* black */
  --colour-background-button-text-alt3: #000000; /* black */
  --colour-background-button-text-hover-alt3: #ffffff; /* white */
  --colour-background-button-border-alt3: #000000; /* black */
  --colour-background-button-border-hover-alt3: #000000; /* black */
	
	--colour-form-label-text: #8c9199; /* dark grey */
	--colour-form-input-background: #ffffff; /* white */
	--colour-form-input-text: #000000; /* black */
	--colour-form-input-border: #ebecef; /* light grey */
	--colour-form-input-border-required: #000000; /* black */
	--colour-form-response-background: #000000; /* white */
	--colour-form-response-background-alert: #e60a1c; /* red */

	--colour-form-submit: #e60a1c; /* black */
	--colour-form-submit-hover: #000000; /* red */
	--colour-form-submit-text: #ffffff; /* white */
	--colour-form-submit-text-hover: #ffffff; /* white */
	--colour-form-response-text: #ffffff; /* white */
	--colour-form-response-text-alert: #ffffff; /* white */
  
  --colour-kicker: #e60a1c; /* red */
  
  --colour-banner-home-title-highlight: #ffffff; /* white */
	--colour-banner-title-highlight: #e60a1c; /* red */
  
  --colour-footer-text: #ffffff; /* white */
  --colour-footer-copyright: #8c9199; /* light grey */
  
  --colour-main-menu: #000000; /* black */
  --colour-main-menu-active: #e60a1c; /* red */
  --colour-border: #f7f7fa; /* light grey */
  
  --colour-flyout-menu-btn: #000000; /* black */
  --colour-flyout-menu-btn-hover: #e60a1c; /* red */
  --colour-flyout-menu: #000000; /* black */
  --colour-flyout-menu-hover: #e60a1c; /* red */
  --colour-flyout-menu-background: #ffffff; /* white */
  
  --colour-social: #000000; /* black */
  --colour-social-hover: #e60a1c; /* red */
	
	--colour-reach-background: #f7f7fa; /* light grey */
	--colour-reach-title-highlight: #e60a1c; /* red */
  
  --outer-padding-width: 40px;
  
  --padding-width: 50px;
  --padding-height: 40px;
  --padding-height-2: 50px;
  
  --border-width: 260px;
  
  --gap-width: 40px;
  --gap-menu: 30px;
  --gap-section: 90px;
	--gap-description-width: 70px;
  --gap-description-height: 50px;
  --gap-description-circles-size: 230px;
	--gap-team-width: 80px;
	--gap-team-height: 85px;
	--gap-contact-width: 100px;
  --gap-contact-map-width: 420px;
	--gap-contact-sidebar-height: 50px;
	--gap-form-width: 25px;
	--gap-form-height: 35px;
  --gap-section-list-width: 80px;
  --gap-section-list-height: 120px;
  --section-list-image-width: 435px;
  --section-list-columns-image-gap: 50px;
  --section-banner-height: 400px;
  --section-banner-home-circle-height: 170px;
  --section-banner-home-circle-top: -38px;
	--gap-section-reach-height: 80px;
	--gap-section-reach-col-spacing: 160px;
	
  --gap-footer-width: 70px;

	--size-text-h2: 32px;
  --size-text-h3: 46px;
  --size-text-main-menu: 14px;
  --size-text-body: 18px;
  --size-text-banner-home: 72px;
  --section-brand-height: 100px;
  --section-brand-height-logo: 45px;
  --size-text-description: 54px;
  --size-text-button: 12px;
	--size-text-team-name: 24px;
	--size-text-team-title: 18px;
	--size-text-form-label: 10px;
	--size-text-form-input: 18px;
	--size-text-form-submit: 12px;
	--size-text-form-response: 14px;
  --size-text-banner-description: 24px;
  --size-text-kicker: 12px;
  --size-text-social: 32px;
	--size-text-reach-content: 18px;
	--size-text-reach-content-h4: 32px;
  --size-text-footer: 15px;
  --size-text-footer-copyright: 14px;
  --size-text-flyout-menu-btn: 26px;

}


/*** site defaults ***/

html, BODY { height: 100%; }
BODY { background: var(--colour-background); font-family: var(--font-content); font-weight: 300; font-size: var(--size-text-body); color: var(--colour1); line-height: 1.3; text-align: center; overflow-wrap: break-word; }

h1, h2, h3, h4, h5 { margin: 0 0 15px; padding: 0; line-height: 1.3; font-family: var(--font-heading); color: var(--colour1); }
h1 { font-size: 32px; font-weight: 600; }
h2 { font-size: var(--size-text-h2); font-weight: 400; }
h3 { font-size: var(--size-text-h3); font-weight: 300; }
h4, h5 { font-size: 24px; font-weight: 400; margin: 0; }

a { color: var(--colour-a); text-decoration: none; }
a:hover { color: var(--colour-a-hover); text-decoration: none; }

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

ul, ol { margin: 0 0 30px 15px; padding: 0; list-style-type: disc; }
ol { list-style-type: decimal; }
li { margin: 0 0 10px 15px; 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; }
h2 + h4, h4 + p { margin-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, .section { position: relative; display: block; box-sizing: border-box; -moz-box-sizing: border-box; overflow: hidden; }

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

.width-page { width: 100%; max-width: 1236px; margin: 0 auto; }
.width-content { width: 100%; max-width: 870px; }

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

.horiz-right { justify-content: right; }
.horiz-center { margin-left: auto; margin-right: auto; }

.flyout-menu { display: none; }
.flyout-menu a { font-size: var(--size-text-flyout-menu-btn); color: var(--colour-flyout-menu-btn); text-decoration: none; }
.flyout-menu a:hover { color: var(--colour-flyout-menu-btn-hover); text-decoration: none; }

#flyout-menu { position: fixed; top: 0; left: 0; display: none; width: 100%; height: 100%; background: var(--colour-flyout-menu-background); padding: 30px var(--outer-padding-width); z-index: 9999999; overflow-y: auto; }
#flyout-menu-top { margin: 0 0 30px; }
#flyout-menu-top .row-1 { grid-template-columns: 1fr auto; gap: 0 0; }
#flyout-menu-top .row-1 .logo { width: 150px; }
#flyout-menu-top .row-1 ul, #flyout-menu-top .row-1 li, #flyout-menu-main .row-1 ul, #flyout-menu-main .row-1 li { list-style-type: none; margin: 0; padding: 0; }
#flyout-menu-top .row-1 li a { text-decoration: none; color: var(--colour-flyout-menu); font-size: 24px; }
#flyout-menu-top .row-1 li a:hover { text-decoration: none; color: var(--colour-flyout-menu-hover); }
#flyout-menu-main .row-1 { grid-template-columns: auto; gap: 30px 0; }
#flyout-menu-main .row-1 .col-1 li { display: block; border-bottom: 1px solid rgba(255, 255, 255, .2); }
#flyout-menu-main .row-1 .col-1 li a { display: block; background: var(--colour-flyout-menu-background); color: var(--colour-flyout-menu); font-size: 13px; text-transform: uppercase; font-weight: 500; letter-spacing: 1.2px; text-decoration: none; text-align: center; 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-1 .col-1 li a:hover, #flyout-menu-main .row-1 .col-1 li.current-menu-item a:hover { background: var(--colour-flyout-menu-background); color: var(--colour-flyout-menu-hover); text-decoration: none; }
#flyout-menu-main .row-1 .col-2 { font-size: 16px; }
#flyout-menu-main .row-1 .col-3 a { color: var(--colour1); text-decoration: none; font-size: 24px; }
#flyout-menu-main .row-1 .col-3 a:hover { color: var(--colour5); text-decoration: none; }
#flyout-menu-sub { display: none; }

a.button { position: relative; display: block; font-family: var(--font-sub-heading); font-weight: 500; letter-spacing: 1.2px; font-size: var(--size-text-button); text-transform: uppercase; background: var(--colour-background-button); color: var(--colour-background-button-text); border: solid 1px var(--colour-background-button-border); border-radius: 45px; line-height: 45px; text-align: center; text-decoration: none !important; box-sizing: border-box; -moz-box-sizing: border-box; }
a.button span { margin-left: 10px; }
a.button:hover { background: var(--colour-background-button-hover); color: var(--colour-background-button-text-hover); border-color: var(--colour-background-button-border-hover); }

a.button.alt-1 { background: var(--colour-background-button-alt); color: var(--colour-background-button-text-alt); border-color: var(--colour-background-button-border-alt); }
a.button.alt-1:hover { background: var(--colour-background-button-hover-alt); color: var(--colour-background-button-text-hover-alt); border-color: var(--colour-background-button-border-hover-alt); }

a.button.alt-2 { background: var(--colour-background-button-alt2); color: var(--colour-background-button-text-alt2); border-color: var(--colour-background-button-border-alt2); }
a.button.alt-2:hover { background: var(--colour-background-button-hover-alt2); color: var(--colour-background-button-text-hover-alt2); border-color: var(--colour-background-button-border-hover-alt2); }

a.button.alt-3 { background: var(--colour-background-button-alt3); color: var(--colour-background-button-text-alt3); border-color: var(--colour-background-button-border-alt3); }
a.button.alt-3:hover { background: var(--colour-background-button-hover-alt3); color: var(--colour-background-button-text-hover-alt3); border-color: var(--colour-background-button-border-hover-alt3); }

form label { position: absolute; top: 0; display: none; width: 100%; opacity: 0; font-size: var(--size-text-form-label); color: var(--colour-form-label-text); font-family: var(--font-sub-heading); font-weight: 200; text-transform: uppercase; -webkit-transition: all 0.2s ease-out; transition: all 0.2s ease-out; z-index: 1 }
form input, form select, form textarea { position: relative; width: 100%; background: var(--colour-form-input-background); font-family: var(--font-content); font-weight: 400; font-size: var(--size-text-form-input); letter-spacing: .02rem; color: var(--colour-form-input-text); padding: 15px 15px; border: none; border-bottom: 1px solid var(--colour-form-input-border); 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: 90px; }

form select { padding-top: 14px; padding-bottom: 13px; }
form .select-wrap { position: relative; display: block; background: var(--colour-form-input-text); }
form .select-box-wrap { position: relative; display: block; z-index: 20; }
form select { -webkit-appearance: none; -moz-appearance: none; text-overflow: ''; background: none; border: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; padding-right: 60px; cursor: pointer; }
form select::-ms-expand { display: none; }
form .select-dir { position: absolute; top: 18px; right: 0px; display: block; height: 43%; padding: 0 15px; color: var(--colour-form-input-text); line-height: 1.1; z-index: 10; }

form .radio-wrap, form .checkbox-wrap { position: relative; display: block; }
form .radio-box-wrap, form .checkbox-box-wrap { position: relative; display: block; z-index: 20; }
form .radio-wrap label, form .checkbox-wrap label { position: relative; display: block; opacity: 1; font-family: var(--font-content); font-size: var(--size-text-body); letter-spacing: .02rem; color: var(--colour1); text-transform: none; padding: 10px 0px; }
form .radio-box-wrap label input { position: absolute; top: 15px; width: auto; }
form .checkbox-wrap label input { position: relative; width: auto; padding: 0; background: none; border: none; }
form .checkbox-wrap label input:before { font-family: "fontello"; font-style: normal; font-weight: normal; speak: never; display: inline-block; text-decoration: inherit; width: 1em; margin-right: 0; text-align: center; font-variant: normal; text-transform: none; line-height: 1em; margin-left: 0; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; content: '\f096'; background: none; }
form .checkbox-wrap label input:checked:before { content: '\f14a'; background: none; }
form .checkbox-wrap .wpcf7-checkbox { display: grid; grid-template-columns: repeat(12, auto); grid-template-rows: auto; grid-auto-rows: minmax(min-content, max-content); gap: 0 30px; }
form .radio-box-wrap label .wpcf7-list-item, form .checkbox-wrap .wpcf7-list-item { margin-left: 0; }
form .radio-box-wrap .wpcf7-list-item.first, form .checkbox-wrap .wpcf7-list-item.first { padding-left: 0; margin-left: 0; }
form .radio-box-wrap label .wpcf7-list-item-label, form .checkbox-wrap label .wpcf7-list-item-label { padding-left: 5px; }

form .floating label { display: block; margin-top: 2px; margin-left: 0; padding: 0 15px; text-align: left; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-transform: translateY(3px); transform: translateY(3px); pointer-events: none; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; -webkit-box-sizing: border-box; box-sizing: border-box; opacity: 1; }
form .wpcf7-not-valid { border-bottom: 1px solid var(--colour-form-input-border-required); }
form .wpcf7-not-valid-tip { display: none; }
form .floating input, form .floating select, form .floating textarea { padding-top: 24px; padding-bottom: 6px; }
form .floating select { padding-top: 25px; padding-bottom: 5px; padding-left: 15px; }
.firefox form .floating select { padding-left: 11px; }

form input[type="submit"] { padding: 0 30px; border: none; font-family: var(--font-sub-heading); background: var(--colour-form-submit); color: var(--colour-form-submit-text); font-size: var(--size-text-form-submit); font-weight: 700; letter-spacing: 1.2px; line-height: 45px; text-transform: uppercase; border-radius: 45px; -webkit-box-sizing: border-box; box-sizing: border-box; }
/*.firefox form input[type="submit"] { line-height: 1; padding-top: 16px; padding-bottom: 11px; }*/
form input[type="submit"]:hover { background: var(--colour-form-submit-hover); color: var(--colour-form-submit-text-hover); }

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(--colour-form-response-background); color: var(--colour-form-response-text); font-size: var(--size-text-form-response); text-align: center; border-radius: 45px; }
form.invalid .wpcf7-response-output { background: var(--colour-form-response-background-alert); color: var(--colour-form-response-text-alert); }

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

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


/*** site styles ***/

header { background: var(--colour2); padding: 0 var(--outer-padding-width); border-bottom: 1px solid var(--colour-border); }
header .inner.grid { padding: 25px 0; grid-template-columns: auto 1fr; gap: 0 var(--gap-width); }
header .logo { width: 185px; }
header .menu ul, .menu li { display: inline-block; list-style-type: none; padding: 0; margin: 0; }
header .menu li { margin-left: var(--gap-menu); }
header .menu li:first-of-type { margin-left: 0; }
header .menu li a { font-family: var(--font-sub-heading); text-decoration: none; color: var(--colour-main-menu); text-transform: uppercase; font-weight: 500; font-size: var(--size-text-main-menu) }
header .menu li a:hover, header .menu li.current-menu-item a { text-decoration: none; color: var(--colour-main-menu-active); }


.section { padding: 0 var(--outer-padding-width) var(--gap-section); }
.section .heading h2 { margin-bottom: 0; }
.section a.tel { color: var(--colour-body-text); text-decoration: none; }
.section a.tel:hover { color: var(--colour-body-text); text-decoration: none; }

.section.banner.banner-home { height: calc(100vh - 205px); }
.section.banner.banner-home .banner-content { height: var(--section-banner-home-circle-height); }
.section.banner.banner-home h1 { font-size: var(--size-text-banner-home); font-weight: 200; margin: 0; padding: 0; }
.section.banner.banner-home h1 span { position: relative; display: inline-block; color: var(--colour-banner-home-title-highlight); font-style: italic; font-weight: 700; padding-left: 15px; }
.section.banner.banner-home h1 span::before { position: absolute; display: block; top: var(--section-banner-home-circle-top); left: -5px; width: var(--section-banner-home-circle-height); height: var(--section-banner-home-circle-height); content: ""; background: url("images/red-circle.png") no-repeat; background-size: contain; }
.section.banner.banner-home .banner-video { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; }
.section.banner.banner-home .banner-video .video-wrapper { width: auto; height: 100%; padding-top: 0; }
.section.banner.banner-home .banner-video .video-wrapper video { width: 100vw; height: auto; }


.section.brand-list { }
.section.brand-list .grid.brand-listing { grid-template-columns: 1fr 1fr 1fr; gap: 0 0; max-width: 600px; margin: 0 auto; }
.section.brand-list .grid.brand-listing .grid.brand-item { height: var(--section-brand-height); border-left: 1px solid var(--colour-border); padding: 0 20px; -webkit-box-sizing: border-box; box-sizing: border-box; }
.section.brand-list .grid.brand-listing .grid.brand-item:first-child { border-left: none; }
.section.brand-list .grid.brand-listing .grid.brand-item .brand-item-logo img { max-height: var(--section-brand-height-logo); width: auto; max-width: 100%; }

.section.description { font-family: var(--font-heading); font-weight: 400; font-size: var(--size-text-description); padding-bottom: 35px; }
.section.description .inner { padding: var(--gap-description-height) 0; }
.section.description .inner .op { position: absolute; top: 15%; left: 0; display: block; height: 85%; width: 100%; background: url("images/op.png") right center no-repeat; background-size: contain; z-index: 1; }
.section.description .inner .content-wrapper { position: relative; min-height: var(--gap-description-circles-size); z-index: 10; }
.section.description .inner .circles { position: absolute; top: 0; left: 0; display: block; height: var(--gap-description-circles-size); width: var(--gap-description-circles-size); background: url("images/circle.png") no-repeat; background-size: cover; z-index: 1; }
.section.description .inner .content { position: relative; display: block; padding: 0 var(--gap-description-width); z-index: 10; }

.section.team { }
.section.team .inner.grid { grid-template-columns: auto; grid-template-rows: auto; gap: 30px 0; }
.section.team .inner.grid .team-listing.grid { grid-template-columns: 1fr 1fr 1fr 1fr; gap: var(--gap-team-height) var(--gap-team-width); }
.section.team .inner.grid .team-listing.grid .team-member.grid { grid-template-rows: auto 1fr 1fr; gap: 5px 0; }
.section.team .inner.grid .team-listing.grid .team-member.grid .team-member-image { border: 1px solid #f7f7fa; }
.section.team .inner.grid .team-listing.grid .team-member.grid .team-member-name { padding-top: 15px; font-size: var(--size-text-team-name); }
.section.team .inner.grid .team-listing.grid .team-member.grid .team-member-title { font-size: var(--size-text-team-title); }


.section.contact { }
.section.contact .columns.grid { grid-template-columns: 1fr var(--gap-contact-map-width); gap: 0 var(--gap-contact-width); }
.section.contact .columns.grid .col-main { grid-template-columns: auto; grid-template-rows: auto 1fr; gap: 30px 0; }
.section.contact .columns.grid .col-main .contact-form.grid { gap: var(--gap-form-height) 0; }
.section.contact .columns.grid .col-main .contact-form.grid .row.grid { grid-template-columns: 1fr 1fr; gap: 0 var(--gap-form-width); }
.section.contact .columns.grid .col-main .contact-form.grid textarea { height: 100px; }
.section.contact .columns.grid .col-main .contact-form.grid input[type="submit"] { max-width: var(--border-width); }
.section.contact .columns.grid .col-sidebar { grid-template-columns: auto; grid-template-rows: auto 1fr; gap: var(--gap-contact-sidebar-height) 0; }
.section.contact .columns.grid .col-sidebar .content { font-weight: 500; }
.section.contact .columns.grid .col-sidebar .page-map { height: 350px; }


.section.section-list { }
.section.section-list.top-margin { margin-top: var(--gap-section-list-height); }
.section.section-list .section-listing.grid { grid-template-columns: auto; grid-template-rows: auto; }
.section.section-list .section-listing.grid.section-listing-rows { gap: var(--gap-section-list-height) 0; }
.section.section-list .section-listing.grid.section-listing-columns { grid-template-columns: 1fr 1fr; gap: var(--gap-section-list-height) 0; }

.section.section-list .section-listing.grid .section-item { border-top: 1px solid var(--colour-border); padding-top: var(--gap-section-list-height); }
.section.section-list .section-listing.grid .section-item:first-child { border: none; padding-top: 0; }

.section.section-list .section-listing.grid.section-listing-columns .section-item:first-child, .section.section-list .section-listing.grid.section-listing-columns .section-item:nth-child(1n) { border-top: none; padding-top: 0; }

.section.section-list .section-listing.grid.section-listing-columns .section-item:nth-child(odd) { padding-right: var(--gap-section-list-width); }
.section.section-list .section-listing.grid.section-listing-columns .section-item:nth-child(even) { padding-left: var(--gap-section-list-width); border-left: 1px solid var(--colour-border); }

.section.section-list .section-listing.grid .section-item h2 { margin-bottom: 0; }
.section.section-list .section-listing.grid .section-item .section-item-kicker { font-family: var(--font-sub-heading); color: var(--colour-kicker); font-size: var(--size-text-kicker); font-weight: 500; text-transform: uppercase; margin-bottom: 5px; }
.section.section-list .section-listing.grid .section-item .section-item-button a.button { max-width: var(--border-width); }

.section.section-list .section-listing.grid .section-item .section-item-content.grid { grid-template-rows: auto 1fr; gap: 30px 0; }
.section.section-list .section-listing.grid .section-item .section-item-content.grid.section-item-content-button { grid-template-rows: auto auto 1fr; gap: 30px 0; }

.section.section-list .section-listing.grid.section-listing-rows .section-item.grid {}
.section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image { grid-template-columns: var(--section-list-image-width) 1fr; grid-template-areas: "image content"; gap: 0 var(--gap-section-list-width); }
.section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image:nth-child(even) { grid-template-columns: 1fr var(--section-list-image-width); grid-template-areas: "content image"; }
.section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image .section-item-image { grid-area: image; }
.section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image .section-item-content { grid-area: content; }

.section.section-list .section-listing.grid.section-listing-columns .section-item.grid {}
.section.section-list .section-listing.grid.section-listing-columns .section-item.grid.section-item-image { grid-template-rows: auto 1fr; gap: var(--section-list-columns-image-gap) 0; }

.section.section-list .section-listing.grid .section-item .grid.section-group { grid-template-columns: auto 1fr; gap: 30px 30px; padding-top: 20px; }
.section.section-list .section-listing.grid .section-item .grid.section-group .section-item-button a.button { width: var(--border-width); }
.section .grid.section-social { grid-template-columns: auto auto 1fr; gap: 0 30px; }
.section .grid.section-social a { font-size: var(--size-text-social); color: var(--colour-social); text-decoration: none; }
.section .grid.section-social a:hover { color: var(--colour-social-hover); text-decoration: none; }

.section.banner { font-size: var(--size-text-banner-description); height: var(--section-banner-height); padding-bottom: 20px; padding-top: 20px; }
.section.banner h3 { font-weight: 200; }
.section.banner h3 span { color: var(--colour-banner-title-highlight); font-style: italic; font-weight: 700; }
.section.banner .banner-button { padding-top: var(--padding-height); }
.section.banner a.button { max-width: var(--border-width); }
.section.banner .banner-video { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; }
.section.banner .banner-video .video-wrapper { width: auto; height: 100%; padding-top: 0; }
.section.banner .banner-video .video-wrapper video { width: 100vw; height: auto; }

.section.reach { background-color: var(--colour-reach-background); font-size: var(--size-text-reach-content); padding-bottom: var(--gap-section-reach-height); padding-top: var(--gap-section-reach-height); }
.section.reach .inner.grid { gap: 35px 0; }
.section.reach h3 { font-weight: 200; margin-bottom: 0; }
.section.reach h3 span { color: var(--colour-reach-title-highlight); font-style: italic; font-weight: 700; }
.section.reach h4 { font-weight: 400; margin: 0; font-size: var(--size-text-reach-content-h4); }
.section.reach .reach-form.grid { gap: var(--gap-form-height) 0; }
.section.reach .reach-form.grid .row.grid { grid-template-columns: 1fr 1fr; gap: 0 var(--gap-section-reach-col-spacing); }
.section.reach .reach-form.grid input[type='text'], .section.reach .reach-form.grid input[type='email'], .section.reach .reach-form.grid textarea { background: none; }
.section.reach .reach-form.grid textarea { height: 100px; }
.section.reach .reach-form.grid input[type="submit"] { max-width: var(--border-width); }
.section.reach .reach-form.grid .row-2 .row { grid-template-columns: 1fr; gap: var(--gap-form-height) 0; }
.section.reach .reach-form.grid .row-3.bottom > .col-1.grid { grid-template-columns: 1fr; gap: 15px 0; }
.section.reach .reach-form.grid .row-3.bottom .row-2.grid { grid-template-columns: 1fr var(--border-width); gap: 0 30px; }
.section.reach .reach-form.grid .row-3.bottom .row-2.grid .wpcf7-list-item { white-space: nowrap; }


footer { background: var(--colour-background-footer); color: var(--colour-footer-text); padding: 0 var(--outer-padding-width); font-weight: 300; font-size: var(--size-text-footer); font-family: var(--font-content); }
footer a { color: var(--colour-footer-text); text-decoration: none; }
footer a:hover { color: var(--colour-footer-copyright); text-decoration: none; }
footer a.tel { color: var(--colour-footer-text); text-decoration: none; }
footer a.tel:hover { color: var(--colour-footer-text); text-decoration: none; }
footer .border-top { border-top: 1px solid rgba(255,255,255,0.15); }

footer .inner.grid { padding: 40px 0; grid-template-columns: 1fr; gap: 30px 0; }
footer .row-1.grid { grid-template-columns: 166px 1fr 260px; gap: 0 var(--gap-footer-width); }
footer .row-1.grid .name { margin-bottom: 3px; }
footer .row-1.grid .location.grid { grid-template-columns: 160px 1fr; gap: 0 var(--gap-width); }
footer .row-2 { padding-top: 30px; font-size: var(--size-text-footer-copyright); color: var(--colour-footer-copyright); }

.grecaptcha-badge { display: none; }
.page-id-59 .grecaptcha-badge { display: block; }


@viewport { width: auto; }

@media only screen and (max-width: 1100px) {
  
  .section.section-list .section-listing.grid .section-item .grid.section-group { grid-template-columns: auto; grid-template-rows: auto; }
  .section.section-list .section-listing.grid .section-item .grid.section-group .section-item-button a.button { width: auto; }
	
	.section.reach form .checkbox-wrap .wpcf7-checkbox { grid-template-columns: repeat(3, auto); }
  
}

@media only screen and (max-width: 1020px) {
  
  :root {

    --size-text-banner-home: 62px;
    --size-text-h3: 42px;
    --size-text-description: 44px;
    --size-text-team-name: 22px;
    --size-text-social: 28px;
    
    --gap-team-height: 50px; 
    --gap-team-width: 50px;
    --gap-section: 60px;
    --section-banner-home-circle-height: 150px;
    --section-banner-home-circle-top: -35px;
		--gap-section-reach-col-spacing: 100px;
    
  }
	
	.section.reach form .checkbox-wrap .wpcf7-checkbox { grid-template-columns: repeat(2, auto); }
  
  footer .row-1.grid .location.grid { grid-template-columns: 1fr; gap: 15px var(--gap-width); }
  
}

@media only screen and (max-width: 820px) {
  
  :root {
    
    --size-text-banner-home: 56px;
    --size-text-h2: 28px;
    --size-text-h3: 38px;
    --size-text-description: 30px;
    --size-text-banner-description: 20px;
		--size-text-reach-content-h4: 28px;
    
    --gap-section-list-width: 40px;
    --gap-description-height: 40px;
    --gap-description-circles-size: 180px;
    --gap-contact-map-width: 300px;
    --gap-form-height: 20px;
    --section-list-image-width: 300px;
    --section-brand-height-logo: 30px;
    --gap-contact-width: 40px;
    --section-banner-home-circle-height: 130px;
    --section-banner-home-circle-top: -29px;
		--gap-section-reach-col-spacing: 30px;
		--gap-section-reach-height: 40px;
    
  }
  
  .section.team .inner.grid .team-listing.grid { grid-template-columns: 1fr 1fr 1fr; }
  .section.contact .columns.grid .col-main .contact-form.grid .row.grid { grid-template-columns: 1fr; gap: 20px var(--gap-form-width); }
  
  .section.brand-list .grid.brand-listing .grid.brand-item { font-size: 14px; }
  
  .section.contact .columns.grid { grid-template-columns: 1fr; gap: var(--gap-contact-width) 0; }
	.section.reach .reach-form.grid .row.grid { grid-template-columns: 1fr; gap: 20px var(--gap-section-reach-col-spacing); }
	.section.reach .reach-form.grid .row-3.bottom .row-2.grid { grid-template-columns: 1fr; gap: 30px 30px; }
  
  footer .row-1.grid { grid-template-columns: 1fr; grid-template-areas: "logo" "address" "contact"; gap: 35px 0; }
  footer .row-1.grid .logo { grid-area: logo; max-width: 166px; margin: 0 auto; }
  footer .row-1.grid .address { grid-area: address; margin: 0 auto; }
  footer .row-1.grid .contact { grid-area: contact; width: 260px; margin: 0 auto; }
  footer .row-1.grid .location.grid { grid-template-columns: 160px 1fr; gap: 0 var(--gap-width); }
  
}

@media only screen and (max-width: 667px) {
  
  :root {
    
    --section-banner-height: 300px;
    --gap-section-list-height: 40px;
    --gap-description-width: 40px;
    --gap-team-height: 30px;
    --gap-team-width: 30px;
    --section-banner-home-circle-height: 100px;
    --section-banner-home-circle-top: -22px;  
    
    --size-text-h2: 24px;
    --size-text-h3: 32px;
		--size-text-reach-content-h4: 24px;
    --size-text-banner-home: 42px;
    --size-text-description: 28px;
    --size-text-banner-description: 18px;
    --size-text-team-name: 20px;
    --size-text-team-title: 16px;
    
  }
  
  header .logo { width: 170px; }
  #menu-main-menu { display: none; }
  .flyout-menu { display: block; }
  .section.description .inner .content br { display: none; }

  .section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image, .section.section-list .section-listing.grid.section-listing-rows .section-item.grid.section-item-image:nth-child(2n) { grid-template-columns: 1fr; grid-template-areas: "image" "content"; gap: 30px var(--gap-section-list-width); }
  .section.section-list .section-listing.grid.section-listing-columns { grid-template-columns: 1fr; gap: var(--gap-section-list-height) 0; }
  .section.section-list .section-listing.grid.section-listing-columns .section-item:nth-child(2n) { padding-left: 0; border-left: none; }
  .section.section-list .section-listing.grid.section-listing-columns .section-item:nth-child(2n+1) { padding-right: 0; }
  .section.section-list .section-listing.grid.section-listing-columns .section-item { border-top: 1px solid var(--colour-border) !important; padding-top: var(--gap-section-list-height) !important; }
  .section.section-list .section-listing.grid.section-listing-columns .section-item:first-child { border-top: none !important; padding-top: 0 !important; }
  
  .section.team .inner.grid .team-listing.grid { grid-template-columns: 1fr 1fr; }
    
  .section.banner.banner-home { height: calc(100vh - 96px); margin-bottom: var(--gap-section-list-height); }
  .section.description .inner .op { display: none; }
  .section.brand-list { display: none; }
  
}

@media only screen and (max-width: 480px) {
  
  .section.banner.banner-home h1 span::before { display: none; }
  
}

@media only screen and (max-width: 420px) {
  
  :root {
    
    --size-text-banner-home: 36px;
    --size-text-description: 24px;
    
    --outer-padding-width: 20px;
    --gap-description-height: 25px;
    --gap-team-height: 20px;
		--gap-section-reach-height: 25px;
    
  }
  
  header .logo { width: 135px; }
  #flyout-menu-top .row-1 .logo { width: 135px; }
  
  .section.team .inner.grid .team-listing.grid { grid-template-columns: 1fr; }
  .section.contact .columns.grid .col-main .contact-form.grid input[type="submit"] { max-width: 100%; }
	
	.section.reach form .checkbox-wrap .wpcf7-checkbox { grid-template-columns: repeat(1, auto); }
	.section.reach .reach-form.grid input[type="submit"] { max-width: 100%; }
  
  footer .row-1.grid .logo { max-width: 150px; }
  footer .row-1.grid .location.grid { grid-template-columns: 1fr; gap: 15px var(--gap-width); }
  
}

@media only screen and (max-width: 360px) {
  

}