@import url('type.css');
@import url('header.css');

/* CLEARING FIX FOR IE */
.clearfix:after, .navitem:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: '';
    clear: both;
    height: 0;
}
/* * html .clearfix, * html .navitem { height: 1%; } /* IE6 */
*:first-child + html .clearfix, *:first-child + html .navitem { height: 1%; } /* IE7 */

.HideFromScreen { position: absolute; top: -9999em; }

.clear { clear: both; }
fieldset, 
a img { border: none; }
table { border-collapse: collapse; }

/* MORE / BACK LINK */
a.more-link, a.back-link {
    display: block;
    border: 1px solid #dae0e7;
    line-height: 2em;
    text-align: center;
    font-weight: bold;
    width: 85px;
    background-color: #fff;
}

a.more-link:hover, a.back-link:hover { background-color: #303b4b; color: #fff; }

.blogpost p a {
    color: #738baf;
}

.blogpost p a:hover {
    text-decoration: underline;
}


/* HTML, BODY */
html {
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}
html, body { margin: 0; padding: 0; }
body { background-color: #fafafa; }
body.menu { height: 3000px; }

.trustpilot-widget {
    border:1px solid #7086a2;
    border-radius: 4px;
}

.trustpilot-widget iframe {
    width: 191px !important;
}

@media (min-width:1024px) {
    .trustpilot-widget iframe {
        width: 218px !important;
    }
}

.buyNowPage #article {
    width: 100%;
}

.buyNowPage #aside {
    display: none;
}

/* WELCOME */
#welcome {
    position: absolute;
    right: 84px;
    top: 10px;
}
#welcome p { font-weight: bold; margin: 0 90px 0 0; }
#welcome p, #welcome a.mydetails {
    background-color: #fafafa;
    border: 1px solid #dae0e7;
    color: #303b4b;
    text-transform: capitalize;
}
#welcome a.mydetails:hover { background-color:#303b4b; color: #fff; }
#welcome p, #welcome a {
    line-height: 28px;
    padding: 0 10px;
    height: 28px;
    border: 1px solid #dae0e7;
}
#welcome a, #welcome span { font-weight: normal; }
#welcome span.logged_in { padding-right: 6px; }

#welcome a.mydetails {
    display: block;
    position: absolute;
    right: 0;
    top: 0;
}

#welcome a.basket { margin-left: 8px; }
#welcome a.logout, #welcome a.basket {
    border-width: 0 0 0 1px;
    padding: 0 0 0 10px;
}

#welcome a.logout:hover, #welcome a.basket:hover { text-decoration: underline; }

/* MAIN STRUCTURE */
#wrapper {
    width: 940px;
    padding: 0 10px 36px;
    background-color: #fff;
    margin: 0 auto;
    position: relative;
}

#header {
    width: 940px;
    height: 130px;
    margin-bottom: 10px;
    position: relative;
}

/* HEADER CUSTOM BLOCKS */
#NavHeader {
    left: 20px;
    position: absolute;
    top: 20px;
}
#NavHeaderSlogan {
    position: absolute;
    right: 230px;
    top: 53px;
}
#NavHeaderTelephone {
    background: url(default/telephone.png) no-repeat 0 0 scroll transparent;
    position: absolute;
    right: 20px;
    top: 54px;
}

#section { margin-bottom: 15px; /* position: relative; */ width: 940px; }
#content { width: 940px; }
#article { float: right; height: auto; width: 700px; }
#breadcrumbs {
    background:url(default/main-sprite.png) no-repeat -240px -85px scroll transparent;
    height: 30px;
    max-height: 30px;
    overflow: hidden;
    width: 700px;
}

#breadcrumbs p { margin: 0; }
#breadcrumbs ul {
    float: right;
    height: 30px;
    margin: 0;
    overflow: hidden;
    padding: 0 10px;
}
#breadcrumbs li {
    display: block;
    float: left;
    height: 30px;
    line-height: 30px;
    margin: 0;
    padding: 0;
    width: auto;
}
#breadcrumbs li a,
#breadcrumbs li span.thispage,
#breadcrumbs li span.thisproduct { padding: 0 5px; }

#pagecopy {
    margin: 0 0 10px;
    overflow: hidden;
    position: relative;
}
#pagecopy table { width: 100%; }
img { width: 100%; }
#pages { margin: 10px 0; }

#aside { float: left; height: auto; width: 220px; }

#NavFooter { display: none; padding: 20px 0; }
 
#search {
    background-color: #fff;
    border: 1px solid #303b4b;
    height: 28px;
    overflow: hidden;
    position: absolute;
    right: 20px;
    top: 10px;
    width: 58px !important;
    z-index: 10;
    -webkit-transition: width 300ms;
    transition: width 300ms;
}
#search.open { width: 400px !important; }

#searchToggle {
    background-color: #303b4b;
    background-image: url(default/search_slider_sprite.png);
    background-repeat: no-repeat;
    height: 28px;
    left: 0;
    position: absolute;
    top: 0;
    width: 29px;
    z-index: 10;
}
#searchToggle.slider_opened { background-position: 0 -28px; }
#searchToggle.slider_closed { background-position: -1px -1px; }
#search p { margin: 0; line-height: 28px; }
#search label { display: none; }

#searchbox {
    background-color: transparent;
    border: 0;
    height: 28px;
    left: 28px;
    line-height: 28px;
    margin: 0;
    padding: 0 10px;
    position: absolute;
    top: 0;
    width: 423px;
}

input.pagesearchbutton, input.go {
    border-left: 1px solid #303b4b;
    height: 28px;
    position: absolute;
    right: 0;
    width: 28px;
}

#designedby { clear: right; float: right; }
#designedby a { font-weight: bold; }
#copyright { clear: left; float: left; }
#copyright, #designedby { margin: 10px 5px; }

/* FOOTER CUSTOM BLOCKS */
#NavFooterMenu { overflow: hidden; width: 940px; }
#NavFooterMenu .navitem { display: inline-block; }
#NavFooterMenu .navitem p { font-size: 0.813em; margin: 0; }
#NavFooterMenu p a { color:#fff; display: block; padding: 0.850em; }
#NavFooterMenu p a:hover {
    background-color: #dae0e7;
    color: #303b4b;
    text-decoration: none;
}

/* LI BASED NAVIGATION TOP */
#nav { position: absolute; top: 0; z-index: 200; }
#nav .column { width: 100%; }

#nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
}
#nav li { margin: 0; padding: 0; }

#nav li.H a { background-position: -537px -120px; border-radius: 4px 0 0 4px; }
#nav li.H:hover a { background-position: -482px -120px; }
#nav .directCatLink { background: rgba(0, 0, 0, 0.125); }

#nav li a {
    color: #fff;
    display: block;
    font-weight: bold;
    height: 39px;
    line-height: 40px;
    padding: 0 14px;
    position: relative;
}
#nav li.active { background-color: #404b5b; }

#nav > ul > li > ul /*, #nav > ul > li > div */ {
    background-color: #303b4b;
    display: none;
    height: auto;
    left: 0;
    margin: 0;
    min-width: 220px;
    top: 0;
    width: 100%;
    z-index: 1;
}

/* COLS */
.column { position: relative; }
div.two-cols,
div.three-cols {
    width: 96%;
    padding: 1% 2%;
    border-bottom: 1px solid #dddddd;
    overflow: hidden;
}
div.two-cols p,
div.three-cols p { margin: 5px 0; }
div.two-cols dt,
div.two-cols dd,
div.two-cols dd li,
div.three-cols dt,
div.three-cols dd,
div.three-cols dd li {
    font-size: 12px;
}
div.two-cols dl ul,
div.three-cols dl ul,
div.two-cols dl ol,
div.three-cols dl ol {
    margin: 5px 0;
}
div.two-cols dl dd,
div.three-cols dl dd {
    margin: 0 0 5px 0;
}
div.two-cols dd,
div.three-cols dd {
    margin: 0;
    padding: 0;
}
div.two-cols dt,
div.three-cols dt {
    font-weight: bold;
    float: left;
    margin-right: 5px;    
}

div.two-cols dd ul,
div.three-cols dd ul {
    display: block;
    float: left;
    clear: both;
} 

div.three-cols div.right dl {
    margin: 0;
}

div.two-cols div.column {
    float: left;
    margin-right: 4%;
    overflow: hidden;
    width: 48%;
}
div.two-cols div.left.twothirds {
    margin-right: 5%;
}
div.two-cols div.right.onethird {
    margin-right: 0;
}

div.two-cols div.right { margin-right: 0; }
div.two-cols div.column p { margin: 8px 0; }
div.two-cols div.column h2 { padding: 0; }
div.two-cols div.heading { width: 100%; margin-right: 0; }
div.two-cols div.onethird { width: 25%; margin-right: 5%; }
div.two-cols div.onethird img,
div.three-cols div.onethird img {
    padding: 5%;
    box-sizing: border-box;
    background: #fff;
    width: auto;
    max-width: 100%;
}
div.three-cols div.left.onethird img { min-width: 100%; }
div.three-cols div.left.onethird a {
    box-sizing: border-box;
    border: 1px solid #ddd;
    display: block;
    min-width: 100%;
    background-color: #fff;
}

.help-planning div.three-cols div.left.onethird a {
    box-sizing: border-box;
    border:none;
    display: block;
    min-width: auto;
}

div.heading img {
    padding: 2%;
    box-sizing: border-box;
}

p.key {
    line-height: 26px;
}
p.key img {
    float: left;
}

div.two-cols div.onethird .check,
div.two-cols div.twothirds .check,
div.three-cols div.onethird .check {
    margin: 1em 0;
    background-color: #E4E9DF;
    border: 1px solid #BDC1BA;
    padding: 10px;
    font-weight: bold;   
    border-radius: 30px; 
}
div.two-cols .check,
div.three-cols .check {
    max-width: 180px;
    box-sizing: border-box;
}

div.two-cols div.onethird h2 img,
div.two-cols div.twothirds h2 img,
div.three-cols div.onethird h2 img,
div.two-cols div.onethird .check img,
div.two-cols div.twothirds .check img,
div.three-cols div.onethird .check img {
    border: none;
    float: left;
    margin-right: 10px;
    padding: 3px 0;
    background: none;
    box-sizing: content-box;
}

div.two-cols div.twothirds { width: 70%; }

div.three-cols.even,
div.two-cols.even {
    /*background-color: #f9f9f9;*/
}

div.two-cols li {
    margin-bottom: 1em;
}
div.two-cols li span {
    display: block;
}
div.two-cols li span a {
    text-decoration: underline;
}


#sitemap { padding: 0; width: auto; }
#sitemap div.column { float: none; margin: 0; }
#sitemap > div.column { float: left; width: 50%; }
#sitemap ul { box-sizing: border-box; padding-left: 25px; }

.three-cols .column {
    float: left;
    margin-right: 5%;
    overflow: hidden;
    width: 30%;
}
div.two-cols .onethird,
div .two-cols .left, 
div.three-cols .left { width: 20%; }
div.three-cols .right { margin-right: 0; }

div.four-cols {
    height: auto;
    padding: 0 3px 0 2px;
    width: 695px;
}
div.four-cols div.column {
    box-sizing: border-box;
    float: left;
     padding: 10px;
     width: 25%;
}
div.four-cols div.column:hover { background-color: #efefef; }
div.four-cols div.right { margin-right: 0; }
div.four-cols div.image,
div.four-cols div.pic a.thm {
    background-color: #fff;
    overflow: hidden;
    position: relative;
}
div.four-cols div.image a,

div.four-cols div.pic a.thm img { display: block; position: relative; }

div.four-cols div.pic a.thm { display: block; margin-bottom: 10px; }



div.four-cols div.column h2 { font-size: 0.75em; }
div.four-cols div.column h2,
div.four-cols div.column p { margin: 0 0 8px 0; }
div.four-cols div.column p:last-child { margin: 0; }

/* FORMS */
div.formcontainer { clear: both; margin-top: 20px; }
div.form_section h4 { font-size: 1.25em; margin-top: 20px; }

form.contact select {
    background-color: #fafafa;
    border: 1px solid #d6dddc;
    border-radius: 0;
    height: 28px;
    line-height: 28px;
    margin: 7px 0 0;
    padding: 0 10px;
    width: 253px;
}

div.formcontainer h3 {
    height: 40px;
    line-height: 40px;
    padding-left: 40px;
    width: 100%;
}
form.contact { padding: 0 10px 40px; }
form.contact label, form.contact strong, form.contact span.form_fieldmsg {
    font-family: Helvetica, Arial, sans-serif;
    font-size: 0.75em;
    font-weight: normal;
}
form.contact input { border: medium none; font-size: 0.75em; }
form.contact textarea.form_textarea {
    border: medium none;
    font-size: 0.75em;
    height: 120px;
}
form.contact span.form_req { float: none; }
form.contact span.checkbox, form.contact span.checkboxes {
    float: left;
    line-height: 30px;
    width: 300px;
}
form.contact input.form_text {
    background-color: #fafafa;
    border: 1px solid #d6dddc;
    border-radius: 0;
    height: 26px;
    line-height: 26px;
    margin: 2px 0;
    padding: 0 10px;
    width: 232px;
    -webkit-appearance: none;
}
form.contact input#postcode,
form.contact input.form_date {
    background-color: #fafafa;
    border: 1px solid #d6dddc;
    height: 26px;
    line-height: 26px;
    margin: 2px 0;
    padding: 0 10px;
    width: 100px;
}
form.contact input.form_captcha {
    background-color: #fafafa;
    border: 1px solid #d6dddc;
    height: 26px;
    line-height: 26px;
    margin: 2px 0 2px 2px;
    padding: 0 25px 0 10px;
    width: 60px;
}
form.contact input.form_file {
    background-color: #f5f5f5;
    color: #202020;
    margin: 5px 0;
    padding: 0 10px;
    width: 232px;
}
form.contact textarea.form_textarea {
    background-color: #fafafa;
    border: 1px solid #d6dddc;
    font-size: 0.75em;
    height: 110px;
    margin: 2px 0;
    padding: 5px 10px;
    width: 232px;
    border-radius: 0;
    -webkit-appearance: none;
}
form.contact label.form_fieldreq,
form.contact label.form_field {
    display: block;
    float: left;
    font-size: 0.8em;
    line-height: 24px;
    padding: 4px 4px 0 0;
    text-align: right;
    width: 120px;
}
/* * html form.contact label.form_fieldreq,
* html form.contact label.form_field { display: inline; } */
form.contact span.form_fieldmsg { display: block; margin: 2px 0 12px 125px; }
form.contact span.form_fieldmsg strong { display: none; }
form.contact input.form_submit {
    height: 45px;
    font-size: 16px;
    line-height: 1.5em;
    background: #303B4C;
    background: -webkit-linear-gradient(top, #303B4C 0, #1D242F 100%);
    background: linear-gradient(to bottom, #303B4C 0, #1D242F 100%);
    color: #fff;
    min-width: 30%;
    text-align: center;
    line-height: 45px;  
    display: block;
    font-weight: 400;
    border: none;
    text-transform: capitalize;
    padding: 0 30px;
    border-radius: 4px;
    margin: 8px 0 8px 124px;
    -webkit-appearance: none;
}

form.contact input.form_submit:hover { background-color: #303b4b; color: #fff; cursor: pointer; }
form.contact div.form_alert select,
form.contact div.form_alert textarea.form_textarea,
form.contact div.form_alert input.form_text,
form.contact div.form_alert input.form_captcha {
    background: url('../../images/alert.gif') no-repeat scroll 98% 50% #fafafa;
}

form.contact div.form_alert select { background-position: 93% 50%; }
form.contact div.form_alert textarea.form_textarea, form.contact div.form_alert input.form_text {
    padding: 2px 25px 2px 10px;
    width: 217px;
}
form.contact div.form_alert input#postcode, form.contact div.form_alert input.form_date { background-color: #ffe6e6; }

div.form_ok, div.form_alert { clear: both; }
/* * html div.form_ok, * html div.form_alert { height: 1px; } */

form.contact div.controltype_radio * {
    line-height: 40px;
    margin: 0;
    padding: 0;
}

form.contact div.controltype_radio input { margin: 0 10px 0 5px; }

/* BASKET HOVER */
#BasketSummary {
    background-color: #fafafa;
    border: 10px solid #fff;
    overflow: hidden;
    position: absolute;
    right: 174px;
    top: 40px;
    width: 370px;
    z-index: 1000;
}

#BasketMessage {
    border-color: #dae0e7;
    border-style: solid;
    border-width: 1px 1px 0;
    overflow: hidden;
    padding: 0 10px;
    height: 50px;
}

#BasketMessage p { font-size: 1em; margin: 0; }
#BasketMessage span.qty { line-height: 50px; margin: 0; }

#BasketMessage span.qty,
#BasketMessage span.cost { font-size: 1em; font-weight: bold; }
#BasketMessage span.qty span { font-weight: normal; }

#BasketMessage p a span.view {
    background: none repeat scroll 0 0 #fff;
    border: 1px solid #dae0e7;
    display: block;
    font-size: 0.75em;
    line-height: 28px;
    padding: 0 10px;
    position: absolute;
    right: 10px;
    text-align: center;
    top: 10px;
    width: 70px;
}

#BasketMessage p a span.view:hover { background-color: #303b4b; color: #fff; }
#BasketContents { overflow: hidden; }
#BasketSummary p.loading { background: url('default/ajax-loader.gif') no-repeat scroll 50% 50% transparent; height: 34px; }
#BasketSummary p.loading span,
#BasketSummary div.summary,
#BasketSummary div.quantity { display: none; }
#BasketSummary div.image {
    background-color: #fff;
    border: 1px solid #dae0e7;
    height:78px;
    overflow: hidden;
    position: relative;
    width:78px;
}
#BasketSummary div.image .thm { margin: -1px; }
#BasketSummary div.shipping {
    clear:both;
    font-weight: bold;
    margin-bottom: 10px;
    width: 348px;
}
#BasketSummary a.close { display: none; }

#BasketSummary div.price {
    font-size: 1em;
    line-height: 30px;
    text-align: center;
    width: 80px;
}
#BasketSummary div.price strong { font-weight: normal; }
#BasketSummary div.quantity {
    margin: 5px 0 5px 5px;
    text-align: center;
    width: 20px;
}
#BasketSummary ul {
    border-color: #dae0e7;
    border-style: solid;
    border-width: 0 1px 1px;
    margin: 0;
    overflow: hidden;
    padding: 0;
}

#BasketSummary ul li {
    float: left;
    list-style: none outside none;
    margin: 0 0 10px 10px;
    padding: 0;
}

/* GALLERY */
#gallery .column { height: auto; overflow: hidden; width: 150px; }
#gallery h5, #gallery p { display: none; }
#gallery .column a.more-link { display: none; }
#gallery .column a.image { margin-bottom: 10px; }

/* SOCIAL */
.socialmedia_wrapper {
    clear: left;
    min-height: 28px;
    margin: 10px 0;
    overflow: hidden;
}

.socialmedia {
    float: left;
    margin-right: 5px;
    position: relative;
    z-index: 0;
}

#files { margin: 20px 0; padding: 0 10px; }
#files ul { list-style-type: none; margin: 0 0 20px 0; padding: 0; }
#files li { margin: 5px 0; padding: 0; }
#files li a {
    background: url(/images/byextension/other.png) no-repeat 0 50%;
    display: block;
    height: 32px;
    line-height: 32px;
    padding: 16px 0 16px 80px;
}
#files li.pdffile a { background-image: url(/images/byextension/pdf.png); }
#files li.docfile a { background-image: url(/images/byextension/doc.png); }
#files li.docxfile a { background-image: url(/images/byextension/docx.png); }
#files li.xlsfile a { background-image: url(/images/byextension/xls.png); }
#files li.xlsxfile a { background-image: url(/images/byextension/xlsx.png); }
#files li.pptfile a { background-image: url(/images/byextension/ppt.png); }
#files li.pptxfile a { background-image: url(/images/byextension/pptx.png); }
#files li.zipfile a { background-image: url(/images/byextension/zip.png); }
#files a.get_adobe_reader {
    background: url(/images/get_adobe_reader.gif) no-repeat 0 0;
    display: block;
    float: left;
    font-size: 0.8em;
    margin: 0 20px 0 0;
    padding: 38px 0 0 0;
    text-align: center;
    width: 112px;
}

/**
 * Resources
 */
.help-planning .three-cols .column {
    width: 30%;
    margin-right: 2%;
}
.help-planning .three-cols .left {
    width: 46%;
}
.help-planning .three-cols .middle {
    width: 20%;
}
.help-planning .three-cols .right {
    margin-right: 0;
}

#resources .pic,
.help-planning .pic {
    width: 34px;
    height: 34px;
    float: left;
    margin-right: 10px;
    text-align: center;
    display: table;
}
.help-planning .pic {
    margin-bottom: 10px;
}
#resources .pic a,
.help-planning .pic a {
    display: table-cell;
    vertical-align: middle;
    line-height: 10px;
}
#resources .pic img,
.help-planning .pic img {
    width: auto;
    max-width: 34px;
    max-height: 34px;
}
#resources .resource {
    overflow: hidden;
    min-height: 34px;
    margin: 10px 0;
}
#resources .title,
.help-planning h3 {
    font-size: 0.750em;
    font-weight: 600;
}
#resources .title {
    line-height: 34px;
}
.help-planning h3 {
    display: table;
    height: 34px;
    margin-bottom: 10px;
}
.help-planning h3 a {
    display: table-cell;
    vertical-align: middle;
}
.help-planning .pic
.help-planning h3 {
    margin: 10px 0;
}

#SidebarBlock { display: block; margin-top: 20px; }

#nav { overflow: visible; }
#nav input, #nav label { display: none; }

/**
 * Glossary
 */
.glossary dl dt {
    font-weight: bold;
}
.glossary dl dd {
    margin: 0;
    padding: 0;
}
/*.purifying-drinking-water h2,*/
.purifying-drinking-water h3,
.purifying-drinking-water h4 {
    font-size: 0.750em;
}
.purifying-drinking-water h4 {
    font-weight: normal;
}
.European_Emergency_Phone_Numbers tr,
.North_American_Emergency_Phone_Numbers tr,
.Australasian_Emergency_Phone_Numbers tr {
    border-bottom: 1px solid #ddd;
}
.European_Emergency_Phone_Numbers tr:nth-of-type(even),
.North_American_Emergency_Phone_Numbers tr:nth-of-type(even),
.Australasian_Emergency_Phone_Numbers tr:nth-of-type(even) {
    background-color: #f9f9f9;

}
.European_Emergency_Phone_Numbers td,
.North_American_Emergency_Phone_Numbers td,
.Australasian_Emergency_Phone_Numbers td {
    padding: 1em;
}
.European_Emergency_Phone_Numbers img,
.North_American_Emergency_Phone_Numbers img,
.Australasian_Emergency_Phone_Numbers img {
    width: auto;
    max-width: 100%;
}

table { 
    margin-bottom: 40px; 
    text-align: center;
    min-width: 100%;
    max-width: 100%;
}
td {
    font-size:12px;
    padding:7px 5px;
    overflow:hidden;
    word-break:normal;
    border-left: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
tr td:first-child { border-left: none; }
th {
    font-size:15px;
    padding:10px 5px;
    overflow:hidden;
    word-break:normal;
    border-bottom: 1px solid #ccc;
    border-top: 1px solid #ccc;
}
tr:nth-child(odd) { background-color: #f9f9f9; } 
tr:nth-child(even) { background-color: #ffffff; } 
.womens tr:nth-child(odd) { background-color: #f3f3f8; } 
.womens tr:nth-child(even) { background-color: transparent; }

.highlight1 { background: #c4cdd9; }
.highlight2 { background: #f8f8f8; }
.highlight3 { background: #afbcbc; }
.highlight4 { background: #eef0f3; }
.highlight5 { background: #f5f5f5; }

.highlight1, 
.highlight2, 
.highlight3, 
.highlight4, 
.highlight5 { border-radius: 3px; overflow: hidden; }

.highlight1 div:first-child { background: #B3BCC8; }
.highlight2 div:first-child { background: #E8E8E8; }
.highlight3 div:first-child { background: #A0ADAD; }
.highlight4 div:first-child { background: #DADBDE; }
.highlight5 div:first-child { background: #E8E8E8; }

.highlight1 div div:first-child,
.highlight2 div div:first-child,
.highlight3 div div:first-child,
.highlight4 div div:first-child,
.highlight5 div div:first-child  { background: transparent; }


#pagepictures,
#pagecopy > #pagesummary {
    height: 250px;
    float: left;
    margin: 0 0 1em 0;
}
#pagepictures {
    min-width: 470px;
}

#pagepictures span {
    display: block;
    text-align: center;
    max-width: 470px;
}
#pagepictures img {
    width: auto;
    height: 250px;
}
#pagecopy > #pagesummary {
    padding: 20px;
    color: #fff;
    background: #303B4B;
    width: 230px;
    overflow: auto;
    box-sizing: border-box;
    float: right;
}
#pagecopy > #pagesummary p { margin: 0; }

#pagecopy > #pagesummary + * {
    clear: left;
}
@media (max-width: 1024px) {
    #wrapper { width: 835px; }
    #header { width: 835px; }
    #NavHeaderSlogan { left: 330px; }
    #section { width: 835px; }
    #nav, #footer #NavFooterMenu { width: 835px; }
    #nav li a { padding: 0 10px; }

    #pagemenu > ul > li { width: 192px; }
    #pagemenu > ul > li a { width: 172px; }
    #content { width: 832px; }
    #article, #aside { box-sizing: border-box; }
    #article { width: 75%; }
    #aside { width: 25%; padding-right: 2%; }


    #pagemenu h3 { width: auto; padding: 0 0 0 0.5em; }
    #pagemenu li, #pagemenu li a { }
    #breadcrumbs {
        background: #fafafa;
        border-radius: 4px;
        width: auto;
    }

    #pagecopy iframe { width: 100%; }
    div.four-cols { width: auto; padding: 0; }
    div.four-cols div.column,
    #gallery .column {
        box-sizing: border-box;
        margin-right: 0;
        width: 25%;
    }
    div.four-cols img { width: 100%; }
    div.two-cols { width: auto; }

    #pagepictures,
    #pagepictures img,
    #pagecopy > #pagesummary {
        height: 210px;
    }
    #pagepictures {
        min-width: 395px;
    }
    #pagecopy > #pagesummary {
        width: 229px;
    }
    #pagepictures span { max-width: 395px; }
}
@media (max-width: 852px) {
    #background-wrapper { display: none; }
    #wrapper { width: auto; }
    #header { width: auto; }
    #wrapper:before { background: #303b4d; border-bottom: 1px solid #202b3c; content: ''; height: 39px; left: 0; position: absolute; top: 0; width: 100%; }
    #section { width: auto; }

    /* Header */
    #header { height: 115px; }
    #welcome, #NavHeader, #NavHeaderSlogan, #NavHeaderTelephone {
        left: auto;
        position: static;
        right: auto;
        top: auto;
    }
    #welcome { height: 38px; margin-bottom: 1em; }
    #header #welcome p {
        background: #303b4c;
        color: #fff;
        font-size: 0;
        margin: 0;
    }
    #welcome p, #welcome a {
        border: 0;
        height: 38px;
        line-height: 38px;
        padding: 0;
    }
    #header #welcome a.mydetails {
        background: url(default/mobile.png) no-repeat scroll -66px 10px transparent;
        background-size: 92px 17px;
        border: 0;
        font-size: 12px;
        text-indent: -9999em;
        top: 0;
        width: 36px;
    }
    #search { top: -100px; right: 0; }
    #HeaderBlock #NavHeader,
    #NavHeaderTelephone {
        margin: 0 auto;
    }

    #HeaderBlock #NavHeader, #NavHeader img {
        height: 30px;
        width: 150px;
    }
    #HeaderBlock #NavHeaderTelephone {
        background-size: 14px;
        background-position: 6px 1px;
        width: 150px;
        margin-top: 10px;
    }
    #NavHeaderTelephone div.tel {
        font-size: 12px;
        height: 18px;
        line-height: 18px;
    }
    #NavHeaderSlogan { display: none; }

    /* Responsive Nav */
    #nav {
        background: none;
        border-radius: 0;
        height: 38px;
        left: 0;
        position: absolute;
        width: 3em;
    }

    #nav label {
        background: none;
        cursor: pointer;
        display: block;
        height: 48px;
        padding: 0;
        position: relative;
        text-indent: -9999px;
        top: 2px;
        width: 100%;
    }

    #nav label:after {
        border-top: 9px double #fff;
        border-bottom: 3px solid #fff;
        content: '';
        display: block;
        height: 3px; margin: 10px;
        position: absolute;
        top: 0;
        width: 1.5em;
    }

    #nav ul {
        background: #303b4c;
        border: 0 solid #202b3c;
        border-width: 0 1px 0 0;
        display: none;
        height: 100%;
        overflow: hidden;
        position: absolute;
        top: 0;
        width: 260px;

        -webkit-overflow-scrolling: touch;

        -webkit-transform: translate3d(-260px, 0, 0);
        transform: translate3d(-260px, 0, 0);

        -webkit-transition: all 0.2s ease;
        transition: all 0.2s ease;
    }

    .csstransforms3d #nav > ul { display: block; }

    #menuCheck { left: -99px; position: absolute; }
    #menuCheck:checked { display: block; } /* Used as a mask via :after */
    #menuCheck:checked + ul {
        display: block;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    /* Allows hide on page unload */
    #nav ul.unload {
        -webkit-transform: translate3d(-260px, 0, 0);
        transform: translate3d(-260px, 0, 0);
    }

    #menuCheck:after {
        background: #fff;
        content: '';
        height: 100%;
        left: 0;
        opacity: 0.5;
        position: fixed;
        top: 0;
        width: 100%;
    }

    #nav ul > li {
        border-bottom: 1px solid #202b3c;
        clear: both;
        text-indent: 12px;
        width: 100%;
    }

    /* Submenus */
    #nav > ul > li ul { height: 100%; position: absolute; top: 40px; z-index: 99; }
    #nav ul.active { display: block; width: 100%; }
    #nav ul ul ul { top: 0; }

    .csstransforms3d #nav > ul > li ul {
        display: block;
        -webkit-transform: translate3d(260px, 0, 0);
        transform: translate3d(260px, 0, 0);

        -webkit-transition: -webkit-transform 0.2s ease;
        transition: transform 0.2s ease;
    }
    .csstransforms3d #nav > ul > li ul.active {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    #nav ul > li.haschildren > a:after {
        border: 0 solid #fff;
        border-width: 2px 2px 0 0;
        content: '';
        height: 8px;
        position: absolute;
        right: 18px;
        top: 16px;
        width: 8px;
        -webkit-transform: rotateZ(45deg);
        transform: rotateZ(45deg);
    }

    #nav > ul > li a {
        color: #fff;
        padding-left: 0;
        padding-right: 0;
        width: 100%;
    }
    #nav li.H a { background: none; width: 70%; }
    #nav li.H a span { margin: 0; }
    #nav ul .column ul { width: 100%; }

    #menuClose {
        color: #fff;
        cursor: pointer;
        height: 16px;
        left: 220px;
        padding: 12px 10px 12px 14px;
        position: absolute;
        top: 0;
        width: 16px;

        -webkit-transform: translate3d(0, -40px, 0);
        transform: translate3d(0, -40px, 0);
    }
    #menuCheck:checked ~ #menuClose {
        -webkit-transition: -webkit-transform 0.2s ease;
        transition: transform 0.2s ease;

        -webkit-transition-delay: 0.4s;
        transition-delay: 0.4s;

        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    #menuBack { text-indent: 3em; }
    #menuBack:after {
        border: 0 solid #fff;
        border-width: 2px 0 0 2px;
        content: '';
        height: 8px;
        left: 1.5em;
        position: absolute;
        top: 16px;
        width: 8px;
        -webkit-transform: rotateZ(-45deg);
        transform: rotateZ(-45deg);
    }

    /* FOOTER */
    #footer { width: auto; }
    #NavFooter { display: block; }
    #footer #NavFooterMenu { width: auto; }
    #content { width: auto; }
    #article { width: auto; max-width: 832px; float: none; }
    #NavHeaderSlogan { left: 0; }
    #aside { display: none; }

    form.contact label.form_fieldreq,
    form.contact label.form_field { box-sizing: border-box; width: 33%; }
    form.contact input.form_text,
    form.contact div.form_alert input.form_text { box-sizing: border-box; width: 33%; }
    form.contact textarea.form_textarea,
    form.contact div.form_alert textarea.form_textarea { box-sizing: border-box; width: 33%; }
    form.contact select,
    form.contact div.form_alert select { box-sizing: border-box; width: 33%; }
    form.contact input.form_submit { box-sizing: border-box; width: 33%; }
    form.contact div.form_alert textarea.form_textarea { width: 33%; }

    form.contact span.form_fieldmsg,
    form.contact input.form_submit { margin-left: 33%; }

    #pagepictures {
        display: none;
    }
    #pagepictures {
        width: 100%;
        height: auto;
        min-width: 0;
        max-height: 250px;
        float: none;
    }
    #pagepictures img {
        max-width: 100%;
        height: auto;
    }
    #pagecopy > #pagesummary {
        width: auto;
        height: auto;
        float: none;
        margin-bottom: 1.8em;
    }    

    #breadcrumbs {
        background: none;
    }
    #breadcrumbs ul {
        padding: 0;
    }
    #breadcrumbs li,
    #breadcrumbs li a,
    #breadcrumbs li span.thispage,
    #breadcrumbs li span.thisproduct {
        height: auto;
        line-height: 1em;
        padding: 0;
    }
    #breadcrumbs li a,
    #breadcrumbs li span.thispage,
    #breadcrumbs li span.thisproduct {
        padding: 0 4px;
    }
    #breadcrumbs li {
        line-height: 20px;
    }

    /**
     * Footer Navigation
     */
    #NavFooterMenu {
        background: #303b4c;
    }
}
@media (max-width: 768px) {
    #sitemap ul { padding-left: 1.2em; }

    #NavFooterMenu { width: 100%; }
    #NavFooterMenu div.navitem {
        display: inline-block;
        float: left;
        height: auto;
        margin: 0;
        width: 25%;
    }
    #NavFooterMenu div.navitem p { line-height: 1em; }
    #NavFooterMenu div.navitem p a {
        box-sizing: border-box;
        display: block;
        padding: 0.75em;
        text-decoration: none;
        text-align: center;
    }
    
    
    div.four-cols div.column {
        padding: 0;
        width: 24%;
        margin-right: 1.33%;
        margin-bottom: 10px;
        margin-top: 10px;
    }
    div.four-cols div.column:hover {
        background: none;
    }
    div.four-cols div.right {
        margin-right: 0;
    }
}
@media (max-width: 700px) {
    #NavFooterMenu div.navitem { width: 50%; }
}
@media (max-width: 600px) {
    #sitemap > div.column { width: auto; }

    form.contact { padding: 0 0 2em 0; }

    /**
     * Disable iPhone auto zoom on focus
     */
    form.contact input.form_text,
    form.contact input.form_text:focus,
    form.contact textarea.form_textarea,
    form.contact textarea.form_textarea:focus,
    form.contact select.form_select,
    form.contact select.form_select:focus {
        font-size: 16px;
    }

    div.formcontainer h3 { padding-left: 0; }
    div.form_ok, div.form_alert { margin-bottom: 10px; }

    form.contact label.form_fieldreq,
    form.contact label.form_field {
        width: 100%;
    }

    form.contact input.form_text,
    form.contact div.form_alert input.form_text {
        width: 100%;
        height: 32px;
        line-height: 16px;
    }

    form.contact textarea.form_textarea,
    form.contact div.form_alert textarea.form_textarea {
        width: 100%;
    }

    form.contact select,
    form.contact div.form_alert select {
        width: 100%;
        height: 32px;
    }

    form.contact input.form_submit { width: 100%; }

    form.contact label.form_fieldreq,
    form.contact label.form_field {
        text-align: left;
        padding: 0;
    }

    form.contact input.form_text,
    form.contact textarea.form_textarea,
    form.contact select {
        margin: 0;
    }
    
    form.contact input.form_submit {
        margin-left: 0;
        width: auto;
        height: auto;
        padding: 0 1em;
    }

    form.contact span.form_fieldmsg { margin: 2px 0 0 0; }

    form.contact div.controltype_radio * { line-height: 24px; }
    form.contact div.controltype_radio span.form_fieldmsg {
        margin: 2px 0 12px 125px;
        line-height: 1em;
    }

    .three-cols .middle {
        clear: none;
        width: 50%;
    }
    .three-cols .right {
        width: 50%;
    }
    div.two-cols div.onethird img,
    div.three-cols div.onethird img {
        padding: 2%;
    }
    
    .help-planning .three-cols .column {
        width: 75%;
        margin-right: 0;
        margin-left: 0;
    }
    .help-planning .three-cols .left {
        width: 100%;
        margin: 0;
    }
    .help-planning .three-cols .middle {
        width: 25%;
    }
    
}

@media (max-width: 540px) {
    div.four-cols div.column, #gallery .column {
        width: 49%;
        margin-right: 2%;
    }
    div.four-cols div.leftmiddle,
    div.four-cols div.right {
        margin-right: 0;
    }
    div.three-cols .right { float: left; clear: left; margin-left: 25%; }

    #wrapper { }
    #copyright, #designedby {
        margin: 1em 0 0 0;
        text-align: center;
        width: 100%;
    }
}
@media (max-width: 480px) {
    #pagepictures {
        margin-right: 0;
    }
}
@media (max-width: 320px) {
    #NavFooterMenu div.navitem { width: 100%; }

    div.four-cols div.column, #gallery .column {
        width: 100%;
        margin: 1em 0;
    }
}

@media (max-width: 300px) {
    #nav > ul { width: 240px; }
}

/* Fixed width design styles that interfere with mobile styles */
@media (min-width: 853px) {
    #nav, #NavFooterMenu {
        height: 40px;
        width: 835px;
        border-radius: 4px;
        background: #8592ac;
        background: -webkit-linear-gradient(top, #8592ac 0, #637595 100%);
        background: linear-gradient(to bottom, #8592ac 0, #637595 100%);
        top: 90px;
    }

    #nav ul { height: auto !important; }
    #nav ul ul ul { display: none; }
    #nav li {
        float: left;
        margin: 0;
        padding: 0;
        position: relative;
    }
    #nav > ul > li > a { height: 40px; }
    #nav li.active { background: #303b4b; }

    #nav li:hover div.multilevelview {
        background-color: #303b4b;
        border-radius: 0 0 5px 5px;
        display: block;
        height: auto;
        left: 0;
        overflow: hidden;
        padding: 10px 0;
        position: absolute;
        top: 40px;
        width: 660px;
        z-index: 1;
    }

    #nav > ul > li > ul {
        border-radius: 0 0 5px 5px;
        padding: 10px 0;
        position: absolute;
        top: 40px;
    }
    #nav > ul > li:hover > ul { display: block; }
    #nav > ul > li:last-child > ul { left: -114px; }

    #nav .P19 > ul, #nav .P139 > ul {
        width: 640px;
        -moz-column-count: 3;
        -ms-column-count: 3;
        -webkit-column-count: 3;
        column-count: 3;
    }

    #nav li:hover, #nav li.active:hover { background-color: #dae0e7; }
    #nav li:hover > a { color: #303b4b; }
    #nav li li { float: none; }
    #nav li li a {
        display: block;
        float: none;
        height: auto;
        line-height: 1.5em;
        overflow: hidden;
        padding: 5px 15px;
    }
    #nav li li.active a, #nav li li a:hover { background-color: #dae0e7; color: #303b4b; }

    #nav .column { float: left; width: 220px; }
    #nav .H a {
        background: url('default/main-sprite.png') no-repeat scroll -487px -120px transparent;
        text-indent: -9999px;
        width: 24px;
    }

    #menuBack, #menuClose { display: none; }

    /* PAGE MENU LIST */
    #pagemenu h3 {
        background: #fafafa;
        height: 40px;
        line-height: 40px;
        margin-bottom: 10px;
        overflow: hidden;
        padding: 0 20px;
    }

    #pagemenu ul { margin: 0; padding: 0; }
    #pagemenu li {
        list-style: none;
        padding: 0;
        width: 220px;
        position: relative;
        height: 32px;
    }

    #pagemenu li.haschildren {
        background: url('default/haschildren-bg.png') no-repeat scroll 4px 11px transparent;
    }

    #pagemenu ul li:hover {
    /*  background: url('default/main-sprite.png') no-repeat scroll 0 -40px transparent; */
        background: #363d4c;
        border-radius: 4px;
    }

    #pagemenu ul li:hover a {
        color: #fff;
        line-height: 21px;
        padding: 5px 0 6px 20px;
    }

    #pagemenu li.haschildren:hover {
        background: url('default/top-nav-hover-arrow.png') no-repeat 0px 0px scroll transparent;
        width: 300px;
        z-index: 10;
    }

    #pagemenu li.current.haschildren:hover {
        background-image: url('default/top_nav_hover_onSelected.png');
    }

    #pagemenu li a {
        display: block;
        line-height: 20px;
        padding: 5px 0 5px 20px;
        position: absolute;
        width: 200px;
    }

    #pagemenu li.haschildren:hover a {
        background: none;
        color: #303b4b;
        left: 66px;
        line-height: 25px;
        width: 214px;
    }

    #pagemenu li.current:hover a { color: #fff; }
    #pagemenu li.current:hover li a { color: #303b4b; }
    #pagemenu li.haschildren:hover li a:hover,
    #pagemenu ul li.haschildren:hover ul li.current ul li a:hover,
    #pagemenu li.haschildren:hover li a {
        background-color: #303B4B;
        background-image: url(default/li-icon-selected.png);
        background-position: 20px 5px;
        background-repeat: no-repeat;
        color: #fff;
    }

    #pagemenu ul li.haschildren:hover ul li.current ul li a:hover,
    #pagemenu ul li.haschildren:hover ul li ul li a:hover,
    #pagemenu li.haschildren:hover li ul li a {
        background-position: 35px 5px;
    }

    #pagemenu li.haschildren:hover a:hover {
        background: url(default/top_nav_hover_onHover.png) no-repeat 0px 0px scroll transparent;
        color: #fff;
    }

    #pagemenu li.haschildren:hover li a {
        background-color: #dae0e7;
        background-image: url(default/li-icon.png);
        color: #303b4b;
        left: 0;
        line-height: 20px;
        padding-left: 35px;
        position: static;
        width: 195px;
    }

    #pagemenu li.haschildren:hover li li a { padding-left: 50px; width: 180px; }
    #pagemenu li.haschildren:hover li { height: auto; width: 234px; }
    #pagemenu li.active a {
        color: #fff;
        line-height: 21px;
        padding: 5px 0 6px 20px;
    }

    #pagemenu li.active {
        background: #363d4c;
        border-radius: 3px;
    }
    #pagemenu ul ul {
        padding: 0 0 5px;
        margin-bottom: 10px;
        background: url('default/bottom_nav_hover.png') no-repeat scroll bottom left transparent;
        width: 234px;
        margin-top: 32px;
        position: absolute;
        left: 66px;
        top: 0;
        z-index: 100;
    }
    #pagemenu ul ul li { width: 234px; }
    #pagemenu ul ul li a, #pagemenu li.active li a {
        background: url('default/li-icon.png') no-repeat scroll 20px 5px #dae0e7;
        border-left: 2px solid #fff;
        border-right: 2px solid #fff;
        padding-left: 35px;
        width: 195px;
    }

    #pagemenu ul ul li a:hover { background-color: #303b4b; }
    #pagemenu ul li ul li.current a, #pagemenu ul li.haschildren:hover ul li.current a {
        background-color: #303B4B;
        background-image: url(default/li-icon-selected.png);
        color: #fff;
    }

    #pagemenu ul li.haschildren:hover ul li.current ul li a {
        background-color: #dae0e7;
        background-image: url(default/li-icon.png);
        color: #303b4b;
    }

    #pagemenu ul ul li.haschildren li a, #pagemenu ul li.active ul li ul li a {
        background: url('default/li-icon.png') no-repeat 35px 5px scroll transparent;
        font-weight: normal;
        margin-left: 2px;
        padding: 5px 0 5px 50px;
        width: 180px;
    }

    #pagemenu ul li.active ul li ul li a,
    #pagemenu ul ul li.haschildren ul li a { margin-left: 0; }
    #pagemenu ul ul li ul li a:hover,
    #pagemenu ul li ul li ul li.active a,
    #pagemenu ul li.active ul li ul li a:hover { background-color: #efefef; }
    #pagemenu li li:hover { background-color: transparent; }
    #pagemenu li.active li a { color: #303b4b; }
    #pagemenu ul ul ul { background: none; margin: 0; padding: 0; }
    #pagemenu ul ul ul li { height: auto; padding: 0; width: auto; }

/*  #pagemenu li li li:hover { background-color: #fafafa; }
    #pagemenu ul ul li a:hover, #pagemenu li.active li a:hover {
        background: url('default/middle_nav_hover_onHover.png') repeat-y scroll bottom left transparent;
    } */

    #pagemenu li.active li li a { font-weight: normal; }
    #pagemenu ul#mymenu, #pagemenu ul#backto { display: none; }
    #pagemenu li ul { display: none; }
    #pagemenu li.active ul { display: block; }

    /* HOVER NAV */
    #pagemenu li.active ul { display: none; }
    #pagemenu li:hover ul { display: block; }
    #pagemenu li:hover ul ul {
        background: url('default/middle_nav_hover.png') repeat-y scroll bottom left transparent;
        left: 0;
        position: static;
        width: 234px;
    }

/*  #pagemenu li.haschildren li.haschildren { background: url("default/middle_nav_hover.png") repeat-y scroll bottom left transparent; } */
}

@media (min-width: 1025px) {
    #nav, #NavFooterMenu { width: 940px; }
    #nav > ul > li:last-child > ul { left: -104px; }

}
