* { -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: #000; font-size: 1em; text-align: left; font-family: Arial, Sans-Serif; text-rendering: optimizeLegibility; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased;  background: #fff; }

/* = Typography
----------------------------------------------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 { margin: 0 0 20px; color: #CC1740; line-height: normal; }
h1 { font-size: 1.8em; margin-bottom: 30px; }
h2 { font-size: 1.6em; }
h3 { font-size: 1.4em; }
h4 { font-size: 1.3em; }
h5 { font-size: 1.2em; }
h6 { font-size: 1.2em; }

p { margin: 0 0 20px; line-height: 1.5em; }

.leader { font-size: 1.2em; margin-bottom: 40px; max-width: 750px; }

blockquote { margin: 40px 0; border-left: 6px solid #c7c7c7; padding-left: 35px; }
blockquote p { margin: 0; font-size: 1.4em; line-height: 1.4em; font-family: Arial, sans-serif; }
blockquote cite { font-size: 1em; font-style: normal; margin-top: 15px; display: block; }
blockquote p cite { font-size: 0.75em; }

a { color: #CC1740; }
a:hover { color: #CC1740; text-decoration: none; }

img { max-width: 100%; height:auto; vertical-align: bottom; height: auto; -ms-interpolation-mode: bicubic; }

hr { margin: 40px 0; height: 1px; border: 0; border-top: 1px solid #CC1740; }
small { font-size: 0.8em; }
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: #444; font-size: 0.85em; }

.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: #e38626; }
.marked { color: #fff; background: #e38626; }
.meta { color: #666; font-style: italic; font-size: 0.9em; margin-bottom: 10px; }

/* = Colours
----------------------------------------------------------------------------------------------------------------- */
.brandblack { color: #fff; background: #000; }
.brandorange { color: #fff; background: #e38626; }
.brandred { color: #fff; background: #a8274c; }
.block { display: inline-block; padding: 50px 50px 10px 20px; font-weight: bold; }

/* = Buttons
----------------------------------------------------------------------------------------------------------------- */
.btn { display: inline-block; padding: 10px 20px; margin:0; color: #fff; font-weight: bold; font-family: Arial, Sans-Serif; text-decoration: none; outline: none; cursor: pointer; border: 1px solid #CC1740; background: #CC1740; -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; }
.btn:hover { color: #fff; opacity: 0.8; }

.btnImpact { border-color: #a8274c; background: #a8274c; }

input.btn { font-size: 1em; line-height: 1.5em; }

/* = Lists
----------------------------------------------------------------------------------------------------------------- */
ul { margin: 0 0 25px;  padding-left: 25px; line-height: 1.5em; }
ul li { margin: 0 0 10px; }
ul li ul { margin-top: 20px; margin-left: 30px; list-style-type: circle; }

ol { margin: 0 0 25px;  padding-left: 25px; line-height: 1.5em; }
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;  line-height: 1.5em; }
dt { color: #111; font-weight: bold; }
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; }

.progress { margin: 0 0 20px; position: relative; }
.progress:before { width: 99%; height: 3px; content: ""; position: absolute; top: 19px; bottom: 0; left: 1%; background: #cbcbcb; }
.progress ul { padding: 0; }
.progress ul li { float: left; margin-right: 25px; text-align: center; position: relative; }
.progress ul li span { width: 40px; display: block; margin: 0 auto 5px; padding: 20px 0; background: #cbcbcb url(/_img/icons/dot.svg) no-repeat center center; -moz-border-radius: 50%; -webkit-border-radius: 50%; border-radius: 50%; }
.progress ul li a { color: #222; }
.progress ul li.progressSuccess span { background-image: url(/_img/icons/complete.svg); background-color: #69b239; }
.progress ul li.progressActive span { background-image: url(/_img/icons/down.svg); background-color: #e28724; }

.checkoutProgress ul { padding: 0; }
.checkoutProgress ul li { margin-right: 50px; }
.checkoutProgress ul li.progressSuccess span { background-color: #69b239; }
.checkoutProgress ul li.progressActive span { background-color: #e28724; }
.checkoutProgress ul li.progressBasket span { background-image: url(/_img/icons/basket.svg); }
.checkoutProgress ul li.progressLogin span { background-image: url(/_img/icons/login.svg); }
.checkoutProgress ul li.progressAddress span { background-image: url(/_img/icons/address.svg); }
.checkoutProgress ul li.progressSummary span { background-image: url(/_img/icons/summary.svg); }
.checkoutProgress ul li.progressPayment span { background-image: url(/_img/icons/payment.svg); }
.checkoutProgress ul li.progressComplete span { background-image: url(/_img/icons/complete.svg); }

.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: bold; padding: 6px 12px; color: #fff; background: #666; }
.paging ul li a:hover { background: #454545; }
.paging ul li a.on { background: #080808; }

@media screen and (max-width: 600px) {
    .paging ul li.det { display: block; margin:0 0 5px; }
}

/* = Tables
----------------------------------------------------------------------------------------------------------------- */
.tableWrap { overflow: auto; }
table { width: 100%; margin: 0 0 20px; border-spacing: 0; border-collapse: collapse; }
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 20px; padding: 20px; background: #f5f5f5; }
.msg p { margin-bottom: 0; }
.msg ul {  margin-bottom: 0; }
.msg ul li { margin-bottom: 5px; }
.msg ul li:last-child {margin-bottom: 0;}

.msgImp { padding-left: 65px; color: #fff; background: #8ec3d9 url(/_img/icons/important.svg) no-repeat 30px center; }
.msgError { padding-left: 65px; color: #fff; background: #e84d54 url(/_img/icons/error.svg) no-repeat 20px center; }
.msgSuccess { padding-left: 65px; color: #fff; background: #a1c897 url(/_img/icons/success.svg) no-repeat 20px center; }
.msgSuccess h3 { color: #fff; margin: 0 0 10px; }
.msgAssist { background-color: #fff0bc; }

.msgImp a,
.msgError a,
.msgSuccess a { color: #fff; font-weight: bold; }

/* = Flex
----------------------------------------------------------------------------------------------------------------- */
.flx { display: -ms-flexbox; display: -webkit-flex; display: flex; }
.flx-inl { display: -ms-inline-flexbox; display: -webkit-inline-flex; display: inline-flex; }
.flx--col { -webkit-flex-direction: column; -ms-flex-direction: column; flex-direction: column; }
.flx--jc { -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; }
.flx--ac { -webkit-align-content: center; -ms-flex-line-pack: center; align-content: center; }
.flx--ai { -webkit-align-items: center; -ms-flex-align: center; align-items: center; }
.flx--wr { -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.flx--noSh { -webkit-flex: 0 0 auto; -ms-flex: 0 0 auto; flex: 0 0 auto; }

/* = Columns
----------------------------------------------------------------------------------------------------------------- */
.cols { margin-bottom: 20px; }
.colsHalf .col { width: 49%; float: left; margin-right: 2%; }
.colsThird .col { width: 32%; float: left; margin-right: 2%; }
.colsFourth .col { width: 22%; float: left; margin-right: 4%; }
.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; }
}

/* = 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: #000; position: relative; }
.tabs > ul li a:hover { color: #666; }
.tabs > ul li a.on { color: #e38626; }
.tabs > ul li a.on:after  {content:''; position: absolute; bottom:0; left:0; width:100%; height: 2px; background:#e38626; }

.tabs .panel { padding: 20px 0 0; }

/* = Accordions
----------------------------------------------------------------------------------------------------------------- */
.accordion { margin: 30px 0; padding: 0; list-style: none; }
.accordion:first-child { margin-top: 0; }
.accordion:last-child { margin-bottom: 0; }

.accordion > h3,
.accordion > dt { display: block;  margin: 0 0 10px; padding: 10px 55px 10px 20px; font-size: 18px; line-height: 1.4em;  background: #a8274c; color: #fff;  cursor: pointer; position: relative;   -webkit-transition: background-color 300ms; transition: background-color 300ms; }

.accordion > h3:after,
.accordion > dt:after { content:''; width:18px; height:12px; position: absolute; top:calc(50% - 6px); right:20px; background:  url(/_img/icons/down-chevron.svg) 0 0 no-repeat;}

.accordion > h3.on,
.accordion > dt.active { margin: 0; background-color: #e38626;  }

.accordion > h3.on:after ,
.accordion > dt.active:after {  -webkit-transform:rotate(180deg); transform:rotate(180deg); }

.accordion > dt:last-of-type {margin:0;}

.accordion .content,
.accordion dd { display: none; padding: 25px 10px; }

.accordion dd.active:last-child { padding-bottom: 5px; }

.accordion .content.contentopen,
.accordion dd.active { display: block; margin: 0; }

@media screen and (max-width: 600px) {
    .accordion { margin: 25px 0; }

    .accordion > h3,
    .accordion > dt { font-size: 16px; padding: 10px 50px 10px 18px; }

    .accordion > h3:after,
    .accordion > dt:after {  right:18px; }

    .accordion .content, 
    .accordion dd { padding: 20px 5px; }
}

/* = Inline images (CKeditor)
----------------------------------------------------------------------------------------------------------------- */
.inline-image { margin: 30px 0; }
p + .inline-image:not(.image-captioned) {margin-top:10px;}

.image-left { float:left; margin: 5px 30px 30px 0;  max-width: 50%;}
.image-right {float:right;  margin: 5px 0 30px 30px; max-width: 50%;  }
.image-center { margin: 30px 0; text-align: center; } 
.image-center .inline-image {margin:0; }

.image-captioned {padding:12px; background:#ededed; }

@media screen and (max-width: 600px) {
    .image-captioned { padding:10px;  }
}

@media screen and (max-width: 480px) {
    .image-left,
    .image-right  { float: none; margin: 25px 0; width: 100%; max-width: 100%; }
}

@media screen and (max-width: 400px) {
    .image-left,
    .image-right  {  margin: 22px 0;  }
}

/* = Oembed plugin (CKeditor - Inline Tweets, Media, Vimeo etc.)
----------------------------------------------------------------------------------------------------------------- */
.embeddedContent { margin: 30px 0;  }
.twitter-tweet  {margin:0 auto; }

/* = YouTube plugin (CKeditor - Inline YouTube video)
----------------------------------------------------------------------------------------------------------------- */
.youtube-container { position: relative; margin: 30px 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; }
.webForm > div em { display: block; float: left; margin-left: 25%; margin-top: 8px; font-size: .9em; }

.webForm .submitBtn { margin: 20px 0; }
.webForm .submitBtn label { display:none; }

label { width: 25%; float: left; padding: 10px 0; }
input.text, textarea, select { width: 75%; padding: 10px 12px; margin:0; font-size: 1em; font-family: Arial, Sans-Serif; border: 1px solid #e5e5e5; background: transparent; -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: 0; height: 0; right: 15px; bottom: 0; margin: auto; border-style: solid; border-width: 6px 5px 0px 5px; border-color: #333 transparent transparent transparent; 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; }

/*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:75%; max-width:75%; }

/*Cross browser placeholder text reset*/
::-webkit-input-placeholder { color: #000; opacity:1; }
::-moz-placeholder { color: #000; opacity:1; }
:-ms-input-placeholder { color: #000; opacity:1; }
:-moz-placeholder { color: #000;  opacity:1; }

.formList { display: inline-block; padding: 2px 0; line-height: 1.5em; }
.formList label { width: auto;  float: none; }
.formList input { width: auto; margin: 0 10px 0 0; padding: 0; border: 0; }

/*Cross browser custom checkboxes and radio lists*/
.checkbox, .check { display: inline-block;padding: 0; margin: 8px 0;  position: relative;}
.checkbox input, .check input { opacity: 0;  position: relative; width: 22px;  height: 22px; left:0; top:0; margin: 0; padding: 0; border: 0;  cursor:pointer;   z-index: 1;  }

.formList input { opacity: 0; position: absolute;  margin: 10px; }
.formList label {  margin: 5px 0; padding: 0 0 0 30px; cursor: pointer; display: inline-block; vertical-align: middle; position: relative }

.formList label:before,
.checkbox:before, 
.check:before { content: '';   position: absolute; left:0; top:0; border: 1px solid #ddd;  width: 16px; height: 16px; padding: 2px;  display: inline-block; vertical-align: middle; background: #fff; 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: 6px; width: 10px; height: 10px; border-radius: 10px; background: #333; }

.formListCheckbox label.checked:after,
.checkList label.checked:after,
.checkbox.checked:after,
.check.checked:after { content: ''; position: absolute; left: 8px; top: 4px; width: 4px; height: 10px; border: solid #333; border-width: 0 2px 2px 0; -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.labelfullwidth div { clear: left;  }
.labelfullwidth div .label { display: block;     float: none; 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 .select { width: 100%; float: none; }
.labelfullwidth textarea  {min-width: 100%; max-width: 100%; }
.labelfullwidth .formList label { width: auto; float: none; }
.labelfullwidth .formList br { clear: left; }

@media screen and (max-width: 750px) {
    .nolabel {display: none;}

    .webForm div em { margin-top: 5px; margin-left: 0;  float: none; font-size: .85em; }
    .select { width:100%; float: none; clear: both; }
    label { width: 100%; float: left; padding-top: 0; padding-bottom: 5px; }
    
    .webForm > div {margin: 0 0 15px; }
    .webForm > div > label { padding:0; margin-bottom:6px; }

    input.text, textarea, select { width: 100%; }
    input.file { margin-top: 0; margin-bottom: 0; }
    .formList { padding-top: 0; padding-bottom: 0; }
    .checkbox {    margin: 5px 0;}
    textarea { min-width: 100%; max-width: 100%; }
}

/* = 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 { content: ""; display: table; clear: both; }