body {
font-family: 'josefin sans';
font-weight: 300;
line-height: 1.5;
color: #666;
}
h1 {
font-size: 50px;
}
h2 {
font-size: 45px;
}
a {
text-decoration:none;
transition:0.3s;
color:inherit;
}
header {
height: 129px;
}
.centre {
text-align: center;
}
.small {
font-size:18px;
}
.medium {
font-size:22px;
}
.large {
font-size:32px;
}
.x-large {
font-size:45px;
}
.blk {
padding: 80px 0;
text-align:center;
}
.hl-blk {
padding: 150px 0;
text-align:center;
}
.fixed {
background-size:cover;
background-attachment:fixed;
}
.inner {
width:50%;
margin: 0 25%;
}
.services-section {
  position: relative;
  background: linear-gradient(180deg, #97c23a 0%, #8dbb34 100%);
  padding: 140px 20px 80px;
  overflow: hidden;
}

.services-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -120px;                  /* move it above the section */
  transform: translateX(-50%);
  width: 140%;
  height: 180px;
  background: #ececec;          /* colour above */
  border-radius: 0 0 50% 50% / 0 0 100% 100%;
  z-index: 0;
}

.services-section .inner {
  position: relative;
  z-index: 1;
}
.dkgrey-bk {
background: #332a29;
}
.green-back {
background: linear-gradient(180deg, #8FBF3F 0%, #7AA832 100%);
}
.ltgreen-back {
background: #c2d28f;
}
.hl-back {
background-image: url(/sites/default/files/highlight.jpg);
background-size:cover;
}
.no-webp .firewood-back {
background-image: url(/sites/default/files/firewood-intro.jpg);
}
.webp .firewood-back {
background-image: url(/sites/default/files/firewood-intro.webp);
}
.rural-back {
background-image: url(/sites/default/files/rural-intro.jpg);
}
.no-webp .con-back {
background-image: url(/sites/default/files/construction-intro.jpg);
}
.webp .con-back {
background-image: url(/sites/default/files/construction-intro.webp);
}
.no-webp .plant-back {
background-image: url(/sites/default/files/plant-hire-intro.jpg);
}
.webp .plant-back{
background-image: url(/sites/default/files/plant-hire-intro.webp);
}
.white {
color:white;
}
.green {
color:#a0cc3a;
}
.black {
color:black;
}
.form-item input,
.form-item select,
.form-item textarea {
background: #a0cd3a2e;
border: 0;
color: #666;
padding: 10px 0;
margin: 10px 0;
width: 500px;
}
.block-postfooter {
background: #666;
padding: 5px 0;
}
.footerlinks {
width: 900px;
margin: 2% auto;
}
.footerlinks a {
padding: 0 20px;
transition: 0.3s;
}
.footerlinks a:hover,
.jpfoot a:hover{
color:#a0cc3a;
}
.checkboxes {
text-align: left;
}
.checkboxes svg{
	height:20px;
margin-right:10px;
fill:black;
}
.seperator {
margin-bottom: -8px;
}
.seperator path {
fill: #8ebe3f;
    stroke: #8dbc3e;
}
.block-footer svg{
margin: 0 25px;
transition: 0.5s;
}
.block-footer svg:hover{
fill:white;
}
.mobilemenu svg {
color: #a0cc3a;
transition: 0.5s;
}
.mobilemenu svg:hover{
color: #332a29;
}
.button,
form input.form-submit {
display: inline-block;
padding: 20px 30px;
text-align: center;
position: relative;
z-index: 1;
font-weight:500;
border-radius: 40px;
}
.button--antiman {
background: none;
border: none;
font-size: 18px;
color: white;
}
.button--inverted {
transition: color 0.3s;
transition-timing-function: cubic-bezier(0.75,0,0.125,1);
}
.button--inverted::before {
border-color: #a0cc3a;
}
.button--antiman::before {
border: 2px solid #a0cc3a;
opacity: 0;
transform: scale3d(1.2,1.2,1);
}
form input.form-submit {
border: 2px solid #a0cc3a;
}
.button--antiman::before,
.button--antiman::after,
form input.form-submit::before,
form input.form-submit::after {
content: '';
z-index: -1;
border-radius: inherit;
pointer-events: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
transition: transform 0.3s,opacity 0.3s;
transition-timing-function: cubic-bezier(0.75,0,0.125,1);
}
.button--inverted::after,
form input.form-submit {
background: #a0cc3a;
}
.button--inverted:hover,
form input.form-submit:hover {
color: #a0cc3a;
cursor: pointer;
}
.button--antiman:hover::before,
form input.form-submit:hover::before {
opacity: 1;
transform: scale3d(1,1,1);
}
.button--antiman:hover::after,
form input.form-submit:hover::after {
opacity: 0;
transform: scale3d(0.8,0.8,1);
}
form input.form-submit:hover {
background:none;
}
.logobottom {
font-size: 26px;
line-height: 0;
}
.logotop {
font-size: 40px;
line-height: 0;
}
.block-highlight .logotop {
font-size: 55px;
}
.block-highlight .logobottom {
font-size: 40px;
}
.headerlogo img{
float: left;
width: 125px;
top: 5px;
position: relative;
}
.headerlogo .logotop {
font-size:35px;
}
.headerlogo .logobottom {
font-size:24px;
}
.user-login-form {
width: 500px;
margin: 50px auto;
text-align: center;
}
.main {
margin-top: 126px;
}
.bw-menu {
position: fixed;
top: 0;
left: 0;
background: white;
width: 100%;
z-index: 9999;
border-bottom: 2px solid green;
}
.bw-menu nav{
width: 1170px;
margin: 0 auto;
text-align: center;
font-size: 22px;
}
nav a:hover {
color: #a0cc3a;
}
.bw-menu nav a{
padding: 0 20px;
}
.mobilemenu {
display:none;
}
.headerlogo {
width: 308px;
margin: 0 auto;
display: table;
}
.menubutton {
display: none;
}
.g-recaptcha {
width: 307px;
margin: 10px auto;
}
.cbp-so-scroller {
margin-top: 50px;
overflow: hidden;
}
.cbp-so-section {
margin-bottom: 1em;
position: relative;
}
.cbp-so-section:before,
.cbp-so-section:after {
content: " ";
display: table;
}
.cbp-so-section:after {
clear: both;
}
.cbp-so-section p {
font-size: 25px;
}
.cbp-so-side {
width: 42%;
float: left;
margin: 0 4%;
padding: 3em 0;
overflow: hidden;
min-height: 12em;
}
.cbp-so-side:before,
.cbp-so-side:after {
content: " ";
display: table;
}
.cbp-so-side:after {
clear: both;
}
.cbp-so-side-right {
text-align: left;
}
.cbp-so-side-left {
text-align: right;
}
.cbp-so-side-right img {
float: left;
}
.cbp-so-side-left img {
float: right;
}
.cbp-so-init .cbp-so-side {
opacity: 0;
transition: none;
}
.cbp-so-init .cbp-so-side-left {
transform: translateX(-80px);
}
.cbp-so-init .cbp-so-side-right {
transform: translateX(80px);
}
.cbp-so-animate .cbp-so-side-left,
.cbp-so-animate .cbp-so-side-right {
transition: transform 0.5s, opacity 0.5s;
transform: translateX(0px);
opacity: 1;
}
.grid {
margin: 0 auto;
width:1100px;
}
.grid figure {
position: relative;
float: left;
overflow: hidden;
margin: 10px 75px;
width: 400px;
height:300px;
text-align: center;
cursor: pointer;
}
.grid figure img {
position: relative;
display: block;
min-height: 100%;
max-width: 100%;
opacity: 0.8;
}
.grid figure figcaption {
text-transform: uppercase;
font-size: 1.25em;
backface-visibility: hidden;
}
.grid figure figcaption::before,
.grid figure figcaption::after {
pointer-events: none;
}
.grid figure figcaption,
.grid figure figcaption > a {
position: absolute;
top: 0;
left: 0;
width: 400px;
height: 300px;
}
.grid figure figcaption > a {
opacity: 0;
}
.greview img {
float: none;
width: 55% !important;
}
.grid figure p {
letter-spacing: 1px;
font-size: 13px;
width: 80%;
margin: 0 10%;
}
.effect-oscar {
background: linear-gradient(45deg, #22682a 0%,#9b4a1b 40%,#3a342a 100%);
}
.effect-oscar img {
opacity: 0.9;
transition: opacity 0.35s;
}
.effect-oscar figcaption {
background-color: rgb(58 52 42 / 41%);
transition: background-color 0.35s;
}
.effect-oscar figcaption::before {
position: absolute;
top: 30px;
right: 30px;
bottom: 30px;
left: 30px;
border: 1px solid #fff;
content: '';
}
.effect-oscar h2 {
margin: 20% 0 10px 0;
transition: transform 0.35s;
transform: translate3d(0,100%,0);
}
.effect-oscar figcaption::before,
.effect-oscar p {
opacity: 0;
transition: opacity 0.35s, transform 0.35s;
transform: scale(0);
}
.effect-oscar:hover h2 {
transform: translate3d(0,0,0);
}
.effect-oscar:hover figcaption::before,
.effect-oscar:hover p {
opacity: 1;
transform: scale(1);
}
.effect-oscar:hover figcaption {
background-color: rgba(58,52,42,0);
}
.effect-oscar:hover img {
opacity: 0.4;
}
.webform-submission-form {
width: 500px;
margin: 0px auto 60px;
text-align: center;
font-size: 22px;
line-height: 28px;
}
.clear { 
clear: both; 
}
@media (max-width: 1600px) {
.cbp-so-side img {
width:100%;
height:auto;
}
}
@media (max-width: 1280px) {
.bw-menu nav{
display:none;
}
header {
height: 126px;
}
.mobilemenu {
display: block;
width: 25%;
margin-top: 25px;
float: left;
font-size: 50px;
text-align: center;
}
.headerlogo {
width: 50%;
text-align: center;
margin:15px 0;
float:left;
}
.headerlogo img {
top: 20px;
position: absolute;
left: 30%;
} 
.mainspot {
width: 100%;
}
.toprightspot,
.bottomrightspot {
width: 40%;
height: 250px;
}
}
@media (max-width: 1100px) {
.grid {
width:900px;
}
.grid figure {
margin: 10px 25px;
}
}
@media (max-width: 1024px) {
.headerlogo img {
display:none;
}
}
@media (max-width: 999px) {
.grid figure {
margin: 10px 0;
}
.home {
width: 90%;
margin: 50px 5%;
}
.grid {
width: 400px;
}
.grid figure{
width:100%;
}
.cbp-so-side {
width:80%;
margin:0 10%;
text-align:center;
}
.footerlinks a {
display:block;
float:none;
}
.footerlinks {
width:90%;
}
}
@media (max-width: 800px) {
.inner {
width: 80%;
margin: 0 10%;
}
}
@media (max-width: 600px) {
	header {
height: 102px;
}
.medium {
    font-size: 18px;
}
.mainspot {
width: 90%;
padding: 40px 5%;
text-align: center;
background-position: 60%;
box-shadow: inset 0 0 0 2000px #00000080;
color: white;
}
.webform-submission-form,
.form-item input,
.form-item select,
.form-item textarea {
width: 300px;
}
.headerlogo {
margin:5px 0;
}
.bw-menu {
height: 100px;
}
.main {
margin-top: 100px;
}
.grid {
width: 300px;
}
.mainspot .inner {
width: 100%;
padding:0;
}
.grid figure {
width: 100%;
margin: 10px 0;
max-width: unset;
min-width: unset;
}
.grid figure figcaption {
width: 90%;
padding: 5%;
height: 85%;
}
.grid figure figcaption > a {
width: 100%;
height: 100%;
}
figure.effect-ming figcaption::before {
top: 3%;
right: 3%;
width: 94%;
height: 90%;
bottom: 5%;
left: 3%;
}
.grid figure p {
width: 80%;
margin: 0 10%;
padding: 0;
}
figure.effect-ming h2 {
margin: 23% 0 10px 0;
width: 100%;
font-size: 25px;
}
.mainlogo {
font-size: 23px;
}
.headerlogo {
width:60%;
}
.mobilemenu {
font-size:35px;
width:20%;
}
.block-highlight .logobottom {
    font-size: 30px;
}
}
@media (max-width: 360px) {
h2 {
    font-size: 30px;
}
h1 {
    font-size: 42px;
}
}

