/*****************************************
 CSS rules common to all, or most, of site
******************************************/
/*********
 Clean-ups
**********/
:focus {
  outline: 0; }

a {
  color: #8cc63e;
  font-weight: bold;
  text-decoration: none; }

a:hover {
  text-decoration: underline; }

img {
  border: none;
  display: inline; }

/********
 Defaults
*********/
body {
  background: url("images/e-house-woodgrain-alt.85e3922c8e83.jpg") top center repeat fixed black;
  color: black;
  font: normal 12px 'Muli', sans-serif;
  margin: 0px; }

h1 {
  font: bold 32px 'Muli', sans-serif;
  margin: 10px 0px;
  color: #8cc63e; }

h2 {
  font: normal 18px 'Muli', sans-serif;
  margin: 20px 0px 10px 0px;
  color: #8cc63e; }

h3 {
  font: bold 15px 'Muli', sans-serif;
  margin: 15px 0px 10px 0px;
  color: #8cc63e; }

h4 {
  font: normal 16px 'Muli', 'sans-serif';
  margin: 10px 0px;
  color: #8cc63e; }

h5 {
  font: normal 14px 'Muli', 'sans-serif';
  margin: 10px 0px;
  color: #8cc63e; }

p {
  font: normal 12px 'Arial' , sans-serif;
  margin: 10px 0px;
  line-height: 160%;
  color: #666; }

ul {
  list-style: disc outside none;
  padding-left: 45px;
  margin: 10px 0px; }

ol {
  list-style: decimal outside none;
  padding-left: 45px;
  margin: 10px 0px; }

li {
  font: normal 12px 'Arial' , sans-serif;
  line-height: 160%;
  color: #666; }

hr {
  background-color: #333333;
  border: 0 none;
  color: #333333;
  height: 1px;
  margin: 20px 0; }

code {
  border: 1px gray solid;
  display: block;
  padding: 5px;
  white-space: pre; }

table {
  border-collapse: collapse;
  border-spacing: 0px;
  width: 100%;
  margin: 10px 0px; }

td {
  text-align: left;
  padding: 5px 10px;
  border-bottom: 1px dotted #333333; }

tr.highlight {
  background: #EFEFEF; }

table h5 {
  font-size: 12px; }

blockquote {
  margin-left: 25px;
  padding: 15px 10px;
  background: #EFEFEF;
  border: 1px dotted #333333;
  font-style: italic; }

hr {
  border-top: 1px dotted #8CC63E;
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  background: none; }

/***************
 Common Classes
****************/
.block {
  display: block; }

.inline {
  display: inline; }

.print-only {
  display: none; }

ul.messages {
  background: #ddd;
  margin: 5px;
  padding: 10px; }

ul.messages li {
  margin-left: 20px; }

/**************
 CSS Rollovers
***************/
.rollover {
  display: block;
  float: left;
  display: inline; }

.rollover:hover {
  visibility: visible; }

.rollover img {
  width: 100%;
  height: 100%;
  border: 0; }

.rollover:hover img {
  visibility: hidden; }

/**********
Form Styles
**********/
fieldset {
  border: 1px dotted #333333;
  padding: 10px 20px;
  background: #EFEFEF;
  margin: 10px 0px; }

legend {
  font-size: 14px;
  color: #277CD0; }

label {
  text-align: right;
  float: left;
  padding: 10px 5px; }

input {
  margin: 5px 0; }

input[type="submit"]:hover,
input[type="submit"]:focus {
  cursor: pointer; }

input.submit {
  margin-left: 100px; }

textarea {
  margin: 5px 10px; }

/***************
 Overall layout
****************/
#brand-bar {
  background: black;
  position: fixed;
  z-index: 8000;
  width: 100%;
  bottom: 0;
  padding: 7px 20px 5px 0;
  color: white;
  text-align: center; }
  #brand-bar a {
    display: inline-block;
    margin: 0 5px;
    opacity: 0.7; }
    #brand-bar a.selected, #brand-bar a:hover {
      opacity: 1; }
    #brand-bar a img {
      display: block;
      width: 32px;
      height: auto; }

#outer-wrap {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.2));
  padding-bottom: 70px;
  padding-top: 1px; }

#inner-wrap {
  width: 100%;
  max-width: 1140px;
  padding: 0 5px;
  box-sizing: border-box;
  margin: 0px auto 0px auto;
  position: relative;
  min-height: 840px; }

#share {
  background-color: white;
  position: absolute;
  z-index: 1;
  left: 50%;
  top: 0px;
  margin: 0 0 0 525px;
  padding: 0px 0px 0px 5px;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
  width: 70px;
  /* Drop shadow */
  box-shadow: 5px 5px 15px black; }

#share a.closed {
  display: block;
  float: right;
  width: 30px;
  height: 104px;
  background: url("images/share-closed.315756761b4d.png") no-repeat; }

#share a.open {
  display: block;
  float: right;
  width: 30px;
  height: 104px;
  background: url("images/share-open.e8760dda4f11.png") no-repeat; }

#share a.icons {
  display: block;
  margin: 20px 0px 20px 0px; }

#google-plus-button {
  margin: 10px 0px 5px 0px; }

#custom-tweet-button a {
  display: block;
  background: url("images/twitter-icon.8ed0e9b9f7e0.png") no-repeat;
  height: 32px;
  width: 32px;
  margin-bottom: 8px; }

#custom-facebook-button a {
  display: block;
  background: url("images/facebook-icon.3e2d18a61ec5.png") no-repeat;
  height: 32px;
  width: 32px;
  margin-bottom: 10px; }

/*******
 Header
********/
header {
  max-width: 1140px;
  margin: 0 auto;
  min-height: 150px;
  /**********
   Navigation
  ***********/ }
  header #logo {
    margin: 15px 20px 0 0;
    width: 120px;
    float: left; }
    header #logo img {
      width: 100%;
      height: auto; }
  header nav {
    float: left;
    background: white;
    border: none;
    border-radius: 10px 10px 10px 0;
    width: calc(100% - 142px);
    margin: 87px 0 0 0px; }
    header nav ul#main-nav {
      list-style: none;
      margin: 0px 0px 0px 0px;
      padding: 0px;
      position: relative; }
      header nav ul#main-nav li {
        display: inline-block;
        margin: 0 -4px 0 0;
        /* sub navigation drop down */ }
        header nav ul#main-nav li:first-child a {
          border-top-left-radius: 10px; }
        header nav ul#main-nav li a {
          color: black;
          display: block;
          background: url("images/nav-bullet.5e2096ad4bc9.png") 10px 14px no-repeat;
          padding: 12px 15px 15px 30px;
          font: 300 14px 'Muli', sans-serif;
          text-decoration: none; }
          header nav ul#main-nav li a:hover, header nav ul#main-nav li a:focus {
            background: url("images/nav-bullet.5e2096ad4bc9.png") 10px 14px no-repeat #333;
            text-decoration: none;
            color: white; }
        header nav ul#main-nav li ul {
          position: absolute;
          width: inherit;
          background: #dbdbdb;
          padding-left: 0;
          list-style: none outside none;
          margin: 0;
          display: none;
          border-radius: 0 0 10px 0;
          z-index: 100; }
          header nav ul#main-nav li ul li {
            display: block;
            min-width: 150px; }
        header nav ul#main-nav li:hover ul {
          display: block; }
  header nav ul#main-nav li a.selected {
    color: black;
    display: block;
    background: url("images/nav-bullet.5e2096ad4bc9.png") 10px 14px no-repeat #dbdbdb; }
  header nav ul#main-nav li a.selected:hover,
  header nav ul#main-nav li a.selected:focus {
    background: url("images/nav-bullet.5e2096ad4bc9.png") 10px 14px no-repeat #dbdbdb;
    opacity: 0.85; }
  header nav ul#main-nav ul li a {
    background: none;
    color: #333;
    padding: 12px 15px; }
  header nav ul#main-nav ul li a:hover,
  header nav ul#main-nav ul li a:focus,
  header nav ul#main-nav ul li a.selected {
    background: #b9b9b9; }
  header nav ul#main-nav ul li a.selected:hover,
  header nav ul#main-nav ul li a.selected:focus {
    background: #b9b9b9; }
  header nav ul#main-nav ul li:first-child a {
    border-top-left-radius: 0; }

/****
 Body
*****/
#content {
  margin: 0px auto 0px auto;
  color: black;
  padding: 1.35%;
  text-align: left;
  position: relative;
  z-index: 2;
  background: white; }

video {
  display: block;
  margin: 0px;
  width: 100%;
  height: 624px;
  background: black; }

#movie {
  cursor: pointer; }

#play {
  position: absolute;
  z-index: 300;
  top: 0px; }

#finished {
  position: absolute;
  z-index: 300;
  top: 15px; }

#roundel {
  float: right;
  margin-left: 15px; }

#social {
  padding-top: 30px; }
  #social a.social {
    display: inline-block;
    margin: 0 10px 0 0;
    width: 24px; }
    #social a.social img {
      display: block;
      width: 100%;
      height: auto; }

.body-content {
  margin: 80px 5%; }

.body-content.enquiry {
  margin-top: 70px; }

.body-content.cms-page {
  margin-top: 110px; }

/* unlike the video and gallery, the diagram isn't part of the content container
 * due to the ways in which it is positioned/padded. Therefore, the margin on
 * the body content container is slightly different when part of this configuration.
 * This rule targets body-content containers that are within a content container
 * that directly preceeds the diagram */
#diagram + #content .body-content {
  margin-top: 50px; }

.twocol {
  float: left;
  width: 49%;
  margin-right: 2%; }
  .twocol iframe {
    width: 100%; }

.twocol.last {
  margin-right: 0; }

.twocol h2 {
  margin-top: 0; }

.twocol .carousel .carousel-stage {
  max-height: 200px; }

.twocol.home {
  width: 47%;
  padding-right: 2%; }

/* the blog summary on the homepage */
.blog-summary a:hover,
.blog-summary a:focus {
  text-decoration: none; }

/* contact page styles */
section.twocol.last.introduction p {
  margin-top: 30px; }

/******************
 Text sections
******************/
.introduction {
  margin-bottom: 15px; }

.introduction p {
  font: normal 15px 'Muli', sans-serif;
  color: black;
  line-height: 160%; }

.technical-info h2 {
  margin: 0px;
  padding: 0px; }

.technical-info h2 a {
  display: block;
  padding: 20px 10px; }

.technical-info h2 a:hover {
  background: #effbde;
  text-decoration: none; }

.technical-info p {
  margin: 20px 220px 20px 10px;
  font-size: 13px; }

.technical-info li {
  margin-right: 120px; }

.technical-info hr {
  margin: 0px; }

.page-image {
  float: right;
  margin-left: 20px; }

/* icons */
.icon-print {
  margin-top: 20px;
  display: block;
  float: left;
  padding: 15px 55px;
  background: url("images/print-icon.5d85f1b80c7c.png") left 5px no-repeat;
  font: normal 13px 'Muli', sans-serif;
  border-radius: 10px; }

.icon-doc {
  margin-top: 20px;
  float: left;
  padding: 15px 10px 15px 55px;
  background: url("images/pdf-icon.944859af7309.png") left 5px no-repeat;
  font: normal 13px 'Muli', sans-serif;
  border-radius: 10px; }

.learn-more {
  border-radius: 10px;
  display: block;
  float: left;
  margin: 20px 0px 0px 145px;
  padding: 15px 10px 15px 55px;
  background: url("images/learn-more.551569bd3224.png") left 5px no-repeat;
  font: normal 13px 'Muli', sans-serif;
  border-radius: 10px; }

a:hover.learn-more {
  background: url("images/learn-more.551569bd3224.png") left 5px no-repeat #effbde;
  text-decoration: none; }

a:hover.icon-doc {
  background: url("images/pdf-icon.944859af7309.png") left 5px no-repeat #effbde;
  text-decoration: none; }

a:hover.icon-print {
  background: url("images/print-icon.5d85f1b80c7c.png") left 5px no-repeat #effbde;
  text-decoration: none; }

.icons-diagram {
  min-height: 60px;
  margin: 10px 0px 10px 0px; }

.icons-page {
  min-height: 40px;
  margin: 30px 200px 15px 175px; }

div.explanation {
  position: absolute;
  z-index: 5;
  background: #fff;
  padding: 15px;
  width: 32.5%;
  margin: 0px;
  font-weight: bold;
  border: none;
  text-decoration: none;
  color: black;
  border-radius: 10px;
  -webkit-box-shadow: 3px 3px 8px #000;
  -moz-box-shadow: 3px 3px 8px #000;
  box-shadow: 3px 3px 8px #000; }
