/*! normalize.css v2.1.2 | MIT License | git.io/normalize */
/* ==========================================================================
   HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined in IE 8/9.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block; }

/**
 * Correct `inline-block` display not defined in IE 8/9.
 */
audio,
canvas,
video {
  display: inline-block; }

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Address `[hidden]` styling not present in IE 8/9.
 * Hide the `template` element in IE, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none; }

script {
  display: none !important; }

/* ==========================================================================
   Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/**
 * Remove default margin.
 */
body {
  margin: 0; }

/* ==========================================================================
   Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background: transparent; }

/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted; }

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0; }

/* ==========================================================================
   Typography
   ========================================================================== */
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari 5, and Chrome.
 */
h1 {
  font-size: 1.75em;
  margin: 0.67em 0; }

/**
 * Address styling not present in IE 8/9, Safari 5, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/**
 * Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome.
 */
b,
strong {
  font-weight: bold; }

/**
 * Address styling not present in Safari 5 and Chrome.
 */
dfn {
  font-style: italic; }

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  height: 0; }

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/**
 * Correct font family set oddly in Safari 5 and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  font-size: 1em; }

/**
 * Improve readability of pre-formatted text in all browsers.
 */
pre {
  white-space: pre-wrap; }

/**
 * Set consistent quote types.
 */
q {
  quotes: "\201C" "\201D" "\2018" "\2019"; }

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* ==========================================================================
   Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9.
 */
img {
  border: 0; }

/**
 * Correct overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden; }

/* ==========================================================================
   Figures
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari 5.
 */
figure {
  margin: 0; }

/* ==========================================================================
   Forms
   ========================================================================== */
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct `color` not being inherited in IE 8/9.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Correct font family not being inherited in all browsers.
 * 2. Correct font size not being inherited in all browsers.
 * 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome.
 */
button,
input,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 2 */
  margin: 0;
  /* 3 */
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal; }

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 8+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none; }

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */ }

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default; }

/**
 * 1. Address box sizing set to `content-box` in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 */
input[type="checkbox"],
input[type="radio"] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box; }

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/**
 * 1. Remove default vertical scrollbar in IE 8/9.
 * 2. Improve readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */ }

menu {
  -webkit-padding-start: 0px; }

/* ==========================================================================
   Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/*----- html elements -------------------------------------------------------------------*/
body {
  font-family: "myriad-pro", Verdana, Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  color: #323232;
  background-color: #fff; }

h1 {
  font-weight: 500; }

h2, h3, h4, h5, h6 {
  font-weight: 600; }

strong, bold, .strong {
  font-weight: 600; }

p {
  margin: 0 0 1em 0; }

a {
  color: #3d73b1;
  text-decoration: none;
  border-bottom: 1px solid #3d73b1;
  padding-bottom: 1px; }

a:hover {
  color: #d7213a;
  border-bottom: 1px solid #d7213a; }

ol {
  margin-left: 0;
  padding-left: 2em; }

li {
  padding-bottom: 1rem; }

li li {
  padding-bottom: 0.5rem; }

li ul, li ol {
  margin-top: 1rem; }

table {
  width: 100%;
  margin-bottom: 2em; }

table th {
  padding: 0.5em 1em 1em 1em;
  text-align: left; }

table td {
  padding: 0.25em 1em;
  text-align: left; }

table tr th:first-of-type, table tr td:first-of-type {
  padding-left: 0; }

table th.centre, table td.centre {
  text-align: center; }

section, header, footer {
  width: 100%;
  margin: 0;
  clear: both; }

section > div {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0; }

section > div > div {
  padding: 0 10px; }

/*----- forms -------------------------------------------------------------------*/
form .required:after {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-left: .3em;
  vertical-align: top;
  content: " ";
  background: url("../graphics/required.png") no-repeat top center; }

input, textarea, select {
  font-family: "myriad-pro", Verdana, Arial, sans-serif;
  color: #323232;
  border-radius: 0.4rem;
  border: 1px solid #323232;
  padding: .5em;
  background-color: #fff; }

textarea {
  min-height: 150px; }

button, a.button {
  display: inline-block;
  color: #fff;
  background: #3d73b1;
  border: 0;
  padding: 0.75rem 3rem;
  font-size: 1.2rem;
  text-transform: uppercase;
  font-weight: 600;
  border-radius: 0.4rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

button:hover, a.button:hover {
  color: #fff;
  background-color: #d7213a; }

button:disabled, button:hover:disabled {
  background-color: #ccc;
  color: #323232; }

.button2 {
  text-transform: none;
  font-size: 1rem; }

/* labels for check boxes and radio buttons */
input[type=radio] + label, input[type=checkbox] + label {
  cursor: pointer; }

input[type=radio], input[type=checkbox] {
  display: none !important; }

input[type=radio] + label:before, input[type=checkbox] + label:before {
  display: block;
  float: right;
  content: " ";
  width: 30px;
  height: 25px;
  margin-top: 0px;
  right: 0;
  background: url("../graphics/new/check.png") no-repeat bottom right; }

input:checked + label:before {
  background-position: top right; }

input:unchecked + label:before {
  background-position: bottom right; }

/* Placeholder text color */
input[placeholder]::-webkit-input-placeholder {
  color: #888;
  opacity: .8; }

input[placeholder]:-moz-placeholder {
  /* Firefox 18- */
  color: #888;
  opacity: .8; }

input[placeholder]::-moz-placeholder {
  /* Firefox 19+ */
  color: #888;
  opacity: .8; }

input[placeholder]:-ms-input-placeholder {
  color: #3d73b1;
  opacity: .8; }

/*----- general classes -------------------------------------------------------*/
.pad-top {
  padding-top: 1rem !important; }

.pad-topx2 {
  padding-top: 2rem !important; }

.pad-btm {
  padding-bottom: 1rem !important; }

.pad-btmx2 {
  padding-bottom: 2rem !important; }

.no-top {
  margin-top: 0 !important; }

.no-pad-top {
  padding-top: 0 !important; }

.no-btm {
  margin-bottom: 0 !important; }

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

.margin-top {
  margin-top: 1rem !important; }

.margin-btm {
  margin-bottom: 1rem !important; }

.updated {
  color: #666;
  font-style: italic;
  border-top: 1px solid #ccc;
  padding: 0.5rem 0 1rem 0;
  margin-top: 2rem; }

.focus {
  color: #000;
  font-size: 1.3rem;
  padding-top: .3rem; }

a.pdf, a.read {
  display: block;
  background: url("../graphics/new/pdf.png") no-repeat top left;
  padding: 0.2em 0 0.2em 34px;
  margin: 1em 0 1.5em 0;
  border: 0; }

a.pdf-large {
  display: block;
  background: url("../graphics/new/pdf-large.png") no-repeat top left;
  padding: 1.2rem 0 1rem 70px;
  margin: 1em 0 1.5em 0;
  font-size: 1.1rem;
  border: 0; }

.low a.pdf, .low a.read {
  margin-top: 0.2em;
  margin-bottom: 1em; }

.large {
  font-size: 1.1rem;
  line-height: 1.8rem;
  padding-bottom: 0.5rem; }

.small {
  font-size: 0.8rem; }

.hiline {
  line-height: 2em; }

/* clear fix */
.clearfix:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0; }

.clearfix {
  display: inline-block; }

/* start commented backslash hack \*/
* html .clearfix {
  height: 1%; }

.clearfix {
  display: block; }

/* close commented backslash hack */
.clear {
  clear: both; }

.centre {
  text-align: center; }

/*------ alerts -------------------------------------------*/
.alert {
  position: fixed;
  width: 100%;
  height: auto;
  background: #aacbad;
  border-top: 5px solid #1a7722;
  border-bottom: 5px solid #1a7722;
  z-index: 1001;
  -webkit-box-shadow: 0px 4px 4px #666;
  box-shadow: 0px 4px 4px #666;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  visibility: hidden;
  opacity: 0; }
  .alert > div {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    text-align: center; }
  .alert > div div {
    display: inline-block;
    width: 90%;
    max-width: 50rem;
    margin: 0 auto;
    padding: 0 0 1rem 0;
    vertical-align: middle;
    text-align: left; }
  .alert h3 {
    margin-bottom: .5rem;
    color: #1a7722; }
  .alert button {
    display: inline-block;
    margin-top: 1rem;
    padding: 0.5rem 0.6rem 0.7rem 0.6rem;
    border-radius: .5rem;
    line-height: 1rem;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    font-family: sans-serif;
    color: #829868;
    background: #fff;
    border: 2px solid #829868;
    vertical-align: top;
    outline: 0;
    text-transform: lowercase; }
  .alert button:hover {
    background: #58654a;
    color: #829868;
    border: 2px solid #88a28a; }

.alert.error, .main .staticError {
  background: #ec9280;
  border-top: 5px solid #d33111;
  border-bottom: 5px solid #d33111; }
  .alert.error h3, .main .staticError h3 {
    color: #d33111; }
  .alert.error button, .main .staticError button {
    color: #af6754;
    background: #fff;
    border: 2px solid #af6754; }
  .alert.error button:hover, .main .staticError button:hover {
    background: #a6381d;
    color: #cc9080;
    border: 2px solid #cc9080; }

.staticError {
  padding: 1rem; }

.main .staticError h3 {
  margin-top: 0.5rem; }

/*------ content loading indicator -------------------------------------------*/
.loader {
  background: url("../graphics/loader.svg") no-repeat center;
  width: 60px;
  height: 60px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -30px 0 0 -30px;
  position: fixed;
  z-index: 90;
  visibility: hidden;
  opacity: .25; }

.spin {
  visibility: visible;
  -webkit-animation: rota 0.5s infinite linear;
  animation: rota 0.5s infinite linear; }

@-webkit-keyframes rota {
  0% {
    -webkit-transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg); } }

@keyframes rota {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

/*----- columns ------------------------------------------------------------*/
.colRow {
  clear: both;
  margin: 1.5rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  vertical-align: top; }
  .colRow.low {
    margin: 0 0 1em 0; }
  .colRow.colCentre {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
  .colRow.colStretch {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch; }
  .colRow.colCentreStretch {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch; }
  .colRow .col {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0px;
    margin-right: 1em; }
  .colRow .col:last-of-type {
    margin-right: 0;
    margin-left: 1em; }
  .colRow .col.single {
    margin: 0; }
  .colRow .col.auto {
    -webkit-box-flex: 0;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto; }
  .colRow .col.onethird {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0px;
    flex: 1 0 0px; }
  .colRow .col.twothirds {
    -webkit-box-flex: 2;
    -ms-flex: 2 0 0px;
    flex: 2 0 0px;
    margin-right: 2rem; }

.no-flexbox .colRow {
  display: block;
  width: 100%;
  clear: both;
  overflow: auto; }
  .no-flexbox .colRow .col {
    display: block;
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    float: left;
    width: 47%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
  .no-flexbox .colRow .col.onethird {
    width: 30%; }
  .no-flexbox .colRow .col.twothirds {
    width: 60%; }

/*------ specific form layouts -------------------------------------------*/
/*form > fieldset:first-of-type { padding-top: 0; }*/
form input.short, form textarea.short, form select.short {
  width: 200px;
  max-width: 200px;
  min-width: 100px; }

form input.xshort, form textarea.xshort, form select.xshort {
  width: 200px;
  max-width: 200px;
  min-width: 100px; }

fieldset {
  margin: 0;
  padding: 1em 0 2em 0;
  margin-bottom: 1rem;
  border: 0; }
  fieldset label, fieldset div.field {
    display: inline-block;
    padding: 0.5em 0.5em 0.5em 0;
    clear: left;
    border: none;
    vertical-align: top; }
  fieldset input, fieldset textarea, fieldset select {
    display: inline-block;
    vertical-align: top; }
  fieldset h3 {
    margin: 0.5rem 0 1rem 0; }
  fieldset .group {
    float: left;
    width: 70%; }

.main form h3 {
  font-weight: 400;
  font-size: 1.4rem;
  margin-bottom: 0.5rem; }

.leftform label, .leftform div.field {
  display: block;
  float: left;
  width: 25%;
  min-width: 100px;
  max-width: 200px; }

.leftform input, .leftform textarea, .leftform select, .leftform div.group {
  display: block;
  width: 70%;
  margin-bottom: 1rem;
  max-width: 400px;
  min-width: 300px; }

.leftform input[type=checkbox] + label {
  width: 20rem !important;
  max-width: 20rem; }

.leftform input[type=checkbox] {
  width: 0; }

#quoteform label, #quoteform div.field {
  width: 30%;
  max-width: 100%; }

#quoteform label.checkLabel {
  width: 34% !important; }

form.twoColumnForm {
  padding: 0.5em 0 1em 0;
  margin: 0 auto; }
  form.twoColumnForm fieldset {
    display: inline-block;
    width: 49%;
    margin: 0;
    padding: 0;
    clear: both;
    vertical-align: top; }
  form.twoColumnForm fieldset.wide {
    display: block;
    width: 100%;
    max-width: 45rem; }
  form.twoColumnForm .split {
    border-top: 1px solid #9d9d9d;
    margin: 1rem 0 2rem 0; }
  form.twoColumnForm fieldset > div.fieldrow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start; }
  form.twoColumnForm .fieldrow > div {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto; }
  form.twoColumnForm label {
    width: 10rem !important; }
  form.twoColumnForm fieldset.wide label {
    width: 12rem !important; }
  form.twoColumnForm input, form.twoColumnForm textarea, form.twoColumnForm select, form.twoColumnForm div.field {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    margin-bottom: 1rem;
    margin-right: 1em;
    min-width: 200px; }
  form.twoColumnForm div.field {
    font-weight: 600; }
  form.twoColumnForm input[type=checkbox] + label {
    width: 12em !important; }
  form.twoColumnForm button {
    margin: 1em 0 0 0; }

/*----- Purchase --------------------------------------------------------*/
.preamble {
  margin: 1.5rem 0 2.5rem 0; }

.buyMe {
  border: 1px solid #ccc;
  padding: 0.5rem 0.5rem 1.2rem 0.5rem;
  max-width: 450px;
  min-width: 250px;
  margin: 0 auto 1.5rem auto; }
  .buyMe h2, .buyMe h4, .buyMe p {
    margin: 0.25rem 1rem; }
  .buyMe h2, .buyMe p {
    line-height: 1.8rem; }
  .buyMe .buyMeImage {
    margin: 0.5rem auto 1rem auto;
    width: 100%;
    max-width: 435px;
    height: 173px;
    border: 0; }
  .buyMe .GUARD01, .buyMe .accred {
    background: url(../graphics/home/buy1.jpg) no-repeat top left; }
  .buyMe .GUARD02, .buyMe .reaccred {
    background: url(../graphics/home/buy2.jpg) no-repeat top right; }
  .buyMe .GUARD03, .buyMe .nonaccred {
    background: url(../graphics/home/buy3.jpg) no-repeat top right; }
  .buyMe .buyBtns {
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
    padding: 0.75rem 0 0 0;
    margin-top: 0.75rem;
    text-align: center; }
  .buyMe .buyBtns button, .buyMe .buyBtns .button {
    margin: 0 0.5rem 0.75rem 0.5rem;
    padding: 0.75rem 2rem;
    border: 0;
    text-transform: uppercase; }
  .buyMe .buyBtns p {
    margin-top: 0;
    margin-bottom: 1rem; }

.onethird .buyMe .buyMeImage {
  margin-bottom: 0.35rem; }

.onethird .buyMe p {
  line-height: 1.5rem; }

/*.colRow .col.onethird { min-width:250px; }*/
@media only screen and (max-width: 600px) {
  .colRow, .colRow.colCentre, .colRow.colCentreStretch {
    display: block;
    margin: 0 auto !important; }
    .colRow .col:last-of-type, .colRow.colCentre .col:last-of-type, .colRow.colCentreStretch .col:last-of-type {
      margin: 0 auto; }
    .colRow.low, .colRow.colCentre.low, .colRow.colCentreStretch.low {
      margin: 0 0 1em 0 !important; }
  .no-flexbox .colRow .col {
    float: none;
    width: 100%; }
  .alert button {
    display: block;
    margin: 0 auto 1em auto; }
  .leftform label, .leftform div.field {
    float: none;
    width: 100%;
    max-width: 100%; }
  .leftform input, .leftform textarea, .leftform select {
    width: 100%;
    max-width: 100%; }
  .leftform .group {
    width: 100%; }
  #quoteform label, #quoteform div.field {
    width: 100%;
    max-width: 100%; }
  #quoteform label.checkLabel {
    width: auto !important; }
  #quoteform label.checkLabel:before {
    display: inline-block; }
  form.twoColumnForm fieldset {
    width: 100%; }
  form.twoColumnForm label {
    display: block;
    width: 100% !important; }
  form.twoColumnForm input, form.twoColumnForm select, form.twoColumnForm textarea {
    width: 100% !important; }
  form.twoColumnForm button {
    display: block;
    margin: 1em auto; } }

body {
  background: #fff; }

/*----- header ----------------------------------------------------------------*/
header {
  width: 100%;
  overflow: visible;
  margin: 0 auto 0;
  background: #fff;
  min-width: 300px;
  border-bottom: 2px solid #d62039; }
  header section > div > div {
    min-height: 100px; }
  header h1 {
    float: left;
    width: 140px;
    height: 100px;
    text-indent: 110%;
    white-space: nowrap;
    overflow: hidden;
    background: url(../graphics/saLogo.png) no-repeat center left;
    background-size: auto;
    margin: 0 10px 0 0; }
  header menu {
    min-width: 300px;
    padding: 0;
    overflow: hidden;
    height: auto; }
  header menu > h2, header menu > div {
    display: inline-block; }
  header button.menu-burger {
    width: 40px;
    height: 40px;
    border: 0;
    padding: 0;
    overflow: hidden;
    outline: none;
    text-indent: 101%;
    white-space: nowrap;
    display: none;
    position: absolute;
    right: 0;
    top: 0;
    margin: 2rem 1rem 1rem 1rem;
    background: transparent url(../graphics/hamburger.png) 0 0 no-repeat; }
  header button.menu-burger:hover, header button.menu-burger.open {
    background-position: -40px 0px; }

.no-flexbox header {
  display: block;
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none; }
  .no-flexbox header h1, .no-flexbox header menu {
    display: inline-block; }
  .no-flexbox header menu {
    float: right;
    width: auto;
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    text-align: right;
    padding: 0 22px 0 0;
    margin-top: 50px; }
  .no-flexbox header menu a {
    display: inline-block; }

menu {
  padding: 0 0 1.2rem 0;
  margin: 0;
  text-align: right; }
  menu h2 {
    color: #3d73b1;
    margin: 0;
    font-weight: 400;
    font-size: 2rem;
    padding: 1.5rem 0 0.1rem 0; }
  menu > div {
    padding: 0.75rem 0; }
  menu a {
    display: inline-block;
    width: 90px;
    color: #3d73b1;
    text-decoration: none;
    font-weight: 500;
    text-transform: uppercase;
    text-align: center;
    padding: 0 0.5em;
    border: 0;
    white-space: nowrap;
    outline: none; }
  menu a:hover, menu a.selected {
    font-weight: 700;
    border: 0;
    outline: none; }
  menu a:hover {
    color: #3d73b1; }
  menu a:nth-child(1) {
    width: 60px; }
  menu a:nth-child(2) {
    width: 110px; }
  menu a:nth-child(3) {
    width: 200px; }
  menu a:nth-child(4) {
    width: 160px; }
  menu a:nth-child(5) {
    width: 64px;
    text-align: right;
    background: url(../graphics/home/logonIcon.png) no-repeat 0px -14px;
    padding-left: 14px;
    padding-right: 0;
    margin-left: 20px; }

/*----- hero image -----------------------------------------------------------*/
.hero {
  width: 100%;
  height: 540px;
  background: #fff no-repeat top center;
  opacity: 1;
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden;
  -webkit-transition: all 1s ease-in-out;
  -moz-transition: all 1s ease-in-out;
  -o-transition: all 1s ease-in-out;
  transition: all 1s ease-in-out; }

.hero.hero1 {
  background-image: url("../graphics/home/home1.jpg"); }

.hero.hero2 {
  background-image: url("../graphics/home/home2.jpg"); }

.hero.hero3 {
  background-image: url("../graphics/home/home3.jpg"); }

.heroSmall {
  width: 100%;
  height: 450px;
  background: #fff no-repeat top center;
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden; }

#aboutHero {
  background-image: url("../graphics/home/aboutHero.jpg"); }

#supportHero {
  background-image: url("../graphics/home/supportHero.jpg"); }

#coursesHero {
  background-image: url("../graphics/home/coursesHero.jpg"); }

/*----- main -----------------------------------------------------------------*/
.main {
  line-height: 1.4em;
  /*p, blockquote, ul, ol, .wide-col { max-width: 45rem; }*/ }
  .main section {
    background-color: #fff; }
  .main section > div {
    padding: 2.5rem 0 2rem 0; }
  .main h1, .main h2, .main h3, .main h4 {
    color: #323232;
    font-weight: 400; }
  .main .byline {
    font-size: 1.3rem;
    text-align: center;
    margin-bottom: 2.5rem; }
  .main h2 {
    font-size: 1.4rem;
    margin: 1.5rem 0 0.2rem 0;
    line-height: 2rem; }
  .main h3 {
    font-size: 1.1rem;
    margin: 1.5rem 0 0.2em 0;
    font-weight: 400; }
  .main h4 {
    font-weight: 600;
    font-size: 1rem;
    margin: 0.5rem 0; }
  .main * > h2:first-child {
    margin-top: 0; }
  .main h4.contact {
    color: #323232;
    font-size: 1rem; }
  .main h1 + h2 {
    margin-top: 1.5rem; }
  .main h1 .note, .main h2 .note, .main h3 .note {
    color: #3d73b1; }
  .main p.switch {
    border-top: 1px dotted #999;
    margin: 0;
    padding: 0.5em 1em;
    max-width: 100%; }
  .main li {
    padding-bottom: 0.5em; }

.hdr, .main .hdr {
  font-size: 2rem;
  line-height: 2rem;
  font-weight: 600;
  text-align: center;
  padding-bottom: 1rem;
  margin: 0 auto !important; }

.hdr:after {
  display: block;
  content: " ";
  width: 100%;
  border-bottom: 1px solid #323232;
  padding-top: 1.25rem;
  margin: 0 auto !important; }

.invis {
  opacity: 0; }

.vis {
  opacity: 100;
  -webkit-transition: 3s all ease;
  -o-transition: 3s all ease;
  transition: 3s all ease; }

section.expo {
  background-color: #e9f7ff; }

.img-mid {
  display: block;
  margin: 0.5rem auto 1.5rem auto;
  max-width: 100%;
  height: auto; }

.img-left {
  display: inline-block;
  margin: 1rem 2rem 1rem 0;
  clear: left;
  vertical-align: top; }

a.internal {
  font-size: 1.1rem;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid transparent; }

a.internal:after {
  display: inline-block;
  width: 1em;
  height: 1em;
  content: " ";
  background: url(../graphics/linkPuck.png) no-repeat 6px 0.5em; }

a.internal:hover {
  border-bottom: 1px solid #d7213a; }

a.internal:hover:after {
  background-position: -14px 0.5em; }

a.button.right {
  display: inline-block;
  vertical-align: top; }

.notice {
  width: 90%;
  min-width: 300px;
  margin: 2em auto 2rem auto;
  padding: 1.75rem 2rem 1rem 2rem;
  background-color: #D5D6C8;
  border-radius: .75rem;
  color: #2c3774; }
  .notice h2, .notice h3 {
    color: #2c3774;
    font-weight: 600;
    margin-bottom: 0.5em; }
  .notice .colRow {
    margin: 0; }
  .notice .col {
    margin: 0;
    padding: 0;
    -webkit-box-flex: 5;
    -ms-flex: 5;
    flex: 5; }

#pd .col:nth-of-type(2) {
  min-width: 150px;
  max-width: 150px;
  padding: 1rem 0; }

.emp {
  color: #da2900;
  border-bottom: 1px dotted #323232;
  padding-bottom: 1px; }

/*----- footer ------------------------------------------------------------*/
footer menu {
  text-align: right;
  margin: 0;
  vertical-align: middle;
  padding-top: 1rem; }
  footer menu a, footer menu a.selected, footer menu a:hover {
    color: #fff; }
  footer menu a:nth-child(5) {
    background-position: 0px 5px; }

footer .menuLinks {
  min-height: 60px;
  background-color: #3d73b1; }

footer .legalLinks {
  background: #d7213a;
  color: #fff;
  font-size: 0.8rem;
  border-top: 4px solid #fff; }

footer .legalLinks > div > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0.5em 0px; }

footer .legalLinks > div > div span {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto; }

footer .legalLinks > div > div span:nth-child(2) {
  text-align: right; }

footer .legalLinks a {
  color: #fff;
  border: 0; }

footer .legalLinks a:hover {
  color: #222;
  border: 0; }

.regSelect {
  border: 1px solid #ccc;
  padding: 1rem;
  max-width: 450px;
  margin: 0 auto; }

button.type2, .button.type2 {
  background: #83a0b5; }

button.type2:hover, .button.type2:hover {
  background: #3d73b1; }

.drop-head {
  padding-left: 30px;
  cursor: pointer; }

.drop-head:before {
  display: inline-block;
  content: "+";
  width: 30px;
  margin-left: -30px;
  font-size: 1.2rem;
  font-weight: bold; }

.drop-head.open:before {
  content: "\2013"; }

.drop-head:hover {
  color: #d7213a; }

.drop-text {
  height: 0;
  overflow: hidden;
  margin-bottom: 1rem; }

.drop-text > div {
  padding: 0.5rem 0 1rem 30px; }

/* login form */
.loginForm {
  overflow: hidden;
  clear: both;
  margin: 0;
  /*h2 { text-align: center; margin: 0; padding: 2rem 0 1rem 0; color: #2d3677; font-size: 1.2rem; }*/ }
  .loginForm section {
    height: 0;
    -webkit-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease; }
  .loginForm h2.hdr {
    font-size: 1.5rem;
    margin: 0 auto;
    padding: 2rem 0 3rem 0; }
  .loginForm form {
    width: auto;
    max-width: 19rem;
    margin: 0 auto;
    padding-bottom: 2rem; }
    .loginForm form input {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      width: 100%;
      margin: 0 0 1rem 0; }
    .loginForm form input {
      background-color: #fff; }
    .loginForm form input.blurred:valid {
      background-position: 98% 10px; }
    .loginForm form input.blurred:invalid {
      background-position: 98% -390px; }
    .loginForm form button {
      display: block;
      margin: 1.5rem auto 1.5rem auto;
      padding: 0.75rem 3rem;
      font-size: 1.2rem; }
    .loginForm form a {
      display: inline-block;
      width: 60%;
      vertical-align: top;
      font-weight: 600;
      font-size: .8rem;
      border: 0; }
    .loginForm form a:nth-of-type(2) {
      width: 38%;
      text-align: right; }

.loginForm.visible section {
  height: 25rem; }

.placeholder .loginForm form label {
  display: none; }

.no-placeholder .loginForm.visible section {
  height: 25rem; }

.no-placeholder .loginForm h2 {
  padding-bottom: 1.5rem; }

.no-placeholder .loginForm form label {
  display: inline-block;
  width: 30%; }

.no-placeholder .loginForm form form input {
  display: inline-block;
  width: 70%; }

.no-placeholder .loginForm form button {
  margin-top: 0.5rem; }

/* IMAGE BLOCK DROP ============================================================================================== */
.dropRow {
  width: 100%;
  margin: 1em 0;
  text-align: center;
  vertical-align: top; }

.dropRow button {
  position: relative;
  width: 250px;
  max-width: 250px;
  height: 225px;
  margin-bottom: 1em;
  text-transform: none;
  padding: 0;
  background: no-repeat top center;
  background-size: auto;
  border-radius: 0;
  text-align: center; }

.dropRow button span {
  display: block;
  position: absolute;
  width: 100%;
  max-width: 250px;
  top: 160px;
  padding: 0.5em 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-weight: normal;
  color: #323232; }

.no-flexbox .dropRow button {
  margin-left: 0.5%;
  margin-right: 0.5%; }

.dropRow button::-moz-focus-inner {
  border: 0;
  padding: 0; }

.dropRow button:hover {
  opacity: .8; }

.dropRow button:hover span, .dropRow button.active span {
  font-weight: 600;
  color: #111; }

.drop {
  overflow: hidden;
  height: 0;
  margin: 0;
  padding: 0; }

.drop .dropText {
  margin: 0; }

.dropText {
  background: #eef0f2;
  padding: 0rem 3rem 1.5rem 3rem;
  margin-top: 20px; }

.dropText:before {
  position: relative;
  left: 50%;
  content: "";
  display: block;
  width: 0;
  margin-top: 0px;
  margin-left: -28px;
  border-width: 28px 28px 0;
  border-style: solid;
  border-color: #fff transparent; }

.dropText > div:before {
  position: relative;
  left: 50%;
  content: "";
  margin-left: -28px;
  top: -3px;
  width: 0;
  border-width: 28px 28px 0;
  border-color: #fff transparent;
  border-style: solid; }

.dropText > div > h3 {
  margin-top: 0; }

.dropText .closeMe {
  margin: 0;
  padding: 0.5em 0;
  text-align: center; }

.dropText.threepart.first:before, .dropText.threepart.first > div:before {
  left: 12%; }

.dropText.threepart.last:before, .dropText.threepart.last > div:before {
  left: 88%; }

.dropText.fourpart.first:before, .dropText.fourpart.first > div:before {
  left: 10%; }

.dropText.fourpart.second:before, .dropText.fourpart.second > div:before {
  left: 36%; }

.dropText.fourpart.third:before, .dropText.fourpart.third > div:before {
  left: 63%; }

.dropText.fourpart.fourth:before, .dropText.fourpart.fourth > div:before {
  left: 90%; }

.new-flash {
  background: #D7213A;
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
  margin-left: 1em;
  padding: 0.25em 0.5em; }

/* Media queries smaller screens */
@media only screen and (max-width: 1100px) {
  .hero {
    height: 405px;
    background-position: center top;
    background-size: 2100px 405px; }
  .heroSmall {
    height: 337px;
    background-position: -500px 0;
    background-size: 1800px 337px; } }

@media only screen and (max-width: 800px) {
  .hero {
    height: 324px;
    background-position: center top;
    background-size: 1680px 324px; }
  .heroSmall {
    height: 270px;
    background-position: -400px 0;
    background-size: 1440px 270px; } }

@media only screen and (max-width: 615px) {
  header {
    height: auto; }
    header h1 {
      max-width: 80%; }
    header section > div > div {
      display: block; }
    header menu {
      display: block;
      height: 0;
      -webkit-box-flex: 0;
      -ms-flex: none;
      flex: none;
      float: none;
      clear: both;
      margin-bottom: 0; }
    header menu a {
      padding-bottom: 1rem; }
    header menu h2 {
      display: none; }
    header button.menu-burger {
      display: block; }
  .no-flexbox header {
    display: block; }
  menu, footer menu {
    text-align: center; }
  .hero {
    height: 270px;
    background-position: -445px 0;
    background-size: 1400px 270px; }
  .heroSmall {
    height: 225px;
    background-position: -340px 0;
    background-size: 1200px 225px; }
  footer .legalLinks > div > div {
    display: block;
    padding: 0.5em 0px;
    text-align: center; }
    footer .legalLinks > div > div span {
      display: block;
      -webkit-box-flex: 0;
      -ms-flex: none;
      flex: none; }
    footer .legalLinks > div > div span:nth-child(2) {
      text-align: center; }
  .loginForm form {
    width: 100%; }
  .colRow .col.regSelect {
    display: block;
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1rem; }
  .colRow .col.regSelect:first-of-type {
    margin-top: 1rem; }
  .colRow .col.regSelect:last-of-type {
    margin-bottom: 1rem; } }

@media only screen and (max-width: 500px) {
  .hero {
    height: 216px;
    background-position: -355px 0;
    background-size: 1120px 216px; }
  .heroSmall {
    height: 180px;
    background-position: -270px 0;
    background-size: 960px 180px; } }
