﻿* { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

/* = Reset
----------------------------------------------------------------------------------------------------------------- */
html, body, div, span, h1, h2, h3, h4, h5, h6, p, hr, a, a img, font, img, dd, dl, dt, li, ol, ul, blockquote, fieldset, form, label, legend, table, caption, tr, th, td { margin: 0; padding: 0; border: 0; font-size: 100%; }

/* = HTML5 Elements
----------------------------------------------------------------------------------------------------------------- */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
audio, canvas, video { display: inline-block; }

html { -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

/* = Body
----------------------------------------------------------------------------------------------------------------- */
body { color: #655C59; font-size: 24px; text-align: left; font-family: 'Source Sans Pro', sans-serif; text-rendering: optimizeLegibility; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; background: #fff; }

@media screen and (max-width: 1280px) {
    body { font-size: 22px; }
}

@media screen and (max-width: 650px) {
    body { font-size: 20px; }
}

@media screen and (max-width: 400px) {
    body { font-size: 18px; }
}

/* = Typography
----------------------------------------------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, .heading1, .heading2, .heading3, .heading4, .heading5, .heading6 { margin: 0 0 25px; color: #655C59; font-weight: 400; line-height: normal; }

h1, .heading1 { font-size: 270%; font-weight: 700; margin-bottom: 35px; }
h2, .heading2 { font-size: 125%; font-weight: 600; margin-bottom: 35px; }
h3, .heading3 { font-size: 120%; line-height: 1.2em; }
h4, .heading4 { font-size: 120%; line-height: 1.2em; font-weight: 600; }
h5, .heading5 { font-size: 105%; font-weight: 600; line-height: 1.2em; }
h6, .heading6 { font-size: 100%; font-weight: 600; }

.main-content h2 { font-weight: 600; }

p { margin: 0 0 32px; line-height: 1.75em; font-weight: 300; }
p + h2 { margin-top: 40px; }
p + h3 { margin-top: 40px; }
p + h4 { margin-top: 35px; }
p + h3:last-of-type { font-weight: 700; }

.brFax { display:none; }

@media screen and (max-width: 1280px) {
    p { margin: 0 0 28px; }
}

@media screen and (max-width: 1024px) {
    .brFax { display: block; }
    .dash { display:none; }
}

@media screen and (max-width: 650px) {
    p { margin: 0 0 24px; }
}

@media screen and (max-width: 600px) {
    p { margin: 0 0 22px; }
}

@media screen and (max-width: 400px) {
    p { margin: 0 0 20px; }
}

.container .inner h3:last-of-type { font-weight: 700; }
.container .inner .tab-content h3:last-of-type { font-weight: 600; }

.leader + h2,
.leader + h3 { margin-top: 40px; }

.hero .hero-text .leader { font-size: 180%; line-height: 1.25em; }

@media screen and (max-width: 650px) {
    .leaderLarge { line-height: 1.6em; }
}

@media screen and (max-width: 600px) {
    h1, .heading1 { margin-bottom: 25px; }
    h2, .heading2 { margin-bottom: 25px; }
    .leader + h2 { margin-top: 35px; }
}

@media screen and (max-width: 480px) {
    h1, h2, h3, h4, h5, h6, .heading1, .heading2, .heading3, .heading4, .heading5, .heading6 { margin: 0 0 20px; }
    h1, .heading1 { font-size: 36px; }
}

@media screen and (max-width: 440px) {
    h1, .heading1 { font-size: 34px; }
}

b, strong { font-weight: 600; }

h1 strong, .heading1 strong,
h2 strong, .heading2 strong,
h3 strong, .heading3 strong,
h4 strong, .heading4 strong,
h5 strong, .heading5 strong,
h6 strong, .heading6 strong { font-weight: 600; }

blockquote { margin: 40px 0; border-left: 6px solid #3ede83; padding-left: 35px; }
blockquote p { margin: 0; line-height: 1.4em; font-family: 'Source Sans Pro', sans-serif; }
blockquote cite { font-size: 75%; font-style: normal; margin-top: 15px; display: block; }
blockquote p cite { font-size: 0.75em; }

@media screen and (max-width: 600px) {
    blockquote {  padding-left: 30px; }
}

@media screen and (max-width: 360px) {
    blockquote { border-width:5px;  padding-left: 26px; }
}


a { color: #655C59; text-decoration: none; }
a:hover { color: #fa7300; text-decoration: none; }


#page-terms .main-content a:hover,
#page-privacy .main-content a:hover,
#page-cookies .main-content a:hover,
#page-locations .main-content a:hover { color: #3ede83; }

.main-content .container p:not(.leader) a:not(.btn),
.main-content .inner p:not(.leader) a:not(.btn) { text-decoration: underline; }


img { vertical-align: bottom; height: auto; -ms-interpolation-mode: bicubic; }
hr { margin: 40px 0; height: 1px; border: 0; border-top: 1px solid #ccc; }
small { font-size: 75%; }
address { margin: 0 0 25px; line-height: 1.65em; font-style: normal; }

sub, sup { line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }

p sup { font-weight: 200; font-size: .65em; }

pre { margin: 0; }
pre code { font-size: 1.5em; white-space: pre-wrap; }

figure { margin: 0; }
figcaption { color: #655C59; font-size: 0.667em; margin-top: .8em; }

.floatLeft { float: left; }
.floatRight { float: right; }
.hide { display: none; }
.hideText { text-indent: 100%; white-space: nowrap; overflow: hidden; }
.clr { clear: both; }

.textLeft { text-align: left; }
.textCenter { text-align: center; }
.textRight { text-align: right; }
.highlight { color: #fa7300; }
.marked { color: #fff; background: #fa7300; }
.meta { color: #666; font-style: italic; font-size: 0.9em; margin-bottom: 10px; }
.lrgfont { font-size: 120%; }
.fixed { position: fixed; top: 20px; }

@media screen and (max-width: 750px) {
    .fixed { position: static; }
}

.scrollTo { position: absolute; display: block; width: 34px; height: 34px; bottom: 50px; left: 50%; margin-left: -17px; color: #fff; cursor: pointer; background: url(/_img/icons/down-white.svg) no-repeat 0 0; background-size: 34px; animation: bounce .8s infinite alternate; -webkit-animation: bounce .8s infinite alternate; z-index: 10; }

@media screen and (max-width: 1200px) {
    .scrollTo { bottom: 40px; }
}


@media screen and (max-width: 1024px) {
    .scrollTo { bottom: 25px; width: 30px; margin-left: -15px; background-size: 30px; }
}

@media screen and (max-width: 600px) {
    .scrollTo { display: none; }
}

@keyframes bounce {
    from { transform: translateY(0px); }
    to { transform: translateY(-6px); }
}

@-webkit-keyframes bounce {
    from { transform: translateY(0px); }
    to { transform: translateY(-6px); }
}

/* = Colours
----------------------------------------------------------------------------------------------------------------- */
.brandblack { color: #fff; background: #000; }
.brand--orange { color: #fff; background: #fa7300; }
.brand--green { color: #fff; background: #3ede83; }
.brand--blue { color: #fff; background: #00acdb; }
.brand--grey { color: #fff; background: #655c59; }
.block { display: inline-block; padding: 50px 50px 10px 20px; font-weight: 600; }

/* = Buttons
----------------------------------------------------------------------------------------------------------------- */
.btn, .location .split-content .content-inner .locationMore p { display: inline-block; vertical-align: middle; padding: 10px 20px; height: 36px; font-size: 14px; font-weight: 400; color: #fff; font-family: 'Source Sans Pro', sans-serif; outline: none; cursor: pointer; border: none; background: #fa7300; -moz-border-radius: 10px; -webkit-border-radius: 10px; border-radius: 10px; line-height: 1em; -webkit-transform: perspective(1px) translateZ(0); transform: perspective(1px) translateZ(0); position: relative; -webkit-transition-property: color; transition-property: color; -webkit-transition-duration: 0.3s; transition-duration: 0.3s; z-index: 0; }
.btn:hover, .location .split-content .content-inner .locationMore p:hover { color: #fff; }

.btn:before, .location .split-content .content-inner .locationMore p::before { content: ""; position: absolute; z-index: -1; top: 0; left: 0; right: 0; bottom: 0; height: 36px; background: #3ede83; -moz-border-radius: 0; -webkit-border-radius: 10px; border-radius: 10px; -webkit-transform: scale(0); transform: scale(0); -webkit-transition-property: transform; transition-property: transform; -webkit-transition-duration: 0.3s; transition-duration: 0.3s; -webkit-transition-timing-function: ease-out; transition-timing-function: ease-out; }
.btn:hover, .btn:focus, .btn:active, .location .split-content .content-inner .locationMore p:hover, .location .split-content .content-inner .locationMore p:focus, .location .split-content .content-inner .locationMore p:active { color: #fff; }
.btn:hover:before, .btn:focus:before, .btn:active:before, .location .split-content .content-inner .locationMore p:hover::before, .location .split-content .content-inner .locationMore p:focus::before, .location .split-content .content-inner .locationMore p:active::before { -webkit-transform: scale(1); transform: scale(1); }

.btn--green,
#page-who .btn:not(.cookieNoticeClose) { border-color: #3ede83; background: #3ede83; }

.btn--green:before,
#page-who .btn:not(.cookieNoticeClose):before { background: #fa7300; }

.btn--green-grey:before,
#page-who .btn--green-grey:not(.cookieNoticeClose):before { background: #655C59; }

.btn--blue,
#page-what-matters .btn:not(.cookieNoticeClose) { border-color: #00acdb; background: #00acdb; }

.btn--blue:before,
#page-what-matters .btn:not(.cookieNoticeClose):before { background: #3ede83; }

.btn--grey,
#page-news .btn:not(.cookieNoticeClose),
#page-contact .btn:not(.cookieNoticeClose) { border-color: #655c59; background: #655c59; }

.btn--grey:before,
#page-news .btn:not(.cookieNoticeClose):before,
#page-contact .btn:not(.cookieNoticeClose):before { background: #fa7300; }

.btn--vwfi { background: #009595; }
.btn--wilm { background: #CAD400; }


.btnImpact { border-color: #3ede83; background: #3ede83; }
input.btn { font-size: 75%; line-height: 1em; -webkit-border-radius: 10px; border-radius: 10px; }
input.btn:hover { opacity: 0.8; }

@media screen and (max-width: 400px) {
    .btn { padding: 13px 18px; height: 44px; }
    .btn:before { height: 44px; }
}

/* = Lists
----------------------------------------------------------------------------------------------------------------- */
ul { margin: 35px 0; overflow: hidden; padding-left: 40px; padding-right: 25px; line-height: 1.65em; font-weight: 300; }
ul li { margin: 0 0 24px; }
ul li ul { margin-top: 20px; margin-left: 30px; list-style-type: disc; }

@media screen and (max-width: 650px) {
    ul li { margin: 0 0 10px; }
}

ol { margin: 35px 0; overflow: hidden; padding-left: 40px; padding-right: 25px; line-height: 1.65em; }
ol li { margin: 0 0 10px; }
ol li ol { margin-top: 20px; margin-left: 30px; list-style-type: lower-latin; }

dl { margin: 0 0 25px; overflow: hidden; line-height: 1.65em; }
dt { color: #111; font-weight: 600; }
dd { margin: 0 0 20px; }

.inline { margin-left: 0; padding: 0; list-style: none; }
.inline li { display: inline; margin: 0 15px 0 0; }

.breadcrumb ul { margin-left: 0; padding: 0; list-style: none; }
.breadcrumb ul li { display: inline; margin: 0 10px 0 0; }

.paging { margin: 0 0 20px; }
.paging ul { margin: 0; padding: 0; list-style: none; }
.paging ul li { display: inline; }
.paging ul li.det { padding-right: 10px; }
.paging ul li a { display: inline-block; font-weight: 600; padding: 6px 12px; -webkit-border-radius: 8px; border-radius: 8px; color: #fff; background: #655C59; }
.paging ul li a:hover { background: #fa7300; }
.paging ul li a.on { background: #3ede83; }

@media screen and (max-width: 1280px) {
    ul, ol { margin: 0 0 28px; }
}

@media screen and (max-width: 600px) {
    .paging ul li.det { display: block; }
    .paging ul li:not(.det) { display: inline-block; margin: 10px 2px 0 0; font-size: 12px; }
    .paging ul li a { padding: 0px 10px; }
}

@media screen and (max-width: 650px) {
    ul, ol { margin: 0 0 24px; }
}


/* = Tables
----------------------------------------------------------------------------------------------------------------- */
.tableWrap { overflow: auto; }
table { width: 100%; margin: 0 0 20px; border-spacing: 0; border-collapse: collapse; font-size: 75%; }
th { padding: 15px 10px; color: #fff; border: 1px solid #333; background: #333; }
tr:nth-child(even) td { background: #f6f6f6; }
td { padding: 10px; border: 1px solid #e5e5e5; background: #fff; }
.rowItemStandout td { color: #fff; background: #a1c897; }

/* = Screen Messages
----------------------------------------------------------------------------------------------------------------- */
.msg { margin: 0 0 25px; padding: 20px; background: #f5f5f5; }
.msg p { margin-bottom: 0; font-size: 75%; }
.msg ul { padding: 0; padding-left: 25px; margin-bottom: 0; font-size: 75%; }
.msg ul li { margin-bottom: 5px; }

.msgImp { padding-left: 65px; color: #fff; background: #00acdb url(/_img/icons/important.svg) no-repeat 30px center; }
.msgImp a { color: #fff; font-weight: 600; }
.msgError { padding-left: 65px; color: #fff; background: #fa7300 url(/_img/icons/error.svg) no-repeat 20px center; }
.msgError a { color: #fff; font-weight: 600; }
.msgSuccess { padding-left: 65px; color: #fff; background: #3ede83 url(/_img/icons/success.svg) no-repeat 20px center; }
.msgSuccess h3 { color: #fff; margin: 0 0 10px; }
.msgSuccess a { color: #fff; font-weight: 600; }
.msgAssist { background-color: #fff0bc; }

/* = Columns
----------------------------------------------------------------------------------------------------------------- */
.cols { margin-bottom: 30px; }
.colsHalf .col { width: 48%; float: left; margin-right: 3%; }
.colsHalf--wider .col { width: 47.5%; margin-right: 5%; }
.colsThird .col { width: 32%; float: left; margin-right: 2%; }
.colsFourth .col { width: 22%; float: left; margin-right: 4%; }
.cols .endCol,
.colsHalf--wider .endCol { margin-right: 0; }
.cols .col p:last-child { margin: 0; }

.cols + h3 { margin-top: 45px; }

.colsFourth .col:nth-child(4n+4) { clear: right; margin-right: 0; }
.colsFourth .col:nth-child(4n+1) { clear: left; }

.colsTwoThirds .col { float: left; margin-right: 5%; width: 64%; }
.colsTwoThirds .endCol { margin-right: 0; width: 31%; }


@media screen and (max-width: 1024px) {
    .colsFourth .col { width: 30.666%; margin-right: 4%; }
    .colsFourth .col:nth-child(4n+4),
    .colsFourth .col:nth-child(4n+1) { clear: none; margin-right: 4%; }

    .colsFourth .col:nth-child(3n+3) { clear: right; margin-right: 0; }
    .colsFourth .col:nth-child(3n+1) { clear: left; }
}

@media screen and (max-width: 750px) {
    .colsHalf .col { width: 100%; margin-right: 0; }
    .colsThird .col { width: 100%; margin-right: 0; }
    .cols .col { margin-bottom: 35px; }
    .cols .endCol { margin-bottom: 0; }


    .colsFourth .col { width: 48%; margin-right: 4%; }

    .colsFourth .col:nth-child(4n+4),
    .colsFourth .col:nth-child(4n+1),
    .colsFourth .col:nth-child(3n+3),
    .colsFourth .col:nth-child(3n+1) { clear: none; margin-right: 4%; }

    .colsFourth .col:nth-child(even) { margin-right: 0; clear: right; }
    .colsFourth .col:nth-child(odd) { clear: left; }

    .colsTwoThirds .col { float: none; margin-right: 0; width: 100%; }
}

/* = Tabs that change to accordion on mobile
----------------------------------------------------------------------------------------------------------------- */
.tabs-wrap { margin: 40px 0; }

ul.tabs { margin: 0; padding: 0; list-style: none; }
ul.tabs li { float: left; margin: 0; cursor: pointer; padding: 0px 25px 0 0; overflow: hidden; position: relative; }
ul.tabs li:hover,
ul.tabs li.active { color: #fa7300; }

.tab-container { width: 100%; overflow: auto; }
.tab-content { padding: 25px 0 0; display: none; position: relative; }
.tab-content p:last-child { margin: 0; }
.tab-heading { display: none; }

@media screen and (max-width: 750px) {
    .tabs { display: none; }
    .tab-heading { background-color: #ccc; color: #fff; margin: 0 0 10px; padding: 10px 20px; display: block; cursor: pointer; -webkit-touch-callout: none; -webkit-user-select: none; -ms-user-select: none; user-select: none; position: relative; z-index: 1; }
    .tab-heading a { display: block; color: #fff; }
    .th-active { background-color: #3ede83; color: #fff; }

    .tab-content { margin: 20px 0; padding: 0; }
    .tab-content[id]:before { display: block; content: " "; margin-top: -200px; height: 200px; visibility: hidden; }

    #page-what-we-do .th-active { background: #fa7300; }
    #page-what-matters .th-active { background: #00acdb; }
    #page-contact .th-activer { background: #655c59; }
}

/* = Accordions
----------------------------------------------------------------------------------------------------------------- */
.accordion { margin: 40px 0; }
.accordion > h4 { display: block; text-align: center; margin: 0 0 10px; padding: 10px 20px; background-color: #ccc; color: #fff; }
.accordion > h4:hover { cursor: pointer; background: #3ede83; }
.accordion > h4.on { margin: 0 0 15px; background: #3ede83; }
.accordion .content { display: none; }
.accordion .content.contentopen { display: block; margin-bottom: 35px; }

@media screen and (max-width: 750px) {
    .accordion > h4 { text-align: left; }
}

/* = Lazy loading images fade
----------------------------------------------------------------------------------------------------------------- */
.lazyload,
.lazyloading { opacity: 0; }
.lazyloaded { opacity: 1; transition: opacity 300ms; }

/* = Inline images (CKeditor)
----------------------------------------------------------------------------------------------------------------- */
.inline-image { margin: 30px 0; }
figure { margin: 40px 0; }
.inline-image--left-half { float: left; margin: 5px 5% 5% 0; width: 50%; }
.inline-image--right-half { float: right; margin: 5px 0 5% 5%; width: 50%; }

.inline-image--left-third { float: left; margin: 5px 4% 4% 0; width: 33.3%; }
.inline-image--right-third { float: right; margin: 5px 0 4% 4%; width: 33.3%; }

figure .inline-image { margin: 0; }

@media screen and (max-width: 1024px) {
    .inline-image--left-third { margin: 5px 5% 5% 0; width: 50%; }
    .inline-image--right-third { margin: 5px 0 5% 5%; width: 50%; }
}

@media screen and (max-width: 650px) {
    .inline-image { margin: 15px 0; }
    figure { margin: 25px 0; }

    .inline-image--left-half,
    .inline-image--right-half,
    .inline-image--left-third,
    .inline-image--right-third { float: none; margin: 30px 0; width: 100%; }
}

/* = YouTube Videos (CKeditor)
----------------------------------------------------------------------------------------------------------------- */
.youtube-container { position: relative; margin: 40px 0; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; }
.youtube-container iframe, .youtube-container object, .youtube-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* = Forms
----------------------------------------------------------------------------------------------------------------- */
.webForm { font-size: 75%; }

.webForm div { margin: 0 0 25px; }
.webForm div em { display: block; margin-left: 25%; margin-top: 10px; }
.webForm .submitBtn { margin: 25px 0; }
.webForm .submitBtn label { display: none; }

label { width: 25%; float: left; padding: 10px 0; }
input.text, textarea, select { width: 75%; padding: 10px 14px; font-size: 1em; font-family: 'Source Sans Pro', sans-serif; border: 1px solid #eaeaea; background: #fff; -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; }
input.text:focus, textarea:focus, select:focus { outline: none; border-color: #ccc; }
input.file { margin: 8px 0; }

/*Cross browser & device select reset*/
.select { position: relative; width: 75%; float: left; }
.select:after { content: ''; position: absolute; top: 0; width: 10px; height: 6px; right: 15px; bottom: 0; margin: auto; pointer-events: none; background: url(/_img/icons/chevron-down.svg) no-repeat 0 0; background-size: 10px 6px; }
.select select { content: ''; height: 100%; width: 100%; cursor: pointer; outline: none; padding-right: 40px; -moz-appearance: none; -webkit-appearance: none; -webkit-box-shadow: none; box-shadow: none; -webkit-border-radius: 0; border-radius: 0; }
.select select:-moz-focusring { color: transparent; text-shadow: 0 0 0 #000; }
.select select::-ms-expand { display: none; }

.no-csstransforms3d .select select { padding-right: 10px; }
.no-csstransforms3d .select:after { content: none; }

/*Cross browser & device input reset*/
textarea,
input.text,
input[type="text"],
input[type="button"],
.input-checkbox { -webkit-appearance: none; border-radius: 0; }

input[type="submit"] { -webkit-appearance: none; }

textarea { min-height: 150px; min-width: 75%; max-width: 75%; }

/*Cross browser & device placeholder reset*/
::-webkit-input-placeholder { color: #000; }
::-moz-placeholder { color: #000; }
:-ms-input-placeholder { color: #000; }
:-moz-placeholder { color: #000; }

input:-webkit-autofill,
select:-webkit-autofill,
input:-webkit-autofill:hover,
select:-webkit-autofill:hover input:-webkit-autofill:focus,
select:-webkit-autofill:focus,
input:-webkit-autofill:active,
select:-webkit-autofill:active { -webkit-animation: autofill 0s forwards; animation: autofill 0s forwards; }

@keyframes autofill {
    100% { background: transparent; color: #000; }
}

@-webkit-keyframes autofill {
    100% { background: transparent; color: #000; }
}

.formList { display: inline-block; padding: 2px 0; line-height: 1.65em; }
.formList label { width: auto; padding: 0 10px 0 0; float: none; }
.formList input { width: auto; margin: 0 10px 0 0; padding: 0; border: 0; }

.checkbox, .check { display: inline-block; padding: 6px 0; }
.checkbox input, .check input { float: left; margin: 0; padding: 0; border: 0; position: relative; }

/*Cross browser & device custom checkbox and radio lists*/
.formList input { opacity: 0; position: absolute; margin: 12px 10px 0 12px; }
.formList label { display: inline-block; vertical-align: middle; margin: 5px 0; cursor: pointer; position: relative }
.formList label:before, .checkbox input:before, .check input:before { content: ''; background: #fff; border: 1px solid #ddd; display: inline-block; vertical-align: middle; width: 16px; height: 16px; padding: 2px; margin-bottom: 4px; margin-right: 10px; text-align: center; cursor: pointer }
.formListRadio label:before,
.radList label:before { -webkit-border-radius: 16px; border-radius: 16px; }
.formListRadio label.checked:after,
.radList label.checked:after { content: ''; position: absolute; left: 6px; top: 10px; width: 10px; height: 10px; border-radius: 10px; background: #3ede83; }
.formListCheckbox label.checked:after,
.checkList label.checked:after,
.checkbox input.checked:after,
.check input.checked:after { content: ''; position: absolute; left: 8px; top: 7px; width: 4px; height: 10px; border: solid #3ede83; border-width: 0 3px 3px 0; -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.checkbox input.checked:after,
.check input.checked:after { top: 4px; }

/* IE9 input fallback */
.no-csstransforms3d .formList { margin-top: 6px; }
.no-csstransforms3d .checkbox, .no-csstransforms3d .check { padding: 10px 0; }
.no-csstransforms3d .formList input { opacity: 1; position: relative; margin: 0 10px 0 0; }
.no-csstransforms3d .formList label { margin: 0 0 5px; }
.no-csstransforms3d .formList label:before,
.no-csstransforms3d .checkbox input:before,
.no-csstransforms3d .formListCheckbox label.checked:after,
.no-csstransforms3d .checkList label.checked:after,
.no-csstransforms3d .checkbox input.checked:after,
.no-csstransforms3d .formListRadio label.checked:after,
.no-csstransforms3d .radList label.checked:after { content: none; }

.labelfullwidth div { clear: left; margin: 0 0 10px; }
.labelfullwidth div .label { width: 100%; padding: 0 0 10px; }
.labelfullwidth label.labelhide { display: none; }
.labelfullwidth input.text, .labelfullwidth textarea, .labelfullwidth select { width: 100%; }
.labelfullwidth .formList { width: 100%; float: left; margin: 0 0 10px; }
.labelfullwidth .formList input { float: left; margin: 3px 5px 0 0; }
.labelfullwidth .formList label { width: auto; float: none; padding: 0; }
.labelfullwidth .formList br { clear: left; }

@media screen and (max-width: 750px) {
    .webForm div em { margin-top: 5px; margin-left: 0; }
    .select { width: 100%; }
    label { width: 100%; float: left; padding-top: 0; padding-bottom: 5px; }
    .webForm > div > label { margin-bottom: 10px; }
    input.text, textarea, select { width: 100%; }
    input.file { margin-top: 0; margin-bottom: 0; }
    .formList { padding-top: 0; padding-bottom: 0; }
    .checkbox { padding-top: 5px; }
    textarea { min-width: 100%; max-width: 100%; }
}

/* = Page loader
----------------------------------------------------------------------------------------------------------------- */
.pagePreload { position: fixed; left: 0px; top: 0; border-top: 1px solid #ececec; bottom: 0; right: 0; width: 100%; height: 100%; z-index: 9999; background: url(/_img/loader.gif) center no-repeat #fff; }
.no-js .pagePreload { display: none; }

@media screen and (max-width: 480px) {
    .pagePreload { background-size: 32px 32px; }
}

/* = Animations
----------------------------------------------------------------------------------------------------------------- */
/*Fade slide in Up*/
.csstransforms3d .fadeUp,
.csstransforms3d .main-content .inner,
.csstransforms3d .banner--fullwidth,
.csstransforms3d .banner--split,
.csstransforms3d .cta,
.csstransforms3d .cv-item,
.csstransforms3d .partner { opacity: 0; -ms-transform: translate(0, 30px); -webkit-transform: translate(0, 30px); transform: translate(0, 30px); -webkit-transition: transform .4s cubic-bezier(0.18, 0.49, 0.71, 1.01), opacity .4s ease-in; transition: transform .4s cubic-bezier(0.18, 0.49, 0.71, 1.01), opacity .4s ease-in; }
/*Fade slide in Down*/
.csstransforms3d .fadeDown { opacity: 0; -ms-transform: translate(0, -30px); -webkit-transform: translate(0, -30px); transform: translate(0, -30px); -webkit-transition: transform .4s cubic-bezier(0.18, 0.49, 0.71, 1.01), opacity .4s ease-in; transition: transform .4s cubic-bezier(0.18, 0.49, 0.71, 1.01), opacity .4s ease-in; }
/*Fade slide in Up Small*/
.csstransforms3d .fadeUpSmall,
.csstransforms3d .news > ul > li { opacity: 0; -ms-transform: translate(0, 15px); -webkit-transform: translate(0, 15px); transform: translate(0, 15px); -webkit-transition: transform .5s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .5s ease-in; transition: transform .5s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .5s ease-in; }
/*Fade slide in Down Small*/
.csstransforms3d .fadeDownSmall,
.csstransforms3d #page-home .logo--main,
.csstransforms3d #page-home .header--main .burger-menu { opacity: 0; -ms-transform: translate(0, -15px); -webkit-transform: translate(0, -15px); transform: translate(0, -15px); -webkit-transition: transform .5s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .5s ease-in; transition: transform .5s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .5s ease-in; }
/*Reset transform origin for ALL animations*/
.csstransforms3d .fadeUp.animate,
.csstransforms3d .fadeDown.animate,
.csstransforms3d .fadeUpSmall.animate,
.csstransforms3d .fadeDownSmall.animate,
.csstransforms3d .main-content .inner.animate,
.csstransforms3d .banner--fullwidth.animate,
.csstransforms3d .cta.animate,
.csstransforms3d .cv-item.animate,
.csstransforms3d .banner--split.animate,
.csstransforms3d #page-home .logo--main.animate,
.csstransforms3d #page-home .header--main .burger-menu.animate,
.csstransforms3d .news > ul > li.animate,
.csstransforms3d .partner.animate { opacity: 1; -ms-transform: translate(0); -webkit-transform: translate(0); transform: translate(0); }

/*Hero text custom  animations*/
.csstransforms3d #page-home .hero--full .hero-text { opacity: 0; -ms-transform: translateY(-44%); -webkit-transform: translateY(-44%); transform: translateY(-44%); -webkit-transition: transform .4s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .4s ease-in; transition: transform .4s cubic-bezier(0.45, 0.26, 0.51, 1.03), opacity .4s ease-in; }
.csstransforms3d #page-home .hero--full .hero-text.animate { opacity: 1; -ms-transform: translateY(-50%); -webkit-transform: translateY(-50%); transform: translateY(-50%); }

/* = No Javascript
----------------------------------------------------------------------------------------------------------------- */
.no-js .tabs ul { display: none; }
.no-js .tabs .panel { padding: 0; }
.no-js .accordion .content { display: block; }
.no-js header { padding-top: 0; }
.no-js header .nojavascript { padding: 10px 15px; text-align: center; background-image: none; }

/* = Clearing
----------------------------------------------------------------------------------------------------------------- */
.clearFix:after, .container:after, .cols:after, .progress:after, .template:after, .webForm > div:after, .coreValues:after, .team-member:after, .newsList:after, .location:after, .contactBlock:after, .partner:after, .partner .partner-content:after, .contacts-results .contact-item:after, .no-csstransforms3d .contacts-grid:after, .cta:after { content: ""; display: table; clear: both; }

/* = Modal
----------------------------------------------------------------------------------------------------------------- */
.modal { display: none; background: rgba(0, 0, 0, 0.5); position: fixed; top: 0; height: 100%; width: 100%; z-index: 10; }
.modal .modal-inner { max-width: 840px; width: 90%; max-height: 90%; left: 50%; top: 45%; padding: 50px 40px; margin: 0 auto; background: #fff; display: block; float: none; position: absolute; -ms-transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); overflow: auto; -webkit-transition: top .3s ease-in-out; transition: top .3s ease-in-out; }
.modal.on .modal-inner { top: 50%; }
.modal .modal-inner p { margin-bottom: 30px; }
.modal .modal-inner p:last-child { margin: 0; }
.modalClose { text-decoration: none; width: 20px; height: 20px; overflow: hidden; position: absolute; top: 20px; right: 16px; text-align: center; line-height: 1.2; z-index: 1; }
.modalClose:before { content: ''; display: block; width: 20px; height: 20px; background: url(/_img/icons/close.svg) no-repeat 50% 50%; background-size: 16px 16px; font-size: 1.188em; cursor: pointer; }

.modal h2 { font-weight: 600; }

@media screen and (max-width: 1280px) {
    .modal .modal-inner p { margin-bottom: 28px; }
}

@media screen and (max-width: 650px) {
    .modal .modal-inner p { margin: 0 0 24px; }
}

@media screen and (max-width: 600px) {
    .modal .modal-inner { padding: 40px 30px; max-height: 92%; }
}

@media screen and (max-width: 360px) {
    .modal .modal-inner { padding: 30px 25px; }
}

/* = Styleguide
----------------------------------------------------------------------------------------------------------------- */
.template-images { margin: 40px 0; font-size: 75% }
.template-images > .ti-item { float: left; width: 31.33%; margin: 0 3% 5% 0; cursor: pointer; }
.template-images > .ti-item:nth-child(3n+3) { margin-right: 0; }
.template-images > .ti-item h5 { min-height: 48px; }
.template-images > .ti-item > img { width: 100%; border: 1px solid #eaeaea; }
.template-images > .ti-item:hover > img { opacity: 0.9; border: 1px solid #fa7300; }
.template-images .ti-notes { display: none; }
#page-styleguide .modal-inner .ti-item { max-width: 600px; display: block; margin: 0 auto; }
#page-styleguide .modal-inner .ti-item a { color: #3fbacd; text-decoration: underline; }
#page-styleguide .modal-inner .ti-item > img { margin: 30px auto 0; display: block; max-width: 100%; border: 1px solid #f1f1f1; }
#page-styleguide .modal-inner h5 { font-size: 1.6em; }

#page-styleguide h2 { margin-top: -125px; padding-top: 125px; }

.styleguide-sections { position: fixed; z-index: 2; top: 175px; min-width: 200px; right: 0; background: #fa7300; color: #fff; -webkit-box-shadow: -6px 16px 35px 0 rgba(0, 0, 0, 0.1); box-shadow: -6px 16px 35px 0 rgba(0, 0, 0, 0.1); }
.styleguide-sections .sg-content { margin-bottom: 0; }
.styleguide-sections .sg-content ul { margin-bottom: 0; padding: 0 45px 25px; font-size: .8em; }
.styleguide-sections .sg-content ul li { margin: 3px 0; color: #fff; }
.styleguide-sections .sg-content ul li a { color: #fff; }
.styleguide-sections .sg-content ul li a:hover { text-decoration: underline; }
.styleguide-sections .jumpto { cursor: pointer; font-size: 75% }
.styleguide-sections .jumpto h6 { margin: 0; padding: 20px; color: #fff; }
.sg-content { display: none; }
.sg-section-head { margin-top: -140px; padding-top: 140px; }

@media screen and (max-width: 750px) {
    .styleguide-sections { top: auto; bottom: 0; width: 100%; right: 0; box-shadow: 0px -12px 35px 0 rgba(0, 0, 0, 0.125); }

    #page-styleguide .modal-inner h5 { font-size: 1.4em; }
    .template-images > .ti-item { width: 47%; margin-right: 4%; margin-bottom: 35px; }
    .template-images > .ti-item:nth-child(3n+3) { margin-right: 4%; }
    .template-images > .ti-item:nth-child(even) { margin-right: 0; }
    .template-images > .ti-item h5 { min-height: 42px; }
}

@media screen and (max-width: 400px) {
    .template-images > .ti-item { width: 100%; margin-right: 0; }
    .template-images > .ti-item h5 { min-height: 0; }
}
