/* ---------------------------------- */
/* ------ MAIN BODY OF WEBSITE ------ */
/* ---------------------------------- */
html, body, form, fieldset, p, div, h1, h2, h3, h4, h5, h6 {
  -webkit-text-size-adjust: none;
  /* This stops the iPhone from automatically changing the size of the text when you flip the phone */
}

/* .outerWrap.menu-open {
  cursor: pointer;
} */

.desktop-hide,
a.desktop-hide {
  display: block !important;
}

.mobile-hide,
a.mobile-hide,
#banner #viewCart {
  display: none !important;
}

/* ---------------------------------- */
/* ------------ SIDEBAR ------------- */
/* ---------------------------------- */
.sidebar,
#outerSidebar {
  display: none;
}

/* ---------------------------------- */
/* -------- VIEW CART BUTTON -------- */
/* ---------------------------------- */
#viewCart {
  position: static;
  border: 0px solid transparent;
}
#viewCart .itemCount, #viewCart .total {
  display: inline-block;
}

/* ---------------------------------- */
/* ----------- NAVIGATION ----------- */
/* ---------------------------------- */
#menu {
  display: none;
}

#navToggleWrap {
  width: 100%;
  background: transparent;
  color: var(--primaryDark);
  display: -ms-flexbox;
  display: flex;
  justify-content: flex-end;
  position: absolute;
  z-index:1000;
  top: 0;
  right: 0;
  padding: 15px 30px;
}
#navToggleWrap > #navToggle, #navToggleWrap > a {
  -ms-flex-positive: 1;
      flex-grow: 1;
  padding: 10px 0;
  line-height: 1em;
  position: static;
  cursor: pointer;
  text-decoration: none;
  background: none;
  color: var(--primaryDark);
}

 #navToggleWrap > a {
   display: none;
 }

/* #navToggleWrap > #navToggle:after,  */
#navToggleWrap > a:after {
  text-align: center;
}
/* #navToggleWrap > #navToggle:before,  */
#navToggleWrap > a:before {
  font-family: 'FontAwesome';
  display: block;
  text-align: center;
  margin: 2px 0;
  font-size: 1em;
}


#navToggleWrap > #navToggle {
  width: 26px;
  height:15px;
  padding: 0;
  position: relative;
  background: transparent;
  flex-grow: 0;
  z-index: 200;
}

#navToggleWrap #navToggle:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--primary);
  box-shadow: 0 7px 0  var(--primary);
}



#navToggleWrap #navToggle:after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  right: 8px;
  height: 2px;
  background: var(--primary);
}

#navToggleWrap > #navToggle:after, 
#navToggleWrap > #navToggle span, #navToggleWrap > a:after, #navToggleWrap > a span {
  font-size: .7em;
  text-transform: uppercase;
  margin: 8px 0 2px;
  display: block;
}

/* #navToggleWrap #navToggle:after {
  content: "Menu";
} */
#navToggleWrap .blank:before {
  content: "\f067";
}
#navToggleWrap a[href="#"], 
#navToggleWrap a[href*="$"],
#navToggleWrap #enquire-drdopdown {
  display: none;
}
#navToggleWrap .address:after {
  content: "address";
}
#navToggleWrap .facebook:after {
  content: "facebook";
}
#navToggleWrap .twitter:after {
  content: "twitter";
}
#navToggleWrap .instagram:after {
  content: "instagram";
}
#navToggleWrap .googlePlus:after {
  content: "googlePlus";
}
#navToggleWrap .pinterest:after {
  content: "pinterest";
}
#navToggleWrap .linkedIn:after {
  content: "linkedIn";
}
#navToggleWrap .blank:after {
  content: "blank";
}
#navToggleWrap .youTube:after {
  content: "youTube";
}
#navToggleWrap .email:after {
  content: "enquire";
}
#navToggleWrap .phone:after {
  content: "phone";
}

#mobileMenu {
  display: inline-block;
   background: none;
  
}
#mobileMenu nav {
  display: none;
  padding: 19px 0;
}
#mobileMenu nav > li {

}

#mobileMenu nav > li#link-mobile13 {
  ordeR: 2;
}


#mobileMenu li {
  list-style-type: none;
}
#mobileMenu li a {
  width: 100%;
  text-decoration: none;
  color: inherit;
  display: inline-block;
}
#mobileMenu li span {
  padding: 5px 25px;
  display: block;
  color: var(--fontcolor);
  text-transform: uppercase;
;
}
#mobileMenu .parent > span:after {
  content: "\f107";
  font-family: 'fontAwesome';
  margin-left: 10px;
  transition: .3s;
  transform: rotate(0deg);
  display: inline-block;
}
#mobileMenu .parent.open > span:after {
  transform: rotate(180deg);
}
#mobileMenu .current > span, #mobileMenu .current > a span {
  font-weight: 800;
}

#mobileMenu nav {
  display: inline-flex;
  width: 100%;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
}

#mobileMenu {
  position: fixed;
  top: 0;
 right: -82%;
  width: 82%;
  height: 100%;
  z-index: 10000;
  overflow: scroll;
  transition: .5s ease-out;
  background:#fff;
}
#mobileMenu.menu-open {
  right:0;
  box-shadow: 5px 0 10px var(--opacity10);
  overflow: hidden;
}

/* ----------- SUB MENU ----------- */
#mobileMenu li ul {
  display: none;
  margin: 0;
  padding: 0;
  list-style: none;
  background: var(--opacity10);
}
#mobileMenu li ul li {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

#mobileMenu li ul a {
  padding-left: 30px;
}

/* ---------------------------------- */
/* ------------- FOOTER ------------- */
/* ---------------------------------- */
#footerBottom {
  padding: 0 0 2em 0;
}
#footerBottom .container {
  -ms-flex-direction: column;
      flex-direction: column;
  padding:1em 1em;
}
#footerBottom nav {
  width: 100%;
  padding: 10px 0;
  margin-top: 15px;
}
#footerBottom nav li {
  width: 100%;
}
#footerBottom .footerRight {
  text-align: left;
  margin-right: 0;
  width: 100%;
}

footer .logo {
  margin:0 auto;
}

#footerBottom .footerRight {
  text-align:center;
}

footer .socialMedia {
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:center;
}

.footerCredits, .footerLinks {
  display:flex;
  flex-direction:column;
}

footer .socialMedia > * {
  margin:1em 0.5em;
}




/*----------------------------------------------*/
/*--------------- ENQUIRY FORM -----------------*/
/*----------------------------------------------*/
.enquiryForm, 
.enquiryForm .enqLeft, 
.enquiryForm .enqRight,
.enquiryForm .enqRow.half {
  width: 100%;
  max-width: 100%;
  display: inline-block;
}

.enquiryForm .enqRow {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.enquiryForm .enqLeft {
  padding: 5px 5px 0px 0;

}

.enquiryForm .checkbox .enqLeft:empty {
  display: none;
}

.checkout .siteContent .checkoutLeft .checkoutDetails .checkoutDetailsRow.enqRow {
  display: block;
}

/* ---------------------------------- */
/* ------------- GRID --------------- */
/* ---------------------------------- */
.col-1-small, .cartThumb.category, 
.blog-widget .blog-widget-article,
section[class*="_imgC"] .col-4,
section[class*="_imgC"] .col-6 {
  width: 100%;
  width: calc(100% - var(--gridSpacing));
}

.col-2-small, .contentImgRow .item, .cartThumb.item {
  width: 50%;
  width: calc(50% - var(--gridSpacing));
}

/*.col-1,
.col-2,
.col-3,
.col-3x2,
.col-4,
.col-4x3,
.col-5,
.col-5x2,
.col-5x3,
.col-5x4,
.col-6,
.col-6x5 {
    width: 100%;
    width: calc(100% - var(--gridSpacing));
}*/
/* ---------------------------------- */
/* -------- BANNER OF WEBSITE ------- */
/* ---------------------------------- */
#banner {
  margin-top:0;
  background:#f7f7f7;
  padding:0em 1em;
}

.fixedTopWrap{
  position: relative;
  top: 0;
  left: 0;
  right: 0;  
  z-index: 101;
  color: var(--fontColor);
  /*! background-color: var(--white); */ 
}


.down {
  display:none;
}

.siteTop {
  padding-top: 0;
  /*! position:absolute; */

}

.logo {
  width: 150px;
  margin:initial;
  padding:10px 0px;
}

#subBanner .container.hasImage {
  background-size: cover !important;
  background-position: center center !important;

}


/* ---------------------------------- */
/* -------- GRAPHICAL BUTTONS ------- */
/* ---------------------------------- */

.butFrame .butHeading {
  font-size:2em;
}


.butFrame .butImage {
  width: 100%;
  height: 0;
  padding-bottom: 70%;
}

/* ---------------------------------- */
/* -------- SLIDESHOW STYLES -------- */
/* ---------------------------------- */

.flick-inner, .flickerplate {
  padding-bottom:50vh;
}


.homeSlider .slick-slide img {
}

.sliderText {
  width:100%;
  padding:3% 5%;
}



.sliderText h2 {
  font-size:2.5em;
}

#subBannerHome .container .container{
  position:absolute;
}

.sliderText {
}



#subBannerHome .slick-slide {
  height:0vh;
}





/* ---------------------------------- */
/* ----------- SUB BANNERS ---------- */
/* ---------------------------------- */






#subBannerHome .container[style*=".gif"] {
  position: relative;
  max-width:100%;
  padding-bottom: 0;
}




#subBannerHome .container[style*=".gif"] {
  position: relative;
  padding-bottom: 0;
}

.subBannerImage {
  position: relative;
  height: 50vh
}


.sliderText h2 {
  font-size:2.5em;
  width:100%;
}



.sliderText {
 position:relative;
  padding:6% 3%;
  height:100%;
  top:0;

}




#subBannerHome:after{
  height: 50px;
}

#subBannerHome:before{
  height: 80px;

}


/* ---------------------------------- */
/* ---------- CUSTOM FOOTER --------- */
/* ---------------------------------- */

#footerTop .container {
  overflow: hidden;
  display: -ms-flexbox;
  display: flex;
  flex-direction:row;
  flex-wrap:wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  /*! flex-wrap: wrap; */
  padding: 5em 1em;
  max-width:var(--containerWidth);
  text-align:center;
}


footer nav {
display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:0em 0em;
}


footer nav li {
margin:0.2em 0em!important;
}

footer .col-3 {
  text-align:left;
  margin-top:2em;
}

#footerBottom {
    text-align:left;
}

#footerTop .container > div.locations, .footerRight {
  display:flex;
  flex-direction:column;

}

#footerTop .container > div.locations div {
  padding:2em 2em;
}


footer .col-1-small {
  width:100%!important;
  margin-bottom:2em;
}

footer:before {
  content:"";
  background-size:80%;
  bottom:0;
  background-position:center bottom;
  opacity:0.05;
}


/* ---------------------------------- */
/* ----------- CUSTOM CSS ----------- */
/* ---------------------------------- */

.services.grid [class*="col-"] {
  width:100%;
}

.table-to-div.productsServices div:first-child {
    margin:0!important;
  width:100%;
}

.table-to-div.productsServices div:last-child {
    margin:0!important;
  width:100%;
 
}

.services div:first-child {
  margin:0;
  margin-bottom:2em;
}

.services div:last-child {
  margin:0!important;
}

.flickerplate .dot-navigation {
 position: absolute;
 inset:0;
  bottom:0;
 width: 10px;
 height: 100%;
  width:100%;
 z-index: 100;
 display: flex;
  flex-direction:row;
 align-items: flex-end;
 justify-items: center;
  margin:0 auto;
}

.flickerplate .dot-navigation ul {
  margin:0 auto;
}

.flickerplate .dot-navigation .dot {
 width: 0.5em;
 height: 0.5em;
 margin: 0em 1em;
}


.tabContainer {
  display: flex;
  flex-direction:column;
  margin: 1.5em 0;
}

.tabContainer > *{
  width:100%;
}

.textSection .siteContent, .categorySection .siteContent, .viewCart .siteContent {
  padding: 3em 0;
} 

.siteBottom .container{
  padding:0px 10px;
}

.link0 section:has(.buttonSection) .textSection .siteContent {
  padding:2em 0em;
}





h1 {
  font-size:2.2em;
}


h2 {
  font-size:1.8em;
}

h3 {
  font-size:1.6em;
}


#footerBottom nav {flex-direction: column;}

.contactInfo {flex-direction: column; font-size: 0.8em;}

.contactInfo > :not(:last-child) {border-right: none;}