﻿* { -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%; }

.flex { display: -ms-flexbox; display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-align-content: center; -ms-flex-line-pack: center; align-content: center; }
.flex--alignCenter { -webkit-align-items: center; -ms-flex-align: center; align-items: center; }
.flex--nowWrap { -webkit-flex-wrap: nowrap; -ms-flex-wrap: nowrap; flex-wrap: nowrap; }
.flex--justifyCenter { -webkit-justify-content: center; -ms-flex-pack: center;  justify-content: center; } 

/* = Body
----------------------------------------------------------------------------------------------------------------- */
body { color: #1c0c00; font-size: 1.063em; text-align: left; font-family: 'Montserrat', sans-serif; text-rendering: optimizeLegibility; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; background: #fff; }

/* = Typography
----------------------------------------------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 { margin: 0 0 20px; color: #1c0c00; line-height: 1.25em; font-weight: 600; }

h1, .h1 { font-size: 46px; margin-bottom: 30px; }
h2, .h2 { font-size: 32px; margin-bottom: 25px; }
h3, .h3 { font-size: 28px; margin-bottom: 22px; }
h4, .h4 { font-size: 26px; }
h5, .h5 { font-size: 24px; }
h6, .h6 { font-size: 20px; margin-bottom: 15px; }

.template--home h2 { font-size: 32px; margin-bottom: 35px; }

p + h2,
ul + h2 { margin-top: 30px; }

.container--skinny h1 { font-size: 40px; }

p { margin: 0 0 20px; line-height: 1.75em; font-weight: 300; }
p:last-child { margin-bottom: 0; }

.small { font-size: 15px; }
.leader { font-size: 21px; margin-bottom: 30px; }

.caps { text-transform: uppercase; }

blockquote { margin: 40px 0; border-left: 6px solid #ba2257; padding-left: 30px; }
blockquote p { margin: 0; font-size: 22px; line-height: 1.5em; font-family: 'Merriweather', serif; font-weight: 400; }
blockquote cite { font-size: 1em; font-style: normal; font-weight: 300; margin-top: 15px; display: block; }
blockquote p cite { font-size: 0.75em; }

a { color: #728a56; text-decoration: none; -webkit-transition: color .2s ease; transition: color .2s ease; }
a:hover { color: #728a56; text-decoration: none; }

.inner p a:not(.btn):not(.icon), p.leader a:not(.btn):not(.icon) { text-decoration: underline; }
.modal-content p > a:not(.btn) { text-decoration: underline; }

.inner p a:not([class]) { overflow-wrap: break-word; word-wrap: break-word; word-break: break-word; }


img { vertical-align: bottom; height: auto; -ms-interpolation-mode: bicubic; }
hr { margin: 40px 0; height: 1px; border: 0; border-top: 1px solid #d7d8e0; }
small { font-size: 0.8em; }

p > small { line-height: 1.5em; display: block; }

b, strong { font-weight: 600; }

address { margin: 0 0 20px; line-height: 1.5em; font-style: normal; }

sub, sup { line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }

pre { margin: 0; }
pre code { font-size: 1.5em; white-space: pre-wrap; }

figure { margin: 0 0 20px; }
figcaption { padding-top: 10px; color: #777; font-size: 0.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: #ba2257; }
.marked { background: #578a36; }
.meta { color: #666; font-style: italic; font-size: 0.9em; margin-bottom: 10px; }
.lrgfont { font-size: 3em; }

.pricing { width: 100%; padding: 10px; border: 1px solid #578a36; background-color: #ececec }

.serviceAnchor:before { content: ""; display: block; height: 120px; margin: -120px 0 0; }

@media screen and (max-width: 1600px) {
    h2, .h2 { font-size: 30px; }
    .leader { font-size: 20px; }
}

@media screen and (max-width: 1400px) {
    h2, .h2 { font-size: 30px; margin-bottom: 26px; }
    .template--home h2 { font-size: 30px; }
}

@media screen and (max-width: 1200px) {
    .container--skinny h1,
    .newsview h1 { font-size: 38px; margin-bottom: 25px; }

    h2, .h2 { font-size: 28px; margin-bottom: 24px; }
    .template--home h2 { font-size: 28px; margin-bottom: 30px; }
    h3, .h3, .course-view h2 { font-size: 26px; margin-bottom: 20px; }
    h4, .h4 { font-size: 24px; }
    h5, .h5 { font-size: 22px; margin-bottom: 18px; }
    p + h2,
    ul + h2 { margin-top: 25px; }
}

@media screen and (max-width: 1024px) {
    .container--skinny h1,
    .newsview h1 { font-size: 36px; }
    .leader { font-size: 19px; margin-bottom: 25px; }
}

@media screen and (max-width: 750px) {
    .container--skinny h1,
    .newsview h1 { font-size: 34px; }
    hr { margin: 35px 0; }
}

@media screen and (max-width: 600px) {
    p:last-child .btn { margin-bottom: 5px; }
    .container--skinny h1,
    .newsview h1 { font-size: 30px; margin-bottom: 20px; }
    .template--home h2,
    h2, .h2 { font-size: 26px; margin-bottom: 20px; }
    h3, .h3, .course-view h2 { font-size: 24px; margin-bottom: 18px; }
    h4, .h4 { font-size: 22px; margin-bottom: 18px; }
    h5, .h5 { font-size: 20px; margin-bottom: 16px; }
    h6, .h6 { font-size: 18px; margin-bottom: 15px; }
    p + h2,
    ul + h2 { margin-top: 20px; }
    body { font-size: 1em; }
    .leader { font-size: 18px; }
    blockquote { margin: 35px 0; border-width: 5px; padding-left: 25px; }
    blockquote p { font-size: 20px; }
}

@media screen and (max-width: 480px) {
    .container--skinny h1,
    .newsview h1 { font-size: 28px; margin-bottom: 16px; }
    h2, .h2 { font-size: 24px; }

    .template--home .welcome-box h2 { font-size: 24px; }

    .leader { font-size: 17px; }
    blockquote { margin: 30px 0; border-width: 4px; padding-left: 20px; }
    blockquote p { font-size: 18px; }
    blockquote cite { font-size: .9em; }
    hr { margin: 30px 0; }
}

@media screen and (max-width: 380px) {
    .container--skinny h1,
    .newsview h1 { font-size: 26px; }
    h2, .h2,
    h3, .h3 { font-size: 22px; margin-bottom: 18px; }
    h4, .h4 { font-size: 20px; margin-bottom: 16px; }

    .template--home .welcome-box h2 { font-size: 22px; }

    .main-content p,
    .modal-content p { font-size: 15px; }
    blockquote p,
    .main-content blockquote p { font-size: 17px; }
    blockquote cite { margin-top: 12px; font-size: .8em; }
    .main-content .leader,
    .leader { font-size: 16px; }
    hr { margin: 25px 0; }
    hr + p .btn { margin-top: 5px; }
}

@media screen and (max-width: 360px) {
    .container--skinny h1,
    .newsview h1,
    .template--home h2 { font-size: 25px; }
    .course-view h2 { font-size: 22px; margin-bottom: 16px; }
    h3, .h3 { font-size: 20px; margin-bottom: 16px; }
    h5, .h5 { font-size: 18px; margin-bottom: 15px; }
    h6, .h6 { font-size: 17px; margin-bottom: 14px; }
}

@media screen and (max-width: 340px) {
    blockquote p,
    .main-content blockquote p { font-size: 16px; }
}

/* = Colours
----------------------------------------------------------------------------------------------------------------- */
.brandblack { color: #fff; background: #1c0c00; }
.brandGreen { color: #fff; background: #578a36; }
.brandPink { color: #fff; background: #ba2257; }
.brandLightGrey { color: #1c0c00; background: #d7d8e0; }
.block { display: inline-block; padding: 5px 10px; margin: 0 5px 5px 0; min-width: 90px; font-weight: 600; }

/* = Buttons
----------------------------------------------------------------------------------------------------------------- */
.btn { display: inline-block; padding: 11px 20px 10px; min-width: 150px; text-align: center; color: #fff; font-size: 15px; font-weight: 600; text-transform: uppercase; font-family: 'Montserrat', sans-serif; outline: none; cursor: pointer; border: 1px solid #578a36; background: #578a36; -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; -webkit-transition: background .2s ease, border-color .2s ease, color .2s ease; transition: background .2s ease, border-color .2s ease, color .2s ease; -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; }
.btn:hover { color: #1c0c00; background: #d7d8e0; border-color: #d7d8e0; }

.btn--light { color: #fff; border-color: #ba2257; background: #ba2257; }
.btn--light:hover { color: #1c0c00; border-color: #d7d8e0; background: #d7d8e0; }

.btn--trans { border-color: #fff; background: none; }
.btn--trans:hover { color: #1c0c00; border-color: #d7d8e0; background: #d7d8e0; }

input.btn { font-size: 15px; line-height: 1.75em; }

@media screen and (max-width: 600px) {
    .btn,
    input.btn { font-size: 14px; }
}

@media screen and (max-width: 480px) {
    .btn,
    input.btn { font-size: 13px; }
}

@media screen and (max-width: 380px) {
    .btn,
    input.btn { font-size: 12px; }
}

/* = Lists
----------------------------------------------------------------------------------------------------------------- */
ul { margin: 0 0 25px; padding-left: 25px; line-height: 1.75em; }
ul li { margin: 0 0 10px; }
ul li ul { margin-top: 20px; margin-left: 15px; list-style-type: circle; }

ol { margin: 0 0 25px; padding-left: 25px; line-height: 1.75em; }
ol li { margin: 0 0 10px; }
ol li ol { margin-top: 20px; margin-left: 15px; list-style-type: lower-latin; }

dl { margin: 0 0 25px; overflow: hidden; line-height: 1.75em; }
dt { color: #111; font-weight: bold; }
dd { margin: 0 0 20px; }

.resetUL { list-style: none; margin: 0; padding: 0; }

.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: 40px 0; width: 100%; text-align: center; }
.paging:last-child { margin-bottom: 0; }
.paging ul { margin: 0; padding: 0; list-style: none; }
.paging ul li { margin: 0 3px 3px 0; display: inline-block; vertical-align: middle; }
.paging ul li.det { padding-right: 10px; }
.paging ul li a { font-family: 'Montserrat', sans-serif; font-size: 15px; display: inline-block; font-weight: 600; width: 38px; height: 38px; line-height: 38px; color: #728a56; background: #fff; }
.paging ul li a:hover,
.paging ul li a:focus { color: #fff; background: #728a56; -webkit-transition: none; transition: none; }
.paging ul li a.on { color: #fff; background: #ba2257; }

.paging .last,
.paging .first { display: none; }

.main-content ul:last-child { margin-bottom: 0; }
.main-content ul li ul:last-child { margin-bottom: 20px; }

.main-content .section--top ul:last-child li:last-child { margin-bottom: 0; }

.main-content ul,
.main-content ol { font-weight: 300; }
.main-content ul li { line-height: 1.5em; }

@media screen and (max-width: 850px) {
    .paging ul li a { width: 34px; height: 34px; line-height: 34px; }
}

@media screen and (max-width: 480px) {
    .main-content ol li ol,
    .main-content ul li ul,
    ul li ul,
    ol li ol { margin-left: 10px; }

    .paging ul li { margin: 0 2px 2px 0; }
    .paging ul li a { font-size: 14px; width: 32px; height: 32px; line-height: 32px; }
}

@media screen and (max-width: 380px) {
    .paging { margin: 35px 0; }

    .main-content ul,
    .main-content ol,
    .main-content dl { font-size: 15px; }

    .main-content ol li ol,
    .main-content ul li ul,
    ul li ul,
    ol li ol { margin-left: 5px; }

    .paging ul li { margin: 0 1px 1px 0; }
    .paging ul li a { font-size: 13px; width: 28px; height: 28px; line-height: 28px; }
}

/* = Tables
----------------------------------------------------------------------------------------------------------------- */
.tableWrap { overflow: auto; }
table { width: 100%; margin: 0 0 20px; border-spacing: 0; border-collapse: collapse; font-weight: 300; }
th { padding: 15px 10px; color: #fff; border: 1px solid #728a56; background: #728a56; }
tr:nth-child(even) td { background: #f6f6f6; }
td { padding: 10px; border: 1px solid #e5e5e5; background: #fff; }
.rowItemStandout td { color: #fff; background: #a1c897; }

@media screen and (max-width: 440px) {
    table { font-size: 15px; }
}

@media screen and (max-width: 380px) {
    table { font-size: 14px; }
}

/* = Screen Messages
----------------------------------------------------------------------------------------------------------------- */
.msg { margin: 0 0 20px; padding: 20px 25px; background: #d8e3e8; width: 100%; }
.msg p { margin-bottom: 0; line-height: 1.5em; }
.msg ul { margin-bottom: 0; line-height: 1.5em; }
.msg ul li { margin-bottom: 5px; }
.msg ul li:last-child { margin-bottom: 0; }
.msgImp { padding-left: 65px; color: #fff; background: #547cb7 url(/_img/icons/important.svg) no-repeat 30px center; }
.msgImp a { color: #fff; font-weight: bold; }
.msgError { padding-left: 65px; color: #fff; background: #e84d54 url(/_img/icons/error.svg) no-repeat 20px center; }
.msgError a { color: #fff; font-weight: bold; }
.msgSuccess { padding-left: 65px; color: #fff; background: #71ab62 url(/_img/icons/success.svg) no-repeat 20px center; }
.msgSuccess h3 { color: #fff; margin: 0 0 10px; }
.msgSuccess a { color: #fff; font-weight: bold; }
.msgAssist { background-color: #fff0bc; }

@media screen and (max-width: 380px) {
    .msg { padding: 20px; }
    .msgImp,
    .msgError,
    .msgSuccess { padding-left: 60px; }
    .msg ul { font-size: 1em; }
}

/* = Columns
----------------------------------------------------------------------------------------------------------------- */

.cols { margin-bottom: 30px; }
.colsHalf .col { width: 49%; float: left; margin-right: 2%; }
.colsHalf .col:nth-child(2n+1) { clear: left; }
.colsHalf .col:nth-child(2n+2) { margin-right: 0; clear: right; }

.colsThird .col { width: 32%; float: left; margin-right: 2%; }
.colsThird .col:nth-child(3n+1) { clear: left; }
.colsThird .col:nth-child(3n+3) { margin-right: 0; clear: right; }

.colsFourth .col { width: 22%; float: left; margin-right: 4%; }
.colsFourth .col:nth-child(4n+1) { clear: left; }
.colsFourth .col:nth-child(4n+4) { margin-right: 0; clear: right; }

.cols .endCol { margin-right: 0; }

@media screen and (max-width: 750px) {
    .colsHalf .col { width: 100%; margin-right: 0; }
    .colsThird .col { width: 100%; margin-right: 0; }
    .colsFourth .col { width: 100%; margin-right: 0; }
}

/* .cols { margin-bottom: 60px; }
.cols .inline-image { margin: 0; }

.cols:last-child { margin-bottom: 0; }

.cols--half .col { width: 49%; float: left; margin-right: 2%; }
.cols--half .col:nth-child(2n+1) { clear: left; }
.cols--half .col:nth-child(2n+2) { margin-right: 0; clear: right; }

.cols--third .col { width: 32%; float: left; margin-right: 2%; }
.cols--third .col:nth-child(3n+1) { clear: left; }
.cols--third .col:nth-child(3n+3) { margin-right: 0; clear: right; }

.cols--fourth .col { width: 22%; float: left; margin-right: 4%; }
.cols--fourth .col:nth-child(4n+1) { clear: left; }
.cols--fourth .col:nth-child(4n+4) { margin-right: 0; clear: right; }

.cols--fifth .col { width: 18%; float: left; margin-right: 2%; }
.cols--fifth .col:nth-child(5n+1) { clear: left; }
.cols--fifth .col:nth-child(5n+5) { margin-right: 0; clear: right; }

.cols--imgright .col { width: 58%; margin-right: 6%; }
.cols--imgright .col:last-child,
.cols--imgright .endCol { margin-right: -10%; width: 46%; }
.cols--imgright .endCol img { -webkit-box-shadow: 0 20px 60px rgba(0, 0, 0, 0.175); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.175); }

.cols--lightBlue .col { padding: 35px 30px; background: #d8e3e8; }
.cols--lightBlue .col ul:last-child li:last-child { margin-bottom: 0; }

.cols .endCol { margin-right: 0; }

@media screen and (max-width: 1480px) {
    .cols--imgright .col { width: 56%; margin-right: 4%; }
    .cols--imgright .col:last-child,
    .cols--imgright .endCol { margin-right: 0; width: 40%; }
    .cols--imgright .col .leader { font-size: 19px; }
}

@media screen and (max-width: 1200px) {
    .cols--imgright .col .leader { font-size: 18px; }
}

@media screen and (max-width: 1024px) and (min-width: 851px) {
    .cols--lightBlue .col { padding: 30px 25px; }

    .cols--third .col p { font-size: 16px; }
}

@media screen and (max-width: 1024px) {
    .cols--fourth .col { width: 32%; float: left; margin-right: 2%; margin-bottom: 2%; }
    .cols--fourth .col:last-child, .cols--fourth .col:nth-child(2) { margin-right: 0; }

    .cols--fifth .col { width: 31%; float: left; margin-right: 2%; margin-bottom: 2%; }
    .cols--fifth .col:last-child, .cols--fifth .col:nth-child(3) { margin-right: 0; }

    .cols--imgright .col { margin: 0 0 30px; width: 100%; }
    .cols--imgright .col:last-child { width: 100%; margin: 0; }
}

@media screen and (max-width: 850px) {
    .cols--third .col { width: 100%; margin: 0 0 25px; }
    .cols--third .col:last-child { margin: 0; }
}

@media screen and (max-width: 750px) {
    .cols { margin-bottom: 50px; }

    .cols--half .col { width: 100%; margin: 0 0 25px; }
    .cols--half .col:last-child { margin: 0; }

    .cols--imgright .endCol img { -webkit-box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); }
}

@media screen and (max-width: 480px) {
    .cols--fourth .col { width: 100%; margin: 0 0 25px; }
    .cols--fourth .col:last-child { margin: 0; }

    .cols--fifth .col { width: 100%; margin: 0 0 25px; }
    .cols--fifth .col:last-child { margin: 0; }

    .cols { margin-bottom: 45px; }
    .cols--imgright .col .leader { font-size: 17px; }
}

@media screen and (max-width: 420px) {
    .cols { margin-bottom: 40px; }
}

@media screen and (max-width: 380px) {
    .cols { margin-bottom: 35px; }
    .cols--lightBlue .col { padding: 30px; }
    .cols--imgright .col .leader { font-size: 16px; }
}

@media screen and (max-width: 360px) {
    .cols--third .col { margin: 0 0 20px; }
    .cols--lightBlue .col { padding: 25px 22px; }
} */

/* = Tabs
----------------------------------------------------------------------------------------------------------------- */
.tabs { margin: 40px 0; }
.tabs > ul { margin: 0; padding: 0; list-style: none; }
.tabs > ul li { display: inline; margin: 0 20px 0 0; }
.tabs > ul li a { display: inline-block; color: #728a56; position: relative; font-weight: 400; }
.tabs > ul li a.on { color: #124384; }
.tabs > ul li a:after { content: ''; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: #124384; -webkit-transition: width .2s ease; transition: all .2s ease; }
.tabs > ul li a:hover:after { width: 100%; background: #124384; }
.tabs > ul li a.on:after { width: 100%; }
.tabs .panel { padding: 20px 0 0; }

/* = Accordions
----------------------------------------------------------------------------------------------------------------- */
.accordion { margin: 40px 0; }
.accordion > h3 { display: block; font-size: 1em; color: #d8e3e8; margin: 0 0 10px; padding: 14px 18px; background: #728a56; position: relative; }
.accordion > h3:after { position: absolute; right: 18px; top: 15px; color: #fff; font-size: 20px; -webkit-transition: transform .15s ease; transition: transform .15s ease; }
.accordion > h3:hover { cursor: pointer; background: #728a56; }
.accordion > h3.on { margin: 0 0 15px; background: #728a56; }
.accordion > h3.on:after { -ms-transform: rotate(180deg); -webkit-transform: rotate(180deg); transform: rotate(180deg); }
.accordion .acc-panel { display: none; padding: 0 18px; }
.accordion .acc-panel.contentopen { display: block; margin-bottom: 22px; }

@media screen and (max-width: 600px) {
    .accordion .acc-panel { padding: 0; }
}

@media screen and (max-width: 480px) {
    .accordion { margin: 30px 0; }
    .accordion > h3:after { top: 16px; font-size: 18px; }
}

@media screen and (max-width: 360px) {
    .accordion { margin: 25px 0; }
    .accordion > h3 { font-size: 15px; padding: 12px 16px; }
    .accordion > h3:after { top: 14px; font-size: 16px; right: 16px; }
}

/* = Modal
----------------------------------------------------------------------------------------------------------------- */
.modal { display: none; background: rgba(0, 0, 0, 0.5); position: fixed; top: 0; left: 0; height: 100%; width: 100%; z-index: 9999; }
.modal.on { display: block; }
.modal .modal-inner { max-width: 840px; width: 90%; max-height: 90%; left: 50%; top: 45%; padding: 45px 40px 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%; }
.modalClose { cursor: pointer; text-decoration: none; top: 0; right: 0; width: 40px; height: 40px; color: #fff; background: #ba2257; overflow: hidden; position: absolute; text-align: center; line-height: 30px; z-index: 1; }
.modalClose:before { line-height: 40px; font-size: 20px; text-align: center; }
.modal-content p:last-child { margin-bottom: 5px; }

@media screen and (max-width: 600px) {
    .modal .modal-inner { max-height: 92%; padding: 40px 30px 30px; }
    .modal p { margin-bottom: 15px; }

    .modalClose { width: 34px; height: 34px; line-height: 26px; }
    .modalClose:before { font-size: 18px; line-height: 34px; }
}

@media screen and (max-width: 380px) {
    .modal .modal-inner { padding: 38px 25px 25px; width: 100%; max-height: 100%; }
}

@media screen and (max-width: 340px) {
    .modal .modal-inner { padding: 38px 20px 20px; }
}

/* = Inline images (CKeditor)
----------------------------------------------------------------------------------------------------------------- */
.inline-image { margin: 30px 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%; }

@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--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 div { margin: 0 0 20px; position: relative; }
.webForm div em { display: block; margin-top: 5px; font-size: .8em; }
.webForm .submitBtn { margin: 20px 0 0; }
.webForm .submitBtn label { display: none; }

label { display: block; width: 100%; /*float: left;*/ padding: 10px 0; }
input.text, textarea, select { width: 100%; padding: 10px 14px; margin: 0; font-size: 1em; font-family: 'Open Sans', sans-serif; border: 1px solid #e5e5e5; 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; }
.select:after,
.cf-dateRange div:after { content: '\e81b'; position: absolute; top: 0; width: 15px; height: 15px; right: 15px; bottom: 0; margin: auto; color: #124384; pointer-events: none; }
.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[type="submit"],
.input-checkbox { -webkit-appearance: none; border-radius: 0; }

textarea { min-height: 150px; min-width: 100%; max-width: 100%; }

/*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: #fff; color: #000; }
}

@-webkit-keyframes autofill {
    100% { background: #fff; color: #000; }
}

/*Form on contact page*/
.contactForm .questTypeSwitch label { display: inline-block; }

.contactForm .cf-wrap div,
.contactForm > div { float: left; width: 100%; }

.contactForm .questTypeSwitch { margin-bottom: 5px; }
.contactForm .questTypeSwitch label { font-size: 13px; padding: 0 0 0 35px; display: inline-block; }
.contactForm .questTypeSwitch .check { padding: 2px 0 0; position: absolute; top: 0; left: 0; }
.contactForm .questTypeSwitch .check input:before { position: relative; top: -2px; }
.contactForm .questTypeSwitch .check input.checked:after { top: 1px; }
.contactForm .msgError { font-size: .8em; }
.contactForm .submitBtn { margin: 0; }

.formHome .questTypeSwitch label a { color: #fff; text-decoration: underline; }

@media screen and (min-width: 481px) {
    .contactForm .questTypeFreeText,
    .contactForm .questTypeEmail,
    .contactForm .cf-wrap .questTypeFreeText,
    .contactForm .cf-wrap .questTypeEmail { float: left; width: 49%; margin-right: 2% }

    .contactForm .questTypeFreeText:nth-child(even),
    .contactForm .questTypeEmail:nth-child(even) { margin-right: 0; }
}

.formList { display: inline-block; padding: 2px 0; line-height: 1.75em; }
.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: top; margin: 4px 0; cursor: pointer; position: relative }
.formList label:before, .checkbox input:before, .check input:before { content: ''; background: #fff; border: 1px solid #d7d8e0; display: inline-block; vertical-align: middle; width: 14px; height: 14px; 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: 5px; top: 9px; width: 10px; height: 10px; border-radius: 10px; background: #333; }
.formListCheckbox label.checked:after,
.checkList label.checked:after,
.checkbox input.checked:after,
.check input.checked:after { content: ''; position: absolute; left: 7px; top: 7px; width: 4px; height: 10px; border: solid #333; border-width: 0 2px 2px 0; -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.checkbox 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) {
    label { padding-top: 0; padding-bottom: 5px; }
    input.file { margin-top: 0; margin-bottom: 0; }
    .formList { padding-top: 0; padding-bottom: 0; }
    .checkbox { padding-top: 5px; }
    .contactForm div { margin: 0 0 12px; }
}

@media screen and (max-width: 600px) {
    input.text, textarea, select { font-size: 16px; }
    .contactForm .questTypeSwitch label { font-size: 12px; }
}

@media screen and (max-width: 380px) {
    .webForm div { margin: 0 0 15px; }
    .webForm label { font-size: 15px; }
    .contactForm div { margin: 0 0 10px; }
    input.text, textarea, select { padding: 8px 12px; font-size: 14px; }
    .formList label { margin: 2px 0; }
    .cf-dateRange div:after,
    .select:after { right: 12px; opacity: 0.65; }
}

/* = 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, .welcome-box:after, .course-view:after { content: ""; display: table; clear: both; }
