@font-face {
    font-family: 'AvenirLTStd-Heavy';
    src: url('../fonts/31A6A1_0_0.eot');
    src: url('../fonts/31A6A1_0_0.eot?#iefix') format('embedded-opentype'), url('../fonts/31A6A1_0_0.woff2') format('woff2'), url('../fonts/31A6A1_0_0.woff') format('woff'), url('../fonts/31A6A1_0_0.ttf') format('truetype'), url('../fonts/31A6A1_0_0.svg#wf') format('svg');
}

@font-face {
    font-family: 'AvenirLTStd-Medium';
    src: url('../fonts/31A6A1_1_0.eot');
    src: url('../fonts/31A6A1_1_0.eot?#iefix') format('embedded-opentype'), url('../fonts/31A6A1_1_0.woff2') format('woff2'), url('../fonts/31A6A1_1_0.woff') format('woff'), url('../fonts/31A6A1_1_0.ttf') format('truetype'), url('../fonts/31A6A1_1_0.svg#wf') format('svg');
}

@font-face {
    font-family: 'AvenirLTStd-Roman';
    src: url('../fonts/31A6A1_2_0.eot');
    src: url('../fonts/31A6A1_2_0.eot?#iefix') format('embedded-opentype'), url('../fonts/31A6A1_2_0.woff2') format('woff2'), url('../fonts/31A6A1_2_0.woff') format('woff'), url('../fonts/31A6A1_2_0.ttf') format('truetype'), url('../fonts/31A6A1_2_0.svg#wf') format('svg');
}

@font-face {
    font-family: 'AvenirLTStd-Light';
    src: url('../fonts/31A6A1_3_0.eot');
    src: url('../fonts/31A6A1_3_0.eot?#iefix') format('embedded-opentype'), url('../fonts/31A6A1_3_0.woff2') format('woff2'), url('../fonts/31A6A1_3_0.woff') format('woff'), url('../fonts/31A6A1_3_0.ttf') format('truetype'), url('../fonts/31A6A1_3_0.svg#wf') format('svg');
}

@font-face {
    font-family: 'AvenirLTStd-Black';
    src: url('../fonts/31A6A1_4_0.eot');
    src: url('../fonts/31A6A1_4_0.eot?#iefix') format('embedded-opentype'), url('../fonts/31A6A1_4_0.woff2') format('woff2'), url('../fonts/31A6A1_4_0.woff') format('woff'), url('../fonts/31A6A1_4_0.ttf') format('truetype'), url('../fonts/31A6A1_4_0.svg#wf') format('svg');
}

html {
    width: 100%;
    height: 100%;
    float: left;
    -webkit-font-smoothing: antialiased;
}

body {
    width: 100%;
    height: 100%;
    margin: 0;
    float: left;
    font-family: 'AvenirLTStd-Medium';
    color: #4E4E4E;
    background: #fff;
    overflow-x: hidden;
    transition: 1s margin;
    -moz-transition: 1s margin;
    -webkit-transition: 1s margin;
}

img {
    max-width: 100%;
}

strong {
    font-weight: 400;
    font-family: 'AvenirLTStd-Heavy';
}

p {
    font-family: 'AvenirLTStd-Medium';
    color: #4E4E4E;
    font-size: 16px;
    margin: 20px 0;
    line-height: 1.5;
    font-weight: 400;
}

p a {
    color: #4E4E4E;
    text-decoration: none;
}

p a:hover {
    text-decoration: underline;
}

p.bigger {
    font-size: 18px;
}

h1 {
    color: #137AA6;
    margin: 0;
    margin-bottom: 20px;
    font-weight: 400;
    font-size: 28px;
    font-family: 'AvenirLTStd-Heavy';
    line-height: 1.2;
}

h2 {
    color: #137AA6;
    margin: 0;
    margin-bottom: 20px;
    font-weight: 400;
    font-size: 28px;
    font-family: 'AvenirLTStd-Heavy';
    line-height: 1.2;
}

h3 {
    color: #137AA6;
    margin: 0;
    margin-bottom: 20px;
    font-weight: 400;
    font-size: 18px;
    font-family: 'AvenirLTStd-Heavy';
}

h4 {
    color: #137AA6;
    margin: 0;
    margin-bottom: 20px;
    font-weight: 400;
    font-size: 16px;
    font-family: 'AvenirLTStd-Medium';
    line-height: 1.2;
}

li {
    color: #4E4E4E;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8;
    font-family: 'AvenirLTStd-Medium';
}

input[type="text"], textarea, input[type="submit"], select, input[type="email"] {
    outline: none;
    border-radius: 0 !important;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

input[type="submit"] {
    cursor: pointer;
}

a:not([href]) {
    cursor: pointer;
}

sup {
    font-family: monospace;
}

.container {
    float: left;
    width: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}

.clear {
    clear: both;
}

.fakebody {
    float: left;
    width: 100%;
    height: 100%;
}

.wrapper {
    margin: 0 auto;
    width: 1200px;
}

.wrapper.w900 {
    width: 900px;
}

.wrapper.w1000 {
    width: 1000px;
}

.resp {
    display: none;
}

/*header*/
#head {
    color: #fff;
    float: left;
    width: 100%;
    z-index: 5;
    position: absolute;
    left: 0;
    top: 10px;
}

#head a {
    color: #fff;
    text-decoration: none;
}

#head label {
    display: none;
}

#head input[type="checkbox"] {
    display: none;
}

#head .logo {
    float: left;
    text-align: left;
    line-height: 10px;
    width: calc(100% - 100px);
    width: -moz-calc(100% - 100px);
    width: -webkit-calc(100% - 100px);
}

#head .logo img {
    vertical-align: middle;
}

#head .logo img:last-child {
    display: none;
}

#head .menu {
    cursor: pointer;
}

#head .menu.left {
    float: left;
}

#head .menu.right {
    float: right;
}

#head .menu img:last-child {
    display: none;
}

#head .button {
    display: none;
    margin: 0;
    background: #945822;
}

#head .button:hover {
    display: none;
    margin: 0;
}

#head.inner {
    position: fixed;
    top: 0;
    left: 0;
    background: #F0F0F0;
    padding: 30px 0;
}

#head.inner .button {
    display: block;
}

#head.inner .logo {
    margin-top: 6px;
    width: calc(100% - 540px);
    width: -moz-calc(100% - 540px);
    width: -webkit-calc(100% - 540px);
}

#head.inner .logo img:first-child {
    display: none;
}

#head.inner .logo img:last-child {
    display: inline-block;
}

#head.inner .menu {
    margin-top: 12px;
}

#head.inner .menu.left {
    margin-right: 20px;
}

#head.inner .menu.right {
    margin-left: 20px;
}

#head.inner .menu img:first-child {
    display: none;
}

#head.inner .menu img:last-child {
    display: inline-block;
}

.slideout {
    position: absolute;
    top: 0;
    background: #fff;
    height: 100%;
    min-height: 770px;
    box-sizing: border-box;
    padding: 30px;
    z-index: 7;
    width: calc((100% - 1200px) / 2 + 1200px);
    width: -moz-calc((100% - 1200px) / 2 + 1200px);
    width: -webkit-calc((100% - 1200px) / 2 + 1200px);
    transition: 1s margin;
    -moz-transition: 1s margin;
    -webkit-transition: 1s margin;
}

.slideout.left {
    left: 0;
    min-height: 830px;
    margin-left: calc(((100% - 1200px) / 2 + 1200px) * -1);
    margin-left: -moz-calc(((100% - 1200px) / 2 + 1200px) * -1);
    margin-left: -webkit-calc(((100% - 1200px) / 2 + 1200px) * -1);
}

.slideout.right {
    right: 0;
    margin-right: calc(((100% - 1200px) / 2 + 1200px) * -1);
    margin-right: -moz-calc(((100% - 1200px) / 2 + 1200px) * -1);
    margin-right: -webkit-calc(((100% - 1200px) / 2 + 1200px) * -1);
}

.slideout table {
    float: left;
    width: 100%;
    height: 100%;
    text-align: center;
}

.slideout table ul {
    float: left;
    width: 100%;
    margin: 0;
    padding: 0;
}

.slideout table li {
    float: left;
    width: 100%;
    list-style: none;
    font-family: 'AvenirLTStd-Heavy';
}

.slideout table li a {
    float: left;
    width: 100%;
    text-decoration: none;
    color: #4E4E4E;
    font-size: 24px;
}

.slideout table li.selected a {
    color: #71CAC9;
}

.slideout table .phone {
    margin: 20px 0;
    font-family: 'AvenirLTStd-Heavy';
    color: #77E0EA;
    font-size: 24px;
    text-decoration: none;
}

.slideout table .social img {
    margin-right: 15px;
    width: 50px;
}

.slideout table .social a:last-child img {
    margin-right: 0px;
}

.slideout .close {
    position: absolute;
    right: 400px;
    top: 90px;
    cursor: pointer;
    z-index: 1;
}

.slideout .close span {
    float: left;
    margin-right: 10px;
    color: #77E0EA;
    font-size: 10px;
    line-height: 14px;
    text-transform: uppercase;
    font-weight: 400;
    margin-bottom: 40px;
    letter-spacing: 3px;
    font-family: 'AvenirLTStd-Heavy';
}

.slideout .close .lines {
    float: right;
    height: 18px;
    margin: 6px 0;
}

.slideout .close .line {
    background: #77E0EA;
    width: 50px;
    height: 2px;
    float: right;
    clear: right;
    margin-bottom: -2px;
    transition: 0.5s all ease;
    -moz-transition: 0.5s all ease;
    -webkit-transition: 0.5s all ease;
}

.slideout .close:hover .line:first-child {
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.slideout .close:hover .line:last-child {
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.slideout.left .close {
    right: inherit;
    left: calc((100% - 800px) / 2);
    left: -moz-calc((100% - 800px) / 2);
    left: -webkit-calc((100% - 800px) / 2);
}

.slideout.left .close span {
    float: right;
    margin-right: 0;
    margin-left: 10px;
}

.slideout.left .close .lines {
    float: left;
}

.slideout.left .close .line {
    background: none;
    width: 51px;
}

.slideout.left .box {
    float: left;
    margin-right: 20px;
    width: calc((100% - 90px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.slideout.left .box:nth-child(4n+1) {
    clear: left;
}

.slideout.left .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
}

.slideout.left .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.slideout.left .box .img img {
    width: 130px;
}

.slideout.left .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.slideout.left .box:hover .img table:last-child {
    display: table;
}

.slideout.left .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 10px 0 20px;
    font-family: 'AvenirLTStd-Heavy';
}

.slideout.left .prapper {
    width: 800px;
    margin: 0 auto;
}

.slideout.left h3 {
    margin-top: 70px;
    text-align: center;
    margin-bottom: 40px;
    text-transform: none;
    font-size: 24px;
    font-family: 'AvenirLTStd-Heavy';
    color: #77E0EA;
}

/*isloading*/
.isloading-wrapper {
    padding: 10px 0;
    display: block;
    position: absolute;
    left: 50%;
    margin-left: -50px;
    width: 100px;
    background-color: transparent;
    text-align: center;
    color: #4E4E4E;
    text-transform: uppercase;
}

.icon-spin {
    font-size: 40px;
    color: #49B3D7;
}

/*generic*/
.generic p a {
    color: #4e4e4e;
    text-decoration: none;
}

.generic ul {
    padding-left: 20px;
}

.generic ul li {
    padding: 0;
}

.button {
    cursor: pointer;
    padding: 10px;
    text-decoration: none;
    text-transform: uppercase;
    width: 200px;
    color: #fff;
    float: left;
    margin-right: 10px;
    font-size: 12px;
    text-align: center;
    font-family: 'AvenirLTStd-Medium';
    border: none;
    box-sizing: border-box;
    border-radius: 10px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
}

.button:hover {
    background: #77E0EA;
}

.button.blue {
    color: #fff;
    background: #137AA6;
}

.button.blue:hover {
    background: #fff;
    color: #137AA6;
}

.button.security {
    position: relative;
}

.button.security .recaptcha {
    display: none;
    position: absolute;
    top: -76px;
    left: 50%;
    margin-left: -152px;
}

.button.security span.after {
    display: none;
}

.button.security.active .recaptcha {
    display: block;
}

.button.security.active {
    background: #77E0EA;
    color: #fff;
}

.button.security.active span.before {
    display: none;
}

.button.security.active span.after {
    display: inline;
}

form .button {
    border-radius: 5px;
}

.padding120 {
    padding: 120px 0;
}

.padding80 {
    padding: 80px 0;
}

.padding40 {
    padding: 40px 0;
}

.centred {
    text-align: center;
}

.margin60 {
    margin-bottom: 60px;
}

.header {
    text-align: center;
    height: 310px;
    position: relative;
}

.header h1 {
    color: #fff;
    margin: 0;
    line-height: 310px;
}

.header .nav {
    position: absolute;
    bottom: 0;
    left: 0;
    line-height: 80px;
    padding-top: 40px;
    min-height: 80px;
    background: -moz-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(40, 41, 76, 1) 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(255, 255, 255, 0)), color-stop(100%, rgba(40, 41, 76, 1)));
    background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(40, 41, 76, 1) 100%);
    background: -o-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(40, 41, 76, 1) 100%);
    background: -ms-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(40, 41, 76, 1) 100%);
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(40, 41, 76, 1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffffff', endColorstr='#ffffff', GradientType=0);
}

.header .nav a {
    color: #fff;
    text-decoration: none;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
    padding-bottom: 31px;
    margin-right: 40px;
}

.header .nav a:last-child {
    margin-right: 0px;
}

.header .nav a.selected {
    background-image: url(../images/yellow-line.png);
    background-position: bottom center;
    background-repeat: no-repeat;
}

/*home*/
.home.banner {
    height: 100%;
    min-height: 660px;
    position: relative;
}

.home.banner table {
    float: right;
    width: 470px;
    height: 100%;
    border-spacing: 0;
    position: relative;
    z-index: 1;
}

.home.banner .wrapper {
    height: 100%;
}

.home.banner .line {
    width: 150px;
    height: 1px;
    float: left;
    margin-left: -170px;
    background: #137AA6;
    margin-top: 7px;
}

.home.banner h1 {
    color: #137AA6;
    font-size: 46px;
    font-family: 'AvenirLTStd-Medium';
}

.home.banner h2 {
    color: #137AA6;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 40px;
    letter-spacing: 6px;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.home.banner p {
    color: #137AA6;
}

.home.banner .overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    float: left;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.1);
}

.home.banner .circles {
    position: absolute;
    bottom: 0;
    right: 0;
    height: 450px;
}

.home.health .left {
    float: left;
    width: calc(100% - 490px);
    width: -webkit-calc(100% - 490px);
    width: -moz-calc(100% - 490px);
}

.home.health .left img:first-child {
    float: left;
    width: 39%;
}

.home.health .left img:last-child {
    float: right;
    width: 53%;
}

.home.health .right {
    float: right;
    width: 450px;
}

.home.health .right h2 {
    font-size: 18px;
}

.chiron {
    text-align: center;
    padding: 40px 0;
}

.chiron h2 {
    font-size: 28px;
    margin: 0;
}

.home.imgtext .left {
    float: left;
    width: 50%;
    background-size: cover;
    background-position: center center;
}

.home.imgtext .left .content {
    float: left;
    width: 60%;
    margin-left: 40%;
    text-align: right;
}

.home.imgtext .right .content {
    float: left;
    width: 60%;
    margin-right: 40%;
    text-align: left;
}

.home.imgtext .left .line {
    margin-left: calc(100% - 51px);
    margin-left: -moz-calc(100% - 51px);
    margin-left: -webkit-calc(100% - 51px);
}

.home.imgtext .left h3 {
    text-align: right;
}

.home.imgtext .right {
    float: right;
    width: 50%;
}

.home.imgtext .text {
    background: #F1FAFC;
    box-sizing: border-box;
    padding: 80px;
}

.home.imgtext .text p:last-child {
    margin-bottom: 0;
}

.home.imgtext .text h3 {
    margin-bottom: 60px;
}

.home.imgtext .text h3 span {
    color: #5BBDCB;
    font-family: 'Petit Formal Script', cursive;
    font-size: 24px;
    text-transform: lowercase;
}

.home.imgtext .text .line {
    float: left;
    width: 50px;
    height: 4px;
    background: #137AA6;
}

.home.imgtext .img {
    background-size: cover;
    background-position: center center;
}

.home.threesections .tab:hover {
    color: #fff;
    background: #77E0EA;
}

.home.threesections .tab {
    float: left;
    border: 1px solid #87ECF1;
    background: #F1FAFC;
    color: #137AA6;
    text-align: center;
    text-transform: uppercase;
    cursor: pointer;
    border-right: 0;
    padding: 15px 0;
    font-family: 'AvenirLTStd-Heavy';
    letter-spacing: 3px;
    font-size: 14px;
    box-sizing: border-box;
    width: calc((100% - 1px) / 3);
    width: -moz-calc((100% - 1px) / 3);
    width: -webkit-calc((100% - 1px) / 3);
}

.home.threesections .tab:first-child {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}

.home.threesections .tab:last-child {
    border-right: 1px solid #87ECF1;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.home.threesections .tab.active {
    color: #fff;
    background: #137AA6;
}

.home.threesections .page {
    display: none;
    box-sizing: border-box;
    padding: 60px;
    background: #F8F8F8;
    margin-top: 40px;
}

.home.threesections .page p:first-child {
    margin-top: 0;
}

.hasline {
    box-sizing: border-box;
}

.hasline .line {
    float: none;
    width: auto;
    overflow: hidden;
    margin: 0 150px;
    height: 1px;
    background: #77E0EA;
}

.home.testimonials {
    margin: 120px 0;
}

.testimonials {
    text-align: center;
    background: #F1FAFC;
}

.testimonials .indicators img {
    margin-left: 5px;
}

.testimonials .indicators img:first-child {
    margin-left: 0px;
}

.testimonials h3 {
    font-size: 14px;
    font-weight: 600;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
    letter-spacing: 5px;
}

.testimonials p {
    font-family: 'AvenirLTStd-Light';
    font-size: 24px;
    color: #137AA6;
}

.home.products {
    text-align: center;
}

.home.products .box {
    float: left;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 91px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.home.products .box:nth-child(4n+1) {
    clear: left;
}

.home.products .box:nth-child(4n+4) {
    margin-right: 0px;
}

.home.products .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
}

.home.products .box .img .image {
    float: left;
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.home.products .box .img .image.help {
    background-size: 50%;
}

.home.products .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.home.products .box .img img {
    width: 200px;
}

.home.products .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.home.products .box:hover .img table:last-child {
    display: table;
}

.home.products .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 10px 0 0;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.home.inspiration {
    text-align: center;
}

.home.inspiration h2 {
    margin-bottom: 80px;
}

.home.inspiration .box {
    float: left;
    position: relative;
    margin-right: 30px;
    margin-bottom: 40px;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.home.inspiration .box:nth-child(3n+3) {
    margin-right: 0;
}

.home.inspiration .box .icon {
    width: 60px;
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -30px;
}

.home.inspiration .box .text {
    box-sizing: border-box;
    padding: 40px;
    background: #F1FAFC;
    border-bottom: 4px solid #137AA6;
}

.home.inspiration .box.fibreglass .text {
    border-color: #137AA6;
}

.home.inspiration .box.concrete .text {
    border-color: #71CAC9;
}

.home.inspiration .box.spas .text {
    border-color: #77E0EA;
}

.home.inspiration .box .text p {
    font-size: 14px;
}

.home.inspiration .box .text p:first-child {
    margin-top: 0;
}

.home.inspiration .box .text .fakebutton {
    color: #137AA6;
    font-family: 'Petit Formal Script', cursive;
    font-size: 24px;
}

.home.inspiration .box.fibreglass .text .fakebutton {
    color: #137AA6;
}

.home.inspiration .box.concrete .text .fakebutton {
    color: #71CAC9;
}

.home.inspiration .box.spas .text .fakebutton {
    color: #77E0EA;
}

.home.inspiration .buttons .button:first-child {
    margin-left: calc((100% - 410px) / 2);
    margin-left: -moz-calc((100% - 410px) / 2);
    margin-left: -webkit-calc((100% - 410px) / 2);
}

.home.blog {
    text-align: center;
}

.home.blog h2 {
    margin-bottom: 40px;
}

.home.blog .box {
    float: left;
    margin-right: 80px;
    width: calc((100% - 161px) / 3);
    width: -moz-calc((100% - 161px) / 3);
    width: -webkit-calc((100% - 161px) / 3);
}

.home.blog .box:nth-child(3n+3) {
    margin-right: 0;
}

.home.blog .box .number {
    color: #77E0EA;
    font-family: 'Oswald', sans-serif;
    font-size: 92px;
    line-height: 92px;
}

.home.blog .box .month {
    color: #5BBDCB;
    font-family: 'Petit Formal Script', cursive;
    font-size: 24px;
}

.home.blog .box .line {
    float: left;
    width: 50px;
    height: 4px;
    background: #137AA6;
    margin: 20px 0;
    margin-left: calc((100% - 50px) / 2);
    margin-left: -moz-calc((100% - 50px) / 2);
    margin-left: -webkit-calc((100% - 50px) / 2);
}

.home.blog .box .title {
    color: #137AA6;
    font-family: 'AvenirLTStd-Heavy';
    font-size: 18px;
    height: 44px;
}

.home.blog .buttons .button {
    margin-top: 20px;
    margin-left: calc((100% - 200px) / 2);
    margin-left: -moz-calc((100% - 200px) / 2);
    margin-left: -webkit-calc((100% - 200px) / 2);
}

.subscribe {
    background: #F1FAFC;
    padding: 60px 0;
}

.subscribe .text {
    float: left;
    font-size: 24px;
    line-height: 50px;
    color: #137AA6;
    font-family: 'AvenirLTStd-Heavy';
}

.subscribe input[type="text"] {
    float: left;
    margin-left: 40px;
    border: 0;
    outline: none;
    padding: 10px 20px;
    height: 50px;
    font-size: 14px;
    box-sizing: border-box;
    border-top-left-radius: 5px !important;
    border-bottom-left-radius: 5px !important;
    width: calc(100% - 414px);
    width: -webkit-calc(100% - 414px);
    width: -moz-calc(100% - 414px);
}

.subscribe input[type="submit"] {
    width: 200px;
    margin-right: 0;
    border-top-right-radius: 5px !important;
    border-bottom-right-radius: 5px !important;
    color: #fff;
    background: url(../images/submit.png) !important;
}

.firstelement {
    margin-top: 114px;
}

.inner.banner {
    height: 600px;
    position: relative;
}

.inner.banner table {
    float: left;
    width: 600px;
    height: 100%;
    border-spacing: 0;
    position: relative;
    z-index: 1;
}

.inner.banner .wrapper {
    height: 100%;
}

.inner.banner h2 {
    color: #fff;
    font-family: 'AvenirLTStd-Light';
    font-size: 32px;
}

.inner.banner .overlay {
    position: absolute;
    top: 0;
    left: 0;
    float: left;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.2);
}

.inner.banner .circles {
    position: absolute;
    z-index: 1;
    bottom: 0;
    right: 0;
    height: 550px;
}

.about h3 {
    color: #71CAC9;
}

.about .covered_text {
    height: 200px;
    overflow: hidden;
}

.about .cover {
    height: 40px;
    margin-top: -40px;
    margin-bottom: 80px;
    background: -moz-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1, 1) 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(255, 255, 255, 0)), color-stop(100%, rgba(255, 255, 255, 1, 1)));
    background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1, 1) 100%);
    background: -o-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1, 1) 100%);
    background: -ms-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1, 1) 100%);
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffffff', endColorstr='#d6bf77', GradientType=0);
}

.about .images {
    margin: 80px 0;
}

.about .images .img {
    float: left;
    margin-right: 30px;
    position: relative;
    background-size: cover;
    background-position: center center;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.about .images .img:nth-child(2n+2) {
    margin-right: 0;
}

.about .images .img img {
    float: left;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
}

.about .work .img {
    float: left;
    width: 100px;
}

.about .work .img img {
    float: left;
    width: 100%;
}

.about .work .text {
    float: right;
    width: calc(100% - 150px);
    width: -moz-calc(100% - 150px);
    width: -webkit-calc(100% - 150px);
}

.categories.products {
    text-align: center;
}

.categories.products h1 {
    margin-bottom: 40px;
}

.categories.products .list {
    margin-bottom: 80px;
}

.categories.products .box {
    float: left;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 91px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.categories.products .box:nth-child(4n+1) {
    clear: left;
}

.categories.products .box:nth-child(4n+4) {
    margin-right: 0;
}

.categories.products .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
}

.categories.products .box .img .image {
    float: left;
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.categories.products .box .img .image.help {
    background-size: 50%;
}

.categories.products .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.categories.products .box .img img {
    width: 200px;
}

.categories.products .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.categories.products .box:hover .img table:last-child {
    display: table;
}

.categories.products .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 10px 0 0;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.categories.products .left.img {
    float: left;
    position: relative;
    border-radius: 10px;
    background-size: cover;
    background-position: center center;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.categories.products .left.img img {
    float: left;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
}

.categories.products .right {
    float: right;
    background: #F0F0F0;
    padding: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.categories.products .right h3 {
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
    font-size: 14px;
}

.categories.products .right input[type="text"] {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    background: #fff;
    border-radius: 5px !important;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.categories.products .right select {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    background: #fff;
    border-radius: 5px !important;
    background-image: url(../images/field-drop-down.png);
    background-position: center right;
    background-repeat: no-repeat;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.categories.products .right select:nth-child(2n+2), .categories.products .right input[type="text"]:nth-child(2n+2) {
    margin-right: 0px;
}

.categories.products .right select.full {
    width: 100%;
    margin-right: 0;
}

.categories.products .right input[type="submit"] {
    width: 100%;
    margin-right: 0;
    background: url(../images/submit.png) !important;
    border-radius: 5px !important;
}

.products.list {
    text-align: center;
}

.products.list .list {
    margin-bottom: 80px;
}

.products.list .box {
    float: left;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 91px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.products.list .box:nth-child(4n+1) {
    clear: left;
}

.products.list .box:nth-child(4n+4) {
    margin-right: 0;
}

.products.list .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
}

.products.list .box .img .image {
    float: left;
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.products.list .box .img .image.help {
    background-size: 50%;
}

.products.list .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.products.list .box .img img {
    width: 200px;
}

.products.list .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.products.list .box:hover .img table:last-child {
    display: table;
}

.products.list .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 10px 0 0;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.products.list .nav {
    color: #4E4E4E;
    text-transform: uppercase;
    line-height: 33px;
    font-size: 14px;
    font-family: 'AvenirLTStd-Heavy';
    background-repeat: no-repeat;
    text-decoration: none;
}

.products.list .nav.lft {
    float: left;
    padding-left: 30px;
    background-image: url(../images/product-back.png);
    background-position: center left;
    margin-bottom: -33px;
}

.products.list .nav.rght {
    float: right;
    padding-right: 30px;
    background-image: url(../images/product-next.png);
    background-position: center right;
    margin-top: -53px;
}

.ctas .button {
    float: left;
    margin-right: 30px;
    color: #137AA6;
    background: #F0F0F0;
    font-family: 'AvenirLTStd-Black';
    letter-spacing: 1px;
    font-size: 16px;
    padding: 30px 0;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.ctas .button:nth-child(3n+3) {
    margin-right: 0;
}

.ctas .button:hover {
    background: #87ECF1;
}

.ctas .button span {
    line-height: 40px;
    display: inline-block;
    padding-left: 50px;
    background-repeat: no-repeat;
    background-position: center left;
}

.ctas .button.question span {
    background-image: url(../images/cta-question-green.png)
}

.ctas .button.question:hover span {
    background-image: url(../images/cta-question-white.png)
}

.ctas .button.quote span {
    background-image: url(../images/cta-quote-green.png)
}

.ctas .button.quote:hover span {
    background-image: url(../images/cta-quote-white.png)
}

.ctas .button.phone span {
    background-image: url(../images/cta-call-green.png)
}

.ctas .button.phone:hover span {
    background-image: url(../images/cta-call-white.png)
}

.ctas .button table {
    height: 100px;
    text-align: center;
    float: left;
    width: 100%;
    line-height: 20px;
}

.ctas .button table span {
    line-height: 20px;
    padding: 0;
    font-size: 22px;
    background: none !important;
}

.ctas .button.hastable {
    padding: 0;
}

.products.detail {
    position: relative;
    padding: 80px 0 50px;
}

.products.detail .wrapper {
    position: relative;
    z-index: 1;
}

.products.detail .overlay {
    position: absolute;
    top: 0;
    left: 0;
    background: #F1FAFC;
    height: 300px;
}

.products.detail h1 {
    float: left;
    margin-bottom: 0px;
    line-height: 50px;
}

.products.detail h1 img {
    margin-right: 10px;
}

.products.detail .selector {
    float: right;
}

.products.detail .selector .label {
    float: left;
    color: #137AA6;
    font-size: 20px;
    font-family: 'AvenirLTStd-Heavy';
    line-height: 50px;
    margin-right: 10px;
}

.products.detail .selector select {
    float: right;
    background: #F0F0F0;
    box-sizing: border-box;
    border: 0;
    height: 50px;
    padding: 10px;
    color: #4E4E4E;
    font-size: 14px;
    font-family: 'AvenirLTStd-Medium';
    width: 320px;
    background-image: url(../images/field-drop-down.png);
    background-position: center right;
    background-repeat: no-repeat;
}

.products.detail .threeboxes .box {
    float: left;
    background: #F8F8F8;
    padding: 30px;
    box-sizing: border-box;
    border-radius: 10px;
    margin-right: 30px;
    margin-bottom: 30px;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.products.detail .threeboxes .box:nth-child(3n+3) {
    margin-right: 0;
}

.products.detail .threeboxes .box p:first-child {
    margin-top: 0;
}

.products.detail .threeboxes .box p:last-child {
    margin-bottom: 0;
}

.products.detail .threeboxes .box .button {
    width: 250px;
    max-width: 100%;
}

.products.detail .threeboxes .box table {
    float: left;
    width: 100%;
    height: 100%;
    text-align: center;
}

.products.detail .threeboxes .largetext p {
    color: #137AA6;
    font-size: 20px;
    font-family: 'AvenirLTStd-Heavy';
}

.products.detail .threeboxes .hasgallery {
    background: none;
    padding: 0;
    border-radius: 0;
}

.products.detail .threeboxes .hasgallery .main_img {
    background: #F8F8F8;
    padding: 30px;
    box-sizing: border-box;
    border-radius: 10px;
}

.products.detail .threeboxes .hasgallery .main_img .img {
    float: left;
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.products.detail .threeboxes .hasgallery .mini {
    float: left;
    cursor: pointer;
    margin-top: 30px;
    margin-right: 30px;
    background: #F8F8F8;
    padding: 5px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.products.detail .threeboxes .hasgallery .mini:nth-child(3n+3) {
    margin-right: 0;
}

.products.detail .threeboxes .hasgallery .mini.active {
    background: #A6A6A6;
}

.products.detail .more {
    display: none;
}

.products.detail .textbox {
    background: #F8F8F8;
    padding: 30px;
    box-sizing: border-box;
    margin-bottom: 30px;
    border-radius: 10px;
}

.products.detail .textbox.img {
    text-align: center;
}

.products.detail .textbox ul {
    padding-left: 20px;
}

.products.detail .textbox ul li {
    padding: 5px 0;
}

.products.detail .textbox p:last-child {
    margin-bottom: 0;
}

.products.detail .textbox .threecolumns {
    -webkit-columns: 100px 3; /* Chrome, Safari, Opera */
    -moz-columns: 100px 3; /* Firefox */
    columns: 100px 3;
}

.products.detail .textbox .threecolumns ul:first-child, .products.detail .textbox .threecolumns p:first-child {
    margin-top: 0;
}

.products.detail .ctas {
    margin-bottom: 30px;
}

.products.detail .enquiry .left {
    float: left;
    box-sizing: border-box;
    padding: 30px;
    background: #F8F8F8;
    border-radius: 10px;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.products.detail .enquiry .left p:last-child {
    margin-bottom: 0;
}

.products.detail .enquiry .left h3 {
    font-size: 28px;
}

.products.detail .enquiry .right {
    float: right;
    box-sizing: border-box;
    padding: 50px;
    background: #F0F0F0;
    border-radius: 10px;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.products.detail .enquiry .right.full {
    float: right;
    box-sizing: border-box;
    padding: 50px;
    background: #F0F0F0;
    border-radius: 10px;
    width: 100%;
}

.products.detail .enquiry .right h3 {
    text-align: center;
    text-transform: uppercase;
    font-size: 16px;
    letter-spacing: 2px;
    font-family: 'AvenirLTStd-Heavy';
}

.products.detail .enquiry .right input[type="text"] {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
    background: #fff;
    color: #4E4E4E;
    border: 0;
    border-radius: 5px !important;
    padding: 10px;
    height: 50px;
    box-sizing: border-box;
    font-size: 14px;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.products.detail .enquiry .right input[type="text"]:nth-child(2n+2) {
    margin-right: 0;
}

.products.detail .enquiry .right textarea {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
    background: #fff;
    color: #4E4E4E;
    border: 0;
    border-radius: 5px !important;
    padding: 10px;
    height: 206px;
    box-sizing: border-box;
    font-size: 14px;
    width: 100%;
}

.products.detail .enquiry .right .button {
    float: left;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.products.detail .enquiry .right input[type="submit"] {
    float: right;
    margin-right: 0;
    border-radius: 10px !important;
    background-image: url(../images/submit-grey.png);
}

.products.detail .nav {
    color: #4E4E4E;
    text-transform: uppercase;
    line-height: 33px;
    font-size: 14px;
    font-family: 'AvenirLTStd-Heavy';
    background-repeat: no-repeat;
    text-decoration: none;
}

.products.detail .nav.lft {
    float: left;
    padding-left: 30px;
    background-image: url(../images/product-back.png);
    background-position: center left;
    margin-bottom: 40px;
    margin-top: 10px;
}

.promos {
    margin-bottom: 30px;
}

.promos .promo {
    display: none;
}

.promos .promo:first-child {
    display: block;
}

.promos .img {
    float: left;
    width: 50%;
    background: #E7E7E9;
    padding: 27px;
    box-sizing: border-box;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}

.promos .text {
    float: left;
    width: 50%;
    background: #F0F0F0;
    box-sizing: border-box;
    padding: 30px;
}

.promos .text .nav {
    float: right;
}

.promos .text .nav img {
    float: left;
    margin-left: 10px;
    cursor: pointer;
}

.promos .text .nav img:hover {
    background: #fff;
    border-radius: 5px;
}

.pools .ctas {
    margin-bottom: 30px;
}

.pools p strong {
    color: #137AA6;
}

.pools h3 {
    color: #71CAC9;
}

.pools .tabs {
    margin-top: 60px;
    margin-bottom: 80px;
}

.pools .tabs .tab {
    float: left;
    margin-right: 80px;
    width: calc((100% - 81px) / 2);
    width: -moz-calc((100% - 80px) / 2);
    width: -webkit-calc((100% - 80px) / 2);
}

.pools .tabs .tab:nth-child(2n+2) {
    margin-right: 0;
}

.pools .tabs .tab .number {
    background: #137AA6;
    color: #fff;
    font-family: 'Oswald', sans-serif;
    float: left;
    width: 100px;
    text-align: center;
    line-height: 100px;
    font-size: 52px;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}

.pools .tabs .tab .text {
    min-height: 132px;
    float: right;
    padding: 30px;
    background: #F0F0F0;
    box-sizing: border-box;
    border-radius: 10px;
    border-top-left-radius: 0;
    width: calc(100% - 100px);
    width: -moz-calc(100% - 100px);
    width: -webkit-calc(100% - 100px);
}

.pools .tabs .tab .text p:first-child {
    margin-top: 0;
}

.pools .tabs .tab .text p:last-child {
    margin-bottom: 0;
}

.pools img.container {
    margin-bottom: 80px;
}

.pools .threetabs {
    margin-top: 60px;
    margin-bottom: 80px;
}

.pools .threetabs .tab {
    float: left;
    margin-right: 30px;
    padding: 30px;
    position: relative;
    background: #F0F0F0;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.pools .threetabs .tab:nth-child(3n+3) {
    margin-right: 0;
}

.pools .threetabs .tab .number {
    color: #137AA6;
    font-family: 'Oswald', sans-serif;
    float: left;
    text-align: center;
    font-size: 42px;
    font-weight: 600;
    position: absolute;
    left: 30px;
    top: -31px;
}

.pools .threetabs .tab p:first-child {
    margin-top: 0;
}

.pools .threetabs .tab p:last-child {
    margin-bottom: 0;
}

.heating .box {
    float: left;
    text-align: center;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 91px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.heating .box:nth-child(4n+1) {
    clear: left;
}

.heating .box:nth-child(4n+4) {
    margin-right: 0;
}

.heating .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
}

.heating .box .img .image {
    float: left;
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.heating .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.heating .box .img img {
    width: 200px;
}

.heating .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.heating .box:hover .img table:last-child {
    display: table;
}

.heating .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 10px 0 0;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.heating .line {
    margin: 80px 150px;
}

.heating .forms .left {
    float: left;
    background: #F0F0F0;
    padding: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.heating .forms .right {
    float: right;
    background: #F0F0F0;
    padding: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.heating .forms h3 {
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
    font-size: 14px;
    height: 34px;
}

.heating .forms input[type="text"] {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    border-radius: 5px !important;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.heating .forms select {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    background: #fff;
    border-radius: 5px !important;
    background-image: url(../images/field-drop-down.png);
    background-position: center right;
    background-repeat: no-repeat;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.heating .forms select:nth-child(2n+2), .heating .forms input[type="text"]:nth-child(2n+2) {
    margin-right: 0px;
}

.heating .forms select.full {
    width: 100%;
    margin-right: 0;
}

.heating .forms input[type="text"].full {
    width: 100%;
    margin-right: 0;
}

.heating .forms .right input[type="submit"] {
    width: 100%;
    margin-right: 0;
    background: url(../images/submit.png) !important;
    border-radius: 5px !important;
}

.heating .forms .left .button {
    float: left;
    margin-right: 0;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.heating .forms .left input[type="submit"] {
    float: right;
    background: url(../images/submit-grey.png);
    border-radius: 5px !important;
}

.heating .ctas {
    margin: 30px 0;
}

.faq h1 {
    text-align: center;
}

.faq .questions {
    background: #F8F8F8;
    padding: 30px;
    box-sizing: border-box;
    margin-bottom: 30px;
    margin-top: 40px;
    border-radius: 10px;
}

.faq .question {
    color: #137AA6;
    font-family: 'AvenirLTStd-Black';
    margin-top: 20px;
    border-bottom: 1px solid #137AA6;
    cursor: pointer;
    padding-bottom: 10px;
    padding-right: 20px;
    box-sizing: border-box;
    background-image: url(../images/FAQ-arrow.png);
    background-size: auto;
    background-position: center right;
    background-repeat: no-repeat;
}

.faq .question:first-child {
    margin-top: 0px;
}

.faq .question.open {
    background-image: url(../images/FAQ-minimise.png);
}

.faq .answer {
    display: none;
}

.faq .left.img {
    float: left;
    position: relative;
    border-radius: 10px;
    background-size: cover;
    background-position: center center;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.faq .left.img img {
    float: left;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
}

.faq .right {
    float: right;
    background: #F0F0F0;
    padding: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.faq .right h3 {
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
    font-size: 14px;
    text-align: center;
}

.faq .right input[type="text"] {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    border-radius: 5px !important;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.faq .right select {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    background: #fff;
    border-radius: 5px !important;
    background-image: url(../images/field-drop-down.png);
    background-position: center right;
    background-repeat: no-repeat;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.faq .right select:nth-child(2n+2), .faq .right input[type="text"]:nth-child(2n+2) {
    margin-right: 0px;
}

.faq .right select.full {
    width: 100%;
    margin-right: 0;
}

.faq .right input[type="submit"] {
    width: 100%;
    margin-right: 0;
    background: url(../images/submit.png) !important;
    border-radius: 5px !important;
}

.maintenance {
    text-align: center;
}

.maintenance .list {
    margin-bottom: 60px;
}

.maintenance .box {
    float: left;
    cursor: pointer;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 121px) / 5);
    width: -moz-calc((100% - 121px) / 5);
    width: -webkit-calc((100% - 121px) / 5);
}

.maintenance .box:nth-child(5n+1) {
    clear: left;
}

.maintenance .box:nth-child(5n+5) {
    margin-right: 0;
}

.maintenance .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
    border-radius: 10px;
}

.maintenance .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.maintenance .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.maintenance .box:hover .img table:last-child {
    display: table;
}

.maintenance .box .text {
    text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 20px 0 20px;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.commercial .ctas {
    margin: 30px 0;
}

.commercial .threecolumns ul {
    padding-left: 20px;
    margin: 0;
}

.commercial .threecolumns {
    margin-bottom: 20px;
    -webkit-columns: 100px 3; /* Chrome, Safari, Opera */
    -moz-columns: 100px 3; /* Firefox */
    columns: 100px 3;
}

.blog.featured {
    background: #F1FAFC;
}

.blog.featured .img {
    position: relative;
    border-radius: 10px;
}

.blog.featured .title {
    position: absolute;
    bottom: 30px;
    left: 40px;
    color: #fff;
    font-family: 'AvenirLTStd-Heavy';
    font-size: 28px;
    z-index: 1;
}

.blog.featured .img .shade {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    float: left;
}

.blog.list {
    text-align: center;
}

.blog.list .box {
    float: left;
    margin-right: 40px;
    margin-top: 40px;
    width: calc((100% - 121px) / 4);
    width: -moz-calc((100% - 120px) / 4);
    width: -webkit-calc((100% - 120px) / 4);
}

.blog.list .box:nth-child(4n+4) {
    margin-right: 0;
}

.blog.list .box .number {
    color: #77E0EA;
    font-family: 'Oswald', sans-serif;
    font-size: 92px;
    line-height: 92px;
}

.blog.list .box .month {
    color: #5BBDCB;
    font-family: 'Petit Formal Script', cursive;
    font-size: 24px;
}

.blog.list .box .line {
    float: left;
    width: 50px;
    height: 4px;
    background: #137AA6;
    margin: 20px 0;
    margin-left: calc((100% - 50px) / 2);
    margin-left: -moz-calc((100% - 50px) / 2);
    margin-left: -webkit-calc((100% - 50px) / 2);
}

.blog.list .box .title {
    color: #137AA6;
    font-family: 'AvenirLTStd-Heavy';
    font-size: 18px;
}

.blog.detail .button.blue:hover {
    background: #77E0EA !important;
    color: #fff;
}

.blog.detail {
    position: relative;
}

.blog.detail .wrapper {
    position: relative;
    z-index: 1;
}

.blog.detail .overlay {
    position: absolute;
    top: 0;
    left: 0;
    background: #F1FAFC;
    height: 300px;
}

.blog.detail .img {
    border-radius: 10px;
    margin-bottom: 80px;
}

.blog.detail .date {
    float: right;
    margin-top: 30px;
}

.blog.detail .quote p {
    color: #71CAC9;
    padding: 0 20px;
    font-family: 'AvenirLTStd-Heavy';
    font-size: 18px;
    line-height: 1.2;
}

.blog.detail .quote p:first-child {
    margin-top: 0;
}

.locator {
    text-align: center;
}

.locator h1 {
    margin-bottom: 60px;
}

.locator .left {
    float: left;
    background: #F0F0F0;
    padding: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.locator .left h3 {
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
    font-size: 14px;
}

.locator .left input[type="text"] {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    border-radius: 5px !important;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.locator .left select {
    float: left;
    height: 50px;
    margin-bottom: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    border: 0;
    padding: 10px;
    color: #000;
    background: #fff;
    border-radius: 5px !important;
    background-image: url(../images/field-drop-down.png);
    background-position: center right;
    background-repeat: no-repeat;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.locator .left select:nth-child(2n+2), .categories.products .right input[type="text"]:nth-child(2n+2) {
    margin-right: 0px;
}

.locator .left select.full {
    width: 100%;
    margin-right: 0;
}

.locator .left input[type="submit"] {
    width: 100%;
    margin-right: 0;
    background: url(../images/submit-lightgreen.png) !important;
    border-radius: 5px !important;
}

.locator .left input[type="submit"]:hover {
    background: url(../images/submit.png) !important;
}

.locator .right {
    float: right;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.locator .right .map {
    float: left;
    width: 100%;
    height: 100%;
    border-radius: 10px;
}

.locator .list {
    margin-top: 10px;
}

.locator .box {
    float: left;
    cursor: pointer;
    margin-right: 30px;
    margin-top: 20px;
    width: calc((100% - 122px) / 5);
    width: -moz-calc((100% - 121px) / 5);
    width: -webkit-calc((100% - 121px) / 5);
}

.locator .box:nth-child(5n+1) {
    clear: left;
}

.locator .box:nth-child(5n+5) {
    margin-right: 0;
}

.locator .box .img {
    background: #F8F8F8;
    padding: 10px;
    position: relative;
    box-sizing: border-box;
    border-radius: 10px;
}

.locator .box .img table {
    float: left;
    width: 100%;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
}

.locator .box .img a {
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #fff;
    text-transform: uppercase;
}

.locator .box .img table:last-child {
    display: none;
    position: absolute;
    background: rgba(119, 224, 234, 0.9);
    font-family: 'AvenirLTStd-Medium';
    font-size: 12px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    width: calc(100% - 20px);
    width: -moz-calc(100% - 20px);
    width: -webkit-calc(100% - 20px);
    height: calc(100% - 20px);
    height: -moz-calc(100% - 20px);
    height: -webkit-calc(100% - 20px);
}

.locator .box:hover .img table:last-child {
    display: table;
}

.locator .box.open .img table:last-child {
    display: table;
}

.locator .box .text {
    cursor: default;
    cursor: text-align: center;
    font-size: 14px;
    color: #4E4E4E;
    margin: 20px 0 5px;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.locator .box .address {
    cursor: default;
    text-align: center;
    font-size: 12px;
    color: #4E4E4E;
    margin: 0px;
    font-family: 'AvenirLTStd-Heavy';
}

.locator .box .phone {
    cursor: default;
    text-align: center;
    font-size: 12px;
    color: #4E4E4E;
    margin: 5px 0 20px;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.gallery.list {
    text-align: center;
}

.gallery.list .row {
    width: 100%;
    float: left;
}

.gallery.list .box {
    float: left;
    position: relative;
    margin-right: 30px;
    margin-bottom: 40px;
    width: calc((100% - 62px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.gallery.list .box:nth-child(3n+3) {
    margin-right: 0;
}

.gallery.list .box .icon {
    width: 60px;
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -30px;
}

.gallery.list .box .text {
    box-sizing: border-box;
    padding: 40px;
    background: #F1FAFC;
    border-bottom: 4px solid #137AA6;
}

.gallery.list .box.fibreglass .text {
    border-color: #137AA6;
}

.gallery.list .box.concrete .text {
    border-color: #71CAC9;
}

.gallery.list .box.spas .text {
    border-color: #77E0EA;
}

.gallery.list .box .text p {
    font-size: 14px;
}

.gallery.list .box .text p:first-child {
    margin-top: 0;
}

.gallery.list .box .text .fakebutton {
    color: #137AA6;
    font-family: 'Petit Formal Script', cursive;
    font-size: 24px;
}

.gallery.list .box.fibreglass .text .fakebutton {
    color: #137AA6;
}

.gallery.list .box.concrete .text .fakebutton {
    color: #71CAC9;
}

.gallery.list .box.spas .text .fakebutton {
    color: #77E0EA;
}

.gallery.list #list {
    position: relative;
}

.gallery .tabs {
    margin: 40px 0 100px;
}

.gallery .tabs .tab {
    background: #F0F0F0;
    color: #4E4E4E;
    line-height: 40px;
    margin-right: 30px;
    width: calc((100% - 91px) / 4);
    width: -moz-calc((100% - 90px) / 4);
    width: -webkit-calc((100% - 90px) / 4);
}

.gallery .tabs .tab:nth-child(4n+4) {
    margin-right: 0;
}

.gallery .tabs .tab:hover, .gallery .tabs .tab.active {
    background: #77E0EA;
    color: #fff;
}

.gallery .tabs .tab:nth-child(2):hover, .gallery .tabs .tab:nth-child(2).active {
    background: #137AA6;
}

.gallery .tabs .tab:nth-child(3):hover, .gallery .tabs .tab:nth-child(3).active {
    background: #71CAC9;
}

.gallery .tabs .tab:nth-child(4):hover, .gallery .tabs .tab:nth-child(4).active {
    background: #77E0EA;
}

.gallery .tabs .tab span {
    line-height: 40px;
    display: inline-block;
    padding-left: 50px;
    background-repeat: no-repeat;
    background-position: center left;
}

.gallery .tabs .tab:nth-child(2) span {
    background-image: url(../images/IG-fibreglass.png);
}

.gallery .tabs .tab:nth-child(2):hover span, .gallery .tabs .tab:nth-child(2).active span {
    background-image: url(../images/IG-fibreglass-white.png);
}

.gallery .tabs .tab:nth-child(3) span {
    background-image: url(../images/IG-concrete.png);
}

.gallery .tabs .tab:nth-child(3):hover span, .gallery .tabs .tab:nth-child(3).active span {
    background-image: url(../images/IG-concrete-white.png);
}

.gallery .tabs .tab:nth-child(4) span {
    background-image: url(../images/IG-spas.png);
}

.gallery .tabs .tab:nth-child(4):hover span, .gallery .tabs .tab:nth-child(4).active span {
    background-image: url(../images/IG-spas-white.png);
}

.gallery.detail {
    position: relative;
}

.gallery.detail .wrapper {
    z-index: 1;
    position: relative;
}

.gallery.detail .overlay {
    position: absolute;
    top: 0;
    left: 0;
    background: #F1FAFC;
    height: 300px;
}

.gallery.detail .left {
    float: left;
    width: calc(100% - (100% - 150px) / 3 - 60px);
    width: -moz-calc(100% - (100% - 150px) / 3 - 60px);
    width: -webkit-calc(100% - (100% - 150px) / 3 - 60px);
}

.gallery.detail .top .left .main_img {
    border-radius: 10px;
    background-size: cover;
    background-position: center center;
}

.gallery.detail .right {
    float: right;
    width: calc((100% - 150px) / 3 + 30px);
    width: -moz-calc((100% - 150px) / 3 + 30px);
    width: -webkit-calc((100% - 150px) / 3 + 30px);
}

.gallery.detail .top .right .img {
    float: left;
    margin-right: 30px;
    margin-bottom: 30px;
    border-radius: 10px;
    cursor: pointer;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 31px) / 2);
    width: -webkit-calc((100% - 31px) / 2);
    background-size: cover;
    background-position: center center;
}

.gallery.detail .top .right .img:nth-child(2n+2) {
    margin-right: 0;
}

.gallery.detail .top .right .img.active .hover {
    display: none;
    float: left;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.5);
}

.gallery.detail .top .right .img.active .hover {
    display: block;
}

.gallery.detail .tabs {
    margin: 0 0 30px;
}

.gallery.detail .top .left {
    margin-bottom: 30px;
}

.gallery.detail .bottom .left {
    position: relative;
    box-sizing: border-box;
    border-radius: 10px;
    padding: 30px;
    background: #F0F0F0;
    min-height: 245px;
}

.gallery.detail .bottom .left .icon {
    position: absolute;
    top: 10px;
    left: 10px;
}

.gallery.detail .bottom .left .triangle {
    position: absolute;
    top: 0px;
    left: 0px;
    border-top-left-radius: 10px;
}

.gallery.detail .bottom .left h1 {
    font-size: 18px;
    padding-left: 60px;
    margin-bottom: 30px;
}

.gallery.detail .bottom .right {
    box-sizing: border-box;
    border-radius: 10px;
    padding: 30px;
    background: #F0F0F0;
    min-height: 245px;
}

.gallery.detail .bottom .right .button {
    width: 100%;
    margin-right: 0;
}

.gallery.detail .bottom p:first-child {
    margin-top: 0;
}

.gallery.detail .bottom p:last-child {
    margin-bottom: 0;
}

.gallery.detail .bottom p strong {
    letter-spacing: 2px;
}

.contact {
    position: relative;
}

.contact .wrapper {
    z-index: 1;
    position: relative;
}

.contact .overlay {
    position: absolute;
    top: 0;
    left: 0;
    background: #F1FAFC;
    height: 300px;
}

.contact .map {
    height: 500px;
    border-radius: 10px;
    margin-bottom: 30px;
}

.contact .left {
    float: left;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.contact .left .details {
    box-sizing: border-box;
    padding: 30px;
    background: #F0F0F0;
    border-radius: 10px;
}

.contact .left .lft {
    float: left;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.contact .left .rght {
    float: right;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.contact .left p a.green {
    color: #137AA6;
}

.contact .left p:last-child {
    margin-bottom: 0;
}

.contact .left h3 {
    color: #71CAC9;
}

.contact .left .button {
    margin-right: 30px;
    margin-top: 30px;
    line-height: 50px;
    height: 70px;
    width: calc((100% - 31px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.contact .left .button:nth-child(2n+2) {
    margin-right: 0;
}

.contact .left .button.hastable {
    line-height: 16px;
    padding: 0 10px;
}

.contact .left .button.hastable table {
    float: left;
    width: 100%;
    height: 100%;
}

.contact .right {
    float: right;
    box-sizing: border-box;
    padding: 50px;
    background: #F0F0F0;
    border-radius: 10px;
    width: calc((100% - 30px) / 2);
    width: -moz-calc((100% - 30px) / 2);
    width: -webkit-calc((100% - 30px) / 2);
}

.contact .right h3 {
    text-align: center;
    text-transform: uppercase;
    font-size: 16px;
    letter-spacing: 2px;
    font-family: 'AvenirLTStd-Heavy';
}

.contact .right input[type="text"] {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
    background: #fff;
    color: #4E4E4E;
    border: 0;
    border-radius: 5px !important;
    padding: 10px;
    height: 50px;
    box-sizing: border-box;
    font-size: 14px;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.contact .right input[type="text"]:nth-child(2n+2) {
    margin-right: 0;
}

.contact .right textarea {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
    background: #fff;
    color: #4E4E4E;
    border: 0;
    border-radius: 5px !important;
    padding: 10px;
    height: 152px;
    box-sizing: border-box;
    font-size: 14px;
    width: 100%;
}

.contact .right .button {
    float: left;
    width: calc((100% - 11px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
}

.contact .right input[type="submit"] {
    float: right;
    margin-right: 0;
    border-radius: 10px !important;
    background-image: url(../images/submit-grey.png);
}

.quote {
    text-align: center;
}

.quote h1 {
    margin-bottom: 60px;
}

.quote .form {
    float: left;
    margin-right: 30px;
    box-sizing: border-box;
    background: #F0F0F0;
    padding: 50px;
    border-radius: 10px;
    width: calc((100% - 61px) / 3);
    width: -moz-calc((100% - 61px) / 3);
    width: -webkit-calc((100% - 61px) / 3);
}

.quote .form:nth-child(3n+3) {
    margin-right: 0;
}

.quote .form .button {
    width: 100%;
    margin-right: 0;
}

.quote .form h3 {
    text-transform: uppercase;
    letter-spacing: 2px;
    font-family: 'AvenirLTStd-Black';
    font-size: 14px;
}

.quote .form input[type="text"] {
    float: left;
    width: 100%;
    background: #fff;
    padding: 10px;
    border: 0;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 5px !important;
    margin-bottom: 10px;
    line-height: 30px;
    color: #4e4e4e;
    box-sizing: border-box;
}

.quote .form textarea {
    float: left;
    width: 100%;
    background: #fff;
    padding: 10px;
    border: 0;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 5px !important;
    margin-bottom: 10px;
    height: 300px;
    color: #4e4e4e;
    box-sizing: border-box;
}

.quote .form .line {
    float: left;
    width: 100%;
    height: 1px;
    background: #77E0EA;
    margin-bottom: 10px;
}

.quote .form .button {
    margin-bottom: 10px;
}

.quote .form input[type="submit"] {
    margin-bottom: 0px;
    background-image: url(../images/submit-grey.png);
    border-radius: 10px !important;
}

.book {
    text-align: center;
}

.book h1 {
    margin-bottom: 60px;
}

.book .form {
    float: left;
    margin-right: 30px;
    box-sizing: border-box;
    background: #F0F0F0;
    padding: 50px;
    border-radius: 10px;
    width: 100%;
}

.book .form .button {
    width: calc((100% - 10px) / 2);
    margin-right: 10px;
}

.book .form .button:nth-child(2) {
    margin-right: 0px;
}

.book .form h3 {
    text-transform: uppercase;
    letter-spacing: 2px;
    font-family: 'AvenirLTStd-Black';
    font-size: 14px;
}

.book .form input[type="text"] {
    margin-right: 10px;
    float: left;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
    background: #fff;
    padding: 10px;
    border: 0;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 5px !important;
    margin-bottom: 10px;
    line-height: 30px;
    color: #4e4e4e;
    box-sizing: border-box;
}

.book .form input[type="text"]:nth-child(2n+2) {
    margin-right: 0px;
}

.book .form textarea {
    float: left;
    width: 100%;
    background: #fff;
    padding: 10px;
    border: 0;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 5px !important;
    margin-bottom: 10px;
    height: 300px;
    color: #4e4e4e;
    box-sizing: border-box;
}

.book .form .line {
    float: left;
    width: 100%;
    height: 1px;
    background: #77E0EA;
    margin-bottom: 10px;
}

.book .form .button {
    margin-bottom: 10px;
}

.book .form input[type="submit"] {
    margin-bottom: 0px;
    background-image: url(../images/submit-grey.png);
    border-radius: 10px !important;
    margin-right: 0;
}

.four {
    position: relative;
    text-align: center;
    min-height: 300px;
    height: calc(100% - 114px);
    height: -moz-calc(100% - 114px);
    height: -webkit-calc(100% - 114px);
}

.four .wrapper {
    height: 100%;
    position: relative;
}

.four .button {
    margin-left: calc((100% - 200px) / 2);
    margin-left: -moz-calc((100% - 200px) / 2);
    margin-left: -webkit-calc((100% - 200px) / 2);
}

.four table {
    float: left;
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
}

.four .overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    float: left;
    background: rgba(119, 224, 234, 0.6);
}

.four h1 {
    color: #4e4e4e;
}

.four p {
    font-family: 'AvenirLTStd-Heavy';
}

::-webkit-input-placeholder { /* WebKit browsers */
    color: #4E4E4E !important;
    font-family: 'AvenirLTStd-Medium';
}

:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    color: #4E4E4E !important;
    opacity: 1;
    font-family: 'AvenirLTStd-Medium';
}

::-moz-placeholder { /* Mozilla Firefox 19+ */
    color: #4E4E4E !important;
    opacity: 1;
    font-family: 'AvenirLTStd-Medium';
}

:-ms-input-placeholder { /* Internet Explorer 10+ */
    color: #4E4E4E !important;
    font-family: 'AvenirLTStd-Medium';
}

.bluesubmit {
    background: url(../images/submit-blue.png) !important;
}

.popover.brochure .poptext .head .ttl {
    font-size: 19px;
}

.popover.brochure input[type="text"] {
    margin-right: 10px;
    float: left;
    width: calc((100% - 10px) / 2);
    width: -moz-calc((100% - 10px) / 2);
    width: -webkit-calc((100% - 10px) / 2);
    background: #fff;
    padding: 10px;
    border: 0;
    font-family: 'AvenirLTStd-Medium';
    border-radius: 5px !important;
    margin-bottom: 10px;
    line-height: 30px;
    color: #4e4e4e;
    box-sizing: border-box;
}

.popover.brochure input[type="text"]:nth-child(3n+3) {
    margin-right: 0px;
}

.popover.brochure input[type="submit"] {
    margin-bottom: 0px;
    background-image: url(../images/submit-grey.png);
    border-radius: 10px !important;
    margin-right: 0;
}

.popover.brochure .left {
    width: 48%;
    float: left;
}

.popover.brochure .poptext .body .button {
    margin-top: 0px;
    margin-left: 15px;
    cursor: pointer;
    padding: 10px;
    text-decoration: none;
    text-transform: uppercase;
    width: 219px;
    color: #fff;
    float: left;
    margin-right: 0px;
    font-size: 12px;
    text-align: center;
    background: #71CAC9;
    font-family: 'AvenirLTStd-Medium';
    border: none;
    box-sizing: border-box;
    border-radius: 10px;
    line-height: 35px;
    font-weight: 400;
    letter-spacing: 3px;
}

.popover.brochure #captcha5 {
    float: left;
    transform: scale(0.75);
    -webkit-transform: scale(0.75);
    -moz-transform: scale(0.75);
    -moz-transform-origin: top left;
    transform-origin: top left;
    -webkit-transform-origin: top left;
}

/*popovers*/
.popover {
    background: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 6;
    display: none;
}

.popover .poptext {
    width: 700px;
    box-sizing: border-box;
    margin-top: 200px;
    padding: 80px 120px;
    position: relative;
    z-index: 7;
    float: left;
    background: #F0F0F0;
    border-radius: 10px;
    margin-left: calc((100% - 700px) / 2);
    margin-left: -moz-calc((100% - 700px) / 2);
    margin-left: -webkit-calc((100% - 700px) / 2);
}

.popover .poptext .head {
    float: left;
    width: 100%;
}

.popover .poptext .head .ttl {
    float: left;
    text-align: center;
    width: 100%;
    margin-bottom: 20px;
    color: #137AA6;
    font-size: 24px;
    letter-spacing: 1px;
    font-family: 'AvenirLTStd-Heavy';
    text-transform: uppercase;
}

.popover .poptext .head .ttl span {
    font-weight: 300;
}

.popover .poptext .head .close {
    position: absolute;
    right: -25px;
    top: -25px;
    cursor: pointer;
}

.popover .poptext .head .close img {
    width: 50px;
}

.popover .poptext .body {
    float: left;
    width: 100%;
}

.popover .poptext .body p {
    text-align: center;
    font-size: 14px;
    color: #137AA6;
}

.popover .poptext .body .button {
    width: 250px;
    margin-top: 20px;
    margin-left: calc((100% - 250px) / 2);
    margin-left: -moz-calc((100% - 250px) / 2);
    margin-left: -webkit-calc((100% - 250px) / 2);
}

.popover.hasvideo .poptext {
    padding: 0;
}

.footer {
    background: #F0F0F0;
    font-size: 15px;
    color: #fff;
    padding: 30px 0;
}

.footer .top {
    padding: 80px 0;
    position: relative;
}

.footer .top h3 {
    text-transform: uppercase;
    font-size: 16px;
}

.footer .top .left {
    float: left;
    width: 320px;
}

.footer .top .left img {
    width: 100px;
    float: left;
    margin-bottom: 40px;
}

.footer .top .left p {
    clear: left;
    color: #137AA6;
    font-family: 'AvenirLTStd-Medium';
}

.footer .top .left p a {
    color: #71CAC9;
    letter-spacing: 2px;
    font-family: 'AvenirLTStd-Black';
}

.footer .top .right {
    float: right;
    width: 700px;
}

.footer .top .right .lft {
    float: left;
    width: 360px;
}

.footer .top .right .lft a {
    float: left;
    width: 160px;
    margin-right: 20px;
    color: #137AA6;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 14px;
    margin-bottom: 10px;
}

.footer .top .right .rght {
    float: right;
}

.footer .top .right .rght .social img {
    margin-right: 10px;
    width: 50px;
}

.footer .top .right .rght .social a:last-child img {
    margin-right: 0px;
}

.footer .top .buttons {
    position: absolute;
    bottom: 20px;
    right: 0;
}

.footer .top .buttons img {
    float: left;
    cursor: pointer;
}

.footer .top .buttons a img {
    margin-right: 10px;
}

.footer .bottom {
    color: #6D787F;
    font-family: 'AvenirLTStd-Heavy';
    border-top: 1px solid #6D787F;
    padding-top: 30px;
}

.footer .bottom .left {
    float: left;
    line-height: 25px;
}

.footer .bottom .left .copy {
    float: left;
}

.footer .bottom .left .copy a {
    color: #6D787F;
    text-transform: uppercase;
    text-decoration: none;
}

.footer .bottom .left .copy .spacer {
    margin: 0 10px;
}

.footer .bottom .right {
    float: right;
}

/*responsive*/
@media (max-height: 900px) {
    .slideout.right .close {
        top: 40px;
    }

    .popover .poptext {
        margin-top: 100px;
    }
}

@media (max-width: 1250px) {
    .wrapper {
        width: 100% !important;
        box-sizing: border-box;
        padding: 0 4%;
    }

    .hasline .line {
        width: 76%;
        margin: 0 12%;
    }

    .heating .line {
        margin: 80px 12%;
    }

    .home.blog .box {
        margin-right: 40px;
        width: calc((100% - 81px) / 3);
        width: -moz-calc((100% - 81px) / 3);
        width: -webkit-calc((100% - 81px) / 3);
    }

    .footer .top .right {
        width: 610px;
    }

    .slideout {
        width: 100%;
    }

    .slideout .close {
        right: 40px;
        top: 40px;
    }

    .slideout.left .close {
        left: 40px;
        top: 40px;
    }

    .inner.banner {
        height: 500px;
    }

    .inner.banner .circles {
        height: 450px;
    }

    .products.detail h1 {
        width: 100%;
        margin-bottom: 10px;
    }

    .products.detail .selector {
        float: left;
        margin-bottom: 80px;
    }

    .contact .left .lft {
        width: 100%;
    }

    .contact .left .rght {
        width: 100%;
        margin-top: 20px;
    }
}

@media (max-width: 1150px) {
    .quote .form {
        padding: 30px;
    }
}

@media (max-width: 1100px) {
    .gallery .tabs .tab {
        margin-right: 10px;
        width: calc((100% - 31px) / 4);
        width: -moz-calc((100% - 30px) / 4);
        width: -webkit-calc((100% - 30px) / 4);
    }
}

@media (max-width: 1050px) {
    .footer .top .right {
        width: 595px;
    }

    .footer .top .right .lft a {
        width: 155px;
    }

    .footer .top .right .lft {
        width: 350px;
    }
}

@media (max-width: 1024px) {
    .home.imgtext .right .content {
        width: 100%;
        margin-right: 0;
    }

    .home.imgtext .left .content {
        width: 100%;
        margin-left: 0;
    }

    .slider .nav {
        display: none !important;
    }

    .contact .map {
        height: 400px;
    }

    .locator .box:hover .img table:last-child {
        display: none;
    }

    .slideout.left .box:hover .img table:last-child {
        display: none;
    }

    .home.products .box:hover .img table:last-child {
        display: none;
    }

    .categories.products .box:hover .img table:last-child {
        display: none;
    }

    .products.list .box:hover .img table:last-child {
        display: none;
    }

    .promos .text .nav img:hover {
        background: none;
        border-radius: 0;
    }

    .heating .box:hover .img table:last-child {
        display: none;
    }

    .maintenance .box:hover .img table:last-child {
        display: none;
    }

    .locator .box:hover .img table:last-child {
        display: none;
    }

    .locator .box .img table:last-child {
        width: 100%;
        height: 100%;
    }

    .locator .box.open .img table:last-child {
        display: table !important;
    }
}

@media (max-width: 1023px) {
    .home.banner .overlay {
        display: block;
    }

    .home.banner p {
        color: #fff;
    }

    #head .menu.left {
        display: none;
    }

    .slideout.left {
        display: none;
    }

    #head .logo {
        text-align: left;
    }

    .home.health .left {
        display: none;
    }

    .home.health .right {
        width: 100%;
    }

    .padding120 {
        padding: 40px 0;
    }

    .padding80 {
        padding: 40px 0;
    }

    .home.testimonials {
        margin-bottom: 40px;
    }

    .home.health {
        padding-bottom: 0;
    }

    .home.imgtext .text {
        padding: 40px;
    }

    .home.imgtext .text h3 {
        margin-bottom: 40px;
    }

    #head.inner .logo {
        width: auto;
    }

    #head.inner .button {
        display: none;
    }

    .home.threesections .page {
        padding: 40px;
    }

    .home.products .box {
        width: calc((100% - 31px) / 2);
        width: -moz-calc((100% - 30px) / 2);
        width: -webkit-calc((100% - 30px) / 2);
    }

    .home.products .box:nth-child(2n+2) {
        margin-right: 0;
    }

    .home.inspiration .box .text {
        padding: 20px;
    }

    .home.inspiration h2 {
        margin-bottom: 65px;
    }

    .home.blog .box {
        width: 100%;
        margin-right: 0;
    }

    .subscribe {
        padding: 40px 0;
    }

    .footer .top .right .lft {
        display: none;
    }

    .footer .top .right {
        width: auto;
    }

    .footer .top {
        padding: 40px 0 80px;
    }

    .footer .bottom {
        text-align: center;
    }

    .footer .bottom .left {
        width: 100%;
    }

    .footer .bottom .left .copy {
        width: 100%;
    }

    .footer .bottom .right {
        width: 100%;
        margin-top: 10px;
    }

    .inner.banner .circles {
        display: none;
    }

    #head.inner {
        padding: 33px 0;
    }

    .about .cover {
        margin-bottom: 40px;
    }

    .about .images {
        margin: 40px 0;
    }

    .categories.products h1 {
        margin-bottom: 20px;
    }

    .categories.products .box {
        width: calc((100% - 61px) / 3);
        width: -moz-calc((100% - 61px) / 3);
        width: -webkit-calc((100% - 61px) / 3);
    }

    .categories.products .box:nth-child(4n+4) {
        margin-right: 30px;
    }

    .categories.products .box:nth-child(3n+3) {
        margin-right: 0;
    }

    .categories.products .box:nth-child(4n+1) {
        clear: none;
    }

    .categories.products .box:nth-child(3n+1) {
        clear: left;
    }

    .categories.products .left.img {
        width: 100%;
        margin-bottom: 10px;
    }

    .categories.products .right {
        width: 100%;
        padding: 30px;
    }

    .products.list .box {
        width: calc((100% - 61px) / 3);
        width: -moz-calc((100% - 61px) / 3);
        width: -webkit-calc((100% - 61px) / 3);
    }

    .products.list .box:nth-child(4n+4) {
        margin-right: 30px;
    }

    .products.list .box:nth-child(3n+3) {
        margin-right: 0;
    }

    .products.list .box:nth-child(4n+1) {
        clear: none;
    }

    .products.list .box:nth-child(3n+1) {
        clear: left;
    }

    .products.list .left.img {
        width: 100%;
        margin-bottom: 30px;
    }

    .products.list .right {
        width: 100%;
    }

    .products.list .nav {
        display: none;
    }

    .heating .box {
        width: calc((100% - 61px) / 3);
        width: -moz-calc((100% - 61px) / 3);
        width: -webkit-calc((100% - 61px) / 3);
    }

    .heating .box:nth-child(4n+4) {
        margin-right: 30px;
    }

    .heating .box:nth-child(3n+3) {
        margin-right: 0;
    }

    .heating .box:nth-child(4n+1) {
        clear: none;
    }

    .heating .box:nth-child(3n+1) {
        clear: left;
    }

    .ctas .button {
        width: 100%;
        margin-bottom: 10px;
        margin-right: 0;
    }

    .ctas .button:last-child {
        margin-bottom: 0px;
    }

    .products.detail .selector {
        margin-bottom: 40px;
    }

    .products.detail .threeboxes .box.fixedheight {
        width: 100%;
        height: auto !important;
    }

    .products.detail .threeboxes .box {
        width: 100%;
    }

    .products.detail .textbox .threecolumns {
        -webkit-columns: 1;
        -moz-columns: 1;
        columns: 1;
    }

    .products.detail .textbox .threecolumns ul:last-child, .products.detail .textbox .threecolumns p:last-child {
        margin-bottom: 0;
    }

    .promos .img {
        width: 100%;
        border-radius: 10px;
        margin-bottom: 10px;
        text-align: center;
        height: auto !important;
    }

    .promos .text {
        width: 100%;
        border-radius: 10px;
    }

    .products.detail .enquiry .left {
        width: 100%;
        margin-bottom: 10px;
        height: auto !important;
    }

    .products.detail .enquiry .right {
        width: 100%;
        height: auto !important;
    }

    .products.detail {
        padding: 40px 0 10px;
    }

    .pools .tabs {
        margin: 20px 0 40px;
    }

    .pools .tabs .tab {
        width: 100%;
        margin-right: 0;
    }

    .pools .tabs .tab:last-child {
        margin-top: 30px;
    }

    .pools .tabs .tab .text {
        height: auto !important;
    }

    .pools img.container {
        margin-bottom: 40px;
    }

    .pools .threetabs .tab {
        width: 100%;
        margin-right: 0;
        margin-bottom: 10px;
        height: auto !important;
    }

    .pools .threetabs {
        margin: 40px 0;
    }

    .heating .line {
        margin: 40px 12%;
    }

    .heating .forms .left {
        width: 100%;
        margin-bottom: 30px;
        padding: 30px;
    }

    .heating .forms .right {
        width: 100%;
        padding: 30px;
    }

    .heating .forms h3 {
        height: auto;
    }

    .maintenance .box {
        width: calc((100% - 61px) / 3);
        width: -moz-calc((100% - 61px) / 3);
        width: -webkit-calc((100% - 61px) / 3);
    }

    .maintenance .box:nth-child(5n+5) {
        margin-right: 30px;
    }

    .maintenance .box:nth-child(5n+1) {
        clear: none;
    }

    .maintenance .box:nth-child(3n+3) {
        margin-right: 0px;
    }

    .maintenance .box:nth-child(3n+1) {
        clear: left;
    }

    .commercial .threecolumns {
        -webkit-columns: 1;
        -moz-columns: 1;
        columns: 1;
    }

    .blog.list .box {
        width: calc((100% - 41px) / 2);
        width: -moz-calc((100% - 40px) / 2);
        width: -webkit-calc((100% - 40px) / 2);
    }

    .blog.list .box:nth-child(2n+2) {
        margin-right: 0;
    }

    .blog.detail .img {
        margin-bottom: 40px;
    }

    .gallery .tabs {
        margin: 0 0 65px;
    }

    .gallery .tabs .tab {
        margin-top: 10px;
        width: calc((100% - 11px) / 2);
        width: -moz-calc((100% - 10px) / 2);
        width: -webkit-calc((100% - 10px) / 2);
    }

    .gallery .tabs .tab:nth-child(2n+2) {
        margin-right: 0;
    }

    .gallery.list .box .text {
        padding: 20px;
    }

    .gallery.detail .bottom .left {
        width: 100%;
        margin-bottom: 30px;
    }

    .gallery.detail .bottom .right {
        width: 100%;
        height: auto !important;
    }

    .gallery.detail .left {
        width: calc(100% - (100% - 50px) / 3 - 20px);
        width: -moz-calc(100% - (100% - 50px) / 3 - 20px);
        width: -webkit-calc(100% - (100% - 50px) / 3 - 20px);
    }

    .gallery.detail .right {
        width: calc((100% - 50px) / 3 + 10px);
        width: -moz-calc((100% - 50px) / 3 + 10px);
        width: -webkit-calc((100% - 50px) / 3 + 10px);
    }

    .gallery.detail .top .right .img {
        margin-right: 10px;
        margin-bottom: 10px;
        width: calc((100% - 11px) / 2);
        width: -moz-calc((100% - 11px) / 2);
        width: -webkit-calc((100% - 11px) / 2);
    }

    .gallery.detail .top {
        margin-bottom: 20px;
    }

    .faq .left.img {
        width: 100%;
        margin-bottom: 10px;
    }

    .faq .right {
        width: 100%;
        padding: 30px;
    }

    .quote .form {
        width: 100%;
        margin-right: 0;
        margin-top: 10px;
        height: auto !important;
    }

    .quote h1 {
        margin-bottom: 30px;
    }

    .contact .left {
        width: 100%;
    }

    .contact .right {
        width: 100%;
        padding: 30px;
        margin-top: 30px;
    }

    .contact .left .lft {
        width: calc((100% - 30px) / 2);
        width: -moz-calc((100% - 30px) / 2);
        width: -webkit-calc((100% - 30px) / 2);
    }

    .contact .left .rght {
        margin-top: 0;
        width: calc((100% - 30px) / 2);
        width: -moz-calc((100% - 30px) / 2);
        width: -webkit-calc((100% - 30px) / 2);
    }

    .faq .questions {
        margin-top: 20px;
    }

    .locator .left {
        padding: 30px;
        width: 100%;
        margin-bottom: 30px;
    }

    .locator .right {
        width: 100%;
    }

    .locator h1 {
        margin-bottom: 40px;
    }

    .locator .box {
        width: calc((100% - 62px) / 3);
        width: -moz-calc((100% - 61px) / 3);
        width: -webkit-calc((100% - 61px) / 3);
    }

    .locator .box:nth-child(5n+5) {
        margin-right: 30px;
    }

    .locator .box:nth-child(5n+1) {
        clear: none;
    }

    .locator .box:nth-child(3n+3) {
        margin-right: 0px;
    }

    .locator .box:nth-child(3n+1) {
        clear: left;
    }
}

@media (max-width: 800px) {
    .home.banner .circles {
        height: auto;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .inner.banner {
        height: 350px;
    }
}

@media (max-width: 767px) {

    /* .promos .text .nav{width:100%;}
  .promos .text .nav img:first-child {float:left;margin:0;}
  .promos .text .nav img:last-child {float:right;margin;0;} */
    .footer .top .buttons {
        right: calc((100% - 112px) / 2);
    }

    .blog.detail .button.blue {
        margin-top: 10px;
    }

    .home.imgtext .left h3 {
        text-align: left;
    }

    .home.imgtext .left .content {
        float: left;
        width: 100%;
        margin-left: 0%;
        text-align: left;
    }

    .home.imgtext .right .content {
        float: left;
        width: 100%;
        margin-right: 0%;
        text-align: left;
    }

    .home.imgtext .left .line {
        margin-left: 0px;
    }

    #head {
        top: 20px;
    }

    .home.banner table {
        width: 100%;
    }

    .home.banner .line {
        display: none;
    }

    .home.banner h1 {
        color: #fff;
    }

    .home.banner .button {
        margin-right: 0;
        width: 100%;
        margin-bottom: 10px;
    }

    .home.banner table {
        margin-top: 52px;
        height: calc(100% - 52px);
        height: -moz-calc(100% - 52px);
        height: -webkit-calc(100% - 52px);
    }

    .home.banner h2 {
        color: #fff;
    }

    .home.health .right .button {
        width: 100%;
        margin-right: 0;
        margin-bottom: 10px;
    }

    .home.health .right .button:last-child {
        margin-bottom: 0px;
    }

    .home.imgtext .left {
        width: 100%;
    }

    .home.imgtext .right {
        width: 100%;
    }

    .home.imgtext .img {
        height: 300px !important;
    }

    .home.imgtext .text {
        padding: 30px;
    }

    .home.threesections .tab {
        width: 100%;
        border-radius: 5px;
        border-right: 1px solid #87ECF1;
        margin-bottom: 10px;
    }

    .home.threesections .tab:last-child {
        margin-bottom: 0px;
    }

    .home.threesections .button {
        width: 100%;
        margin-right: 0;
        margin-bottom: 10px;
    }

    .home.threesections .button:last-child {
        margin-bottom: 0px;
    }

    .home.products .box {
        width: 100%;
        margin-right: 0;
    }

    .home.inspiration .box {
        width: 100%;
        margin-right: 0;
    }

    .home.inspiration .buttons .button {
        width: 100%;
        margin-right: 0;
    }

    .home.inspiration .buttons .button:first-child {
        margin-left: 0;
        margin-bottom: 10px;
    }

    .subscribe .text {
        width: 100%;
        text-align: center;
        margin-bottom: 20px;
    }

    .subscribe input[type="text"] {
        width: 100%;
        margin-left: 0;
        margin-bottom: 10px;
        border-radius: 5px !important;
    }

    .subscribe input[type="submit"] {
        width: 100%;
        border-radius: 5px !important;
    }

    .footer .top {
        text-align: center;
    }

    .footer .top .left {
        width: 100%;
    }

    .footer .top .right {
        width: 100%;
    }

    .footer .top .left img {
        float: none;
        margin: 0;
    }

    .footer .top .right .rght {
        width: 100%;
    }

    .footer .bottom .left .copy span {
        float: left;
        width: 100%;
    }

    .footer .bottom .left .copy a {
        float: left;
        width: 100%;
    }

    .footer .bottom .left .copy .spacer {
        display: none;
    }

    .inner.banner table {
        width: 100%;
    }

    .inner.banner {
        padding: 40px 0 20px;
        height: auto;
    }

    .about .images .img {
        width: 100%;
        margin-right: 0;
    }

    .about .images .img:last-child {
        margin-top: 10px;
    }

    .about .button {
        width: 100%;
        margin-right: 0;
    }

    .about .button:last-child {
        margin-top: 10px;
    }

    .about .work .img {
        display: none;
    }

    .about .work .text {
        width: 100%;
    }

    .categories.products .box {
        width: 100%;
        margin-right: 0 !important;
    }

    .categories.products .right {
        padding: 30px;
    }

    .categories.products .right input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .categories.products .right select {
        width: 100%;
    }

    .products.list .box {
        width: 100%;
        margin-right: 0 !important;
    }

    .heating .box {
        width: 100%;
        margin-right: 0 !important;
    }

    .products.detail .threeboxes .hasgallery .mini {
        margin-right: 10px;
        margin-top: 10px;
        width: calc((100% - 21px) / 3);
        width: -moz-calc((100% - 21px) / 3);
        width: -webkit-calc((100% - 21px) / 3);
    }

    .products.detail .enquiry .right input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .products.detail .enquiry .right {
        padding: 30px;
    }

    .products.detail .enquiry .right .button {
        width: 100%;
    }

    .products.detail .enquiry .right input[type="submit"] {
        margin-top: 10px;
    }

    .promos .text .button {
        width: 100%;
        margin-right: 0;
    }

    .promos .text .nav {
        margin-top: 10px;
    }

    .products.detail h1 {
        text-align: center;
    }

    .products.detail .selector {
        width: 100%;
    }

    .products.detail .selector select {
        width: calc(100% - 108px);
        width: -moz-calc(100% - 108px);
        width: -webkit-calc(100% - 108px);
    }

    .pools .tabs .tab .number {
        width: 50px;
        font-size: 32px;
    }

    .pools .tabs .tab .text {
        width: calc(100% - 50px);
        width: -moz-calc(100% - 50px);
        width: -webkit-calc(100% - 50px);
    }

    .heating .forms input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .heating .forms select {
        width: 100%;
        margin-right: 0;
    }

    .heating .forms .left .button {
        width: 100%;
        margin-right: 0;
    }

    .heating .forms .left input[type="submit"] {
        margin-top: 10px;
    }

    .maintenance .box {
        width: calc((100% - 30px) / 2);
        width: -moz-calc((100% - 30px) / 2);
        width: -webkit-calc((100% - 30px) / 2);
    }

    .maintenance .box:nth-child(3n+3) {
        margin-right: 30px;
    }

    .maintenance .box:nth-child(3n+1) {
        clear: none;
    }

    .maintenance .box:nth-child(2n+2) {
        margin-right: 0px;
    }

    .maintenance .box:nth-child(2n+1) {
        clear: left;
    }

    .blog.list .box {
        width: 100%;
        margin-right: 0;
    }

    .blog.featured .img {
        height: auto !important;
    }

    .blog.featured .title {
        position: relative;
        left: 0;
        bottom: 0;
        padding: 20px;
        box-sizing: border-box;
        background: rgba(0, 0, 0, 0.2);
        border-radius: 10px;
    }

    .blog.featured .img .shade {
        display: none;
    }

    .blog.detail .button {
        width: 100%;
        margin-right: 0;
    }

    .gallery .tabs .tab {
        margin-right: 0px;
        width: 100%;
    }

    .gallery.list .box {
        width: 100%;
        margin-right: 0px;
    }

    .faq .right {
        padding: 30px;
    }

    .faq .right input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .faq .right select {
        width: 100%;
    }

    .contact .left .lft {
        width: 100%;
    }

    .contact .left .rght {
        width: 100%;
        margin-top: 20px;
    }

    .contact .left .button {
        width: 100%;
        margin-right: 0;
    }

    .contact .map {
        height: 300px;
    }

    .contact .right input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .contact .right .button {
        width: 100%;
        margin-right: 0;
    }

    .contact .right input[type="submit"] {
        margin-top: 10px;
    }

    .slideout .close {
        right: 10px;
        top: 30px;
    }

    .slideout.right .close {
        top: 30px;
    }

    .slideout .close span {
        display: none;
    }

    .slideout .close .line:first-child {
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    .slideout .close .line:last-child {
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }

    .popover .poptext {
        margin: 0;
        width: 100%;
        height: 100%;
        overflow: auto;
        border-radius: 0;
        padding: 80px 40px;
    }

    .popover.brochure .poptext .body .button {
        width: calc(50% - 2px);
    }

    .popover.brochure #captcha5 {
        transform: scale(0.75);
        -webkit-transform: scale(0.75);
        -moz-transform: scale(0.75);
        -moz-transform-origin: top left;
        transform-origin: top left;
        -webkit-transform-origin: top left;
    }

    .popover .poptext .head .close {
        top: 10px;
        right: 10px;
    }

    .locator .left input[type="text"] {
        width: 100%;
        margin-right: 0;
    }

    .locator .left select {
        width: 100%;
        margin-right: 0;
    }

    .locator .box {
        width: calc((100% - 31px) / 2);
        width: -moz-calc((100% - 30px) / 2);
        width: -webkit-calc((100% - 30px) / 2);
    }

    .locator .box:nth-child(3n+3) {
        margin-right: 30px;
    }

    .locator .box:nth-child(3n+1) {
        clear: none;
    }

    .locator .box:nth-child(2n+2) {
        margin-right: 0px;
    }

    .locator .box:nth-child(2n+1) {
        clear: left;
    }

    .slideout {
        min-height: 650px;
    }

    .slideout table li a {
        line-height: 34px;
    }
}

@media (max-width: 420px) {
    .home.banner h2 {
        font-size: 12px;
        text-align: center;
        letter-spacing: 3px;
        margin-top: 5px;
    }

    #head.inner {
        position: absolute;
        top: 0;
        left: 0;
    }

    .popover {
        position: absolute;
    }

    .home.banner {
        background-position: 75% 50%;
    }

    .popover.brochure input[type="text"] {
        width: 100%;
        margin: 0;
        margin-top: 15px;
    }

    .popover.brochure .left {
        margin-top: 15px;
    }

    .popover.brochure #captcha5 {
        transform: scale(1.05);
        -webkit-transform: scale(1.05);
        -moz-transform: scale(1.05);
    }

    .popover.brochure .poptext .body .button {
        width: 100%;
        margin-top: 15px;
        margin-left: 0;
    }

    .home.imgtext .img.efficient {
        background-position: 100% 50%;
    }
}

@media (max-width: 400px) {
    .products.detail .selector .label {
        display: none;
    }

    .products.detail .selector select {
        width: 100%;
    }
}

@media (max-width: 375px) {
    .popover.brochure #captcha5 {
        transform: scale(.75);
        -webkit-transform: scale(.75);
        -moz-transform: scale(.75);
    }
}

@media (max-width: 350px) {
    .slideout table .social img {
        margin-right: 5px;
        width: 40px;
    }

    #head .logo img {
        width: 180px;
    }
}

@media (max-width: 320px) {
    .home.banner {
        padding-bottom: 10px;
    }

    .home.banner h2 {
        font-size: 11px;
    }
}